/**
 * Way2Rentals Configuration - CSS Variables & Main Container
 * @package Way2Rentals
 */

/* CSS Variables */
:root {
    --breakpoint-sm: 576px;
    --breakpoint-md: 768px;
    --breakpoint-lg: 992px;
    --breakpoint-xl: 1200px;

    /* Backgrounds */
    --color-bg-main: #fafafa;
    --color-bg-panel: #fff;
    --color-bg-card: #f5f5f5;
    --color-bg-header: #3498db;

    /* Text */
    --color-text-main: #212121;
    --color-text-theme: #314a89;
    --color-text-header: #fff;
    --color-text-detail: #5c5c5c;
    --color-text-muted: #757575;
    --color-text-price: #388e3c;
    --color-text-discount: #d32f2f;

    /* Buttons */
    --color-btn-bg: #3498db;
    --color-btn-text: #fff;
    --color-btn-selected-bg: #1976d2;
    --color-btn-selected-text: #fff;

    /* Cards */
    --color-card-selected-bg: #e3f2fd;
    --color-card-selected-border: #1976d2;
    --color-bg-selected: rgba(52, 152, 219, 0.05);

    /* Status */
    --color-success: #4caf50;
    --color-error: #f44336;
    --color-warning: #ff9800;
    --color-warning-hover: #e65100;
    --color-info: #2196f3;

    /* Alert backgrounds */
    --color-error-bg: #fff6f6;
    --color-error-light-bg: #f8d7da;
    --color-error-light-border: #f5c6cb;
    --color-success-bg: #d4edda;
    --color-success-border: #c3e6cb;
    --color-warning-bg: #fff3cd;
    --color-warning-border: #ffeaa7;

    /* Borders & Dividers */
    --color-border: #e0e0e0;

    /* Shadows */
    --shadow-main: 0 2px 8px rgba(0, 0, 0, 0.1);

    /* Promotion ribbon */
    --promo-ribbon-bg: #e63946;
    --promo-ribbon-text: #fff;
    --promo-ribbon-font-size: 0.6rem;
}

/* Main Container */
.w2r-container {
    width: 100%;
    font-size: 14px;
}

.is-layout-constrained>.w2r-container {
    max-width: 1300px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* WordPress theme override — remove side padding on mobile */
.has-global-padding {
    padding-right: 0px !important;
    padding-left: 0px !important;
}/**
 * Way2Rentals Layout System
 * Flexible layout patterns for content and sidebar arrangements
 * @package Way2Rentals
 */

/* =================================================================
   Base Layout Container
   Flexible container that supports multiple layout patterns
   ================================================================= */

.w2r-layout {
    display: flex;
    align-items: flex-start;
    gap: 20px;
}

/* =================================================================
   Content Area
   Main content region that grows to fill available space
   ================================================================= */

.w2r-layout-main {
    flex: 1 1 100%;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

/* =================================================================
   Sidebar Area
   Fixed-width sidebar that can be positioned left or right
   ================================================================= */

.w2r-layout-sidebar {
    min-width: 270px;
    max-width: 400px;
}


.w2r-layout-bordered {
    background: var(--color-bg-main);
    box-shadow: var(--shadow-main);
    background: var(--color-bg-panel);
}

/* =================================================================
   Layout Modifiers
   ================================================================= */

/* Right Sidebar (default) */
.w2r-layout--sidebar-right {
    flex-direction: row;
}

.w2r-layout--sidebar-right .w2r-layout-sidebar {
    order: 2;
}

/* Left Sidebar (for fleet search with filters) */
.w2r-layout--sidebar-left {
    flex-direction: row;
}

.w2r-layout--sidebar-left .w2r-layout-sidebar {
    order: 1;
}

.w2r-layout--sidebar-left .w2r-layout-main {
    order: 2;
}

/* Full Width (no sidebar, just padded content) */
.w2r-layout--full {
    flex-direction: column;
}

.w2r-layout--full .w2r-layout-main {
    width: 100%;
    max-width: 100%;
}

/* =================================================================
   Responsive Behavior
   Stack vertically on mobile, sidebar position depends on layout type
   ================================================================= */

@media (max-width: 992px) {
    .w2r-layout {
        flex-direction: column !important;
        padding: 15px;
    }

    .w2r-layout-sidebar,
    .w2r-layout-main {
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }

    /* Right sidebar: sidebar goes below main content */
    .w2r-layout--sidebar-right .w2r-layout-main {
        order: 1;
    }

    .w2r-layout--sidebar-right .w2r-layout-sidebar {
        order: 2;
    }

    /* Left sidebar: sidebar goes above main content */
    .w2r-layout--sidebar-left .w2r-layout-sidebar {
        order: 1;
    }

    .w2r-layout--sidebar-left .w2r-layout-main {
        order: 2;
    }
}

@media (max-width: 768px) {
    .w2r-layout {
        padding: 8px !important;
        gap: 10px;
    }

    .w2r-layout-bordered {
        box-shadow: none;
    }
}

@media (max-width: 375px) {
    .w2r-layout {
        padding: 4px !important;
    }
}

/* =================================================================
   Responsive Visibility Utilities
   Toggle elements based on the same breakpoint as the layout stack
   ================================================================= */

/* Hidden on mobile (≤992px), visible on desktop */
.w2r-hide-mobile {
    display: block;
}

/* Visible on mobile (≤992px), hidden on desktop */
.w2r-hide-desktop {
    display: none;
}

@media (max-width: 992px) {
    .w2r-hide-mobile {
        display: none;
    }

    .w2r-hide-desktop {
        display: block;
    }
}/**
 * Way2Rentals Panels - Summary & Price Panels
 * @package Way2Rentals
 */

/* Panel Base */
.w2r-panel {
    background: var(--color-bg-panel);
    border: 1px solid var(--color-border);
    border-radius: 5px;
    margin-bottom: 20px;
}

.w2r-panel-header {
    background: var(--color-btn-selected-bg);
    color: var(--color-text-header);
    padding: 15px 20px;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.5px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    text-transform: uppercase;
}

/* View Toggle Buttons */
.w2r-view-toggle {
    display: flex;
    gap: 8px;
    align-items: center;
}

.w2r-view-btn {
    background: transparent;
    border: 1px solid var(--color-border);
    color: var(--color-text-main);
    padding: 6px 12px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 6px;
    transition: all 0.2s ease;
}

.w2r-view-btn:hover {
    background: var(--color-bg-card);
    border-color: var(--color-btn-bg);
}

.w2r-view-btn.active {
    background: var(--color-btn-bg);
    color: var(--color-btn-text);
    border-color: var(--color-btn-bg);
}

.w2r-view-btn i {
    font-size: 14px;
}

.w2r-panel-body {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 20px;
}

.w2r-help-text {
    padding: 5px 20px;
}

/* Summary Panel */
.w2r-summary-section {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding-bottom: 15px;
    margin-bottom: 15px;
}

.w2r-summary-section:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

/* Date & Location Compact Layout */
.w2r-date-location-compact {
    display: flex;
    flex-direction: row;
    gap: 8px;
    justify-content: space-around;
}

.w2r-date-location-row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 10px;
}

.w2r-date-icon {
    font-size: 18px;
    line-height: 1;
    margin-top: 2px;
    flex-shrink: 0;
}

.w2r-date-location-content {
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-size: 13px;
    line-height: 1.4;
}

.w2r-date-location-content strong {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-main);
}

