/* Vogel Mietwagen — Frontend Styles
 * Design: refined neutral + warmes Orange als Akzent,
 * Mobile-first, klare Hierarchie, fühlt sich nicht generisch an.
 */

.vmw-rechner {
    --vmw-bg: #fafaf9;
    --vmw-surface: #ffffff;
    --vmw-border: #e7e5e4;
    --vmw-border-strong: #d6d3d1;
    --vmw-text: #1c1917;
    --vmw-text-muted: #57534e;
    --vmw-accent: #c2410c;
    --vmw-accent-hover: #9a3412;
    --vmw-accent-soft: #fff7ed;
    --vmw-success: #15803d;
    --vmw-error: #b91c1c;
    --vmw-error-bg: #fef2f2;
    --vmw-radius: 8px;
    --vmw-shadow: 0 1px 2px rgba(0,0,0,.05), 0 4px 12px rgba(28,25,23,.04);
    --vmw-shadow-hover: 0 2px 4px rgba(0,0,0,.06), 0 12px 24px rgba(28,25,23,.08);

    position: relative;
    max-width: 980px;
    margin: 0 auto;
    padding: 32px 16px;
    color: var(--vmw-text);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
    line-height: 1.5;
    box-sizing: border-box;
}

.vmw-rechner *, .vmw-rechner *::before, .vmw-rechner *::after {
    box-sizing: border-box;
}

/* Step container */
.vmw-step {
    display: none;
    animation: vmwFadeIn .35s ease both;
}
.vmw-step.vmw-active {
    display: block;
}
@keyframes vmwFadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

.vmw-step-title {
    font-size: 20px;
    font-weight: 600;
    color: var(--vmw-text);
    margin: 0 0 20px;
    display: flex;
    align-items: center;
    gap: 12px;
    letter-spacing: -0.01em;
}

.vmw-step-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--vmw-accent);
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    flex-shrink: 0;
}

.vmw-selected-vehicle {
    font-size: 14px;
    font-weight: 500;
    color: var(--vmw-text-muted);
    margin-left: auto;
}

