/* ═══════════════════════════════════════════════════════════
   VERKAUFDA — Design System & Main CSS
   ═══════════════════════════════════════════════════════════ */

/* ── Variables ──────────────────────────────────────────── */
:root {
  --color-primary:     #f97316;
  --color-primary-dark:#ea580c;
  --color-secondary:   #f97316;
  --color-accent:      #fbbf24;
  --color-danger:      #ef4444;

  --bg-base:           #111111;
  --bg-surface:        #1c1c1c;
  --bg-card:           #ffffff;
  --bg-muted:          #f8f8f8;

  --text-primary:      #111111;
  --text-secondary:    #4b5563;
  --text-muted:        #9ca3af;
  --text-inverse:      #ffffff;

  --border:            #e5e7eb;
  --border-dark:       #2a2a2a;

  --radius-sm:   0.375rem;
  --radius:      0.625rem;
  --radius-lg:   1rem;
  --radius-xl:   1.5rem;
  --radius-full: 9999px;

  --shadow-sm:   0 1px 2px rgba(0,0,0,.05);
  --shadow:      0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -2px rgba(0,0,0,.05);
  --shadow-lg:   0 10px 15px -3px rgba(0,0,0,.08), 0 4px 6px -4px rgba(0,0,0,.05);
  --shadow-xl:   0 20px 25px -5px rgba(0,0,0,.08), 0 8px 10px -6px rgba(0,0,0,.04);

  --font-sans:   'Inter', system-ui, sans-serif;
  --transition:  0.2s ease;
}