.w2r-date-location-content .w2r-time {
    font-size: 13px;
    color: var(--color-text-main);
    font-weight: 500;
}

.w2r-date-location-content .w2r-location {
    font-size: 12px;
    color: var(--color-text-muted);
    white-space: break-spaces;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 250px;
}

.w2r-date-arrow {
    font-size: 16px;
    color: var(--color-text-muted);
    margin-left: 4px;
    line-height: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.w2r-summary-section-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--color-text-main);
    margin: 0 0 10px 0;
    padding-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    border-bottom: 2px solid var(--color-btn-selected-bg);
}

.w2r-summary-item {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
}

.w2r-summary-label {
    font-size: 12px;
    color: var(--color-text-muted);
    margin-bottom: 3px;
}

.w2r-summary-value {
    font-size: 14px;
    color: var(--color-text-main);
    line-height: 1.5;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    /* Add this line */
    box-sizing: border-box;
}

.w2r-summary-price {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-price);
    margin-top: 5px;
}

.w2r-vehicle-thumb {
    width: 100%;
    max-height: 150px;
    object-fit: contain;
}

.w2r-summary-content {
    font-size: 14px;
    color: var(--color-text-main);
    padding: 0 8px;
}

/* Price Panel */
.w2r-price-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 15px;
    padding: 10px 12px;
    border-bottom: 1px solid var(--color-border);
    margin: 0 -12px;
}

.w2r-price-row:last-of-type {
    border-bottom: none;
}

.w2r-price-label {
    flex: 1;
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-main);
}

.w2r-price-detail {
    display: block;
    font-size: 12px;
    font-weight: 400;
    color: var(--color-text-muted);
    margin-top: 3px;
}

.w2r-price-value {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-price);
    text-align: right;
    white-space: nowrap;
}

/* Excess/Fee Rows */
.w2r-excess-row {
    background: var(--color-bg-main);
}

.w2r-reduction-row .w2r-reduction {
    color: var(--color-success);
}

.w2r-final-excess-row {
    background: var(--color-bg-panel);
    border-top: 2px solid var(--color-border);
}

.w2r-final-excess-row .w2r-price-label,
.w2r-final-excess-row .w2r-price-value {
    font-size: 15px;
}

.w2r-price-total {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 20px 0 0 0;
    margin-top: 15px;
    border-top: 2px solid var(--color-btn-selected-bg);
}

.w2r-price-total-label {
    font-size: 18px;
    font-weight: 700;
    color: var(--color-text-main);
}

.w2r-price-total-value {
    font-size: 20px;
    font-weight: 700;
    color: var(--color-text-price);
    text-align: right;
}

.w2r-price-total-note {
    font-size: 10px;
    font-weight: 400;
    color: var(--color-text-muted);
    text-transform: lowercase;
    margin-top: 3px;
}

/* Payment Split Section */
.w2r-payment-split-section {
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid var(--color-border);
}

.w2r-payment-split-row .w2r-price-label {
    font-size: 13px;
    font-weight: 600;
}

.w2r-payment-split-row .w2r-price-value {
    font-size: 15px;
}

.w2r-online-payment-value {
    color: var(--color-success);
    font-weight: 700;
}

.w2r-desk-payment-value {
    color: var(--color-text-price);
}

/* Discount Row */
.w2r-discount-row {
    background: rgba(40, 167, 69, 0.05);
}

.w2r-discount-value {
    color: var(--color-success);
}

.w2r-discount-label {
    color: var(--color-text-muted);
    font-style: italic;
}

.w2r-discount-apply-note {
    color: var(--color-text-muted);
    font-size: 0.85em;
}

/* Subtotal Row */
.w2r-subtotal-row {
    padding-top: 10px;
    border-top: 1px solid var(--color-border);
    margin-top: 10px;
}

/* ---- Mobile ---- */
@media (max-width: 768px) {
    .w2r-panel {
        margin-bottom: 12px;
        border-radius: 4px;
    }

    .w2r-panel-header {
        padding: 10px 12px;
        font-size: 13px;
    }

    .w2r-panel-body {
        padding: 12px;
        gap: 8px;
    }

    .w2r-summary-section {
        padding-bottom: 10px;
        margin-bottom: 10px;
        gap: 6px;
    }

    .w2r-view-btn {
        padding: 4px 8px;
        font-size: 12px;
    }

    .w2r-view-btn span {
        display: none;
    }

    /* Price panel font reductions */
    .w2r-price-label {
        font-size: 13px;
    }

    .w2r-price-value {
        font-size: 13px;
    }

    .w2r-price-detail {
        font-size: 11px;
    }

    .w2r-final-excess-row .w2r-price-label,
    .w2r-final-excess-row .w2r-price-value {
        font-size: 13px;
    }

    .w2r-price-total-label {
        font-size: 16px;
    }

    .w2r-price-total-value {
        font-size: 18px;
    }

    .w2r-price-total-note {
        font-size: 9px;
    }

    .w2r-payment-split-row .w2r-price-label {
        font-size: 12px;
    }

    .w2r-payment-split-row .w2r-price-value {
        font-size: 13px;
    }

    /* Summary panel font reductions */
    .w2r-summary-value {
        font-size: 13px;
    }

    .w2r-summary-label {
        font-size: 11px;
    }

    .w2r-summary-price {
        font-size: 14px;
    }

    .w2r-summary-content {
        font-size: 13px;
    }

    .w2r-date-icon {
        font-size: 16px;
    }

    .w2r-date-location-content {
        font-size: 12px;
    }

    .w2r-date-location-content strong {
        font-size: 13px;
    }

    .w2r-date-location-content .w2r-time {
        font-size: 12px;
    }

    .w2r-date-location-content .w2r-location {
        font-size: 11px;
    }

    .w2r-date-arrow {
        font-size: 14px;
    }
}

@media (max-width: 480px) {
    .w2r-panel-header {
        padding: 8px 10px;
        font-size: 12px;
    }

    .w2r-panel-body {
        padding: 10px;
    }

    .w2r-view-btn {
        padding: 3px 6px;
        font-size: 11px;
    }
}

@media (max-width: 375px) {
    .w2r-panel-header {
        padding: 6px 8px;
        font-size: 11px;
    }

    .w2r-view-btn {
        padding: 2px 5px;
        font-size: 10px;
    }

    .w2r-panel-body {
        padding: 8px;
    }

    .w2r-summary-section {
        padding-bottom: 8px;
        margin-bottom: 8px;
        gap: 4px;
    }

    /* Price panel font reductions */
    .w2r-price-label {
        font-size: 12px;
    }

    .w2r-price-value {
        font-size: 12px;
    }

    .w2r-price-detail {
        font-size: 10px;
    }

    .w2r-final-excess-row .w2r-price-label,
    .w2r-final-excess-row .w2r-price-value {
        font-size: 12px;
    }

    .w2r-price-total-label {
        font-size: 14px;
    }

    .w2r-price-total-value {
        font-size: 16px;
    }

    .w2r-payment-split-row .w2r-price-label {
        font-size: 11px;
    }

    .w2r-payment-split-row .w2r-price-value {
        font-size: 12px;
    }

    /* Summary panel font reductions */
    .w2r-summary-value {
        font-size: 12px;
    }

    .w2r-summary-label {
        font-size: 10px;
    }

    .w2r-summary-price {
        font-size: 13px;
    }

    .w2r-summary-content {
        font-size: 12px;
    }

    .w2r-date-icon {
        font-size: 14px;
    }

    .w2r-date-location-content {
        font-size: 11px;
    }

    .w2r-date-location-content strong {
        font-size: 12px;
    }

    .w2r-date-location-content .w2r-time {
        font-size: 11px;
    }

    .w2r-date-location-content .w2r-location {
        font-size: 10px;
    }

    .w2r-date-arrow {
        font-size: 13px;
    }
}/* Field error highlight for Way2Rentals forms */
.w2r-form-input-error {
    border: 2px solid var(--color-error) !important;
    background-color: var(--color-error-bg) !important;
    box-shadow: 0 0 2px var(--color-error);
}

