/* CHSO Booking Widget v1.7.0 | Rufus Design */

/* ── Root vars — also picks up inline --chso-primary/accent overrides ── */
[data-chso="widget"],
[data-chso="details"] {
    --cp: var(--chso-primary, #1a1a1a);
    --ca: var(--chso-accent,  #c9a96e);
    --cb: #e0ddd8;
    --cs: #f8f7f4;
    --cm: #767676;
    --cr: 4px;
    --csh: 0 4px 24px rgba(0,0,0,.10);
    --ct: 180ms ease;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    color: #1a1a1a;
    -webkit-text-size-adjust: 100%;
    display: block;
}

[data-chso="widget"] *,
[data-chso="details"] * {
    box-sizing: border-box;
    font-family: Arial, Helvetica, sans-serif;
}

/* Strip theme form-element overrides scoped tightly */
[data-chso] input,
[data-chso] select,
[data-chso] textarea {
    -webkit-appearance: none !important;
    -moz-appearance:    none !important;
    appearance:         none !important;
    box-shadow:         none !important;
    outline:            none !important;
}

/* ══════════════════════════════════════════════════
   STEP 1 — BOOKING BAR
   ══════════════════════════════════════════════════ */

[data-chso="widget"] .chso-w-header { margin-bottom: 10px; display: block; }
[data-chso="widget"] .chso-w-label  { font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--ca); }
[data-chso="widget"] .chso-w-sublabel { font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: rgba(255,255,255,.5); margin-left: 8px; }

[data-chso="widget"] .chso-bar {
    display: flex !important;
    align-items: stretch;
    background: rgba(255,255,255,.97);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: var(--cr);
    box-shadow: var(--csh);
    overflow: visible;
    position: relative;
}

[data-chso="widget"] .chso-divider {
    flex-shrink: 0;
    width: 1px;
    background: var(--cb);
    align-self: stretch;
    margin: 10px 0;
    display: block;
}

[data-chso="widget"] .chso-col {
    display: flex !important;
    align-items: flex-start;
    gap: 10px;
    padding: 13px 15px;
    flex: 1;
    min-width: 0;
    position: relative;
}
[data-chso="widget"] .chso-col-date   { flex: 0 0 180px; }
[data-chso="widget"] .chso-col-time   { flex: 0 0 145px; }
[data-chso="widget"] .chso-col-pickup,
[data-chso="widget"] .chso-col-dest   { flex: 1; }

[data-chso="widget"] .chso-col-icon {
    flex-shrink: 0;
    width: 17px; height: 17px;
    color: var(--ca);
    display: flex !important;
    align-items: center;
    margin-top: 3px;
}

[data-chso="widget"] .chso-col-body {
    display: flex !important;
    flex-direction: column;
    gap: 4px;
    flex: 1;
    min-width: 0;
}

[data-chso="widget"] .chso-col-label {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--cm);
    white-space: nowrap;
    display: block;
}

/* ── Date trigger (span — immune to theme button styles) */
[data-chso="widget"] .chso-date-trigger {
    display: inline-block;
    cursor: pointer;
    font-size: 13px;
    color: #1a1a1a;
    line-height: 1.3;
    user-select: none;
    -webkit-user-select: none;
}
[data-chso="widget"] .chso-date-trigger:hover { color: var(--ca); }

/* ── Select wrapper + stripped select */
[data-chso="widget"] .chso-sel-wrap {
    position: relative;
    display: inline-block;
}
[data-chso="widget"] .chso-sel {
    display: block;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 20px 0 0 !important;
    font-size: 13px;
    color: #1a1a1a;
    cursor: pointer;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    outline: none;
    min-width: 90px;
}
[data-chso="widget"] .chso-sel-arrow {
    pointer-events: none;
    position: absolute;
    right: 2px; top: 50%;
    transform: translateY(-50%);
    width: 10px; height: 6px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23aaa' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center;
    display: block;
}

