/* ========================================
   cs4u RentCar v2 - Frontend Styles
   ======================================== */

:root {
    --oscar-primary: var(--oscar-color-primary, #0053b5);
    --oscar-primary-dark: color-mix(in srgb, var(--oscar-primary), #000 20%);
    --oscar-primary-light: color-mix(in srgb, var(--oscar-primary), #fff 85%);
    --oscar-text: #333;
    --oscar-text-light: #777;
    --oscar-border: #ddd;
    --oscar-bg: #fafafa;
    --oscar-white: #fff;
    --oscar-success: #28a745;
    --oscar-danger: #dc3545;
    --oscar-airbnb: #FF5A5F;
    --oscar-booking: #003580;
    --oscar-direct: #0053b5;
    --oscar-blocked: #6c757d;
    --oscar-closed: #495057;
    --oscar-radius: 6px;
    --oscar-shadow: 0 2px 12px rgba(0,0,0,0.08);
    --oscar-font: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* ===== BOOKING BAR ===== */
.oscar-booking-bar {
    background: var(--oscar-bg);
    border-top: 1px solid var(--oscar-border);
    border-bottom: 1px solid var(--oscar-border);
    padding: 40px 24px 32px;
    text-align: center;
    font-family: var(--oscar-font);
}
.oscar-bar-title { font-size: 15px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: var(--oscar-text); margin-bottom: 12px; }
.oscar-bar-diamond { width: 10px; height: 10px; background: var(--oscar-primary); transform: rotate(45deg); margin: 0 auto 24px; }
.oscar-bar-form { display: flex; align-items: flex-end; justify-content: center; gap: 12px; max-width: 900px; margin: 0 auto; flex-wrap: wrap; }
.oscar-bar-field { flex: 1; min-width: 120px; text-align: left; }
.oscar-bar-field label { display: block; font-size: 11px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--oscar-text-light); margin-bottom: 6px; }
.oscar-bar-field input, .oscar-bar-field select { width: 100%; padding: 12px 14px; border: 1px solid var(--oscar-border); border-radius: var(--oscar-radius); font-size: 14px; color: var(--oscar-text); background: var(--oscar-white); font-family: var(--oscar-font); box-sizing: border-box; line-height: 1.4; height: auto; }
.oscar-bar-field select { cursor: pointer; padding-right: 30px; }
.oscar-bar-field input:focus, .oscar-bar-field select:focus { outline: none; border-color: var(--oscar-primary); box-shadow: 0 0 0 2px var(--oscar-primary-light); }
.oscar-bar-submit { flex: 0 0 auto; min-width: auto; }
.oscar-bar-btn { background: var(--oscar-primary); color: var(--oscar-white); border: 2px solid var(--oscar-primary); padding: 12px 28px; font-size: 12px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; cursor: pointer; transition: all 0.3s; border-radius: var(--oscar-radius); font-family: var(--oscar-font); white-space: nowrap; }
.oscar-bar-btn:hover { background: var(--oscar-primary-dark); border-color: var(--oscar-primary-dark); }
.oscar-bar-result { max-width: 600px; margin: 20px auto 0; padding: 16px 20px; border-radius: var(--oscar-radius); font-size: 14px; text-align: center; }
.oscar-bar-result.oscar-result-available { background: #d4edda; color: #155724; border: 1px solid #c3e6cb; }
.oscar-bar-result.oscar-result-unavailable { background: #f8d7da; color: #721c24; border: 1px solid #f5c6cb; }

/* ===== CALENDAR ===== */
.oscar-calendar-wrapper { background: var(--oscar-white); border: 1px solid var(--oscar-border); border-radius: 12px; padding: 28px; margin: 24px 0; box-shadow: var(--oscar-shadow); font-family: var(--oscar-font); }
.oscar-cal-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 20px; flex-wrap: wrap; gap: 12px; }
.oscar-cal-title h3 { margin: 0 0 4px; font-size: 22px; font-weight: 700; color: var(--oscar-text); }
.oscar-cal-subtitle { font-size: 13px; color: var(--oscar-text-light); margin: 0; }
.oscar-cal-legend { display: flex; gap: 12px; flex-wrap: wrap; font-size: 11px; color: var(--oscar-text-light); }
.oscar-legend-item { display: flex; align-items: center; gap: 4px; }
.oscar-dot { display: inline-block; width: 10px; height: 10px; border-radius: 2px; }
.oscar-dot-airbnb { background: var(--oscar-airbnb); }
.oscar-dot-booking { background: var(--oscar-booking); }
.oscar-dot-direct { background: var(--oscar-direct); }
.oscar-dot-blocked { background: var(--oscar-blocked); }
.oscar-dot-closed { background: var(--oscar-closed); }
.oscar-dot-available { background: var(--oscar-success); }
.oscar-dot-partial { background: linear-gradient(135deg, var(--oscar-success) 45%, var(--oscar-blocked) 45%); }

.oscar-cal-combined-hint { font-size: 13px; color: var(--oscar-text-light); margin: 0 0 14px; line-height: 1.5; max-width: 720px; }
.oscar-day-partial.oscar-day-available { background: linear-gradient(180deg, rgba(40,167,69,0.12) 0%, rgba(108,117,125,0.18) 100%); outline: 1px dashed rgba(0,83,181,0.55); outline-offset: -1px; }

.oscar-cal-nav { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.oscar-cal-nav-btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 16px; background: none; border: 1px solid var(--oscar-border); border-radius: var(--oscar-radius); font-size: 13px; font-weight: 500; color: var(--oscar-text); cursor: pointer; transition: all 0.2s; font-family: var(--oscar-font); }
.oscar-cal-nav-btn:hover { border-color: var(--oscar-primary); color: var(--oscar-primary); }

/* 6 months: 2 rows x 3 columns */
.oscar-cal-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }

.oscar-cal-month { background: var(--oscar-bg); border: 1px solid var(--oscar-border); border-radius: 8px; padding: 14px; overflow: hidden; }
.oscar-cal-month-name { text-align: center; font-weight: 700; font-size: 14px; color: var(--oscar-text); margin-bottom: 8px; }
.oscar-cal-days-header { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1px; margin-bottom: 2px; }
.oscar-cal-day-label { text-align: center; font-size: 9px; font-weight: 700; color: var(--oscar-text-light); text-transform: uppercase; padding: 3px 0; }
.oscar-cal-days { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1px; }

/* Calendar day cell */
.oscar-cal-day { position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center; font-size: 11px; font-weight: 500; border-radius: 3px; padding: 2px 1px; min-height: 32px; transition: all 0.15s; cursor: default; }
.oscar-cal-day .oscar-day-num { font-size: 11px; font-weight: 600; line-height: 1; }
.oscar-cal-day .oscar-day-price { font-size: 8px; font-weight: 400; opacity: 0.8; line-height: 1; margin-top: 1px; display: flex; align-items: baseline; gap: 1px; }
.oscar-cal-day .oscar-day-min { font-size: 7px; font-weight: 600; color: #e67e22; opacity: 1; }

/* Day states */
.oscar-cal-day.oscar-day-other { color: #ccc; }
.oscar-cal-day.oscar-day-past { color: #bbb; }
.oscar-cal-day.oscar-day-past .oscar-day-num { text-decoration: line-through; }
.oscar-cal-day.oscar-day-available { background: #e8f5e9; color: #2e7d32; }
.oscar-cal-day.oscar-day-available:hover { background: #c8e6c9; }
.oscar-cal-day.oscar-day-clickable { cursor: pointer; }
.oscar-cal-day.oscar-day-clickable:hover { transform: scale(1.08); z-index: 2; box-shadow: 0 2px 8px rgba(0,0,0,0.15); }
.oscar-cal-day.oscar-day-today { outline: 2px solid var(--oscar-primary); outline-offset: -1px; }

/* Date selection (External 1/Booking style) */
.oscar-cal-day.oscar-sel-start {
    background: var(--oscar-primary) !important;
    color: #fff !important;
    border-radius: 50% 0 0 50% !important;
    z-index: 3;
    box-shadow: 0 2px 8px rgba(0,0,0,0.2);
}
.oscar-cal-day.oscar-sel-end {
    background: var(--oscar-primary) !important;
    color: #fff !important;
    border-radius: 0 50% 50% 0 !important;
    z-index: 3;
    box-shadow: 0 2px 8px rgba(0,0,0,0.2);
}
.oscar-cal-day.oscar-sel-range {
    background: var(--oscar-primary-light) !important;
    color: var(--oscar-primary-dark) !important;
    border-radius: 0 !important;
}
.oscar-cal-day.oscar-sel-start .oscar-day-price,
.oscar-cal-day.oscar-sel-end .oscar-day-price { color: rgba(255,255,255,0.8); }
.oscar-cal-day.oscar-sel-range .oscar-day-price { color: var(--oscar-primary); }

/* Booking spans - continuous appearance */
.oscar-cal-day.oscar-day-airbnb { background: var(--oscar-airbnb); color: #fff; }
.oscar-cal-day.oscar-day-booking { background: var(--oscar-booking); color: #fff; }
.oscar-cal-day.oscar-day-direct { background: var(--oscar-direct); color: #fff; }
.oscar-cal-day.oscar-day-manual { background: #6f42c1; color: #fff; }
.oscar-cal-day.oscar-day-airbnb_block { background: #FF5A5F; color: #fff; opacity: 0.55; }
.oscar-cal-day.oscar-day-booking_block { background: #003580; color: #fff; opacity: 0.55; }
.oscar-cal-day.oscar-day-blocked { background: var(--oscar-blocked); color: #fff; }
.oscar-cal-day.oscar-day-closed { background: var(--oscar-closed); color: #fff; }
.oscar-cal-day.oscar-day-pending { background: #ffc107; color: #333; }

/* Continuous span styling */
.oscar-cal-day.oscar-span-start { border-radius: 3px 0 0 3px; }
.oscar-cal-day.oscar-span-middle { border-radius: 0; }
.oscar-cal-day.oscar-span-end { border-radius: 0 3px 3px 0; }
.oscar-cal-day.oscar-span-single { border-radius: 3px; }

.oscar-cal-loading { grid-column: 1 / -1; text-align: center; padding: 40px; color: var(--oscar-text-light); font-size: 14px; }
.oscar-cal-stats { text-align: center; margin-top: 16px; font-size: 13px; color: var(--oscar-text-light); min-height: 24px; transition: all 0.2s; }
.oscar-cal-stats a { text-decoration: none; }
.oscar-cal-stats a:hover { text-decoration: underline; }

/* Clear selection button */
.oscar-cal-clear-btn {
    display: inline-block;
    margin-left: 12px;
    padding: 4px 12px;
    background: none;
    border: 1px solid var(--oscar-border);
    border-radius: var(--oscar-radius);
    font-size: 11px;
    color: var(--oscar-text-light);
    cursor: pointer;
    font-family: var(--oscar-font);
    transition: all 0.2s;
    vertical-align: middle;
}
.oscar-cal-clear-btn:hover {
    border-color: var(--oscar-danger);
    color: var(--oscar-danger);
    background: #fff5f5;
}

/* ===== BOOKING FORM ===== */
.oscar-booking-form-wrapper { background: var(--oscar-white); border: 1px solid var(--oscar-border); border-radius: 12px; padding: 32px; margin: 24px 0; box-shadow: var(--oscar-shadow); font-family: var(--oscar-font); }
.oscar-form-title { font-size: 22px; font-weight: 700; color: var(--oscar-text); margin: 0 0 24px; }
.oscar-form-row { display: flex; gap: 16px; margin-bottom: 16px; }
.oscar-form-field { flex: 1; }
.oscar-form-half { flex: 0 0 calc(50% - 8px); }
.oscar-form-third { flex: 0 0 calc(33.333% - 11px); }
.oscar-form-field label { display: block; font-size: 13px; font-weight: 600; color: var(--oscar-text); margin-bottom: 6px; }
.oscar-form-field input, .oscar-form-field select, .oscar-form-field textarea { width: 100%; padding: 12px 14px; border: 1px solid var(--oscar-border); border-radius: var(--oscar-radius); font-size: 14px; color: var(--oscar-text); font-family: var(--oscar-font); background: var(--oscar-white); box-sizing: border-box; line-height: 1.4; height: auto; }
.oscar-form-field select { cursor: pointer; padding-right: 30px; }
.oscar-form-field input:focus, .oscar-form-field select:focus, .oscar-form-field textarea:focus { outline: none; border-color: var(--oscar-primary); box-shadow: 0 0 0 2px var(--oscar-primary-light); }

.oscar-discount-input { display: flex; gap: 6px; }
.oscar-discount-input input { flex: 1; }
.oscar-btn-small { padding: 10px 14px; background: var(--oscar-primary); color: #fff; border: none; border-radius: var(--oscar-radius); font-size: 12px; font-weight: 600; cursor: pointer; white-space: nowrap; }
.oscar-btn-small:hover { background: var(--oscar-primary-dark); }
#oscar-discount-result { margin-top: 6px; font-size: 12px; padding: 4px 8px; border-radius: 3px; }
#oscar-discount-result.oscar-disc-ok { background: #d4edda; color: #155724; }
#oscar-discount-result.oscar-disc-err { background: #f8d7da; color: #721c24; }

.oscar-avail-result { padding: 14px 18px; border-radius: var(--oscar-radius); margin-bottom: 16px; font-size: 14px; font-weight: 500; }
.oscar-avail-result.oscar-avail-ok { background: #d4edda; color: #155724; border: 1px solid #c3e6cb; }
.oscar-avail-result.oscar-avail-no { background: #f8d7da; color: #721c24; border: 1px solid #f5c6cb; }

/* Price summary */
.oscar-price-summary { background: var(--oscar-bg); border: 1px solid var(--oscar-border); border-radius: var(--oscar-radius); padding: 18px 22px; margin-bottom: 20px; font-size: 14px; }
.oscar-price-summary .oscar-price-row { display: flex; justify-content: space-between; padding: 4px 0; }
.oscar-price-summary .oscar-price-section-title { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--oscar-text-light); padding-bottom: 4px; margin-bottom: 4px; border-bottom: 1px dashed var(--oscar-border); }
.oscar-price-summary .oscar-price-row.oscar-price-period { padding: 6px 0; }
.oscar-price-summary .oscar-price-row.oscar-price-period small { font-size: 11px; color: var(--oscar-text-light); }
.oscar-price-summary .oscar-price-row.oscar-price-total { border-top: 2px solid var(--oscar-border); margin-top: 8px; padding-top: 10px; font-weight: 700; font-size: 16px; color: var(--oscar-primary); }
.oscar-price-summary .oscar-price-label { color: var(--oscar-text-light); }
.oscar-price-summary .oscar-price-discount { color: var(--oscar-success); }

.oscar-form-submit { margin-top: 24px; text-align: center; }
.oscar-btn { display: inline-block; padding: 14px 40px; font-size: 14px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; border: none; border-radius: var(--oscar-radius); cursor: pointer; transition: all 0.3s; font-family: var(--oscar-font); }
.oscar-btn-primary { background: var(--oscar-primary); color: var(--oscar-white); }
.oscar-btn-primary:hover:not(:disabled) { background: var(--oscar-primary-dark); }
.oscar-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.oscar-form-note { font-size: 12px; color: var(--oscar-text-light); margin-top: 12px; }

.oscar-booking-success { text-align: center; padding: 40px 20px; }
.oscar-success-icon { width: 64px; height: 64px; background: var(--oscar-success); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 32px; margin: 0 auto 16px; }
.oscar-booking-success h3 { font-size: 24px; color: var(--oscar-text); margin: 0 0 8px; }
.oscar-booking-success p { color: var(--oscar-text-light); font-size: 15px; }
#oscar-success-details { background: var(--oscar-bg); border: 1px solid var(--oscar-border); border-radius: var(--oscar-radius); padding: 20px; margin-top: 20px; text-align: left; font-size: 14px; }

/* ===== CALENDAR ROOM TABS ===== */
.oscar-cal-tabs { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; padding: 8px 0 16px; border-bottom: 1px solid var(--oscar-border); margin-bottom: 16px; }
.oscar-cal-tab-loc { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--oscar-text-light); padding: 0 4px 0 8px; }
.oscar-cal-tab-loc:first-child { padding-left: 0; }
.oscar-cal-tab { background: transparent; border: 1px solid var(--oscar-border); color: var(--oscar-text); padding: 8px 16px; border-radius: 999px; font-size: 13px; font-weight: 600; cursor: pointer; transition: all .2s; font-family: var(--oscar-font); }
.oscar-cal-tab:hover { border-color: var(--oscar-primary); color: var(--oscar-primary); }
.oscar-cal-tab.is-active { background: var(--oscar-primary); border-color: var(--oscar-primary); color: var(--oscar-white); }

/* ===== ROOM INFO BLOCK (form when room preset) ===== */
.oscar-form-room-info { background: var(--oscar-primary-light); border: 1px solid var(--oscar-primary); color: var(--oscar-text); border-radius: var(--oscar-radius); padding: 12px 16px; margin-bottom: 16px; font-size: 14px; }
.oscar-form-room-info small { color: var(--oscar-text-light); }

/* ===== SEARCH RESULTS ===== */
.oscar-search-results { max-width: 900px; margin: 24px auto 0; text-align: left; }
.oscar-search-results-header { font-size: 14px; color: var(--oscar-text); padding: 0 4px 12px; }
.oscar-search-results-header strong { color: var(--oscar-primary); font-size: 16px; }
.oscar-search-results-header small { color: var(--oscar-text-light); }
.oscar-search-results-list { display: flex; flex-direction: column; gap: 12px; }
.oscar-search-divider { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--oscar-text-light); padding: 16px 4px 8px; border-top: 1px solid var(--oscar-border); margin-top: 8px; }

.oscar-room-card { display: flex; gap: 16px; background: var(--oscar-white); border: 1px solid var(--oscar-border); border-radius: 10px; padding: 14px; box-shadow: var(--oscar-shadow); transition: all .2s; }
.oscar-room-card:hover { border-color: var(--oscar-primary); transform: translateY(-1px); }
.oscar-room-card.is-unavailable { opacity: .55; }
.oscar-room-card-img { flex: 0 0 140px; height: 100px; border-radius: 8px; overflow: hidden; background: var(--oscar-bg); }
.oscar-room-card-img img { width: 100%; height: 100%; object-fit: cover; }
.oscar-room-card-body { flex: 1; min-width: 0; display: flex; flex-direction: column; justify-content: center; }
.oscar-room-card-title { font-size: 16px; color: var(--oscar-text); margin-bottom: 4px; }
.oscar-room-card-title small { color: var(--oscar-text-light); font-weight: 400; }
.oscar-room-card-sub { font-size: 13px; color: var(--oscar-text-light); margin-bottom: 6px; }
.oscar-room-card-meta { font-size: 12px; color: var(--oscar-text-light); }
.oscar-room-card-meta strong { color: var(--oscar-text); }
.oscar-room-card-price { flex: 0 0 160px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: 6px; padding-left: 12px; border-left: 1px solid var(--oscar-border); }
.oscar-room-price-total { font-size: 22px; font-weight: 700; color: var(--oscar-primary); line-height: 1; }
.oscar-room-price-sub { font-size: 11px; color: var(--oscar-text-light); text-transform: uppercase; letter-spacing: 1px; }
.oscar-room-card-btn { background: var(--oscar-primary); color: var(--oscar-white); border: none; padding: 10px 18px; border-radius: var(--oscar-radius); font-size: 12px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; cursor: pointer; transition: all .2s; margin-top: 4px; font-family: var(--oscar-font); }
.oscar-room-card-btn:hover { background: var(--oscar-primary-dark); }
.oscar-room-card-na { color: var(--oscar-text-light); font-size: 13px; font-weight: 600; }

/* ===== RESPONSIVE ===== */
@media (max-width: 900px) {
    .oscar-cal-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .oscar-cal-grid { grid-template-columns: 1fr; }
    .oscar-bar-form { flex-direction: column; }
    .oscar-bar-field { min-width: 100%; }
    .oscar-form-row { flex-direction: column; gap: 12px; }
    .oscar-form-half, .oscar-form-third { flex: 1; }
    .oscar-booking-form-wrapper { padding: 20px; }
    .oscar-calendar-wrapper { padding: 16px; }
    .oscar-room-card { flex-direction: column; }
    .oscar-room-card-img { flex: 0 0 auto; width: 100%; height: 160px; }
    .oscar-room-card-price { flex: 0 0 auto; padding: 12px 0 0; border-left: none; border-top: 1px solid var(--oscar-border); }
}

/* cs4u RentCar vehicle grid / slider */
.cs4u-rentcar-grid{display:grid;grid-template-columns:repeat(var(--rc-cols,3),minmax(0,1fr));gap:24px;margin:28px 0;align-items:stretch}.cs4u-rentcar-grid.is-slider{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:12px}.cs4u-rentcar-grid.is-slider .cs4u-rentcar-card{min-width:calc(100% / var(--rc-cols,3) - 18px);scroll-snap-align:start}.cs4u-rentcar-card{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:22px;box-shadow:0 16px 42px rgba(15,23,42,.10);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease}.cs4u-rentcar-card:hover{transform:translateY(-4px);box-shadow:0 22px 56px rgba(15,23,42,.16)}.cs4u-rentcar-media{position:relative;background:linear-gradient(135deg,#f8fafc,#e2e8f0);aspect-ratio:4/3;overflow:hidden}.cs4u-rentcar-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}.cs4u-rentcar-card:hover .cs4u-rentcar-media img{transform:scale(1.045)}.cs4u-rentcar-noimg{height:100%;display:flex;align-items:center;justify-content:center;color:#64748b;font-weight:700}.cs4u-rentcar-badge{position:absolute;top:14px;left:14px;background:rgba(15,23,42,.86);color:#fff;border-radius:999px;padding:7px 12px;font-size:12px;font-weight:700;letter-spacing:.03em}.cs4u-rentcar-body{padding:18px 18px 20px;display:flex;flex-direction:column;gap:10px;flex:1}.cs4u-rentcar-body h3{margin:0;font-size:20px;line-height:1.2;color:#0f172a}.cs4u-rentcar-subtitle{margin:0;color:#64748b;font-size:14px;line-height:1.45}.cs4u-rentcar-specs{display:flex;flex-wrap:wrap;gap:8px}.cs4u-rentcar-specs span{background:#f1f5f9;color:#334155;border-radius:12px;padding:7px 9px;font-size:13px;font-weight:600}.cs4u-rentcar-features{display:flex;flex-wrap:wrap;gap:6px}.cs4u-rentcar-features span{border:1px solid #e2e8f0;color:#475569;border-radius:999px;padding:5px 9px;font-size:12px}.cs4u-rentcar-footer{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:auto;padding-top:8px}.cs4u-rentcar-price strong{font-size:24px;color:#0f172a}.cs4u-rentcar-price small{color:#64748b;margin-left:4px}.cs4u-rentcar-btn{display:inline-flex;align-items:center;justify-content:center;background:var(--rc-button,#0053b5);color:#fff!important;text-decoration:none!important;border-radius:14px;padding:11px 16px;font-weight:800;box-shadow:0 10px 22px color-mix(in srgb,var(--rc-button,#0053b5) 32%,transparent);white-space:nowrap}.cs4u-rentcar-btn:hover{filter:brightness(.94);color:#fff!important}@media(max-width:900px){.cs4u-rentcar-grid{grid-template-columns:repeat(var(--rc-tablet,2),minmax(0,1fr))}.cs4u-rentcar-grid.is-slider .cs4u-rentcar-card{min-width:calc(100% / var(--rc-tablet,2) - 16px)}}@media(max-width:600px){.cs4u-rentcar-grid{grid-template-columns:repeat(var(--rc-mobile,1),minmax(0,1fr));gap:16px}.cs4u-rentcar-grid.is-slider .cs4u-rentcar-card{min-width:calc(100% / var(--rc-mobile,1) - 10px)}.cs4u-rentcar-footer{align-items:flex-start;flex-direction:column}.cs4u-rentcar-btn{width:100%}}
.oscar-booking-form-wrapper.oscar-rentcar-focus{animation:oscarRentcarFocus 1.6s ease;border-radius:18px}@keyframes oscarRentcarFocus{0%,100%{box-shadow:0 0 0 rgba(0,83,181,0)}25%{box-shadow:0 0 0 6px rgba(0,83,181,.20),0 18px 44px rgba(15,23,42,.16)}}.cs4u-rentcar-hero{background:radial-gradient(circle at 20% 20%,rgba(0,83,181,.20),transparent 32%),linear-gradient(135deg,#0f172a,#1e293b 60%,#334155);color:#fff;border-radius:28px;padding:56px 28px;margin:20px 0 34px;overflow:hidden;position:relative}.cs4u-rentcar-hero:after{content:"";position:absolute;inset:auto -80px -100px auto;width:320px;height:320px;background:rgba(255,255,255,.08);border-radius:999px}.cs4u-rentcar-hero-inner{max-width:980px;margin:0 auto;text-align:center;position:relative;z-index:1}.cs4u-rentcar-hero h1{color:#fff;font-size:clamp(34px,6vw,64px);line-height:1.02;margin:0 0 14px;font-weight:900}.cs4u-rentcar-hero p{color:#cbd5e1;font-size:18px;max-width:760px;margin:0 auto 24px}.cs4u-rentcar-hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.cs4u-rentcar-hero .hero-btn{background:var(--rc-button,#0053b5);color:#fff!important;text-decoration:none;border-radius:14px;padding:13px 20px;font-weight:800}.cs4u-rentcar-hero .hero-btn.secondary{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22)}

/* cs4u RentCar single vehicle page */
.cs4u-vehicle-page{margin:20px 0 50px}.cs4u-vehicle-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,48%);gap:28px;align-items:center;background:linear-gradient(135deg,#0f172a,#1e293b);border-radius:32px;padding:34px;overflow:hidden;color:#fff;box-shadow:0 24px 70px rgba(15,23,42,.22)}.cs4u-vehicle-kicker{display:inline-flex;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:8px 13px;font-size:13px;font-weight:800;margin-bottom:16px}.cs4u-vehicle-hero h1{font-size:clamp(34px,5vw,62px);line-height:1.02;margin:0 0 14px;color:#fff;font-weight:950}.cs4u-vehicle-hero p{font-size:18px;color:#cbd5e1;margin:0 0 18px}.cs4u-vehicle-price{display:flex;align-items:flex-end;gap:8px;margin:22px 0}.cs4u-vehicle-price strong{font-size:42px;color:#fff}.cs4u-vehicle-price span{color:#cbd5e1;padding-bottom:8px}.cs4u-vehicle-actions{display:flex;gap:12px;flex-wrap:wrap}.cs4u-vehicle-ghost{display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.10);color:#fff!important;text-decoration:none!important;border-radius:14px;padding:11px 16px;font-weight:800}.cs4u-vehicle-hero-media{border-radius:26px;overflow:hidden;background:#e2e8f0;min-height:330px}.cs4u-vehicle-hero-media img{width:100%;height:100%;object-fit:cover;display:block}.cs4u-vehicle-gallery{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin:18px 0}.cs4u-vehicle-gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:18px;box-shadow:0 8px 22px rgba(15,23,42,.12)}.cs4u-vehicle-spec-panel,.cs4u-vehicle-calendar,.cs4u-vehicle-booking{background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:0 16px 44px rgba(15,23,42,.08);border-radius:26px;padding:26px;margin:24px 0}.cs4u-vehicle-spec-panel h2,.cs4u-vehicle-calendar h2,.cs4u-vehicle-booking h2{margin-top:0;color:#0f172a}.cs4u-vehicle-spec-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.cs4u-vehicle-spec-grid div{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:14px}.cs4u-vehicle-spec-grid strong{display:block;color:#64748b;font-size:12px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.cs4u-vehicle-spec-grid span{color:#0f172a;font-size:16px;font-weight:800}.cs4u-vehicle-feature-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}.cs4u-vehicle-feature-pills span{background:color-mix(in srgb,var(--rc-button,#0053b5) 10%,#fff);border:1px solid color-mix(in srgb,var(--rc-button,#0053b5) 22%,#e2e8f0);color:#334155;border-radius:999px;padding:8px 12px;font-weight:700;font-size:13px}@media(max-width:900px){.cs4u-vehicle-hero{grid-template-columns:1fr;padding:24px}.cs4u-vehicle-spec-grid{grid-template-columns:repeat(2,1fr)}.cs4u-vehicle-gallery{grid-template-columns:repeat(3,1fr)}}@media(max-width:560px){.cs4u-vehicle-spec-grid{grid-template-columns:1fr}.cs4u-vehicle-gallery{grid-template-columns:repeat(2,1fr)}.cs4u-vehicle-hero-media{min-height:240px}}
.oscar-cal-vehicle-select-wrap{display:flex;align-items:center;gap:14px;flex-wrap:wrap;background:#f8fafc;border:1px solid #e2e8f0;border-radius:18px;padding:16px 18px;margin:18px 0}.oscar-cal-vehicle-select-wrap label{font-weight:900;color:#0f172a}.oscar-cal-room-select{min-width:min(100%,420px);border:1px solid #cbd5e1;border-radius:12px;padding:11px 14px;background:#fff;color:#0f172a;font-weight:700}.oscar-cal-vehicle-select-wrap .oscar-cal-combined-hint{flex-basis:100%;margin:0;color:#64748b;font-size:13px}.ela-hero-search-card{background:white;border-radius:26px;box-shadow:0 24px 70px rgba(15,23,42,.16);padding:24px;border:1px solid rgba(15,23,42,.08)}
/* v2.7.1 premium polish */
.ela-premium-home .section-content,.ela-stolos-page .section-content{position:relative;z-index:2}.ela-hero-panel{background:linear-gradient(135deg,#0053b5 0%,#07356f 52%,#101827 100%);border-radius:34px;overflow:hidden;box-shadow:0 28px 80px rgba(0,43,96,.24);position:relative}.ela-hero-panel:before{content:"";position:absolute;right:-140px;top:-120px;width:420px;height:420px;border-radius:999px;background:rgba(220,35,45,.22)}.ela-hero-panel:after{content:"";position:absolute;right:8%;bottom:12%;width:46%;height:3px;background:linear-gradient(90deg,transparent,#dc232d,#fff);transform:skewY(-8deg);opacity:.9}.ela-hero-copy{padding:72px 56px;color:#fff;position:relative;z-index:2}.ela-hero-copy h1{color:#fff;font-weight:950;letter-spacing:-.04em;font-size:clamp(38px,6vw,72px);line-height:.96;margin:0 0 18px}.ela-hero-copy p{color:#dbeafe;font-size:19px;line-height:1.7;max-width:660px}.ela-kicker{display:inline-flex;gap:8px;align-items:center;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.20);border-radius:999px;padding:9px 14px;color:#fff;font-weight:900;letter-spacing:.06em;text-transform:uppercase;font-size:12px;margin-bottom:18px}.ela-kicker b{color:#ff4b55}.ela-hero-card{background:#fff;border-radius:28px;box-shadow:0 24px 70px rgba(15,23,42,.20);padding:24px;border:1px solid rgba(15,23,42,.08)}.ela-mini-card{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:24px;padding:24px;height:100%;box-shadow:0 14px 36px rgba(15,23,42,.08);transition:.2s ease}.ela-mini-card:hover{transform:translateY(-4px);box-shadow:0 22px 58px rgba(15,23,42,.13)}.ela-mini-card strong{display:block;color:#0053b5;font-size:34px;line-height:1;margin-bottom:8px}.ela-mini-card.red strong{color:#dc232d}.cs4u-vehicle-page{--veh-blue:#0053b5;--veh-red:#dc232d}.cs4u-vehicle-hero{grid-template-columns:minmax(0,0.9fr) minmax(420px,1.1fr);background:linear-gradient(135deg,#08111f,#0f2f63 58%,#0053b5);padding:0;min-height:560px}.cs4u-vehicle-hero-copy{padding:54px;align-self:center}.cs4u-vehicle-kicker{background:rgba(220,35,45,.95);border:none;color:#fff}.cs4u-vehicle-price strong{font-size:58px}.cs4u-vehicle-hero-media{border-radius:0;min-height:560px;height:100%;position:relative}.cs4u-vehicle-hero-media:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,17,31,.45),transparent 38%)}.cs4u-vehicle-gallery{grid-template-columns:2fr 1fr 1fr;grid-auto-rows:210px}.cs4u-vehicle-gallery img{height:100%;aspect-ratio:auto;border-radius:24px}.cs4u-vehicle-gallery img:first-child{grid-row:span 2}.cs4u-vehicle-spec-panel,.cs4u-vehicle-calendar,.cs4u-vehicle-booking{border-radius:30px;box-shadow:0 18px 54px rgba(15,23,42,.09)}.cs4u-vehicle-spec-grid div{border-radius:18px;background:linear-gradient(180deg,#fff,#f8fafc)}@media(max-width:900px){.cs4u-vehicle-hero{grid-template-columns:1fr;min-height:0}.cs4u-vehicle-hero-copy{padding:32px}.cs4u-vehicle-hero-media{min-height:320px}.cs4u-vehicle-gallery{grid-template-columns:1fr 1fr;grid-auto-rows:150px}.cs4u-vehicle-gallery img:first-child{grid-column:span 2;grid-row:span 1}.ela-hero-copy{padding:42px 28px}}
/* v2.7.2 horizontal premium booking bar */
.ela-booking-strip{margin-top:-34px;position:relative;z-index:10}.ela-booking-strip .oscar-booking-bar{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:24px;box-shadow:0 24px 70px rgba(15,23,42,.18);padding:22px}.ela-booking-strip .oscar-bar-title{font-size:18px;font-weight:950;color:#0f172a;margin:0 0 14px;text-transform:uppercase;letter-spacing:.04em}.ela-booking-strip .oscar-bar-diamond{display:none}.ela-booking-strip .oscar-bar-form{display:grid;grid-template-columns:minmax(180px,1.3fr) repeat(3,minmax(145px,1fr)) auto;gap:12px;align-items:end}.ela-booking-strip .oscar-bar-field{margin:0}.ela-booking-strip .oscar-bar-field label{font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.07em;color:#64748b;margin-bottom:7px}.ela-booking-strip .oscar-bar-field input,.ela-booking-strip .oscar-bar-field select{height:48px;border-radius:14px;border:1px solid #dbe3ef;background:#f8fafc;font-weight:800;color:#0f172a}.ela-booking-strip .oscar-bar-btn{height:48px;border-radius:14px;background:#dc232d;color:#fff;font-weight:950;box-shadow:0 12px 28px rgba(220,35,45,.28);white-space:nowrap}.ela-booking-strip .oscar-search-results{margin-top:18px}.ela-booking-strip .oscar-bar-result{margin-top:14px}@media(max-width:980px){.ela-booking-strip{margin-top:18px}.ela-booking-strip .oscar-bar-form{grid-template-columns:1fr 1fr}.ela-booking-strip .oscar-bar-submit{grid-column:1/-1}.ela-booking-strip .oscar-bar-btn{width:100%}}@media(max-width:560px){.ela-booking-strip .oscar-bar-form{grid-template-columns:1fr}}
/* v2.7.3 pickup/dropoff + time fields */
.ela-booking-strip .oscar-bar-form{grid-template-columns:repeat(4,minmax(140px,1fr)) repeat(3,minmax(120px,.8fr)) auto}.oscar-bar-field input[type="time"],.oscar-form-field input[type="time"]{font-variant-numeric:tabular-nums}.oscar-bar-field select[name="pickup_location_id"],.oscar-bar-field select[name="dropoff_location_id"]{min-width:170px}@media(max-width:1200px){.ela-booking-strip .oscar-bar-form{grid-template-columns:repeat(4,1fr)}}@media(max-width:760px){.ela-booking-strip .oscar-bar-form{grid-template-columns:1fr 1fr}}@media(max-width:560px){.ela-booking-strip .oscar-bar-form{grid-template-columns:1fr}}


/* v2.7.2 mobile booking bar overflow fix */
.ela-booking-strip .oscar-bar-form{width:100%;max-width:100%;box-sizing:border-box;}
.ela-booking-strip .oscar-bar-field,.ela-booking-strip .oscar-bar-submit{min-width:0;max-width:100%;box-sizing:border-box;}
.ela-booking-strip .oscar-bar-field input,.ela-booking-strip .oscar-bar-field select,.ela-booking-strip .oscar-bar-btn{max-width:100%;box-sizing:border-box;}
.ela-booking-strip .oscar-bar-field select[name="pickup_location_id"],.ela-booking-strip .oscar-bar-field select[name="dropoff_location_id"]{min-width:0;}
.ela-booking-strip .oscar-bar-btn{display:flex;align-items:center;justify-content:center;width:100%;overflow:visible;text-align:center;padding-left:14px;padding-right:14px;}
@media(max-width:760px){.ela-booking-strip .oscar-bar-form{grid-template-columns:1fr!important;}.ela-booking-strip .oscar-booking-bar{padding-left:16px;padding-right:16px;}.ela-booking-strip .oscar-bar-btn{white-space:normal;min-height:48px;height:auto;line-height:1.2;}}


/* v2.7.3 robust booking bar responsive grid fix */
.ela-booking-strip .oscar-booking-bar{overflow:visible;}
.ela-booking-strip .oscar-bar-form{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:14px!important;align-items:end!important;width:100%!important;max-width:1180px!important;margin-left:auto!important;margin-right:auto!important;}
.ela-booking-strip .oscar-bar-field,.ela-booking-strip .oscar-bar-submit{min-width:0!important;width:auto!important;max-width:100%!important;grid-column:auto!important;position:static!important;}
.ela-booking-strip .oscar-bar-submit{grid-column:1/-1!important;}
.ela-booking-strip .oscar-bar-field input,.ela-booking-strip .oscar-bar-field select{width:100%!important;min-width:0!important;max-width:100%!important;height:50px!important;box-sizing:border-box!important;font-size:13px!important;}
.ela-booking-strip .oscar-bar-btn{width:100%!important;min-width:0!important;max-width:100%!important;height:52px!important;box-sizing:border-box!important;display:flex!important;align-items:center!important;justify-content:center!important;white-space:normal!important;text-align:center!important;line-height:1.15!important;padding:10px 16px!important;margin:0!important;position:static!important;}
@media(max-width:980px){.ela-booking-strip .oscar-bar-form{grid-template-columns:repeat(2,minmax(0,1fr))!important;max-width:760px!important;}}
@media(max-width:560px){.ela-booking-strip .oscar-bar-form{grid-template-columns:1fr!important;max-width:420px!important;}.ela-booking-strip .oscar-booking-bar{padding-left:14px!important;padding-right:14px!important;}}

/* OPENCLAW calendar vehicle select mobile fit - 2026-05-20 */
.oscar-cal-vehicle-select-wrap{width:100%!important;max-width:100%!important;}
.oscar-cal-vehicle-select-wrap select,
#oscar-cal-room-select{width:100%!important;max-width:100%!important;min-width:0!important;box-sizing:border-box!important;text-overflow:ellipsis!important;}
@media(max-width:549px){#oscar-cal-room-select{font-size:13px!important;padding-left:8px!important;padding-right:28px!important;}.oscar-cal-vehicle-select-wrap label{font-size:13px!important;}}

/* OPENCLAW availability select height + anchor - 2026-05-20 */
.oscar-calendar-anchor{display:block;position:relative;top:-90px;visibility:hidden;height:0;overflow:hidden;}
#oscar-cal-room-select,
.oscar-cal-vehicle-select-wrap select{
  height:48px!important;
  min-height:48px!important;
  line-height:48px!important;
  padding-top:0!important;
  padding-bottom:0!important;
  display:block!important;
  overflow:visible!important;
  appearance:auto!important;
  -webkit-appearance:menulist!important;
}
.oscar-cal-vehicle-select-wrap{overflow:visible!important;}
@media(max-width:549px){
  #oscar-cal-room-select,
  .oscar-cal-vehicle-select-wrap select{
    height:50px!important;
    min-height:50px!important;
    line-height:50px!important;
    font-size:14px!important;
  }
}

/* OPENCLAW checkbox alignment fix - 2026-05-20 */
.oscar-booking-form label:has(input[type="checkbox"]),
.oscar-booking-form .oscar-checkbox-label,
.oscar-booking-form .oscar-extra-option,
.oscar-booking-form .oscar-extra-row,
.oscar-booking-form .oscar-additional-driver,
.oscar-booking-form .oscar-second-driver,
.oscar-booking-form .oscar-form-checkbox,
.oscar-booking-form .oscar-field-checkbox label,
#oscar-booking-form-wrapper label:has(input[type="checkbox"]){
  display:flex!important;
  align-items:center!important;
  gap:9px!important;
  line-height:1.35!important;
  min-height:28px!important;
  margin:8px 0!important;
}
.oscar-booking-form input[type="checkbox"],
#oscar-booking-form-wrapper input[type="checkbox"]{
  flex:0 0 auto!important;
  width:18px!important;
  height:18px!important;
  min-width:18px!important;
  margin:0!important;
  vertical-align:middle!important;
  position:relative!important;
  top:0!important;
}
.oscar-booking-form label:has(input[type="checkbox"]) span,
#oscar-booking-form-wrapper label:has(input[type="checkbox"]) span{
  line-height:1.35!important;
}

/* OPENCLAW exact extras checkbox inline alignment - 2026-05-20 */
#oscar-booking-form-wrapper .oscar-extras-row label.oscar-extra-option{
  display:flex!important;align-items:center!important;justify-content:flex-start!important;gap:9px!important;
  margin:8px 0!important;line-height:1.35!important;min-height:28px!important;text-align:left!important;
}
#oscar-booking-form-wrapper .oscar-extras-row label.oscar-extra-option input[type="checkbox"]{
  display:inline-block!important;flex:0 0 18px!important;width:18px!important;height:18px!important;min-width:18px!important;
  margin:0!important;padding:0!important;position:static!important;transform:none!important;vertical-align:middle!important;
}