/* Vehicle grid */
.vmw-vehicles {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}
@media (min-width: 640px) {
    .vmw-vehicles { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 960px) {
    .vmw-vehicles { grid-template-columns: repeat(3, 1fr); }
}

.vmw-vehicle-card {
    background: var(--vmw-surface);
    border: 1px solid var(--vmw-border);
    border-radius: var(--vmw-radius);
    overflow: hidden;
    cursor: pointer;
    transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease;
    box-shadow: var(--vmw-shadow);
    display: flex;
    flex-direction: column;
}
.vmw-vehicle-card:hover, .vmw-vehicle-card:focus {
    transform: translateY(-2px);
    border-color: var(--vmw-accent);
    box-shadow: var(--vmw-shadow-hover);
    outline: none;
}
.vmw-vehicle-card.vmw-selected {
    border-color: var(--vmw-accent);
    box-shadow: 0 0 0 2px var(--vmw-accent), var(--vmw-shadow-hover);
}

.vmw-vehicle-image {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: var(--vmw-bg);
}
.vmw-vehicle-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.vmw-vehicle-noimage {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 64px;
    color: var(--vmw-border-strong);
}

.vmw-vehicle-body {
    padding: 16px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.vmw-vehicle-name {
    font-size: 18px;
    font-weight: 600;
    margin: 0 0 12px;
    color: var(--vmw-text);
}

.vmw-vehicle-prices {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin-bottom: 16px;
    padding: 12px;
    background: var(--vmw-bg);
    border-radius: 6px;
}
.vmw-vehicle-prices > div {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}
.vmw-vehicle-prices span {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--vmw-text-muted);
    margin-bottom: 2px;
}
.vmw-vehicle-prices strong {
    font-size: 15px;
    font-weight: 700;
    color: var(--vmw-text);
}

/* Buttons */
.vmw-btn {
    display: inline-block;
    padding: 10px 20px;
    font-size: 15px;
    font-weight: 600;
    border-radius: 6px;
    border: 1px solid transparent;
    cursor: pointer;
    transition: background-color .15s ease, border-color .15s ease, color .15s ease, transform .1s ease;
    text-decoration: none;
    text-align: center;
    font-family: inherit;
}
.vmw-btn:active { transform: translateY(1px); }
.vmw-btn:focus-visible { outline: 2px solid var(--vmw-accent); outline-offset: 2px; }

.vmw-btn-primary {
    background: var(--vmw-accent);
    color: #fff;
    border-color: var(--vmw-accent);
}
.vmw-btn-primary:hover { background: var(--vmw-accent-hover); border-color: var(--vmw-accent-hover); }
.vmw-btn-primary:disabled { opacity: .45; cursor: not-allowed; }

.vmw-btn-secondary {
    background: transparent;
    color: var(--vmw-text);
    border-color: var(--vmw-border-strong);
}
.vmw-btn-secondary:hover { background: var(--vmw-bg); }

.vmw-btn-select {
    width: 100%;
    background: var(--vmw-text);
    color: #fff;
    border: none;
    margin-top: auto;
}
.vmw-btn-select:hover { background: #000; }

.vmw-actions {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    margin-top: 24px;
}
.vmw-actions .vmw-btn { flex: 1; }
@media (min-width: 640px) {
    .vmw-actions .vmw-btn { flex: 0 1 auto; min-width: 160px; }
}

/* Form fields */
.vmw-field {
    margin-bottom: 16px;
}
.vmw-field label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--vmw-text);
    margin-bottom: 6px;
}
.vmw-field input[type="text"],
.vmw-field input[type="email"],
.vmw-field input[type="tel"],
.vmw-field input[type="date"],
.vmw-field textarea {
    width: 100%;
    padding: 10px 12px;
    font-size: 15px;
    font-family: inherit;
    color: var(--vmw-text);
    background: var(--vmw-surface);
    border: 1px solid var(--vmw-border-strong);
    border-radius: 6px;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.vmw-field input:focus,
.vmw-field textarea:focus {
    outline: none;
    border-color: var(--vmw-accent);
    box-shadow: 0 0 0 3px rgba(194, 65, 12, 0.12);
}
.vmw-field textarea { resize: vertical; min-height: 80px; }

.vmw-field-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}
@media (min-width: 640px) {
    .vmw-field-row { grid-template-columns: 1fr 1fr; }
    .vmw-field-row .vmw-field-large { grid-column: span 1; }
    .vmw-field-row:has(.vmw-field-small) { grid-template-columns: 120px 1fr; }
}

.vmw-date-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}
@media (min-width: 640px) {
    .vmw-date-row { grid-template-columns: 1fr 1fr; }
}

.vmw-checkbox-field label {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-weight: 400;
    font-size: 14px;
    color: var(--vmw-text-muted);
    line-height: 1.5;
    cursor: pointer;
}
.vmw-checkbox-field input[type="checkbox"] {
    margin-top: 2px;
    flex-shrink: 0;
    accent-color: var(--vmw-accent);
}
.vmw-checkbox-field a {
    color: var(--vmw-accent);
    text-decoration: underline;
}

/* Extras */
.vmw-extras {
    display: grid;
    gap: 10px;
    margin-bottom: 20px;
}
.vmw-extra-card {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px;
    background: var(--vmw-surface);
    border: 1px solid var(--vmw-border);
    border-radius: 6px;
    cursor: pointer;
    transition: border-color .15s ease, background-color .15s ease;
}
.vmw-extra-card:hover { border-color: var(--vmw-border-strong); }
.vmw-extra-card input[type="checkbox"] {
    margin: 0;
    accent-color: var(--vmw-accent);
    width: 20px;
    height: 20px;
    cursor: pointer;
}
.vmw-extra-card:has(input:checked) {
    border-color: var(--vmw-accent);
    background: var(--vmw-accent-soft);
}
.vmw-extra-body { flex: 1; display: flex; flex-direction: column; }
.vmw-extra-body strong { font-size: 15px; font-weight: 600; color: var(--vmw-text); }
.vmw-extra-body small { font-size: 13px; color: var(--vmw-text-muted); margin-top: 2px; }
.vmw-extra-price { font-size: 14px; font-weight: 600; color: var(--vmw-text); }

