/* ===========
   1. DESIGN TOKENS (DEFAULT THEME)
   =========== */

:root {
    /* Colors */
    --rw-color-bg: #ffffff;
    --rw-color-surface: #ffffff;
    --rw-color-surface-soft: #f9fafb;
    --rw-color-border: #e5e7eb;

    --rw-color-text: #111827;
    --rw-color-text-muted: #6b7280;
    --rw-color-text-soft: #9ca3af;

    --rw-color-primary: #2563eb;
    --rw-color-primary-soft: #eff6ff;
    --rw-color-primary-strong: #1d4ed8;

    --rw-color-danger: #b91c1c;
    --rw-color-danger-soft: #fee2e2;

    --rw-color-focus: #b1c4ed;
    --rw-color-focus-soft: #fff;

    /* Elevation & radius */
    --rw-radius-sm: 4px;
    --rw-radius-md: 8px;
    --rw-radius-lg: 12px;
    --rw-radius-pill: 999px;

    --rw-shadow-soft: 0 10px 30px rgba(15, 23, 42, 0.08);

    /* Typography */
    --rw-font-family: -apple-system, BlinkMacSystemFont, "Segoe UI",
    "Roboto", "Helvetica Neue", Arial, sans-serif;

    --rw-font-size-xs: 0.75rem;
    --rw-font-size-sm: 0.875rem;
    --rw-font-size-md: 1rem;
    --rw-font-size-lg: 1.125rem;

    --rw-font-weight-normal: 400;
    --rw-font-weight-medium: 500;
    --rw-font-weight-semibold: 600;

    /* Spacing scale */
    --rw-space-1: 0.25rem;
    --rw-space-2: 0.5rem;
    --rw-space-3: 0.75rem;
    --rw-space-4: 1rem;
    --rw-space-5: 1.25rem;
    --rw-space-6: 1.5rem;
    --rw-space-7: 1.75rem;
    --rw-space-8: 2rem;

    /* Layout */
    --rw-max-width: 960px;
    --rw-border-width: 1px;

    /* Component-specific tokens */
    --rw-button-radius: var(--rw-radius-pill);
    --rw-card-radius: var(--rw-radius-lg);
    --rw-input-radius: var(--rw-radius-md);

    /* Header and logo */

    --rw-header-color-bg: #ffffff;
    --rw-logo-max-width: 140px;
    --rw-logo-max-height: 70px;
    --rw-invert-logo-filter: 0;
}

/* ===========
   2. BASE & SHELL
   =========== */

.rw-root {
    box-sizing: border-box;
    font-family: var(--rw-font-family);
    background: var(--rw-color-bg);
    color: var(--rw-color-text);
    margin-top: 10px;
}

/* Zorg dat alles binnen de widget scoped is */
.rw-root *,
.rw-root *::before,
.rw-root *::after {
    box-sizing: inherit;
}

.rw-shell {
    max-width: var(--rw-max-width);
    margin: 0 auto;
    background: var(--rw-color-surface);
    border-radius: var(--rw-card-radius);
    box-shadow: var(--rw-shadow-soft);
    padding: var(--rw-space-5);
}

/* Header met logo en stepper */
.rw-header {
    display: flex;
    align-items: center;
    gap: var(--rw-space-4);
    margin-bottom: var(--rw-space-4);
    padding: 15px;
    background: var(--rw-header-color-bg);
}

.rw-logo {
    max-height: var(--rw-logo-max-height);
    max-width: var(--rw-logo-max-width);
    object-fit: contain;
    margin-left: 10px;
    filter: invert(var(--rw-invert-logo-filter));
}

.rw-header-title {
    font-size: var(--rw-font-size-lg);
    font-weight: var(--rw-font-weight-semibold);
}

.rw-content {
    display: flex;
    flex-direction: column;
    gap: var(--rw-space-4);
}