/* Error wrapper */
.w2r-error-wrapper {
    margin: 15px 0;
}

/* Alerts */
.alert {
    padding: 15px;
    margin-bottom: 20px;
    border: 1px solid transparent;
    border-radius: 4px;
}

.alert-danger {
    color: var(--color-error);
    background-color: var(--color-error-light-bg);
    border-color: var(--color-error-light-border);
}

.alert-success {
    color: var(--color-success);
    background-color: var(--color-success-bg);
    border-color: var(--color-success-border);
}

.alert-warning {
    color: var(--color-warning);
    background-color: var(--color-warning-bg);
    border-color: var(--color-warning-border);
}/**
 * Way2Rentals Loading Spinner & UI Lock Overlay
 * Shared loading indicator styles used across the plugin
 *
 * @package Way2Rentals
 * @since 2.2.0
 */

/* Spinner */
.w2r-loading-spinner {
    border: 4px solid var(--color-border);
    border-top: 4px solid var(--color-btn-bg);
    border-radius: 50%;
    width: 50px;
    height: 50px;
    animation: w2r-spin 1s linear infinite;
    margin: 1.5rem auto;
}

.w2r-loading-spinner--small {
    width: 24px;
    height: 24px;
    border-width: 3px;
    margin: 0 auto;
}

@keyframes w2r-spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

/* Full-page overlay that locks UI during async operations */
.w2r-loading-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255, 255, 255, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

.w2r-loading-overlay.active {
    opacity: 1;
    pointer-events: all;
}

/* Container-scoped overlay for step navigation */
.w2r-nav-loading-overlay {
    position: absolute;
    inset: 0;
    background: rgba(255, 255, 255, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 100;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
    border-radius: inherit;
}

.w2r-nav-loading-overlay.active {
    opacity: 1;
    pointer-events: all;
}

/* Inline loading state for containers (e.g. fleet results) */
.w2r-loading {
    position: relative;
    opacity: 0.5;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

.w2r-loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    border: 4px solid var(--color-border);
    border-top: 4px solid var(--color-btn-bg);
    border-radius: 50%;
    width: 40px;
    height: 40px;
    animation: w2r-spin 1s linear infinite;
    z-index: 10;
}/**
 * Way2Rentals Components - Forms, Buttons, Grid
 * @package Way2Rentals
 */

.w2r-form-group {
    margin-bottom: 1.5rem;
}

.w2r-form-group label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 500;
    color: var(--color-text-main);
}

/* Required field asterisk */
.required-asterisk {
    color: var(--color-error);
    font-weight: bold;
    margin-left: 2px;
}

.w2r-form-control {
    display: block;
    width: 100%;
    padding: 0.75rem 1rem !important;
    padding-bottom: 1rem !important;
    padding-top: 1rem !important;
    padding-right: 40px !important;
    font-size: 1rem;
    line-height: 1.5;
    color: var(--color-text-main);
    background-color: var(--color-bg-panel);
    background-clip: padding-box;
    border: 1px solid var(--color-border);
    border-radius: 0.25rem;
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.w2r-form-control:focus,
select.w2r-form-control:focus,
input.w2r-form-control:focus {
    color: var(--color-text-main);
    background-color: var(--color-bg-panel);
    border-color: var(--color-btn-bg);
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(52, 152, 219, 0.25);
}

.w2r-form-control:disabled,
.w2r-form-control[readonly] {
    background-color: var(--color-bg-card);
    opacity: 1;
}

.w2r-field-wrapper {
    position: relative;
}

/* intl-tel-input wraps the input in .iti — ensure it fills the wrapper */
.w2r-field-wrapper .iti {
    width: 100%;
}

.w2r-field-wrapper .w2r-icon {
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-btn-bg);
    pointer-events: none;
    font-size: 18px;
    line-height: 1;
    z-index: 1;
}

.iti input.iti__tel-input,
.iti input.iti__tel-input[type=text],
.iti input.iti__tel-input[type=tel] {
  position: relative;
  z-index: 0;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  padding-right: 36px !important;
  margin-right: 0;
  padding-left: 45px !important;
}

/* Hide native date/time picker icons in WebKit browsers (Chrome, Safari, Edge) */
.w2r-field-wrapper input[type="date"]::-webkit-calendar-picker-indicator,
.w2r-field-wrapper input[type="time"]::-webkit-calendar-picker-indicator {
    opacity: 0;
    position: absolute;
    right: 0;
    width: 40px;
    height: 100%;
    cursor: pointer;
}

/* Ensure the custom icon shows through */
.w2r-field-wrapper input[type="date"],
.w2r-field-wrapper input[type="time"] {
    -webkit-appearance: none;
    --moz-appearance: none;
    appearance: none;
    position: relative;
}

/* Hide native dropdown arrow on selects so the custom icon is visible */
.w2r-field-wrapper select.w2r-form-control {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

/* Navigation Buttons Container */
.w2r-navigation-buttons {
    display: flex;
    gap: 12px;
    align-items: center;
}

button.w2r-button-select {
    padding: 0.75rem 1.5rem;
    border-radius: 4px;
    border: none;
    background: var(--color-btn-bg);
    color: var(--color-btn-text);
    cursor: pointer;
    font-size: 1rem;
    line-height: 1.5;
    font-weight: 500;
    box-shadow: var(--shadow-main);
    transition: background 0.2s;
    flex: 1;
    width: 100%;
}

button.w2r-button-select:hover {
    background: var(--color-btn-selected-bg);
}

button.w2r-button-cancel {
    padding: 0.75rem 1.5rem;
    border-radius: 4px;
    border: 1px solid var(--color-border);
    background: var(--color-bg-panel);
    color: var(--color-text-muted);
    cursor: pointer;
    font-size: 1rem;
    line-height: 1.5;
    font-weight: 500;
    box-shadow: var(--shadow-main);
    transition: all 0.2s;
    flex: 1;
}

button.w2r-button-cancel:hover {
    background: var(--color-bg-card);
    border-color: var(--color-text-muted);
    color: var(--color-text-main);
}

/* Bootstrap-style grid (scoped to plugin) */
.w2r-container .row {
    display: flex;
    flex-wrap: wrap;
    margin: 0;
    padding: 0;
}

.w2r-container .col-md-3,
.w2r-container .col-md-6,
.w2r-container .col-md-12 {
    position: relative;
    width: 100%;
    box-sizing: border-box;
}

@media (min-width: 768px) {
    .w2r-container .col-md-3 {
        flex: 0 0 25%;
        max-width: 25%;
    }

    .w2r-container .col-md-6 {
        flex: 0 0 50%;
        max-width: 50%;
    }

    .w2r-container .col-md-12 {
        flex: 0 0 100%;
        max-width: 100%;
    }
}

/* Quantity Input Component */
.w2r-quantity-input {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.w2r-qty-zero,
.w2r-qty-active {
    display: flex;
    align-items: center;
    gap: 8px;
}

.w2r-qty-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    padding: 0;
    border: 1px solid var(--color-btn-bg);
    border-radius: 4px;
    background: var(--color-bg-panel);
    color: var(--color-btn-bg);
    cursor: pointer;
    transition: all 0.2s ease;
}

.w2r-qty-btn:hover:not(:disabled) {
    background: var(--color-btn-bg);
    color: var(--color-btn-text);
}

.w2r-qty-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.w2r-qty-btn svg {
    display: block;
}

.w2r-qty-delete {
    border-color: var(--color-error);
    color: var(--color-error);
}

.w2r-qty-delete:hover:not(:disabled) {
    background: var(--color-error);
    color: var(--color-btn-text);
}

.w2r-qty-display {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 24px;
    height: 24px;
    padding: 0 6px;
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-main);
    border: 1px solid var(--color-card-selected-border);
    border-radius: 4px;
    background: var(--color-bg-card);
}