.vmw-no-extras { color: var(--vmw-text-muted); font-style: italic; }

/* Availability / Price summary boxes */
.vmw-availability-info,
.vmw-price-summary,
.vmw-final-price {
    margin-top: 16px;
    padding: 16px;
    background: var(--vmw-bg);
    border: 1px solid var(--vmw-border);
    border-radius: var(--vmw-radius);
    font-size: 14px;
}
.vmw-availability-info:empty,
.vmw-price-summary:empty,
.vmw-final-price:empty { display: none; }

.vmw-availability-info.vmw-error,
.vmw-form-error {
    background: var(--vmw-error-bg);
    border-color: var(--vmw-error);
    color: var(--vmw-error);
}

.vmw-price-breakdown {
    width: 100%;
    border-collapse: collapse;
}
.vmw-price-breakdown td {
    padding: 6px 0;
    font-size: 14px;
}
.vmw-price-breakdown td:last-child { text-align: right; font-variant-numeric: tabular-nums; }
.vmw-price-breakdown tr.vmw-price-total td {
    border-top: 2px solid var(--vmw-text);
    padding-top: 12px;
    font-size: 17px;
    font-weight: 700;
}
.vmw-price-breakdown tr.vmw-price-info td {
    color: var(--vmw-text-muted);
    font-size: 13px;
    padding-top: 8px;
}

.vmw-info-box {
    margin: 16px 0;
    padding: 14px 16px;
    background: var(--vmw-accent-soft);
    border-left: 3px solid var(--vmw-accent);
    border-radius: 4px;
    font-size: 14px;
}
.vmw-info-box strong { display: block; margin-bottom: 4px; color: var(--vmw-text); }
.vmw-info-box p { margin: 0; color: var(--vmw-text-muted); }

.vmw-disclaimer {
    margin-top: 16px;
    font-size: 12px;
    color: var(--vmw-text-muted);
    line-height: 1.5;
}

/* Success step */
.vmw-success {
    text-align: center;
    padding: 40px 20px;
}
.vmw-success-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    background: var(--vmw-success);
    color: #fff;
    border-radius: 50%;
    font-size: 32px;
    font-weight: 700;
    margin-bottom: 16px;
}
.vmw-success h3 {
    font-size: 24px;
    font-weight: 700;
    margin: 0 0 12px;
    color: var(--vmw-text);
}
.vmw-success p {
    font-size: 15px;
    color: var(--vmw-text-muted);
    max-width: 500px;
    margin: 8px auto;
}

/* Loader */
.vmw-loader {
    display: none;
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(255,255,255,.75);
    align-items: center;
    justify-content: center;
    z-index: 10;
    border-radius: var(--vmw-radius);
}
.vmw-loader.vmw-show { display: flex; }
.vmw-spinner {
    width: 36px;
    height: 36px;
    border: 3px solid var(--vmw-border-strong);
    border-top-color: var(--vmw-accent);
    border-radius: 50%;
    animation: vmwSpin .8s linear infinite;
}
@keyframes vmwSpin { to { transform: rotate(360deg); } }

/* Form error */
.vmw-form-error {
    padding: 12px 14px;
    background: var(--vmw-error-bg);
    border: 1px solid var(--vmw-error);
    border-radius: 6px;
    color: var(--vmw-error);
    font-size: 14px;
    margin-bottom: 16px;
}

.vmw-input-error {
    border-color: var(--vmw-error) !important;
}

/* ====================================================================
   V0.2: Kalender, Pills, SB-Boxen, Empfehlung-Badge
   ==================================================================== */