/* Typografie helpers */
.rw-title {
    font-size: var(--rw-font-size-lg);
    font-weight: var(--rw-font-weight-semibold);
    margin-bottom: var(--rw-space-2);
}

.rw-subtitle {
    font-size: var(--rw-font-size-sm);
    color: var(--rw-color-text-muted);
    margin-bottom: var(--rw-space-4);
}

.rw-muted {
    color: var(--rw-color-text-muted);
    font-size: var(--rw-font-size-sm);
}

/* ===========
   STEPPER
   =========== */

.rw-stepper {
    display: flex;
    flex-wrap: wrap;
    gap: var(--rw-space-2);
    margin-left: auto;
    padding-top: 10px;
}

.rw-step {
    display: inline-flex;
    align-items: center;
    gap: var(--rw-space-1);
    padding: var(--rw-space-1) var(--rw-space-3);
    border-radius: var(--rw-radius-pill);
    background: var(--rw-color-surface-soft);
    color: var(--rw-color-text-soft);
    font-size: var(--rw-font-size-xs);
    font-weight: var(--rw-font-weight-medium);
}

.rw-step-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--rw-color-border);
    color: var(--rw-color-text);
    font-size: 0.7rem;
}

.rw-step--active {
    background: var(--rw-color-primary-soft);
    color: var(--rw-color-primary-strong);
}

.rw-step--active .rw-step-number {
    background: var(--rw-color-primary);
    color: #fff;
}

.rw-step--done {
    background: var(--rw-color-surface-soft);
    color: var(--rw-color-text-muted);
}

.rw-step--done .rw-step-number {
    background: var(--rw-color-primary);
    color: #fff;
}

/* ===========
   CARDS
   =========== */

.rw-card {
    border-radius: var(--rw-card-radius);
    border: var(--rw-border-width) solid var(--rw-color-border);
    background: var(--rw-color-surface);
    padding: var(--rw-space-4);
    display: flex;
    gap: var(--rw-space-4);
}

.rw-card + .rw-card {
    margin-top: var(--rw-space-3);
}

.rw-card--clickable {
    cursor: pointer;
    transition: box-shadow 0.15s ease, transform 0.15s ease,
    border-color 0.15s ease;
}

.rw-card--clickable:hover {
    box-shadow: 0 10px 28px rgba(15, 23, 42, 0.12);
    transform: translateY(-1px);
    border-color: var(--rw-color-primary-soft);
}

.rw-card-image {
    flex-shrink: 0;
    width: 160px;
    height: 110px;
    border-radius: var(--rw-radius-md);
    overflow: hidden;
    background: var(--rw-color-surface-soft);
}

.rw-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.rw-card-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--rw-space-2);
}

.rw-card-title {
    font-weight: var(--rw-font-weight-semibold);
    font-size: var(--rw-font-size-md);
}

.rw-card-meta {
    font-size: var(--rw-font-size-sm);
    color: var(--rw-color-text-muted);
}

.rw-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--rw-space-2);
    margin-top: auto;
}

.rw-price-main {
    font-size: var(--rw-font-size-md);
    font-weight: var(--rw-font-weight-semibold);
}

.rw-price-secondary {
    font-size: var(--rw-font-size-xs);
    color: var(--rw-color-text-muted);
}

/* ===========
   BUTTONS
   =========== */

.rw-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--rw-space-2);
    border-radius: var(--rw-button-radius);
    font-size: var(--rw-font-size-sm);
    font-weight: var(--rw-font-weight-medium);
    padding: 0.55rem 1.4rem;
    border: none;
    cursor: pointer;
    white-space: nowrap;
    text-decoration: none;
}

.rw-btn-primary {
    background: var(--rw-color-primary);
    color: #ffffff;
}

.rw-btn-primary:hover {
    background: var(--rw-color-primary-strong);
}

.rw-btn-secondary {
    background: var(--rw-color-surface-soft);
    color: var(--rw-color-text);
    border: var(--rw-border-width) solid var(--rw-color-border);
}