/* Checkbox Component */
.w2r-checkbox-group {
    margin-bottom: 1rem;
}

.w2r-checkbox-wrapper {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.w2r-checkbox-input {
    margin-top: 4px;
    width: 18px;
    height: 18px;
    cursor: pointer;
    flex-shrink: 0;
}

.w2r-checkbox-label {
    cursor: pointer;
    font-size: 14px;
    line-height: 1.5;
    margin: 0;
    color: var(--color-text-main);
}

.w2r-checkbox-label a {
    color: var(--color-btn-bg);
    text-decoration: underline;
}

.w2r-checkbox-label a:hover {
    color: var(--color-btn-hover-bg);
}

.w2r-checkbox-error .w2r-checkbox-input {
    border-color: var(--color-error);
    outline: 1px solid var(--color-error);
}

.w2r-checkbox-error .w2r-checkbox-label {
    color: var(--color-error);
}

.w2r-checkbox-group .text-danger {
    display: block;
    margin-top: 4px;
    margin-left: 28px;
    font-size: 13px;
    color: var(--color-error);
}

/* Disabled Button State */
.w2r-button-select:disabled,
.w2r-button-select.w2r-button-disabled {
    background-color: var(--color-bg-card);
    color: var(--color-text-muted);
    border-color: var(--color-border);
    cursor: not-allowed;
    opacity: 0.6;
}

.w2r-button-select:disabled:hover,
.w2r-button-select.w2r-button-disabled:hover {
    background-color: var(--color-bg-card);
    color: var(--color-text-muted);
    transform: none;
}

/* =================================================================
   Mobile Breakpoints
   ================================================================= */

@media (max-width: 768px) {
    .w2r-form-group {
        margin-bottom: 0.75rem;
    }

    .w2r-form-group label {
        font-size: 12px;
        margin-bottom: 0.25rem;
    }

    /* Uniform vertical padding & font for ALL inputs */
    .w2r-container .w2r-form-control {
        padding-top: 0.4rem !important;
        padding-bottom: 0.4rem !important;
        font-size: 0.8125rem;
    }

    .w2r-checkbox-label {
        font-size: 13px;
    }

    .w2r-qty-display {
        font-size: 13px;
    }

    .w2r-checkbox-group .text-danger {
        font-size: 12px;
    }
}

@media (max-width: 375px) {
    .w2r-form-group label {
        font-size: 11px;
    }

    .w2r-container .w2r-form-control {
        padding-top: 0.3rem !important;
        padding-bottom: 0.3rem !important;
        font-size: 0.75rem;
    }

    .w2r-checkbox-label {
        font-size: 12px;
    }

    .w2r-qty-display {
        font-size: 12px;
    }

    .w2r-checkbox-group .text-danger {
        font-size: 11px;
    }
}/**
 * Way2Rentals Cards - Minimal Base Card Component
 * @package Way2Rentals
 */

/* Card Base */
.w2r-card {
    background: var(--color-bg-panel);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    transition: all 0.2s ease;
    cursor: pointer;

    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: space-between;
    gap: 10px;
}

[data-view="list"] .w2r-card {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    gap: 0;
}

.w2r-card:hover {
    border-color: var(--color-btn-bg);
    box-shadow: var(--shadow-main);
}

/* Selected State */
.w2r-card.selected {
    border-color: var(--color-btn-bg);
    background: var(--color-bg-selected);
}

/* Card Layout */
.w2r-card>div {
    padding: 10px;
}

/* ---- Mobile ---- */
@media (max-width: 768px) {
    .w2r-card>div {
        padding: 8px;
    }
}

@media (max-width: 375px) {
    .w2r-card>div {
        padding: 6px;
    }
}/**
 * Way2Rentals Card Selectable - Clickable card with hover and selected states
 * A layout-agnostic base for any selectable card (payment methods, plans, etc.)
 *
 * Selected state via:
 *   - CSS :has(input:checked) for radio/checkbox cards (automatic)
 *   - .selected class for non-input use cases (e.g. link mode, JS toggle)
 *
 * @package Way2Rentals
 * @since 2.2.0
 */

.w2r-card-selectable {
    border: 2px solid var(--color-border);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    background-color: var(--color-bg-card);
}

.w2r-card-selectable:hover {
    border-color: var(--color-btn-bg);
    box-shadow: var(--shadow-main);
}

.w2r-card-selectable.selected,
.w2r-card-selectable:has(input[type="radio"]:checked),
.w2r-card-selectable:has(input[type="checkbox"]:checked) {
    border-color: var(--color-btn-bg);
    background-color: var(--color-bg-selected);
}

/* Radio/checkbox inputs inside selectable cards */
.w2r-card-selectable input[type="radio"],
.w2r-card-selectable input[type="checkbox"] {
    cursor: pointer;
    accent-color: var(--color-btn-bg);
} /**
 * Insurance Cards - Adaptive Layout
 * @package Way2Rentals
 *
 * Grid: radio floats top-right, content stacked vertically
 * List: radio on far left, then info | price (horizontal row)
 */

 /* ================================================================
   GRID VIEW (default) — vertical card, radio at top-right corner
   ================================================================ */

 /* Card needs relative positioning for the absolute radio */
 .w2r-card[data-insurance-id] {
     position: relative;
     padding: 10px;
 }

 /* Radio: absolute top-right in grid mode */
 .w2r-card-insurance-select {
     position: absolute;
     top: 8px;
     right: 8px;
     z-index: 2;
     padding: 0 !important;
 }

 /* Image + description: stacked centered in grid */
 .w2r-card-insurance-info {
     display: flex;
     flex-direction: column;
     align-items: center;
     gap: 0;
     padding: 0 !important;
     /* Extra top padding to avoid overlapping with the radio */
     padding-top: 4px !important;
 }

 .w2r-card-insurance-logo {
     flex: 0 0 auto;
     display: flex;
     align-items: center;
     justify-content: center;
     padding: 10px 10px 4px;
     width: 100%;
     max-width: 120px;
     align-self: center;
 }

 .w2r-card-insurance-logo img {
     width: 100%;
     max-height: 70px;
     object-fit: contain;
 }

 .w2r-card-insurance-description {
     flex: 1 1 auto;
     text-align: center;
     min-width: 0;
     padding: 0 10px;
     line-height: 1.4;
 }

 .w2r-card-insurance-description h5 {
     margin: 0 0 2px;
     font-size: 1.1em;
     font-weight: 600;
     color: var(--color-text-main);
 }

 .insurance-info {
     text-align: center;
     margin: 2px 0;
     font-size: 0.9em;
     color: var(--color-text-muted);
 }

 /* Pricing block */
 .w2r-insurance-pricing {
     display: flex;
     flex-direction: column;
     align-items: center;
     justify-content: center;
     gap: 2px;
     margin-bottom: 4px;
 }

 .w2r-insurance-pricing .w2r-unit-price {
     font-size: 13px;
     color: var(--color-text-muted);
 }

 .w2r-insurance-pricing .w2r-total-price {
     font-size: 20px;
     color: var(--color-text-price);
     font-weight: 600;
 }

 .w2r-insurance-excess-info {
     font-size: 14px;
     text-align: center;
 }

 .w2r-card-insurance-prices .w2r-insurance-excess {
     color: var(--color-text-price);
     font-weight: 600;
 }

 .w2r-insurance-discount {
     color: var(--color-text-muted);
     font-size: 13px;
 }

 /* Radio button styling */
 .w2r-insurance-radio-label {
     display: flex;
     align-items: center;
     justify-content: center;
     cursor: pointer;
     margin: 0;
     padding: 4px;
     border-radius: 50%;
     transition: all 0.2s ease;
 }

 .w2r-insurance-radio {
     width: 20px;
     height: 20px;
     accent-color: var(--color-btn-bg);
     cursor: pointer;
     margin: 0;
     flex-shrink: 0;
 }

 /* ================================================================
   LIST VIEW — radio on left, info center, price right
   Layout: [Radio] | [Logo + Name/Desc] | [Price/Excess]
   ================================================================ */

 [data-view="list"] .w2r-card[data-insurance-id] {
     position: static;
 }

 /* Radio: static left column in list mode */
 [data-view="list"] .w2r-card-insurance-select {
     position: static;
     flex: 0 0 50px;
     display: flex;
     align-items: center;
     justify-content: center;
     padding: 10px !important;
 }

 /* Info: horizontal row with logo + text */
 [data-view="list"] .w2r-card-insurance-info {
     flex: 1 1 0;
     flex-direction: row;
     align-items: center;
     padding-top: 0 !important;
 }

 [data-view="list"] .w2r-card-insurance-logo {
     flex: 0 0 80px;
     padding: 10px 6px;
 }

 [data-view="list"] .w2r-card-insurance-logo img {
     max-height: 60px;
 }

 [data-view="list"] .w2r-card-insurance-description {
     text-align: left;
     padding: 10px;
 }

 [data-view="list"] .insurance-info {
     text-align: left;
 }

 /* Price: right column */
 [data-view="list"] .w2r-card-insurance-prices {
     flex: 0 0 200px;
     display: flex;
     flex-direction: column;
     justify-content: center;
     padding: 10px;
 }

 /* ================================================================
   LIST VIEW — mobile stacked
   ================================================================ */
 @media (max-width: 600px) {
     [data-view="list"] .w2r-card[data-insurance-id] {
         flex-wrap: wrap;
     }

     /* Radio stays on top-left, spanning full width row */
     [data-view="list"] .w2r-card-insurance-select {
         flex: 0 0 50px;
     }

     [data-view="list"] .w2r-card-insurance-info {
         flex: 1 1 calc(100% - 50px);
     }

     [data-view="list"] .w2r-card-insurance-prices {
         flex: 1 0 100%;
         padding: 6px 10px;
     }
 }

 /* ================================================================
   MOBILE — font size & image adjustments
   ================================================================ */
 @media (max-width: 768px) {
     .w2r-card-insurance-description h5 {
         font-size: 0.95em;
     }

     .insurance-info {
         font-size: 0.8em;
     }

     .w2r-insurance-pricing .w2r-total-price {
         font-size: 16px;
     }

     .w2r-insurance-pricing .w2r-unit-price {
         font-size: 11px;
     }

     .w2r-insurance-excess-info {
         font-size: 12px;
     }

     .w2r-insurance-discount {
         font-size: 11px;
     }

     .w2r-card-insurance-logo img {
         max-height: 96px;
     }
 }

 @media (max-width: 480px) {
     .w2r-card-insurance-description h5 {
         font-size: 0.85em;
     }

     .insurance-info {
         font-size: 0.75em;
     }

     .w2r-insurance-pricing .w2r-total-price {
         font-size: 14px;
     }

     .w2r-insurance-pricing .w2r-unit-price {
         font-size: 10px;
     }

     .w2r-insurance-excess-info {
         font-size: 11px;
     }

     .w2r-card-insurance-logo img {
         max-height: 80px;
     }
 }

 @media (max-width: 375px) {
     .w2r-card-insurance-description h5 {
         font-size: 0.8em;
     }

     .insurance-info {
         font-size: 0.7em;
     }

     .w2r-insurance-pricing .w2r-total-price {
         font-size: 13px;
     }

     .w2r-insurance-pricing .w2r-unit-price {
         font-size: 9px;
     }

     .w2r-insurance-excess-info {
         font-size: 10px;
     }

     .w2r-insurance-discount {
         font-size: 9px;
     }

     .w2r-card-insurance-logo img {
         max-height: 60px;
     }

     .w2r-insurance-radio {
         width: 16px;
         height: 16px;
     }
 }/**
 * Insurance Selection Modal
 * Shown when user clicks "Select" on a fleet vehicle card
 * and insurances are enabled in fleet settings.
 */

/* ── Overlay ── */
.w2r-insurance-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    animation: w2rFadeIn 0.2s ease;
}