.vmw-cal-hint {
  background: #fff7ed;
  border-left: 3px solid #c2410c;
  padding: 12px 16px;
  border-radius: 4px;
  margin-bottom: 16px;
  font-size: 14px;
}
.vmw-cal-hint .vmw-legend {
  display: inline-flex;
  gap: 16px;
  margin-left: 16px;
  font-size: 12px;
}
.vmw-cal-hint .vmw-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.vmw-cal-hint .vmw-legend-item::before {
  content: '';
  width: 14px;
  height: 14px;
  border-radius: 3px;
  border: 1px solid #d4d4d8;
  display: inline-block;
}
.vmw-cal-hint .vmw-legend-free::before    { background: #fff; }
.vmw-cal-hint .vmw-legend-booked::before  { background: #e5e7eb; }
.vmw-cal-hint .vmw-legend-selected::before { background: #c2410c; border-color: #c2410c; }

.vmw-calendar-container {
  margin: 12px 0;
  display: flex;
  justify-content: center;
}
.vmw-calendar-container .flatpickr-calendar {
  box-shadow: 0 2px 12px rgba(0,0,0,0.08);
  border: 1px solid #e5e7eb;
}

.vmw-calendar-container .flatpickr-day.selected,
.vmw-calendar-container .flatpickr-day.startRange,
.vmw-calendar-container .flatpickr-day.endRange {
  background: #c2410c;
  border-color: #c2410c;
}
.vmw-calendar-container .flatpickr-day.inRange {
  background: #fed7aa;
  border-color: #fed7aa;
  box-shadow: -5px 0 0 #fed7aa, 5px 0 0 #fed7aa;
}
.vmw-calendar-container .flatpickr-day.flatpickr-disabled {
  background: #f3f4f6;
  color: #9ca3af;
  text-decoration: line-through;
}

.vmw-date-summary {
  display: flex;
  gap: 12px;
  margin: 16px 0;
  flex-wrap: wrap;
}
.vmw-date-pill {
  flex: 1;
  min-width: 140px;
  background: #fafaf9;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 10px 14px;
}
.vmw-date-pill span {
  display: block;
  font-size: 11px;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 2px;
}
.vmw-date-pill strong {
  font-size: 15px;
  color: #1c1917;
}
.vmw-date-pill-duration {
  background: #fff7ed;
  border-color: #fdba74;
}
.vmw-date-pill-duration strong { color: #9a3412; }

@media (max-width: 720px) {
  .vmw-cal-hint .vmw-legend {
    display: flex;
    margin-left: 0;
    margin-top: 8px;
    flex-wrap: wrap;
  }
  .vmw-date-summary {
    flex-direction: column;
  }
}

/* Vollkasko-Empfehlung */
.vmw-extra-recommended {
  border: 2px solid #c2410c !important;
  position: relative;
  background: #fff7ed;
}
.vmw-recommended-badge {
  position: absolute;
  top: -10px;
  right: 12px;
  background: #c2410c;
  color: #fff;
  padding: 2px 10px;
  border-radius: 12px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.5px;
}

/* Info-Box "weich" */
.vmw-info-box.vmw-info-soft {
  background: #ecfdf5;
  border-left-color: #15803d;
}

/* ====================================================================
   V0.3: Time-Slots, Cutoff-Warnung
   ==================================================================== */

.vmw-time-row {
  display: flex;
  gap: 16px;
  margin: 16px 0;
}
.vmw-time-row .vmw-field {
  flex: 1;
}
.vmw-time-row select {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid #d4d4d8;
  border-radius: 6px;
  font-size: 15px;
  background: #fff;
}
.vmw-time-row .vmw-hint {
  display: block;
  font-size: 12px;
  color: #64748b;
  margin-top: 4px;
}

.vmw-cutoff-warning {
  background: #fef3c7;
  border-left: 4px solid #d97706;
  padding: 12px 16px;
  border-radius: 4px;
  margin: 8px 0 16px;
  font-size: 14px;
  color: #78350f;
}

.vmw-price-warn {
  color: #92400e;
  font-style: italic;
  font-size: 13px;
}
.vmw-price-warn strong { display: none; }

@media (max-width: 600px) {
  .vmw-time-row {
    flex-direction: column;
  }
}