.rw-btn-secondary:hover {
    background: #e5e7eb;
}

.rw-btn-ghost {
    background: transparent;
    color: var(--rw-color-text-muted);
    padding-inline: var(--rw-space-2);
}

.rw-btn-sm {
    padding: 0.3rem 0.9rem;
    font-size: var(--rw-font-size-xs);
}

.rw-btn-block {
    width: 100%;
}

.rw-btn[disabled],
.rw-btn:disabled {
    opacity: 0.6;
    cursor: default;
}

/* ===========
   FORMS
   =========== */

.rw-form {
    display: flex;
    flex-direction: column;
    gap: var(--rw-space-4);
}

.rw-form-row {
    display: flex;
    flex-direction: column;
    gap: var(--rw-space-1);
}

.rw-label {
    font-size: var(--rw-font-size-sm);
    font-weight: var(--rw-font-weight-medium);
    color: var(--rw-color-text);
}

.rw-label-optional {
    font-size: var(--rw-font-size-xs);
    color: var(--rw-color-text-soft);
}

.rw-input,
.rw-select,
.rw-textarea {
    border-radius: var(--rw-input-radius);
    border: var(--rw-border-width) solid var(--rw-color-border);
    padding: 0.55rem 0.7rem;
    font-family: var(--rw-font-family);
    font-size: var(--rw-font-size-sm);
    color: var(--rw-color-text);
    background-color: #ffffff;
}

.rw-pad-y-3 {
    padding-top: var(--rw-space-3);
    padding-bottom: var(--rw-space-3);
}

.rw-mar-y-3 {
    margin-top: var(--rw-space-3);
    margin-bottom: var(--rw-space-3);
}

.rw-input:focus,
.rw-select:focus,
.rw-textarea:focus {
    outline: 1px solid var(--rw-color-focus);
    border-color: var(--rw-color-focus);
}

.rw-textarea {
    min-height: 80px;
    resize: vertical;
}

.rw-inline-fields {
    display: flex;
    gap: var(--rw-space-3);
}

.rw-inline-fields > .rw-form-row {
    flex: 1;
}

/* Checkbox/extra opties */

.rw-checkbox-row {
    display: flex;
    align-items: flex-start;
    gap: var(--rw-space-2);
}

.rw-checkbox-input {
    margin-top: 0.15rem;
}

.rw-checkbox-label {
    font-size: var(--rw-font-size-sm);
    color: var(--rw-color-text);
}

.rw-checkbox-help {
    font-size: var(--rw-font-size-xs);
    color: var(--rw-color-text-soft);
}

/* ===========
   SUMMARY BOX
   =========== */

.rw-summary {
    border-radius: var(--rw-card-radius);
    border: var(--rw-border-width) solid var(--rw-color-border);
    background: var(--rw-color-surface-soft);
    padding: var(--rw-space-3);
    font-size: var(--rw-font-size-sm);
}

.rw-summary-header {
    display: flex;
    justify-content: space-between;
    margin-bottom: var(--rw-space-2);
    font-weight: var(--rw-font-weight-medium);
}

.rw-summary-row {
    display: flex;
    justify-content: space-between;
    margin-bottom: var(--rw-space-1);
}

.rw-summary-row-muted {
    color: var(--rw-color-text-soft);
}

.rw-summary-total {
    display: flex;
    justify-content: space-between;
    margin-top: var(--rw-space-2);
    border-top: var(--rw-border-width) solid var(--rw-color-border);
    padding-top: var(--rw-space-2);
    font-weight: var(--rw-font-weight-semibold);
}

/* Lay-out: hoofdgebied + zijbalk */
.rw-layout-two-column {
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(0, 1.1fr);
    gap: var(--rw-space-4);
}

/* ===========
   STATES & HELPERS
   =========== */