@keyframes w2rFadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

/* ── Modal container ── */
.w2r-insurance-modal {
    background: var(--color-bg-panel);
    border-radius: 8px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25);
    max-width: 560px;
    width: 100%;
    max-height: 85vh;
    display: flex;
    flex-direction: column;
    animation: w2rSlideUp 0.25s ease;
}

@keyframes w2rSlideUp {
    from {
        transform: translateY(20px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* ── Header ── */
.w2r-insurance-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--color-border);
}

.w2r-insurance-modal-header h3 {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--color-text-main);
}

.w2r-insurance-modal-close {
    background: none;
    border: none;
    font-size: 1.5rem;
    line-height: 1;
    cursor: pointer;
    color: var(--color-text-muted);
    padding: 0 0.25rem;
    transition: color 0.15s;
}

.w2r-insurance-modal-close:hover {
    color: var(--color-error);
}

/* ── Body (scrollable list) ── */
.w2r-insurance-modal-body {
    padding: 1rem 1.25rem;
    overflow-y: auto;
    flex: 1;
}

/* ── Insurance option rows ── */
.w2r-insurance-option {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.75rem;
    border: 2px solid var(--color-border);
    border-radius: 6px;
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s;
    margin-bottom: 0.5rem;
}

.w2r-insurance-option:last-child {
    margin-bottom: 0;
}

.w2r-insurance-option:hover {
    border-color: var(--color-btn-bg);
    background: var(--color-bg-selected);
}

.w2r-insurance-option.selected {
    border-color: var(--color-btn-bg);
    background: var(--color-bg-selected);
}

.w2r-insurance-option-info {
    flex: 1;
    min-width: 0;
}

.w2r-insurance-option-name {
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--color-text-main);
}

.w2r-insurance-option-excess {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    margin-top: 2px;
}

.w2r-insurance-option-price {
    font-weight: 700;
    font-size: 1rem;
    color: var(--color-text-price);
    white-space: nowrap;
}

/* ── Footer ── */
.w2r-insurance-modal-footer {
    display: flex;
    gap: 0.75rem;
    padding: 1rem 1.25rem;
    border-top: 1px solid var(--color-border);
    justify-content: flex-end;
}