/* ── Reset ──────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  color: var(--text-primary);
  background: #fff;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
input, select, textarea, button { font-family: inherit; }

/* ── Layout ─────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

/* ── Buttons ────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.625rem 1.25rem;
  border-radius: var(--radius);
  font-weight: 600;
  font-size: 0.9375rem;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all var(--transition);
  white-space: nowrap;
  text-decoration: none;
}
.btn svg { width: 18px; height: 18px; fill: currentColor; flex-shrink: 0; }
.btn--primary   { background: var(--color-primary);   color: #fff; }
.btn--primary:hover { background: var(--color-primary-dark); }
.btn--secondary { background: #111111; color: #fff; }
.btn--secondary:hover { background: #222; }
.btn--outline   { border-color: var(--color-primary); color: var(--color-primary); background: transparent; }
.btn--outline:hover { background: var(--color-primary); color: #fff; }
.btn--ghost     { background: var(--bg-muted); color: var(--text-secondary); border-color: var(--border); }
.btn--ghost:hover { background: var(--border); }
.btn--white     { background: #fff; color: var(--text-primary); }
.btn--white:hover { background: var(--bg-muted); }
.btn--danger    { background: var(--color-danger); color: #fff; }
.btn--sm  { padding: 0.4rem 0.875rem; font-size: 0.875rem; }
.btn--lg  { padding: 0.875rem 1.75rem; font-size: 1rem; }
.btn--xl  { padding: 1rem 2rem; font-size: 1.0625rem; }
.btn--xs  { padding: 0.25rem 0.625rem; font-size: 0.8125rem; }
.btn--block { width: 100%; }

/* ── Header ─────────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(17,17,17,.97);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid #2a2a2a;
}
.site-header .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 68px;
}
.logo {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  text-decoration: none;
}
.logo-img-wrap {
  background: #fff;
  border-radius: 8px;
  padding: 5px 12px;
  display: flex;
  align-items: center;
  line-height: 0;
}
.logo-img {
  height: 38px;
  width: auto;
  display: block;
}
.logo-mark {
  background: var(--color-primary);
  color: #fff;
  font-weight: 800;
  font-size: 1rem;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: -.5px;
}
.logo-text {
  color: #fff;
  font-weight: 700;
  font-size: 1.1875rem;
  letter-spacing: -.3px;
}
.main-nav {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.main-nav a {
  color: #aaa;
  font-size: 0.9375rem;
  font-weight: 500;
  padding: 0.4rem 0.875rem;
  border-radius: var(--radius-sm);
  transition: color var(--transition), background var(--transition);
}
.main-nav a:hover { color: #fff; background: rgba(255,255,255,.08); }
.main-nav .nav-cta {
  background: var(--color-primary);
  color: #fff;
  padding: 0.5rem 1.125rem;
  border-radius: var(--radius);
}
.main-nav .nav-cta:hover { background: var(--color-primary-dark); }
.nav-toggle { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 0.5rem; }
.nav-toggle span { display: block; width: 22px; height: 2px; background: #fff; border-radius: 2px; transition: all .3s; }

/* ── Hero ───────────────────────────────────────────────── */
.hero {
  position: relative;
  background: var(--bg-base);
  padding: 7rem 0 6rem;
  overflow: hidden;
}
.hero__bg {
  position: absolute;
  inset: 0;
}
.hero__gradient {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 60% 0%, rgba(249,115,22,.22) 0%, transparent 60%),
    radial-gradient(ellipse at 10% 100%, rgba(249,115,22,.08) 0%, transparent 50%);
}
.hero__content {
  position: relative;
  max-width: 720px;
}
.hero__badge {
  display: inline-block;
  background: rgba(249,115,22,.15);
  border: 1px solid rgba(249,115,22,.35);
  color: var(--color-primary);
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: 0.375rem 0.875rem;
  border-radius: var(--radius-full);
  margin-bottom: 1.5rem;
}
.hero__title {
  font-size: clamp(2.25rem, 5vw, 3.5rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.15;
  letter-spacing: -.03em;
  margin-bottom: 1.25rem;
}
.text-accent { color: var(--color-primary); }
.hero__subtitle {
  font-size: 1.125rem;
  color: #94a3b8;
  line-height: 1.7;
  margin-bottom: 2.5rem;
  max-width: 580px;
}
.hero__ctas {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 3.5rem;
}
.hero__stats {
  display: flex;
  align-items: center;
  gap: 2rem;
  flex-wrap: wrap;
}
.hero__stat { text-align: center; }
.stat-number {
  display: block;
  font-size: 1.75rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: -.02em;
}
.stat-label { display: block; font-size: 0.8125rem; color: #64748b; margin-top: 2px; }
.hero__stat-divider { width: 1px; height: 40px; background: #334155; }

/* ── Section Shared ─────────────────────────────────────── */
.section-header {
  text-align: center;
  margin-bottom: 3.5rem;
}
.section-header h2 {
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -.03em;
  margin-bottom: 0.625rem;
}
.section-header p { font-size: 1.0625rem; color: var(--text-secondary); }
.section-header--flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  text-align: left;
}

/* ── Dual Path ──────────────────────────────────────────── */
.dual-path {
  padding: 6rem 0;
  background: var(--bg-muted);
}
.dual-path__cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 2rem;
}
.path-card {
  background: #fff;
  border-radius: var(--radius-xl);
  padding: 2.5rem;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border);
  transition: transform var(--transition), box-shadow var(--transition);
}
.path-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-xl); }
.path-card--primary { border-top: 4px solid var(--color-primary); }
.path-card--secondary { border-top: 4px solid var(--color-secondary); }
.path-card__icon {
  width: 52px;
  height: 52px;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.25rem;
}
.path-card--primary  .path-card__icon { background: rgba(249,115,22,.1); color: var(--color-primary); }
.path-card--secondary .path-card__icon { background: rgba(17,17,17,.08); color: #111; }
.path-card__icon svg { width: 26px; height: 26px; fill: currentColor; }
.path-card__tag {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 0.5rem;
}
.path-card--primary  .path-card__tag { color: var(--color-primary); }
.path-card--secondary .path-card__tag { color: var(--color-secondary); }
.path-card h3 { font-size: 1.5rem; font-weight: 700; margin-bottom: 0.875rem; letter-spacing: -.02em; }
.path-card p { color: var(--text-secondary); margin-bottom: 1.5rem; line-height: 1.7; }
.path-card__features { margin-bottom: 2rem; }
.path-card__features li {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  font-size: 0.9375rem;
  color: var(--text-secondary);
  padding: 0.375rem 0;
}
.path-card__features li::before {
  content: '';
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%23f97316' d='M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z'/%3E%3C/svg%3E") center/contain no-repeat;
  flex-shrink: 0;
}

/* ── How It Works ───────────────────────────────────────── */
.how-it-works {
  padding: 6rem 0;
}
.steps {
  display: flex;
  align-items: flex-start;
  gap: 0;
  flex-wrap: wrap;
  justify-content: center;
}
.step {
  flex: 1;
  min-width: 180px;
  max-width: 240px;
  text-align: center;
  padding: 1rem;
}
.step__number {
  font-size: 3rem;
  font-weight: 900;
  color: var(--border);
  line-height: 1;
  margin-bottom: 1rem;
  letter-spacing: -.04em;
}
.step__icon {
  width: 56px;
  height: 56px;
  background: rgba(249,115,22,.1);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1rem;
  color: var(--color-primary);
}
.step__icon svg { width: 26px; height: 26px; fill: currentColor; }
.step h3 { font-size: 1.0625rem; font-weight: 700; margin-bottom: 0.5rem; }
.step p { font-size: 0.9rem; color: var(--text-secondary); line-height: 1.6; }
.step__connector {
  flex-shrink: 0;
  width: 60px;
  height: 2px;
  background: var(--border);
  margin-top: 5.5rem;
  align-self: flex-start;
}

/* ── Benefits ───────────────────────────────────────────── */
.benefits {
  padding: 6rem 0;
  background: var(--bg-muted);
}
.benefits__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
}
.benefit-item {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  border: 1px solid var(--border);
  transition: box-shadow var(--transition);
}
.benefit-item:hover { box-shadow: var(--shadow-lg); }
.benefit-icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
}
.benefit-icon svg { width: 22px; height: 22px; fill: currentColor; }
.benefit-icon--blue   { background: rgba(249,115,22,.1);  color: #f97316; }
.benefit-icon--green  { background: rgba(249,115,22,.1);  color: #f97316; }
.benefit-icon--orange { background: rgba(249,115,22,.12); color: #ea580c; }
.benefit-icon--purple { background: rgba(17,17,17,.06);   color: #333; }
.benefit-icon--red    { background: rgba(239,68,68,.1);   color: #ef4444; }
.benefit-icon--teal   { background: rgba(249,115,22,.08); color: #f97316; }
.benefit-item h4 { font-size: 1.0625rem; font-weight: 700; margin-bottom: 0.375rem; }
.benefit-item p { font-size: 0.9rem; color: var(--text-secondary); line-height: 1.65; }

/* ── Listings Grid ──────────────────────────────────────── */
.listings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem;
}
.listing-card {
  background: #fff;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  overflow: hidden;
  transition: transform var(--transition), box-shadow var(--transition);
  display: flex;
  flex-direction: column;
}
.listing-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.listing-card__img {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--bg-muted);
}
.listing-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.listing-card:hover .listing-card__img img { transform: scale(1.04); }
.listing-card__badge {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  background: var(--color-primary);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 0.25rem 0.625rem;
  border-radius: var(--radius-full);
}
.listing-card__body { padding: 1.125rem; flex: 1; display: flex; flex-direction: column; }
.listing-card__title {
  font-size: 0.9375rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  color: var(--text-primary);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.listing-card__specs {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.8125rem;
  color: var(--text-muted);
  margin-bottom: 0.875rem;
  flex-wrap: wrap;
}
.listing-card__footer {
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}
.listing-card__price {
  font-size: 1.1875rem;
  font-weight: 800;
  color: var(--text-primary);
}
.listing-card__price small { font-size: 0.75rem; font-weight: 500; color: var(--text-muted); margin-left: 2px; }
.listing-card__location {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.8rem;
  color: var(--text-muted);
}
.listing-card__location svg { width: 13px; height: 13px; fill: currentColor; flex-shrink: 0; }

/* ── Recent Listings Section ────────────────────────────── */
.recent-listings { padding: 6rem 0; }

/* ── CTA Strip ──────────────────────────────────────────── */
.cta-strip {
  background: var(--bg-base);
  padding: 5rem 0;
}
.cta-strip .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  flex-wrap: wrap;
}
.cta-strip__content h2 { font-size: 2rem; font-weight: 800; color: #fff; letter-spacing: -.03em; }
.cta-strip__content p { color: #94a3b8; margin-top: 0.5rem; }
.cta-strip__actions { display: flex; gap: 1rem; flex-wrap: wrap; }

/* ── Footer ─────────────────────────────────────────────── */
.site-footer {
  background: var(--bg-base);
  border-top: 1px solid var(--border-dark);
  padding: 4rem 0 2rem;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr repeat(3, 1fr);
  gap: 3rem;
  margin-bottom: 3rem;
}
.footer-brand p { color: #666; font-size: 0.9rem; margin-top: 1rem; line-height: 1.6; }
.logo--light .logo-text { color: #fff; }
.footer-brand .logo-img-wrap { background: #fff; }
.footer-col h4 { color: #fff; font-size: 0.875rem; font-weight: 700; margin-bottom: 1rem; text-transform: uppercase; letter-spacing: .05em; }
.footer-col ul li { margin-bottom: 0.625rem; }
.footer-col ul li a { color: #64748b; font-size: 0.9rem; transition: color var(--transition); }
.footer-col ul li a:hover { color: #fff; }
.footer-bottom { border-top: 1px solid var(--border-dark); padding-top: 2rem; }
.footer-bottom p { color: #475569; font-size: 0.875rem; }

/* ── Forms (shared) ─────────────────────────────────────── */
.form-group { display: flex; flex-direction: column; gap: 0.375rem; }
.form-group label { font-size: 0.875rem; font-weight: 600; color: var(--text-secondary); }
.required { color: var(--color-danger); }
.form-group input, .form-group select, .form-group textarea {
  padding: 0.625rem 0.875rem;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  font-size: 0.9375rem;
  color: var(--text-primary);
  background: #fff;
  transition: border-color var(--transition), box-shadow var(--transition);
  width: 100%;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(249,115,22,.12);
}
.form-group textarea { resize: vertical; min-height: 100px; }
.form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
}
.form-group--full { grid-column: 1 / -1; }
.form-hint { font-size: 0.8125rem; color: var(--text-muted); }
.input-prefix { position: relative; }
.input-prefix > span {
  position: absolute;
  left: 0.875rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  font-weight: 600;
  pointer-events: none;
}
.input-prefix input { padding-left: 1.75rem; }
.checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: 0.625rem;
  cursor: pointer;
  font-size: 0.9375rem;
  color: var(--text-secondary);
}
.checkbox-label input[type="checkbox"] { width: 16px; height: 16px; margin-top: 2px; flex-shrink: 0; }
.checkbox-label a { color: var(--color-primary); }

/* ── Alerts ─────────────────────────────────────────────── */
.alert {
  padding: 0.875rem 1rem;
  border-radius: var(--radius);
  font-size: 0.9rem;
  margin-bottom: 1.25rem;
}
.alert ul { padding-left: 1.25rem; margin-top: 0.375rem; }
.alert--success { background: #f0fdf4; border: 1px solid #86efac; color: #166534; }
.alert--error   { background: #fef2f2; border: 1px solid #fca5a5; color: #991b1b; }
.alert--info    { background: #fff7ed; border: 1px solid #fdba74; color: #c2410c; }

/* ── Pagination ─────────────────────────────────────────── */
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  margin-top: 2rem;
  flex-wrap: wrap;
}
.pagination__page, .pagination__prev, .pagination__next {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: var(--radius);
  border: 1.5px solid var(--border);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-secondary);
  transition: all var(--transition);
  text-decoration: none;
}
.pagination__page:hover, .pagination__prev:hover, .pagination__next:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}
.pagination__page.active { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }
.pagination__prev svg, .pagination__next svg { width: 16px; height: 16px; fill: currentColor; }

/* ── Marketplace Page ───────────────────────────────────── */
.marketplace-header {
  background: var(--bg-base);
  padding: 3rem 0;
  color: #fff;
}
.marketplace-header h1 { font-size: 2rem; font-weight: 800; letter-spacing: -.03em; }
.marketplace-header p { color: #94a3b8; margin-top: 0.375rem; }
.marketplace-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 2rem;
  padding: 2.5rem 0 4rem;
  align-items: start;
}
.filter-sidebar {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  position: sticky;
  top: 88px;
}
.filter-sidebar__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.25rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--border);
}
.filter-sidebar__header h3 { font-size: 1rem; font-weight: 700; }
.filter-reset { font-size: 0.8125rem; color: var(--color-primary); cursor: pointer; }
.filter-group { margin-bottom: 1.25rem; }
.filter-group label { display: block; font-size: 0.8125rem; font-weight: 600; color: var(--text-secondary); margin-bottom: 0.375rem; }
.filter-group input, .filter-group select {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  font-size: 0.9rem;
}
.filter-range { display: flex; align-items: center; gap: 0.5rem; }
.filter-range input { flex: 1; }
.filter-range span { color: var(--text-muted); font-size: 0.875rem; flex-shrink: 0; }
.listings-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.25rem;
}
.listings-count { font-weight: 600; color: var(--text-secondary); font-size: 0.9rem; }
.listings-toolbar select {
  padding: 0.375rem 0.75rem;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  font-size: 0.875rem;
}
.empty-state {
  text-align: center;
  padding: 4rem 2rem;
  color: var(--text-muted);
}
.empty-state svg { width: 64px; height: 64px; fill: var(--border); margin: 0 auto 1rem; }
.empty-state h3 { font-size: 1.125rem; color: var(--text-secondary); margin-bottom: 0.375rem; }

/* ── Listing Detail ─────────────────────────────────────── */
.listing-detail { padding: 2.5rem 0 5rem; }
.listing-detail__layout {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 2.5rem;
  margin-top: 1.5rem;
}
.gallery { margin-bottom: 2rem; }
.gallery__main {
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--bg-muted);
  aspect-ratio: 16/10;
  margin-bottom: 0.75rem;
}
.gallery__main img { width: 100%; height: 100%; object-fit: cover; }
.gallery__thumbs { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.gallery__thumb {
  width: 80px;
  height: 56px;
  border-radius: var(--radius-sm);
  overflow: hidden;
  border: 2px solid transparent;
  cursor: pointer;
  opacity: 0.7;
  transition: all .2s;
}
.gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }
.gallery__thumb.active, .gallery__thumb:hover { border-color: var(--color-primary); opacity: 1; }
.gallery__placeholder {
  aspect-ratio: 16/10;
  background: var(--bg-muted);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  gap: 0.75rem;
}
.gallery__placeholder svg { width: 56px; height: 56px; fill: var(--border); }
.listing-specs, .listing-description { margin-top: 2rem; }
.listing-specs h2, .listing-description h2 { font-size: 1.25rem; font-weight: 700; margin-bottom: 1.25rem; }
.specs-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
}
.spec-item {
  display: flex;
  flex-direction: column;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--border);
}
.spec-item:nth-child(odd) { padding-right: 1rem; }
.spec-label { font-size: 0.8125rem; color: var(--text-muted); margin-bottom: 0.25rem; }
.spec-value { font-size: 0.9375rem; font-weight: 600; color: var(--text-primary); }
.spec-item--warning .spec-value { color: var(--color-danger); }
.description-text { color: var(--text-secondary); line-height: 1.75; white-space: pre-line; }
.listing-sidebar-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 1.75rem;
  position: sticky;
  top: 88px;
  box-shadow: var(--shadow-lg);
}
.listing-detail__title { font-size: 1.25rem; font-weight: 700; margin-bottom: 0.875rem; line-height: 1.3; }
.listing-detail__price {
  font-size: 2rem;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -.03em;
  margin-bottom: 0.5rem;
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
}
.price-vb { font-size: 1rem; font-weight: 500; color: var(--text-muted); }
.listing-location {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.9rem;
  color: var(--text-secondary);
  margin-bottom: 1.5rem;
}
.listing-location svg { width: 14px; height: 14px; fill: currentColor; flex-shrink: 0; }
.contact-form-wrapper { margin-top: 1.25rem; border-top: 1px solid var(--border); padding-top: 1.25rem; }
.contact-form-wrapper h3 { font-size: 1rem; font-weight: 700; margin-bottom: 1rem; }
.listing-meta {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  margin-top: 1.25rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--border);
  font-size: 0.8125rem;
  color: var(--text-muted);
}

/* ── Form Page ──────────────────────────────────────────── */
.form-page { padding-bottom: 5rem; }
.form-page__header {
  background: var(--bg-base);
  padding: 3rem 0;
  color: #fff;
  margin-bottom: 3rem;
}
.form-page__header h1 { font-size: 2rem; font-weight: 800; margin: 0.75rem 0 0.375rem; letter-spacing: -.03em; }
.form-page__header p { color: #94a3b8; }
.back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.875rem;
  color: #94a3b8;
  margin-bottom: 0.75rem;
  transition: color var(--transition);
}
.back-link:hover { color: #fff; }
.back-link svg { width: 16px; height: 16px; fill: currentColor; }
.form-section {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 2rem;
  margin-bottom: 1.5rem;
}
.form-section h2 { font-size: 1.125rem; font-weight: 700; margin-bottom: 1.5rem; color: var(--text-primary); }

/* ── Success Page ───────────────────────────────────────── */
.success-page { padding: 5rem 0; }
.success-card {
  max-width: 600px;
  margin: 0 auto;
  background: #fff;
  border-radius: var(--radius-xl);
  border: 1px solid var(--border);
  padding: 3rem 2.5rem;
  text-align: center;
  box-shadow: var(--shadow-xl);
}
.success-icon {
  width: 72px;
  height: 72px;
  background: rgba(249,115,22,.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.5rem;
  color: var(--color-primary);
}
.success-icon svg { width: 36px; height: 36px; fill: currentColor; }
.success-card h1 { font-size: 1.75rem; font-weight: 800; margin-bottom: 0.75rem; letter-spacing: -.03em; }
.success-subtitle { color: var(--text-secondary); margin-bottom: 2rem; }
.reference-box {
  background: var(--bg-muted);
  border-radius: var(--radius);
  padding: 1.25rem;
  margin-bottom: 2rem;
}
.reference-label { display: block; font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--text-muted); margin-bottom: 0.375rem; }
.reference-code { display: block; font-size: 1.75rem; font-weight: 800; letter-spacing: .05em; color: var(--color-primary); }
.reference-hint { display: block; font-size: 0.8125rem; color: var(--text-muted); margin-top: 0.375rem; }
.success-steps { text-align: left; margin-bottom: 2rem; }
.success-step {
  display: flex;
  gap: 1rem;
  padding: 0.875rem 0;
  border-bottom: 1px solid var(--border);
}
.success-step:last-child { border-bottom: none; }
.ss-icon {
  width: 32px;
  height: 32px;
  background: var(--color-primary);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.875rem;
  font-weight: 700;
  flex-shrink: 0;
}
.ss-text strong { display: block; font-weight: 700; margin-bottom: 0.125rem; }
.ss-text span { font-size: 0.875rem; color: var(--text-secondary); }
.success-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ── Auth ───────────────────────────────────────────────── */
.auth-page { background: var(--bg-base); min-height: 100vh; display: flex; align-items: center; }
.auth-container { width: 100%; max-width: 420px; margin: 0 auto; padding: 2rem; }
.auth-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-dark);
  border-radius: var(--radius-xl);
  padding: 2.5rem;
}
.auth-logo {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  margin-bottom: 1.75rem;
  font-weight: 700;
  color: #fff;
  font-size: 1rem;
}
.auth-card h1 { font-size: 1.5rem; font-weight: 800; color: #fff; margin-bottom: 1.75rem; letter-spacing: -.03em; }
.auth-card .form-group { margin-bottom: 1rem; }
.auth-card .form-group label { color: #94a3b8; }
.auth-card .form-group input {
  background: rgba(255,255,255,.05);
  border-color: var(--border-dark);
  color: #fff;
}
.auth-card .form-group input:focus { border-color: var(--color-primary); background: rgba(255,255,255,.08); }
.auth-card .btn { margin-top: 1rem; }

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 1024px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .marketplace-layout { grid-template-columns: 220px 1fr; }
  .listing-detail__layout { grid-template-columns: 1fr 340px; }
}
@media (max-width: 768px) {
  .hero { padding: 5rem 0 4rem; }
  .hero__ctas { flex-direction: column; align-items: flex-start; }
  .hero__stats { gap: 1rem; }
  .dual-path__cards { grid-template-columns: 1fr; }
  .step__connector { display: none; }
  .steps { gap: 1rem; }
  .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
  .marketplace-layout { grid-template-columns: 1fr; }
  .filter-sidebar { position: static; }
  .listing-detail__layout { grid-template-columns: 1fr; }
  .listing-sidebar-card { position: static; }
  .form-grid { grid-template-columns: 1fr; }
  .cta-strip .container { flex-direction: column; text-align: center; }
  .section-header--flex { flex-direction: column; gap: 1rem; }
  .main-nav { display: none; }
  .nav-toggle { display: flex; }
}
@media (max-width: 480px) {
  .hero__title { font-size: 2rem; }
  .listings-grid { grid-template-columns: 1fr; }
  .success-card { padding: 2rem 1.25rem; }
}

/* ── Language Switcher ─────────────────────────────────── */
.lang-switcher {
  position: relative;
}
.lang-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: transparent;
  border: 1px solid rgba(255,255,255,.15);
  color: #f9fafb;
  font-size: .8rem;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 6px;
  cursor: pointer;
  font-family: inherit;
  transition: border-color .2s;
}
.lang-btn:hover { border-color: #f97316; color: #f97316; }
.lang-dropdown {
  display: none;
  position: absolute;
  right: 0;
  top: calc(100% + 6px);
  background: #1a1a1a;
  border: 1px solid #2a2a2a;
  border-radius: 8px;
  min-width: 130px;
  z-index: 999;
  box-shadow: 0 8px 24px rgba(0,0,0,.4);
  overflow: hidden;
}
.lang-switcher:hover .lang-dropdown,
.lang-switcher:focus-within .lang-dropdown {
  display: block;
}
.lang-option {
  display: block;
  padding: .5rem 1rem;
  color: #d1d5db;
  font-size: .85rem;
  text-decoration: none;
  transition: background .15s, color .15s;
}
.lang-option:hover { background: #2a2a2a; color: #f97316; }
.lang-option--active { color: #f97316; font-weight: 600; }

/* ── nav-item-user ─────────────────────────────────────── */
.nav-item-user {
  display: inline-flex;
  align-items: center;
  color: #f97316;
  font-weight: 600;
  font-size: .875rem;
  text-decoration: none;
}
.nav-item-user:hover { color: #fb923c; }


/* ── Dashboard ──────────────────────────────────────────── */
.dash-welcome-bar { background: linear-gradient(135deg,#1e40af,#3b82f6); color:#fff; border-radius:12px; padding:24px 28px; display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:24px; }
.dash-welcome-bar h2 { margin:0 0 4px; font-size:1.4rem; }
.dash-welcome-bar p { margin:0; opacity:.85; }
.notif-banner { background:rgba(255,255,255,.25); color:#fff; border-radius:20px; padding:6px 16px; font-size:.85rem; font-weight:600; text-decoration:none; white-space:nowrap; }
.notif-banner:hover { background:rgba(255,255,255,.35); }

.dash-quick-actions { display:flex; gap:12px; margin-bottom:24px; flex-wrap:wrap; }
.quick-action { display:flex; align-items:center; gap:8px; background:#fff; border:1.5px solid #e2e8f0; border-radius:10px; padding:12px 18px; font-weight:500; color:#374151; text-decoration:none; transition:all .2s; font-size:.93rem; }
.quick-action:hover { border-color:#3b82f6; color:#2563eb; box-shadow:0 2px 8px rgba(59,130,246,.12); }
.quick-action--primary { background:#2563eb; color:#fff; border-color:#2563eb; }
.quick-action--primary:hover { background:#1d4ed8; color:#fff; border-color:#1d4ed8; }

.dash-cards-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:20px; }
.dash-card { background:#fff; border-radius:12px; border:1px solid #e5e7eb; padding:20px; }
.dash-card__header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.dash-card__header h3 { margin:0; font-size:1rem; font-weight:600; }
.link-more { font-size:.82rem; color:#3b82f6; text-decoration:none; }
.link-more:hover { text-decoration:underline; }

.dash-list { display:flex; flex-direction:column; gap:10px; }
.dash-list__item { display:flex; align-items:center; justify-content:space-between; padding:10px 0; border-bottom:1px solid #f1f5f9; }
.dash-list__item:last-child { border-bottom:none; }
.dash-stat-big { text-align:center; padding:16px 0; }
.dash-stat-num { font-size:2.5rem; font-weight:700; color:#2563eb; line-height:1; }
.dash-stat-lbl { font-size:.9rem; color:#6b7280; margin-top:4px; }
.empty-sm { text-align:center; padding:20px 0; color:#6b7280; }
.empty-sm p { margin:0 0 12px; }

.badge-count { background:#ef4444; color:#fff; border-radius:10px; font-size:.7rem; font-weight:700; padding:1px 6px; margin-left:6px; }
.topbar-badge { background:#fef3c7; color:#92400e; border-radius:6px; font-size:.78rem; font-weight:600; padding:3px 10px; }

/* ── Badges ─────────────────────────────────────────────── */
.badge { display:inline-block; padding:3px 10px; border-radius:20px; font-size:.75rem; font-weight:600; }
.badge--new,.badge--review { background:#fef9c3; color:#854d0e; }
.badge--sent { background:#dbeafe; color:#1e40af; }
.badge--offer { background:#d1fae5; color:#065f46; }
.badge--accepted { background:#dcfce7; color:#166534; }
.badge--rejected,.badge--abgesagt { background:#fee2e2; color:#991b1b; }
.badge--closed,.badge--erledigt { background:#f3f4f6; color:#374151; }
.badge--angefragt { background:#fef3c7; color:#92400e; }
.badge--bestätigt { background:#d1fae5; color:#065f46; }
.badge--verschoben { background:#dbeafe; color:#1e40af; }
.badge--offen { background:#fef9c3; color:#854d0e; }
.badge--bezahlt { background:#dcfce7; color:#166534; }
.badge--überfällig { background:#fee2e2; color:#991b1b; }
.badge--storniert { background:#f3f4f6; color:#374151; }
.badge--pending { background:#fef3c7; color:#92400e; }
.badge--active { background:#d1fae5; color:#065f46; }
.badge--sold { background:#f3f4f6; color:#374151; }
.badge--paused { background:#fef9c3; color:#92400e; }

/* ── Page Header ────────────────────────────────────────── */
.page-header { margin-bottom:24px; }
.page-header h2 { margin:0 0 4px; font-size:1.5rem; }
.page-header p { margin:0; color:#6b7280; }
.page-header--flex { display:flex; align-items:flex-start; justify-content:space-between; flex-wrap:wrap; gap:12px; }

/* ── Offers ─────────────────────────────────────────────── */
.offers-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:20px; }
.offer-card { background:#fff; border-radius:12px; border:1px solid #e5e7eb; padding:20px; }
.offer-card__header { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.offer-dealer { display:flex; align-items:center; gap:10px; }
.dealer-avatar-sm { width:36px; height:36px; border-radius:8px; background:#e0f2fe; color:#0369a1; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:.9rem; }
.dealer-logo-sm { width:36px; height:36px; object-fit:contain; border-radius:6px; border:1px solid #e5e7eb; }
.offer-amount { font-size:1.4rem; font-weight:700; color:#16a34a; }
.offer-card__vehicle { display:flex; align-items:center; gap:8px; font-size:.85rem; color:#6b7280; margin-bottom:10px; border-top:1px solid #f1f5f9; padding-top:10px; flex-wrap:wrap; }
.offer-card__message { background:#f8fafc; border-radius:8px; padding:10px 14px; font-size:.88rem; color:#4b5563; font-style:italic; margin-bottom:10px; }
.offer-card__footer { display:flex; align-items:center; justify-content:space-between; }
.badge--offer { background:#d1fae5; color:#065f46; }

/* ── Detail Pages ───────────────────────────────────────── */
.back-link { display:inline-flex; align-items:center; gap:6px; color:#6b7280; text-decoration:none; font-size:.88rem; margin-bottom:12px; }
.back-link:hover { color:#374151; }
.detail-header { margin-bottom:24px; }
.detail-header__title { display:flex; align-items:center; gap:12px; margin-bottom:6px; }
.detail-header__title h2 { margin:0; }
.detail-grid { display:grid; grid-template-columns:1fr 360px; gap:24px; }
@media (max-width:768px) { .detail-grid { grid-template-columns:1fr; } }
.detail-main, .detail-sidebar { display:flex; flex-direction:column; gap:20px; }
.detail-card { background:#fff; border-radius:12px; border:1px solid #e5e7eb; padding:20px; }
.detail-card h3 { margin:0 0 16px; font-size:1rem; font-weight:600; }
.detail-rows { display:flex; flex-direction:column; gap:0; }
.detail-row { display:flex; justify-content:space-between; padding:10px 0; border-bottom:1px solid #f1f5f9; font-size:.9rem; }
.detail-row:last-child { border-bottom:none; }
.detail-row span:first-child { color:#6b7280; }
.detail-row strong { text-align:right; }
.image-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(120px,1fr)); gap:8px; margin-top:8px; }
.image-thumb { width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:8px; border:1px solid #e5e7eb; }
.offers-list { display:flex; flex-direction:column; gap:12px; }
.offer-item { padding:12px; border:1px solid #e5e7eb; border-radius:8px; }
.offer-item__dealer { display:flex; flex-direction:column; gap:3px; margin-bottom:8px; }
.offer-item__amount { font-size:1.3rem; font-weight:700; color:#16a34a; }
.offer-item__msg { font-size:.83rem; color:#6b7280; font-style:italic; margin-top:8px; }
.plan-badge { display:inline-block; color:#fff; font-size:.7rem; font-weight:600; border-radius:4px; padding:2px 8px; margin-top:3px; }
.text-link { color:#2563eb; text-decoration:none; font-size:.82rem; }
.text-link:hover { text-decoration:underline; }

/* ── Notifications ──────────────────────────────────────── */
.notif-list { display:flex; flex-direction:column; gap:2px; }
.notif-item { display:flex; align-items:flex-start; gap:12px; padding:14px 16px; border-radius:10px; border:1px solid #f1f5f9; background:#fff; }
.notif-item--unread { background:#eff6ff; border-color:#bfdbfe; }
.notif-item__icon { width:36px; height:36px; border-radius:8px; background:#dbeafe; color:#1d4ed8; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.notif-item__body { flex:1; }
.notif-item__body strong { font-size:.93rem; }
.notif-item__body p { margin:4px 0 0; }
.notif-item__meta { display:flex; flex-direction:column; align-items:flex-end; gap:8px; min-width:90px; }

/* ── Calendar ───────────────────────────────────────────── */
.cal-nav { display:flex; gap:8px; }
.cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:2px; background:#e5e7eb; border-radius:12px; overflow:hidden; border:1px solid #e5e7eb; }
.cal-head { background:#f8fafc; padding:8px; text-align:center; font-size:.8rem; font-weight:600; color:#6b7280; }
.cal-cell { background:#fff; min-height:90px; padding:6px; position:relative; }
.cal-cell--empty { background:#fafafa; }
.cal-cell--today { background:#eff6ff; }
.cal-day-num { font-size:.8rem; font-weight:600; color:#374151; display:block; margin-bottom:4px; }
.cal-cell--today .cal-day-num { color:#2563eb; }
.cal-events { display:flex; flex-direction:column; gap:2px; }
.cal-event { display:block; font-size:.72rem; padding:2px 5px; border-radius:4px; color:#fff; text-decoration:none; overflow:hidden; white-space:nowrap; text-overflow:ellipsis; }
.cal-event--angefragt { background:#f59e0b; }
.cal-event--bestätigt { background:#22c55e; }
.cal-event--verschoben { background:#3b82f6; }
.cal-event--erledigt { background:#9ca3af; }
.cal-legend { display:flex; gap:12px; margin-top:12px; flex-wrap:wrap; }

/* ── Invoice ────────────────────────────────────────────── */
.invoice-sheet { background:#fff; border-radius:12px; border:1px solid #e5e7eb; padding:32px; max-width:800px; }
.invoice-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:32px; gap:16px; flex-wrap:wrap; }
.invoice-header h1 { font-size:2rem; letter-spacing:.05em; margin:0 0 12px; }
.invoice-to { background:#f8fafc; border-radius:8px; padding:16px 20px; margin-bottom:24px; font-size:.9rem; line-height:1.7; }
.invoice-period { color:#6b7280; font-size:.85rem; margin-bottom:16px; }
.invoice-items { width:100%; border-collapse:collapse; margin:16px 0; }
.invoice-items th { background:#f8fafc; padding:10px 12px; text-align:left; font-size:.82rem; color:#6b7280; border-bottom:2px solid #e5e7eb; }
.invoice-items td { padding:10px 12px; border-bottom:1px solid #f1f5f9; font-size:.9rem; }
.invoice-items tfoot td { padding:10px 12px; font-size:.9rem; border-top:1px solid #e5e7eb; }
.invoice-total td { font-size:1.05rem; border-top:2px solid #111 !important; }
.invoice-footer { margin-top:24px; padding-top:16px; border-top:1px solid #e5e7eb; font-size:.85rem; color:#6b7280; }
.invoice-notes { background:#fef9c3; border-radius:8px; padding:12px 16px; margin:16px 0; font-size:.88rem; }
.invoice-status-row { display:flex; align-items:center; gap:16px; margin-bottom:16px; }

/* ── Stats cards ────────────────────────────────────────── */
.stats-grid { display:grid; gap:16px; }
.stats-grid--4 { grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); }
.stat-card { background:#fff; border-radius:12px; border:1px solid #e5e7eb; padding:20px; text-align:center; }
.stat-card--danger { border-color:#fecaca; background:#fff5f5; }
.stat-card--success { border-color:#bbf7d0; background:#f0fdf4; }
.stat-card__value { font-size:1.6rem; font-weight:700; color:#111; margin-bottom:4px; }
.stat-card--danger .stat-card__value { color:#dc2626; }
.stat-card--success .stat-card__value { color:#16a34a; }
.stat-card__label { font-size:.8rem; color:#6b7280; }

/* ── Homepage ───────────────────────────────────────────── */
.hero { background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 60%,#0369a1 100%); color:#fff; padding:80px 0; overflow:hidden; }
.hero__inner { display:grid; grid-template-columns:1fr 420px; gap:48px; align-items:center; }
@media(max-width:900px){ .hero__inner { grid-template-columns:1fr; } .hero__visual { display:none; } }
.hero__badge { display:inline-block; background:rgba(59,130,246,.25); border:1px solid rgba(59,130,246,.4); color:#93c5fd; border-radius:20px; padding:5px 14px; font-size:.82rem; font-weight:500; margin-bottom:20px; }
.hero__title { font-size:clamp(2rem,5vw,3.2rem); font-weight:800; line-height:1.15; margin:0 0 20px; }
.hero__accent { color:#38bdf8; }
.hero__subtitle { font-size:1.1rem; color:#cbd5e1; margin:0 0 32px; line-height:1.6; max-width:520px; }
.hero__ctas { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:40px; }
.btn--hero-primary { background:#f97316; color:#fff; border:none; padding:14px 28px; border-radius:8px; font-weight:600; font-size:1rem; cursor:pointer; text-decoration:none; display:inline-flex; align-items:center; gap:8px; transition:background .2s; }
.btn--hero-primary:hover { background:#ea580c; color:#fff; }
.btn--hero-secondary { background:transparent; color:#fff; border:2px solid rgba(255,255,255,.4); padding:14px 28px; border-radius:8px; font-weight:600; font-size:1rem; cursor:pointer; text-decoration:none; display:inline-flex; align-items:center; gap:8px; transition:all .2s; }
.btn--hero-secondary:hover { border-color:#fff; background:rgba(255,255,255,.08); }
.hero__stats { display:flex; align-items:center; gap:20px; color:#94a3b8; font-size:.9rem; }
.hero__stat { text-align:center; }
.hero__stat-num { display:block; font-size:1.3rem; font-weight:700; color:#fff; }
.hero__stat-div { width:1px; height:30px; background:rgba(255,255,255,.2); }
.hero__card { background:rgba(255,255,255,.08); backdrop-filter:blur(10px); border:1px solid rgba(255,255,255,.15); border-radius:16px; padding:24px; }
.hero__card-icon { font-size:2rem; margin-bottom:12px; }
.hero__card-title { font-weight:600; margin-bottom:16px; font-size:.95rem; }
.hero__card-offers { display:flex; flex-direction:column; gap:8px; }
.offer-pill { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15); border-radius:8px; padding:8px 12px; font-size:.88rem; color:#e2e8f0; }
.offer-pill--best { background:rgba(34,197,94,.15); border-color:rgba(34,197,94,.4); color:#86efac; }
.hero__card-badge { margin-top:14px; background:rgba(249,115,22,.2); color:#fb923c; border-radius:20px; padding:4px 12px; font-size:.78rem; font-weight:600; display:inline-block; }

.section--light { background:#f8fafc; padding:80px 0; }
.section--white { background:#fff; padding:80px 0; }
.section--dark { background:#0f172a; color:#fff; padding:80px 0; }
.section--accent { background:linear-gradient(135deg,#2563eb,#0ea5e9); color:#fff; padding:64px 0; text-align:center; }
.section-header { text-align:center; margin-bottom:48px; }
.section-header h2 { font-size:clamp(1.5rem,3vw,2.2rem); font-weight:700; margin:0 0 12px; }
.section-header p { color:#6b7280; font-size:1.05rem; margin:0; }
.section-header--flex { text-align:left; display:flex; align-items:flex-end; justify-content:space-between; flex-wrap:wrap; gap:12px; }

.two-ways__grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
@media(max-width:700px){ .two-ways__grid { grid-template-columns:1fr; } }
.way-card { background:#fff; border-radius:16px; border:2px solid #e5e7eb; padding:32px; position:relative; }
.way-card--featured { border-color:#2563eb; }
.way-card__tag { display:inline-block; background:#eff6ff; color:#2563eb; border-radius:20px; padding:4px 12px; font-size:.8rem; font-weight:600; margin-bottom:16px; }
.way-card__icon { font-size:2.5rem; margin-bottom:16px; display:block; }
.way-card h3 { font-size:1.2rem; margin:0 0 12px; }
.way-card p { color:#6b7280; line-height:1.6; margin:0 0 20px; }
.way-card__features { list-style:none; padding:0; margin:0 0 24px; display:flex; flex-direction:column; gap:8px; color:#374151; font-size:.9rem; }

.steps-grid { display:grid; grid-template-columns:1fr auto 1fr auto 1fr auto 1fr; gap:8px; align-items:start; }
@media(max-width:800px){ .steps-grid { grid-template-columns:1fr 1fr; } .step__arrow { display:none; } }
.step { text-align:center; padding:24px 16px; }
.step__num { width:48px; height:48px; background:#2563eb; color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.2rem; font-weight:700; margin:0 auto 16px; }
.step h4 { font-size:1rem; margin:0 0 8px; }
.step p { color:#6b7280; font-size:.88rem; margin:0; }
.step__arrow { font-size:1.5rem; color:#cbd5e1; align-self:center; padding:0 4px; }

.car-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:20px; }
.car-card { background:#fff; border-radius:12px; border:1px solid #e5e7eb; overflow:hidden; transition:box-shadow .2s,transform .2s; }
.car-card:hover { box-shadow:0 8px 25px rgba(0,0,0,.1); transform:translateY(-2px); }
.car-card--dealer { border-top:3px solid #f97316; }
.car-card__img-wrap { display:block; position:relative; aspect-ratio:16/10; overflow:hidden; }
.car-card__img { width:100%; height:100%; object-fit:cover; transition:transform .3s; }
.car-card:hover .car-card__img { transform:scale(1.03); }
.car-card__img-placeholder { width:100%; height:100%; background:#f1f5f9; display:flex; align-items:center; justify-content:center; }
.car-card__badge { position:absolute; top:10px; right:10px; background:rgba(0,0,0,.65); color:#fff; border-radius:6px; padding:3px 8px; font-size:.75rem; font-weight:500; }
.car-card__dealer-tag { position:absolute; bottom:0; left:0; right:0; background:rgba(249,115,22,.85); color:#fff; padding:5px 10px; font-size:.75rem; font-weight:500; display:flex; align-items:center; gap:4px; }
.car-card__body { padding:14px 16px; }
.car-card__title { font-weight:600; margin-bottom:8px; font-size:.95rem; }
.car-card__specs { display:flex; gap:8px; flex-wrap:wrap; font-size:.8rem; color:#6b7280; margin-bottom:6px; }
.car-card__location { font-size:.8rem; color:#6b7280; margin-bottom:10px; }
.car-card__footer { display:flex; align-items:center; justify-content:space-between; padding-top:10px; border-top:1px solid #f1f5f9; }
.car-card__price { font-size:1.2rem; font-weight:700; color:#111; }

.benefits-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:24px; }
.benefit-card { background:#f8fafc; border-radius:12px; padding:24px; }
.benefit-card__icon { font-size:2rem; margin-bottom:12px; display:block; }
.benefit-card h4 { margin:0 0 8px; font-size:1rem; }
.benefit-card p { color:#6b7280; margin:0; font-size:.88rem; line-height:1.6; }

.for-dealers__inner { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
@media(max-width:800px){ .for-dealers__inner { grid-template-columns:1fr; } }
.for-dealers__label { display:inline-block; background:rgba(249,115,22,.2); color:#fb923c; border-radius:20px; padding:4px 14px; font-size:.82rem; font-weight:600; margin-bottom:16px; }
.for-dealers__content h2 { font-size:clamp(1.4rem,3vw,2rem); margin:0 0 16px; }
.for-dealers__content p { color:#94a3b8; line-height:1.6; margin:0 0 20px; }
.for-dealers__features { list-style:none; padding:0; margin:0 0 28px; display:flex; flex-direction:column; gap:8px; color:#e2e8f0; font-size:.9rem; }
.for-dealers__ctas { display:flex; gap:12px; flex-wrap:wrap; }
.btn--ghost { background:transparent; color:#fff; border:2px solid rgba(255,255,255,.3); padding:12px 24px; border-radius:8px; font-weight:600; text-decoration:none; transition:all .2s; display:inline-block; }
.btn--ghost:hover { border-color:#fff; }
.for-dealers__plans { display:flex; flex-direction:column; gap:12px; }
.plan-preview { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:12px; padding:20px 24px; position:relative; }
.plan-preview--pro { border-color:#f97316; background:rgba(249,115,22,.08); }
.plan-preview--premium { border-color:#eab308; background:rgba(234,179,8,.06); }
.plan-preview__badge { position:absolute; top:-10px; right:16px; background:#f97316; color:#fff; border-radius:10px; padding:2px 10px; font-size:.72rem; font-weight:700; }
.plan-preview--premium .plan-preview__badge { background:#eab308; }
.plan-preview__name { font-weight:700; color:#fff; margin-bottom:4px; }
.plan-preview__price { font-size:1.1rem; font-weight:700; color:#38bdf8; }
.plan-preview__desc { font-size:.82rem; color:#94a3b8; margin-top:4px; }

.cta-final { padding:80px 0; text-align:center; }
.cta-final h2 { font-size:clamp(1.6rem,3vw,2.4rem); margin:0 0 16px; }
.cta-final p { font-size:1.1rem; opacity:.85; margin:0 0 32px; }
.cta-final__btns { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-bottom:24px; }
.btn--white { background:#fff; color:#2563eb; border:none; padding:14px 28px; border-radius:8px; font-weight:600; font-size:1rem; cursor:pointer; text-decoration:none; display:inline-block; transition:all .2s; }
.btn--white:hover { background:#eff6ff; color:#1d4ed8; }
.btn--white-outline { background:transparent; color:#fff; border:2px solid rgba(255,255,255,.6); padding:14px 28px; border-radius:8px; font-weight:600; font-size:1rem; cursor:pointer; text-decoration:none; display:inline-block; transition:all .2s; }
.btn--white-outline:hover { border-color:#fff; background:rgba(255,255,255,.1); }
.btn--lg { padding:16px 32px; font-size:1.05rem; }
.cta-final__account { color:rgba(255,255,255,.75); font-size:.9rem; }
.cta-final__account a { color:#fff; font-weight:600; }
.cta-final__account a:hover { text-decoration:underline; }

/* ── Form card ──────────────────────────────────────────── */
.form-card { background:#fff; border-radius:12px; border:1px solid #e5e7eb; padding:28px; }
.form-group { margin-bottom:18px; }
.form-label { display:block; font-weight:500; font-size:.9rem; margin-bottom:6px; color:#374151; }
.form-control { width:100%; padding:10px 12px; border:1.5px solid #d1d5db; border-radius:8px; font-size:.95rem; box-sizing:border-box; transition:border-color .15s; }
.form-control:focus { outline:none; border-color:#2563eb; box-shadow:0 0 0 3px rgba(37,99,235,.1); }
.form-control:disabled { background:#f9fafb; cursor:not-allowed; }
.form-hint { font-size:.78rem; color:#9ca3af; margin-top:4px; display:block; }
.form-actions { display:flex; gap:12px; margin-top:24px; }
.btn--full { width:100%; text-align:center; justify-content:center; }
.btn--success { background:#16a34a; color:#fff; border:none; padding:10px 20px; border-radius:8px; font-weight:600; cursor:pointer; text-decoration:none; display:inline-flex; align-items:center; gap:6px; transition:background .2s; }
.btn--success:hover { background:#15803d; }
.btn--danger { background:#dc2626; color:#fff; border:none; padding:10px 20px; border-radius:8px; font-weight:600; cursor:pointer; text-decoration:none; display:inline-flex; align-items:center; gap:6px; transition:background .2s; }
.btn--danger:hover { background:#b91c1c; }

/* ── Misc ───────────────────────────────────────────────── */
.text-right { text-align:right; }
.text-sm { font-size:.82rem !important; }
.text-muted { color:#6b7280; }
.mt-3 { margin-top:12px; }
.btn-group { display:flex; gap:8px; flex-wrap:wrap; }
/* ── Google OAuth button ─────────────────────────────────────── */
.btn--google {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .6rem;
    background: #fff;
    color: #3c4043;
    border: 1.5px solid #dadce0;
    font-weight: 500;
    transition: box-shadow .2s, background .2s;
}
.btn--google:hover {
    background: #f8f9fa;
    box-shadow: 0 1px 4px rgba(60,64,67,.25);
    color: #3c4043;
    text-decoration: none;
}
.auth-divider {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin: 1rem 0;
    color: var(--text-muted);
    font-size: .85rem;
}
.auth-divider::before,
.auth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border);
}