.rw-hidden {
    display: none !important;
}

.rw-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.1rem 0.5rem;
    border-radius: var(--rw-radius-pill);
    font-size: var(--rw-font-size-xs);
    border: var(--rw-border-width) solid var(--rw-color-border);
    color: var(--rw-color-text-soft);
}

.rw-badge-success {
    border-color: rgba(22, 163, 74, 0.2);
    background: rgba(22, 163, 74, 0.06);
    color: #15803d;
}

.rw-badge-warning {
    border-color: rgba(202, 138, 4, 0.2);
    background: rgba(202, 138, 4, 0.06);
    color: #a16207;
}

.rw-message {
    border-radius: var(--rw-radius-md);
    padding: var(--rw-space-3);
    font-size: var(--rw-font-size-sm);
    border: var(--rw-border-width) solid var(--rw-color-border);
    background: var(--rw-color-surface-soft);
}

.rw-message-danger {
    border-color: var(--rw-color-danger-soft);
    background: var(--rw-color-danger-soft);
    color: var(--rw-color-danger);
}

/* Responsiveness */
@media (max-width: 768px) {
    .rw-shell {
        padding: var(--rw-space-4);
        border-radius: var(--rw-radius-md);
        box-shadow: none;
    }

    .rw-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .rw-stepper {
        margin-left: 0;
    }

    .rw-layout-two-column {
        grid-template-columns: minmax(0, 1fr);
    }

    .rw-card {
        flex-direction: column;
    }

    .rw-card-image {
        width: 100%;
        height: 160px;
    }
}

/* ===========
   VOERTUIGSELECTIE
   =========== */

.rw-vehicle-list {
    display: flex;
    flex-direction: column;
    gap: var(--rw-space-3);
    margin-bottom: var(--rw-space-3);
}

/* Kaarten voor voertuigen */
.rw-vehicle-card {
    display: flex;
    gap: var(--rw-space-3);
    padding: var(--rw-space-3);
    border-radius: var(--rw-card-radius);
    border: var(--rw-border-width) solid var(--rw-color-border);
    background: var(--rw-color-surface);
    cursor: pointer;
    transition: box-shadow 0.15s ease,
    transform 0.15s ease,
    border-color 0.15s ease,
    background-color 0.15s ease;
}

/* Geselecteerde kaart */
.rw-vehicle-card--selected {
    border-color: var(--rw-color-primary);
    box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.18);
    background: var(--rw-color-primary-soft);
}

/* Afbeelding in de kaart */
.rw-vehicle-image {
    flex-shrink: 0;
    width: 130px;
    height: 88px;
    border-radius: var(--rw-radius-md);
    overflow: hidden;
    background: var(--rw-color-surface-soft);
}

.rw-vehicle-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

/* Body van de kaart */
.rw-vehicle-body {
    display: flex;
    flex-direction: column;
    gap: var(--rw-space-1);
    flex: 1;
}

.rw-vehicle-name {
    margin: 0;
    font-size: var(--rw-font-size-md);
    font-weight: var(--rw-font-weight-semibold);
}

.rw-vehicle-meta {
    margin: 0;
    font-size: var(--rw-font-size-xs);
    color: var(--rw-color-text-muted);
}

.rw-vehicle-price {
    margin-top: var(--rw-space-1);
    font-size: var(--rw-font-size-sm);
    font-weight: var(--rw-font-weight-semibold);
}

#rw-vehicle-error {
    padding: var(--rw-space-3);
}

/* Foutmelding bij geen selectie */
.rw-error {
    color: var(--rw-color-danger);
    font-size: var(--rw-font-size-xs);
    margin-top: var(--rw-space-2);
}

/* ===========
   RESPONSIVE VOERTUIGKAARTEN
   =========== */