/* ── Plain text input in bar */
[data-chso="widget"] .chso-text-input {
    display: block;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    font-size: 13px;
    color: #1a1a1a;
    width: 100%;
    outline: none !important;
}
[data-chso="widget"] .chso-text-input::placeholder { color: #aaa; }

/* ── Go (div — immune to theme styles) */
[data-chso="widget"] .chso-go-btn {
    flex-shrink: 0;
    width: 52px;
    min-width: 52px;
    background: var(--cp);
    color: #fff;
    border-radius: 0 var(--cr) var(--cr) 0;
    display: flex !important;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background var(--ct);
}
[data-chso="widget"] .chso-go-btn:hover { background: var(--ca); }

/* ── Autocomplete */
[data-chso] .chso-ac-list {
    display: none;
    position: absolute;
    top: 100%; left: 0; right: 0;
    margin-top: 4px;
    z-index: 100001;
    background: #fff;
    border: 1px solid var(--cb);
    border-radius: var(--cr);
    box-shadow: 0 8px 28px rgba(0,0,0,.14);
    list-style: none !important;
    padding: 4px 0;
    max-height: 260px;
    overflow-y: auto;
}
[data-chso] .chso-ac-list li {
    padding: 9px 14px;
    font-size: 12px;
    cursor: pointer;
    color: #1a1a1a;
    list-style: none !important;
    transition: background var(--ct);
    display: block;
}
[data-chso] .chso-ac-list li:hover,
[data-chso] .chso-ac-list .chso-ac-on { background: var(--cs); }

/* ── Error */
[data-chso="widget"] .chso-err {
    margin-top: 8px;
    font-size: 13px;
    font-weight: 600;
    color: #fff;
    min-height: 18px;
    text-shadow: 0 1px 4px rgba(0,0,0,.6);
    display: block;
}

/* ── Mobile */
@media (max-width: 700px) {
    [data-chso="widget"] .chso-bar          { flex-direction: column !important; overflow: visible; }
    [data-chso="widget"] .chso-divider      { width: auto !important; height: 1px; margin: 0; }
    [data-chso="widget"] .chso-col,
    [data-chso="widget"] .chso-col-date,
    [data-chso="widget"] .chso-col-time     { flex: none !important; width: 100%; }
    [data-chso="widget"] .chso-go-btn       { width: 100%; height: 48px; border-radius: 0 0 var(--cr) var(--cr); }
    [data-chso="widget"] .chso-ac-list      { left: -15px; right: -15px; }
}

/* ══════════════════════════════════════════════════
   CALENDAR  (shared, both steps)
   ══════════════════════════════════════════════════ */

[data-chso] .chso-cal {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    z-index: 100000;
    background: #fff;
    border: 1px solid var(--cb);
    border-radius: 8px;
    box-shadow: 0 12px 40px rgba(0,0,0,.18);
    padding: 14px;
    width: 272px;
    user-select: none;
    -webkit-user-select: none;
}

[data-chso] .chso-cal-head {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

[data-chso] .chso-cal-nav {
    cursor: pointer;
    font-size: 20px;
    color: var(--cm);
    padding: 2px 8px;
    border-radius: 3px;
    line-height: 1;
    display: inline-block;
    user-select: none;
}
[data-chso] .chso-cal-nav:hover { background: var(--cs); color: #1a1a1a; }

[data-chso] .chso-cal-month {
    font-size: 13px;
    font-weight: 700;
    color: #1a1a1a;
    display: block;
    text-align: center;
}

[data-chso] .chso-cal-dow {
    display: grid !important;
    grid-template-columns: repeat(7,1fr);
    margin-bottom: 4px;
}
[data-chso] .chso-cal-dow span {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--cm);
    text-align: center;
    padding: 3px 0;
    display: block;
}

[data-chso] .chso-cal-grid {
    display: grid !important;
    grid-template-columns: repeat(7,1fr);
    gap: 2px;
}

[data-chso] .chso-cd {
    display: block;
    text-align: center;
    font-size: 12px;
    color: #1a1a1a;
    padding: 6px 2px;
    border-radius: 3px;
    cursor: pointer;
    line-height: 1;
    user-select: none;
    transition: background var(--ct);
}
[data-chso] .chso-cd:hover:not(.chso-cd-past):not(.chso-cd-empty) { background: var(--cs); }
[data-chso] .chso-cd-today { font-weight: 700; color: var(--ca); }
[data-chso] .chso-cd-sel   { background: var(--cp) !important; color: #fff !important; }
[data-chso] .chso-cd-past,
[data-chso] .chso-cd-empty { opacity: .3; cursor: default; }

/* ══════════════════════════════════════════════════
   STEP 2 — DETAILS PAGE
   ══════════════════════════════════════════════════ */

[data-chso="details"] .chso-d-layout {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    align-items: start;
}
@media (max-width: 800px) {
    [data-chso="details"] .chso-d-layout { grid-template-columns: 1fr !important; }
}

/* Left and right columns — must be block/flex children */
[data-chso="details"] .chso-d-left,
[data-chso="details"] .chso-d-right { display: block; min-width: 0; }

[data-chso="details"] .chso-d-heading { margin-bottom: 20px; display: block; }
[data-chso="details"] .chso-d-heading h2 {
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    margin: 0 0 6px;
    display: block;
    color: #1a1a1a;
}
[data-chso="details"] .chso-d-heading p { font-size: 13px; color: var(--cm); margin: 0; display: block; }

/* Journey editor card */
[data-chso="details"] .chso-editor {
    background: var(--cs);
    border: 1px solid var(--cb);
    border-radius: 8px;
    padding: 18px 22px;
    margin-bottom: 18px;
    display: block;
}

[data-chso="details"] .chso-ed-row {
    display: flex !important;
    align-items: flex-start;
    gap: 12px;
}
[data-chso="details"] .chso-ed-route { align-items: stretch; }

[data-chso="details"] .chso-ed-icon {
    flex-shrink: 0;
    width: 16px; height: 16px;
    color: var(--ca);
    display: flex !important;
    align-items: center;
    margin-top: 20px;
}

[data-chso="details"] .chso-ed-body {
    flex: 1;
    min-width: 0;
    position: relative;
    display: block;
}

[data-chso="details"] .chso-ed-label {
    display: block;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--cm);
    margin-bottom: 5px;
}

/* Date trigger in editor */
[data-chso="details"] .chso-date-trigger {
    display: inline-block;
    background: #fff;
    border: 1px solid var(--cb);
    border-radius: var(--cr);
    padding: 6px 12px;
    font-size: 13px;
    color: #1a1a1a;
    cursor: pointer;
    white-space: nowrap;
    user-select: none;
    -webkit-user-select: none;
    transition: border-color var(--ct);
}
[data-chso="details"] .chso-date-trigger:hover { border-color: var(--ca); }

[data-chso="details"] .chso-ed-datetime {
    display: flex !important;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 2px;
}

/* Time select in editor — needs visible border */
[data-chso="details"] .chso-sel-wrap {
    position: relative;
    display: block;
}
[data-chso="details"] .chso-sel-wrap--sm {
    display: inline-block;
}
[data-chso="details"] .chso-sel-wrap--sm .chso-sel {
    background: #fff !important;
    border: 1px solid var(--cb) !important;
    border-radius: var(--cr) !important;
    padding: 6px 28px 6px 10px !important;
    font-size: 13px;
    min-width: 110px;
}
[data-chso="details"] .chso-sel {
    display: block;
    width: 100%;
    background: #fff !important;
    border: 1px solid var(--cb) !important;
    border-radius: var(--cr) !important;
    padding: 9px 36px 9px 12px !important;
    font-size: 13px;
    cursor: pointer;
    color: #1a1a1a;
    transition: border-color var(--ct);
}
[data-chso="details"] .chso-sel:focus { border-color: var(--ca) !important; box-shadow: 0 0 0 2px rgba(201,169,110,.15) !important; }

[data-chso="details"] .chso-sel-arrow {
    pointer-events: none;
    position: absolute;
    right: 10px; top: 50%;
    transform: translateY(-50%);
    width: 10px; height: 6px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23aaa' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center;
    display: block;
}

/* Route dots */
[data-chso="details"] .chso-ed-dots {
    display: flex !important;
    flex-direction: column;
    align-items: center;
    flex-shrink: 0;
    padding-top: 20px;
    width: 16px;
}
[data-chso="details"] .chso-dot {
    width: 10px; height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
    display: block;
}
[data-chso="details"] .chso-dot--from { background: var(--ca); }
[data-chso="details"] .chso-dot--to   { background: var(--cp); }
[data-chso="details"] .chso-dot-line  { width: 2px; flex: 1; background: var(--cb); margin: 3px 0; min-height: 22px; display: block; }
[data-chso="details"] .chso-ed-routefield { flex: 1; min-width: 0; position: relative; display: block; }
[data-chso="details"] .chso-ed-gap   { height: 14px; display: block; }
[data-chso="details"] .chso-ed-rule  { height: 1px; background: var(--cb); margin: 14px 0; display: block; }

[data-chso="details"] .chso-ed-input {
    display: block;
    width: 100%;
    background: #fff !important;
    border: 1px solid var(--cb) !important;
    border-radius: var(--cr) !important;
    padding: 7px 10px !important;
    font-size: 13px;
    color: #1a1a1a;
    outline: none;
    transition: border-color var(--ct);
}
[data-chso="details"] .chso-ed-input:focus { border-color: var(--ca) !important; box-shadow: 0 0 0 2px rgba(201,169,110,.15) !important; }
[data-chso="details"] .chso-ed-input::placeholder { color: #aaa; }

/* Map */
[data-chso="details"] .chso-map-wrap {
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--cb);
    display: block;
}
[data-chso="details"] .chso-map {
    height: 300px;
    width: 100%;
    background: #e8e4de;
    display: block;
}
[data-chso="details"] .chso-map .leaflet-container { background: #e8e4de; }

/* ══════════════════════════════════════════════════
   FORM CARD
   ══════════════════════════════════════════════════ */
[data-chso="details"] .chso-form-card {
    background: #fff;
    border: 1px solid var(--cb);
    border-radius: 8px;
    padding: 28px;
    box-shadow: var(--csh);
    display: block;
}
@media (max-width: 480px) {
    [data-chso="details"] .chso-form-card { padding: 18px; }
}

[data-chso="details"] .chso-form-title {
    display: block;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    border-bottom: 2px solid var(--ca);
    padding-bottom: 14px;
    margin-bottom: 22px;
    color: #1a1a1a;
}

[data-chso="details"] .chso-fg  { margin-bottom: 18px; display: block; }

[data-chso="details"] .chso-frow {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 18px;
}
@media (max-width: 520px) {
    [data-chso="details"] .chso-frow { grid-template-columns: 1fr !important; }
}

[data-chso="details"] .chso-fl {
    display: block;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--cm);
    margin-bottom: 5px;
}
[data-chso="details"] .chso-fl span { color: var(--ca); }

[data-chso="details"] .chso-fi,
[data-chso="details"] .chso-fta {
    display: block;
    width: 100%;
    background: #fff !important;
    border: 1px solid var(--cb) !important;
    border-radius: var(--cr) !important;
    padding: 9px 12px !important;
    font-size: 13px;
    color: #1a1a1a;
    outline: none;
    transition: border-color var(--ct);
}
[data-chso="details"] .chso-fi:focus,
[data-chso="details"] .chso-fta:focus {
    border-color: var(--ca) !important;
    box-shadow: 0 0 0 3px rgba(201,169,110,.15) !important;
}
[data-chso="details"] .chso-fta { resize: vertical; min-height: 90px; }
[data-chso="details"] .chso-hint { font-size: 11px; color: var(--cm); margin: 0 0 10px; display: block; }

/* ── Passengers slider */
[data-chso="details"] .chso-pax {
    display: flex !important;
    align-items: center;
    gap: 10px;
    margin-top: 2px;
}
[data-chso="details"] .chso-pax-minus,
[data-chso="details"] .chso-pax-plus {
    flex-shrink: 0;
    width: 28px; height: 28px;
    border-radius: 50%;
    background: var(--cs);
    border: 1px solid var(--cb);
    display: flex !important;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 18px;
    color: #1a1a1a;
    line-height: 1;
    user-select: none;
    transition: background var(--ct), border-color var(--ct), color var(--ct);
}
[data-chso="details"] .chso-pax-minus:hover,
[data-chso="details"] .chso-pax-plus:hover { background: var(--ca); border-color: var(--ca); color: #fff; }

[data-chso="details"] .chso-pax-track {
    flex: 1;
    height: 6px;
    background: var(--cs);
    border: 1px solid var(--cb);
    border-radius: 3px;
    position: relative;
    cursor: pointer;
    display: block;
}
[data-chso="details"] .chso-pax-fill {
    position: absolute;
    left: 0; top: 0; bottom: 0;
    background: var(--ca);
    border-radius: 3px;
    width: 7.7%;
    pointer-events: none;
    transition: width .1s;
    display: block;
}
[data-chso="details"] .chso-pax-range {
    position: absolute;
    inset: -6px 0;
    width: 100%;
    opacity: 0;
    cursor: pointer;
    margin: 0;
    padding: 0;
    height: calc(100% + 12px);
    display: block;
}
[data-chso="details"] .chso-pax-val {
    flex-shrink: 0;
    min-width: 26px;
    text-align: center;
    font-size: 15px;
    font-weight: 700;
    color: #1a1a1a;
    display: block;
}

/* ── Vehicle cards */
[data-chso="details"] .chso-vehicles {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 10px;
}
[data-chso="details"] .chso-vcard { display: block; cursor: pointer; position: relative; }
[data-chso="details"] .chso-vchk { position: absolute; opacity: 0; width: 0; height: 0; }

[data-chso="details"] .chso-vcard-inner {
    border: 2px solid var(--cb);
    border-radius: var(--cr);
    overflow: hidden;
    position: relative;
    background: #fff;
    transition: border-color var(--ct), box-shadow var(--ct);
    display: block;
}
[data-chso="details"] .chso-vcard:hover .chso-vcard-inner { border-color: var(--ca); box-shadow: 0 2px 10px rgba(201,169,110,.2); }
[data-chso="details"] .chso-vchk:checked + .chso-vcard-inner { border-color: var(--ca); background: #fdfbf7; box-shadow: 0 0 0 3px rgba(201,169,110,.14); }

[data-chso="details"] .chso-vimg {
    width: 100%;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: var(--cs);
    display: block;
}
[data-chso="details"] .chso-vimg img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s;
}
[data-chso="details"] .chso-vcard:hover .chso-vimg img { transform: scale(1.04); }

[data-chso="details"] .chso-vinfo { padding: 7px 9px; display: block; }
[data-chso="details"] .chso-vname { display: block; font-size: 11px; font-weight: 700; line-height: 1.3; }
[data-chso="details"] .chso-vbadge {
    display: inline-block;
    font-size: 8px; font-weight: 700; letter-spacing: 1px;
    text-transform: uppercase;
    background: #e8f5e9; color: #2e7d32;
    padding: 1px 5px; border-radius: 2px; margin-top: 2px;
}
[data-chso="details"] .chso-vpax { display: block; font-size: 10px; color: var(--cm); margin-top: 1px; }

[data-chso="details"] .chso-vtick {
    position: absolute;
    top: 5px; right: 5px;
    width: 20px; height: 20px;
    border-radius: 50%;
    background: var(--ca);
    display: flex !important;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: scale(.5);
    transition: opacity var(--ct), transform var(--ct);
}
[data-chso="details"] .chso-vchk:checked + .chso-vcard-inner .chso-vtick { opacity: 1; transform: scale(1); }

/* ── Submit (span — immune to theme button styles) */
[data-chso="details"] .chso-submit-wrap { margin-top: 6px; display: block; }

[data-chso="details"] .chso-submit {
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 13px 20px;
    background: var(--cp);
    color: #fff;
    border-radius: var(--cr);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    cursor: pointer;
    user-select: none;
    -webkit-user-select: none;
    transition: background var(--ct), transform var(--ct);
}
[data-chso="details"] .chso-submit:hover { background: var(--ca); transform: translateY(-1px); }
[data-chso="details"] .chso-submit.chso-loading { opacity: .7; cursor: default; transform: none; }

[data-chso="details"] .chso-spinner {
    display: none;
    width: 14px; height: 14px;
    border: 2px solid rgba(255,255,255,.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: chso-spin .7s linear infinite;
}
[data-chso="details"] .chso-submit.chso-loading .chso-spinner { display: block; }
@keyframes chso-spin { to { transform: rotate(360deg); } }

[data-chso="details"] .chso-ferr {
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: var(--cr);
    padding: 9px 13px;
    font-size: 12px;
    color: #c0392b;
    margin-bottom: 14px;
    display: block;
}
[data-chso="details"] .chso-success {
    background: #f0f9f0;
    border: 1px solid #4caf50;
    border-radius: var(--cr);
    padding: 14px 18px;
    font-size: 13px;
    color: #2d6a2d;
    margin-bottom: 18px;
    line-height: 1.6;
    display: block;
}