.w2r-insurance-modal-footer .w2r-button-select {
    min-width: 140px;
}

/* ── Responsive: full-screen on mobile ── */
@media (max-width: 576px) {
    .w2r-insurance-modal-overlay {
        padding: 0;
        align-items: stretch;
    }

    .w2r-insurance-modal {
        max-width: 100%;
        max-height: 100vh;
        height: 100vh;
        border-radius: 0;
    }

    .w2r-insurance-modal-body {
        flex: 1;
        -webkit-overflow-scrolling: touch;
    }

    .w2r-insurance-option {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.5rem;
    }

    .w2r-insurance-modal-footer {
        flex-direction: column;
        padding-bottom: env(safe-area-inset-bottom, 1rem);
    }

    .w2r-insurance-modal-footer .w2r-button-select {
        width: 100%;
        text-align: center;
    }
}/* ============================================================
   Contact Modal — zero-tariff vehicle enquiry form
   ============================================================ */

/* Overlay */
.w2r-contact-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    animation: w2r-contact-fade-in 0.2s ease;
}

/* Modal panel */
.w2r-contact-modal {
    background: var(--color-bg-panel);
    border-radius: 8px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18);
    width: 100%;
    max-width: 520px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    animation: w2r-contact-slide-up 0.25s ease;
}

/* Header */
.w2r-contact-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--color-border);
}

.w2r-contact-modal-title {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--color-text-main);
}

.w2r-contact-modal-close {
    background: none;
    border: none;
    font-size: 1.5rem;
    line-height: 1;
    color: var(--color-text-muted);
    cursor: pointer;
    padding: 0 0.25rem;
    transition: color 0.15s;
}

.w2r-contact-modal-close:hover {
    color: var(--color-text-main);
}

/* Body */
.w2r-contact-modal-body {
    padding: 1.5rem;
    overflow-y: auto;
    flex: 1;
}

/* Vehicle / date summary banner */
.w2r-contact-modal-info {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0.75rem 1rem;
    margin-bottom: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

/* Form fields */
.w2r-contact-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.w2r-contact-field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.w2r-contact-label {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-text-detail);
}

.w2r-contact-input {
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    font-size: 0.95rem;
    color: var(--color-text-main);
    background: var(--color-bg-panel);
    transition: border-color 0.15s;
    width: 100%;
    box-sizing: border-box;
}

.w2r-contact-input:focus {
    outline: none;
    border-color: var(--color-btn-bg);
}

.w2r-contact-textarea {
    resize: vertical;
    min-height: 90px;
}

/* Feedback messages */
.w2r-contact-modal-error {
    margin-top: 0.75rem;
    padding: 0.6rem 0.9rem;
    background: var(--color-error-bg);
    border: 1px solid var(--color-error);
    border-radius: 4px;
    color: var(--color-error);
    font-size: 0.875rem;
}

.w2r-contact-modal-success {
    margin-top: 0.75rem;
    padding: 0.6rem 0.9rem;
    background: var(--color-success-bg);
    border: 1px solid var(--color-success-border);
    border-radius: 4px;
    color: var(--color-success);
    font-size: 0.875rem;
}

/* Footer */
.w2r-contact-modal-footer {
    padding: 1rem 1.5rem;
    border-top: 1px solid var(--color-border);
    display: flex;
    gap: 0.75rem;
    justify-content: flex-end;
}

/* Contact button on vehicle card */
button.w2r-button-contact {
    padding: 0.75rem 1.5rem;
    border-radius: 4px;
    border: none;
    background: var(--color-warning);
    color: #fff;
    cursor: pointer;
    font-size: 1rem;
    line-height: 1.5;
    font-weight: 500;
    box-shadow: var(--shadow-main);
    transition: background 0.2s;
    flex: 1;
    width: 100%;
}

button.w2r-button-contact:hover {
    background: var(--color-warning-hover);
}

/* List-view contact button (mirrors vehicle-group.css overrides for select) */
[data-view="list"] .w2r-vehicle-action button.w2r-button-contact {
    width: auto;
    flex: 0 0 auto;
}

/* Animations */
@keyframes w2r-contact-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

@keyframes w2r-contact-slide-up {
    from { transform: translateY(24px); opacity: 0; }
    to   { transform: translateY(0);    opacity: 1; }
}

/* Mobile */
@media (max-width: 576px) {
    .w2r-contact-modal {
        max-height: 100dvh;
        border-radius: 0;
    }

    .w2r-contact-modal-overlay {
        padding: 0;
        align-items: flex-end;
    }

    .w2r-contact-modal-footer {
        flex-direction: column-reverse;
    }

    .w2r-contact-modal-info .w2r-date-location-compact {
        flex-direction: column;
        gap: 0.25rem;
    }
}
/**
 * Extra Cards - Adaptive Layout
 * @package Way2Rentals
 */

/* ---- Grid (default) ---- */

.w2r-card[data-extra-id] {
    justify-content: space-between;
    padding: 10px;
}

/* Image + details: stacked in grid, side-by-side in list */
.w2r-extra-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
    padding: 0 !important;
}

.w2r-extra-image {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px 10px 4px;
}

.w2r-extra-image img {
    max-width: 100%;
    max-height: 70px;
    object-fit: contain;
}

.w2r-extra-details {
    flex: 1 1 auto;
    text-align: center;
    font-size: 0.9em;
    color: var(--color-text-muted);
    min-width: 0;
    padding: 0 10px;
    line-height: 1.4;
}

.w2r-extra-details .w2r-extra-name {
    margin: 0 0 2px;
    font-size: 1.1em;
    font-weight: 600;
    color: var(--color-text-main);
}

.w2r-extra-pricing {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
}

.w2r-extra-pricing .w2r-unit-price {
    font-size: 12px;
    color: var(--color-text-muted);
}

.w2r-extra-pricing .w2r-total-price {
    font-size: 17px;
    color: var(--color-text-price);
    font-weight: 600;
}

.w2r-extra-actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
}

/* ---- List mode: 3 columns — Info | Price | Action ---- */

[data-view="list"] .w2r-extra-info {
    flex: 1 1 0;
    flex-direction: row;
    align-items: center;
}

[data-view="list"] .w2r-extra-image {
    flex: 0 0 80px;
    padding: 10px 6px;
}

[data-view="list"] .w2r-extra-image img {
    max-height: 60px;
}

[data-view="list"] .w2r-extra-details {
    text-align: left;
    padding: 10px 10px 10px 0;
    /*border-left: 1px solid var(--color-border);*/
    padding-left: 10px;
}

[data-view="list"] .w2r-extra-pricing {
    flex: 0 0 150px;
    justify-content: center;
    /*border-left: 1px solid var(--color-border);*/
}

[data-view="list"] .w2r-extra-actions {
    flex: 0 0 80px;
    /*border-left: 1px solid var(--color-border);*/
}

/* ---- List mode: mobile ---- */
@media (max-width: 600px) {
    [data-view="list"] .w2r-card[data-extra-id] {
        flex-wrap: wrap;
    }

    [data-view="list"] .w2r-extra-info {
        flex: 1 1 100%;
    }

    [data-view="list"] .w2r-extra-pricing {
        flex: 1 0 100%;
        flex-direction: column;
        /*gap: 8px;*/
        border-left: none;
        /*border-top: 1px solid var(--color-border);*/
        padding: 6px 10px;
    }

    [data-view="list"] .w2r-extra-actions {
        flex: 1 0 100%;
        border-left: none;
        /*border-top: 1px solid var(--color-border);*/
        padding: 8px 10px;
        justify-content: center;
    }
}