@media (max-width: 768px) {
    .rw-vehicle-card {
        flex-direction: column;
    }

    .rw-vehicle-image {
        width: 100%;
        aspect-ratio: 4 / 3; /* 👈 houdt consistente vorm */
        height: auto; /* 👈 niet geforceerd */
    }

    .rw-vehicle-image img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
}

/* ===========
   STEP 3 — EXTRA OPTIES
   =========== */

#rw-extra-list {
    display: flex;
    flex-direction: column;
    gap: var(--rw-space-3);
    margin-bottom: var(--rw-space-4);
}

/* Individuele extra-optie als "mini-card" */
.rw-extra-row {
    display: flex;
    align-items: flex-start;
    gap: var(--rw-space-2);
    padding: var(--rw-space-2) var(--rw-space-3);
    border-radius: var(--rw-card-radius);
    border: var(--rw-border-width) solid var(--rw-color-border);
    background: var(--rw-color-surface);
    cursor: pointer;
    transition: background-color 0.15s ease,
    border-color 0.15s ease,
    box-shadow 0.15s ease,
    transform 0.12s ease;
}

.rw-extra-row:hover {
    background: var(--rw-color-surface-soft);
    border-color: var(--rw-color-primary-soft);
    box-shadow: var(--rw-shadow-soft);
    transform: translateY(-1px);
}

/* Geselecteerde extra (checkbox checked) */
.rw-extra-row--checked {
    border-color: var(--rw-color-primary);
    background: var(--rw-color-primary-soft);
    box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.18);
}

/* De checkbox zelf */
.rw-extra-row input[type="checkbox"] {
    margin-top: 0.25rem;
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    cursor: pointer;
}

/* Tekstblok naast de checkbox */
.rw-extra-label {
    display: flex;
    flex-direction: column;
    gap: 2px;
    line-height: 1.3;
}

.rw-extra-title {
    font-size: var(--rw-font-size-sm);
    font-weight: var(--rw-font-weight-medium);
    color: var(--rw-color-text);
}

.rw-extra-price {
    font-size: var(--rw-font-size-xs);
    color: var(--rw-color-text-muted);
}

/* ===========
   RESPONSIVE STEP 3
   =========== */

@media (max-width: 768px) {
    #rw-extra-list {
        gap: var(--rw-space-2);
    }

    .rw-extra-row {
        padding: var(--rw-space-2) var(--rw-space-2);
    }
}

/* ===========
   STEP 5 — CTA
   =========== */

.rw-cta-btn {
    display: inline-block;
    margin-top: 12px;
    padding: 10px 22px;
    background: var(--rw-color-primary);
    color: #fff;
    text-decoration: none;
    border-radius: var(--rw-button-radius);
    font-weight: 600;
    transition: opacity 0.15s ease-in-out;
}

.rw-cta-btn:hover {
    opacity: 0.85;
}

/* Container die knoppen naast elkaar zet */
.rw-cta-row {
    display: flex;
    gap: 8px;
    justify-content: center;
    flex-wrap: wrap; /* zorgt dat ze stacken op mobiel */
}

/* WhatsApp knop groen */
.rw-cta-btn--whatsapp {
    background: #1E944A;
    color: #fff;
}

/* Icon in knop */
.rw-cta-btn--icon {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.rw-cta-icon-img {
    width: 18px;
    height: 18px;
    display: block;
}

/* Subtle top demo CTA */
.rw-top-cta {
    width: 100%;
    text-align: center;
    padding: 6px 0;
    font-size: 0.75em; /* kleiner op mobiel */
    font-family: var(--rw-font-family);
    color: #6b7280; /* zacht grijs */
    background: transparent;
    margin-bottom: 4px;
}

.rw-top-cta a {
    color: var(--rw-color-primary);
    font-weight: 600;
    text-decoration: none;
}

.rw-top-cta a:hover {
    text-decoration: underline;
}

/* Grotere font size op grotere schermen */
@media (min-width: 600px) {
    .rw-top-cta {
        font-size: 1em;
    }
}