/* ================================================================
   MOBILE — font size & image adjustments
   ================================================================ */
@media (max-width: 768px) {
    .w2r-extra-details .w2r-extra-name {
        font-size: 0.95em;
    }

    .w2r-extra-details {
        font-size: 0.8em;
    }

    .w2r-extra-pricing .w2r-total-price {
        font-size: 14px;
    }

    .w2r-extra-pricing .w2r-unit-price {
        font-size: 10px;
    }

    .w2r-extra-image img {
        max-height: 96px;
    }
}

@media (max-width: 480px) {
    .w2r-extra-details .w2r-extra-name {
        font-size: 0.85em;
    }

    .w2r-extra-details {
        font-size: 0.75em;
    }

    .w2r-extra-pricing .w2r-total-price {
        font-size: 13px;
    }

    .w2r-extra-pricing .w2r-unit-price {
        font-size: 9px;
    }

    .w2r-extra-image img {
        max-height: 80px;
    }
}

@media (max-width: 375px) {
    .w2r-extra-details .w2r-extra-name {
        font-size: 0.8em;
    }

    .w2r-extra-details {
        font-size: 0.7em;
    }

    .w2r-extra-pricing .w2r-total-price {
        font-size: 12px;
    }

    .w2r-extra-pricing .w2r-unit-price {
        font-size: 8px;
    }

    .w2r-extra-image img {
        max-height: 60px;
    }
}.w2r-vehicle-main {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    justify-content: space-between;
    gap: 10px;
}

.w2r-vehicle-main h2, .w2r-vehicle-details h2 {
    font-size: 25px;
    font-weight: 800;
    color: var(--color-text-theme);
}

.w2r-vehicle-main h3, .w2r-vehicle-details h3 {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-detail);
    margin: 0;
}

.w2r-vehicle-details {
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex: 1 1 auto;
    justify-content: space-between;
}

.w2r-vehicle-details .title-group{
    display:none;
}

.w2r-vehicle-img {
    display: flex;
    align-items: center;
    justify-content: center;
}

.w2r-vehicle-img-el {
    width: 100%;
    max-height: 120px;
    object-fit: contain;
}

.w2r-vehicle-info {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    gap: 5px;
    justify-content: space-between;
}

/* Card mode: center price section */
.w2r-vehicle-price {
    text-align: center;
    width:100%;
}

/* Original (pre-discount) price: struck through */
.w2r-vehicle-price-original {
    display: block;
    font-size: 0.95rem;
    color: var(--color-text-muted);
    text-decoration: line-through;
    line-height: 1.2;
}

/* Emphasize total price */
.w2r-vehicle-price-total {
    font-size: 1.5rem;
    color: var(--color-text-price);
    font-weight: bold;
    line-height: 1.1;
}

/* Per day price: medium emphasis */
.w2r-vehicle-price-perday {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    font-weight: 500;
    margin-top: 2px;
}

/* Price note: small, muted */
.w2r-vehicle-price .w2r-vehicle-price-note {
    font-size: 0.7rem;
    color: var(--color-text-muted);
    font-weight: 400;
    margin-top: 2px;
}

/* Vehicle Excess/Fee Display */
.w2r-vehicle-excess {
    font-size: 0.7rem;
    color: var(--color-warning);
    margin-top: 4px;
    text-align: center;
}

.w2r-vehicle-action {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    flex-direction:column;
}

/* Promotion ribbon
   Customise in config.css: --promo-ribbon-bg, --promo-ribbon-text, --promo-ribbon-font-size */

.w2r-card--promo {
    position: relative;
    overflow: hidden;
}

.w2r-promo-badge {
    position: absolute;
    top: 22px;
    right: -32px;
    width: 130px;
    padding: 5px 0 !important;
    text-align: center;
    transform: rotate(45deg);
    background: var(--promo-ribbon-bg);
    color: var(--promo-ribbon-text);
    font-size: var(--promo-ribbon-font-size);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    pointer-events: none;
    z-index: 1;
}

/* Insurance Selection at Bottom */
.w2r-insurance-selection {
    display: flex;
    flex-direction: column;
    gap: 8px;
    width: 100%;
}

.w2r-insurance-choice {
    background: var(--color-bg-panel);
    border: 1px solid var(--color-border);
    border-radius: 4px;
    padding: 10px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.w2r-insurance-info-line {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}

.w2r-insurance-name-text {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--color-text-main);
}

.w2r-insurance-price-text {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--color-text-price);
}

.w2r-insurance-excess-line {
    font-size: 0.85rem;
    color: var(--color-success);
}

/* Driver Restrictions Component */

.w2r-driver-restrictions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 0.5em 1.5em;
    font-size: 0.9rem;
    color: var(--color-text-muted);
}

.w2r-restriction-item {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 4px;
    font-size: 13px;
    color: var(--color-text-main);
    transition: all 0.2s ease;
}

.w2r-restriction-item svg {
    flex-shrink: 0;
    opacity: 0.7;
}

.w2r-restriction-item.w2r-restriction-valid {
    background-color: rgba(40, 167, 69, 0.1);
    border-color: var(--color-success);
    color: var(--color-success);
}

.w2r-restriction-item.w2r-restriction-invalid {
    background-color: rgba(220, 53, 69, 0.1);
    border-color: var(--color-error);
    color: var(--color-error);
}

.w2r-restriction-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: 4px;
    padding: 2px 6px;
    border-radius: 3px;
    font-size: 11px;
    font-weight: 600;
    line-height: 1;
}

.w2r-badge-valid {
    background-color: var(--color-success);
    color: white;
}

.w2r-badge-invalid {
    background-color: var(--color-error);
    color: white;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

/* =========================================================================
   LIST MODE — Desktop horizontal card layout
   Image left │ Details center │ Action right
   ========================================================================= */

[data-view="list"] .w2r-vehicle-main {
    flex: 0 0 300px;
    max-width: 300px;
    justify-content: center;
    align-items: center;
    padding: 12px;
}

[data-view="list"] .w2r-vehicle-main .title-group{
    display:none;
}
    
[data-view="list"] .w2r-vehicle-details .title-group{
    display:block;
}

[data-view="list"] .w2r-vehicle-img-el {
    max-height: 150px;
}

[data-view="list"] .w2r-vehicle-details {
    padding: 12px 16px;
}

[data-view="list"] .w2r-vehicle-features {
    justify-content: flex-start;
    gap: 0.5em 1.2em;
    font-size: 0.9rem;
}

[data-view="list"] .w2r-driver-restrictions {
    justify-content: flex-start;
    font-size: 0.8rem;
}

[data-view="list"] .w2r-vehicle-price {
    text-align: center;
}

[data-view="list"] .w2r-vehicle-price-total {
    font-size: 1.3rem;
}

[data-view="list"] .w2r-vehicle-price-original {
    font-size: 0.85rem;
    display: inline;
    margin-right: 6px;
}

[data-view="list"] .w2r-vehicle-price-perday {
    font-size: 0.75rem;
}

[data-view="list"] .w2r-vehicle-excess {
    text-align: center;
    font-size: 0.7rem;
}

[data-view="list"] .w2r-vehicle-price .w2r-vehicle-price-note {
    font-size: 0.65rem;
}

[data-view="list"] .w2r-vehicle-action {
    flex: 0 0 auto;
    min-width: 110px;
    padding: 12px 16px;
}

[data-view="list"] .w2r-vehicle-action button.w2r-button-select {
    white-space: nowrap;
}

[data-view="list"] .w2r-promo-badge {
    top: 14px;
    right: -26px;
    width: 100px;
    padding: 3px 0 !important;
    font-size: 0.55rem;
}

[data-view="list"] .w2r-insurance-selection {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 6px;
}

[data-view="list"] .w2r-insurance-choice {
    flex: 1 1 auto;
    min-width: 140px;
    padding: 8px;
}

/* ---- List mode: mobile ---- */
@media (max-width: 768px) {
    [data-view="list"] .w2r-card {
        flex-wrap: wrap;
    }

    [data-view="list"] .w2r-vehicle-main {
        padding: 8px;
    }
    
    [data-view="list"] .w2r-vehicle-main .title-group{
        display:block;
    }
    
    [data-view="list"] .w2r-vehicle-details .title-group{
        display:none;
    }

    [data-view="list"] .w2r-vehicle-img-el {
        max-height: 100px;
    }

    [data-view="list"] .w2r-vehicle-details {
        padding: 8px 10px;
        gap: 6px;
        align-items:center;
    }

    [data-view="list"] .w2r-vehicle-features {
        font-size: 0.8rem;
        gap: 0.4em 0.8em;
    }

    [data-view="list"] .w2r-vehicle-price-total {
        font-size: 1.1rem;
    }

    [data-view="list"] .w2r-vehicle-action {
        flex: 1 0 100%;
        border-left: none;
        padding: 8px 10px;
    }

    [data-view="list"] .w2r-vehicle-action button.w2r-button-select {
        width: 100%;
    }

    [data-view="list"] .w2r-insurance-selection {
        flex-direction: column;
    }
}/* Vehicle Features Component */

.w2r-vehicle-features {
    display: flex;
    flex-wrap: wrap;
    /* Allow items to wrap to new rows */
    justify-content: center;
    /* Center horizontally */
    align-items: center;
    /* Center vertically */
    gap: 0.75em 1.5em;
    /* Add space between items (row/col) */
    font-size: 1rem;
    min-height: 2.5em;
    /* Optional: ensure some vertical space */
}

.w2r-vehicle-features span {
    display: flex;
    align-items: center;
    margin-bottom: 0.5em;
    flex-direction: column;
    font-size: 12px;
    justify-items: center;
    align-items: center;
    color: var(--color-text-detail);
    gap: 5px;
}

.w2r-feature-icon {
    width: 20px;
    height: 20px;
    vertical-align: middle;
    fill: var(--color-text-theme)
}

@media (max-width: 768px) {
    .w2r-vehicle-features span {
        font-size: 11px;
    }

    .w2r-feature-icon {
        width: 18px;
        height: 18px;
    }
}

@media (max-width: 375px) {
    .w2r-vehicle-features span {
        font-size: 10px;
    }

    .w2r-feature-icon {
        width: 16px;
        height: 16px;
    }
}/**
 * Price Slider Component Styles
 * jQuery UI range slider styling
 * 
 * @package Way2Rentals
 */

/* Label row with clear button */
.w2r-price-label-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.w2r-price-label-row label {
    margin-bottom: 0;
}

.w2r-price-clear-btn {
    background: none;
    border: none;
    color: var(--color-text-muted);
    cursor: pointer;
    padding: 2px 6px;
    font-size: 0.8rem;
    border-radius: 4px;
    transition: color 0.2s, background-color 0.2s;
}

.w2r-price-clear-btn:hover {
    color: var(--color-danger, #dc3545);
    background: var(--color-bg-muted, #f5f5f5);
}

/* Slider wrapper */
.w2r-price-slider-wrapper {
    padding: 0.5rem 0;
}

/* Price slider track */
.w2r-price-slider {
    margin: 1rem 0 0.5rem 0;
    height: 8px;
}

/* Price display values */
.w2r-price-values {
    text-align: center;
    font-weight: 600;
    color: var(--color-text-main);
    margin-top: 0.5rem;
    font-size: 0.95rem;
}

.w2r-price-separator {
    margin: 0 0.5rem;
    color: var(--color-text-muted);
}

/* jQuery UI slider overrides */
.w2r-price-slider.ui-slider {
    background: var(--color-border);
    border: none;
    border-radius: 4px;
    margin-left: 10px;
    margin-right: 10px;
}

.w2r-price-slider .ui-slider-range {
    background: var(--color-btn-bg);
}

.w2r-price-slider .ui-slider-handle {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--color-btn-bg);
    border: 2px solid white;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    cursor: pointer;
    top: 50%;
    transform: translateY(-50%);
    transition: background-color 0.2s ease;
}

.w2r-price-slider .ui-slider-handle:hover,
.w2r-price-slider .ui-slider-handle:focus {
    background: var(--color-btn-selected-bg);
    outline: none;
}

.w2r-price-slider .ui-slider-handle:active {
    transform: translateY(-50%) scale(1.1);
}/**
 * Way2Rentals Voucher Input Component
 * Reuses panel, alert, and form patterns
 * @package Way2Rentals
 */

/* Voucher Form Layout */
.w2r-voucher-form {
    display: flex;
    gap: 10px;
}

/* Remove bottom margin from w2r-form-group inside voucher form */
.w2r-voucher-form .w2r-form-group {
    margin-bottom: 0;
    flex: 1;
}

/* Ensure button is compact and doesn't take too much space */
.w2r-voucher-form .w2r-button-select {
    flex-shrink: 0;
    flex-grow: 0;
    width: auto;
    min-width: fit-content;
    padding-left: 1rem;
    padding-right: 1rem;
}


/* Voucher Status Messages Container */
.w2r-voucher-status {
    margin-top: 10px;
    animation: slideDown 0.3s ease-out;
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Success Message - Enhanced alert pattern */
.w2r-voucher-success {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 15px;
    background: var(--color-success-bg, rgba(40, 167, 69, 0.1));
    border: 1px solid var(--color-success, #28a745);
    border-radius: 4px;
    color: var(--color-success, #28a745);
}

.w2r-voucher-success i.fa-check-circle {
    font-size: 1.2em;
    flex-shrink: 0;
}

.w2r-voucher-success span {
    flex: 1;
    font-weight: 500;
    font-size: 14px;
}

/* Apply type description */
.w2r-voucher-apply-type {
    display: block;
    margin-top: 4px;
    font-weight: 400;
    font-size: 12px;
    opacity: 0.85;
}

/* Remove Button */
.w2r-voucher-remove {
    padding: 4px 8px;
    background: transparent;
    border: none;
    color: var(--color-success, #28a745);
    cursor: pointer;
    opacity: 0.7;
    transition: opacity 0.2s;
    flex-shrink: 0;
}

.w2r-voucher-remove:hover {
    opacity: 1;
}

/* Error Message - Enhanced alert pattern */
.w2r-voucher-error {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 15px;
    background: var(--color-error-light-bg, rgba(220, 53, 69, 0.1));
    border: 1px solid var(--color-error, #dc3545);
    border-radius: 4px;
    color: var(--color-error, #dc3545);
}

.w2r-voucher-error i.fa-exclamation-circle {
    font-size: 1.2em;
    flex-shrink: 0;
}

.w2r-voucher-error span {
    flex: 1;
    font-weight: 500;
    font-size: 14px;
}