/* SVOT Booking Page styles.
 * Uses the same visual language as the rest of the public site (svot-shell,
 * svot-btn, etc). Brand colors: SOT Ocean #0A4D6E + Forest #1F5A36.
 */

.svot-booking {
    max-width: 1100px;
    margin: 0 auto;
    padding: 24px 16px 60px;
    color: #1d2327;
}

.svot-booking__head { margin-bottom: 24px; }
.svot-booking__back {
    display: inline-block;
    color: #0a4d6e;
    text-decoration: none;
    font-size: 14px;
    margin-bottom: 6px;
}
.svot-booking__back:hover { text-decoration: underline; }
.svot-booking__title {
    font-size: 28px;
    font-weight: 700;
    margin: 0;
    line-height: 1.2;
}

.svot-booking__layout {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 32px;
    align-items: start;
}
@media (max-width: 760px) {
    .svot-booking__layout { grid-template-columns: 1fr; gap: 20px; }
}

/* Left summary */
.svot-booking__summary {
    background: #fff;
    border: 1px solid #e1e3e5;
    border-radius: 10px;
    padding: 20px;
    position: sticky;
    top: 20px;
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
}
@media (max-width: 760px) {
    .svot-booking__summary { position: static; }
}
.svot-booking__provider {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    margin-bottom: 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid #f0f0f1;
}
.svot-booking__provider-logo {
    width: 56px;
    height: 56px;
    border-radius: 8px;
    object-fit: cover;
    flex-shrink: 0;
}
.svot-booking__provider-name {
    font-weight: 700;
    font-size: 16px;
    line-height: 1.2;
}
.svot-booking__provider-trades { font-size: 12px; color: #646970; margin-top: 2px; }
.svot-booking__provider-loc    { font-size: 12px; color: #646970; margin-top: 4px; }
.svot-booking__provider-rating { font-size: 12px; color: #1f5a36; margin-top: 4px; font-weight: 600; }

.svot-booking__service {
    margin-bottom: 16px;
}
.svot-booking__service-title { font-weight: 600; font-size: 15px; }
.svot-booking__service-price {
    color: #0a4d6e; font-weight: 700; font-size: 16px; margin-top: 4px;
}
.svot-booking__service-duration { font-size: 12px; color: #646970; margin-top: 4px; }
.svot-booking__service-desc { font-size: 13px; color: #50575e; margin-top: 8px; line-height: 1.5; }

.svot-booking__trust {
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 8px;
    padding: 10px 14px;
    font-size: 12px;
    color: #166534;
    margin-top: 12px;
}
.svot-booking__trust p { margin: 0; }

/* Main flow */
.svot-booking__main {
    background: #fff;
    border: 1px solid #e1e3e5;
    border-radius: 10px;
    padding: 24px;
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
}

.svot-booking__step--hidden { display: none; }
.svot-booking__step-title {
    font-size: 18px;
    font-weight: 700;
    margin: 0 0 6px;
    color: #1d2327;
}
.svot-booking__step-help {
    color: #646970;
    font-size: 13px;
    margin: 0 0 18px;
}

/* Slot picker */
.svot-booking__slots-loading {
    padding: 30px 0;
    text-align: center;
    color: #646970;
    font-style: italic;
}
.svot-booking__day {
    margin-bottom: 14px;
    padding-bottom: 14px;
    border-bottom: 1px solid #f0f0f1;
}
.svot-booking__day:last-child { border-bottom: 0; }
.svot-booking__day-label {
    font-size: 13px;
    font-weight: 700;
    color: #1d2327;
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.svot-booking__day-slots {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.svot-booking__slot {
    background: #fff;
    border: 1.5px solid #d0d7de;
    border-radius: 6px;
    padding: 8px 14px;
    font-size: 13px;
    font-weight: 600;
    color: #0a4d6e;
    cursor: pointer;
    transition: background .12s, border-color .12s, color .12s;
    min-width: 76px;
    text-align: center;
}
.svot-booking__slot:hover {
    background: #0a4d6e;
    border-color: #0a4d6e;
    color: #fff;
}
.svot-booking__slot:focus {
    outline: 2px solid #0a4d6e;
    outline-offset: 2px;
}
.svot-booking__no-slots {
    padding: 24px;
    background: #fef9c3;
    border: 1px solid #fde047;
    border-radius: 8px;
    color: #713f12;
    font-size: 13px;
    text-align: center;
}

/* Customer form */
.svot-booking__chosen {
    background: #f0f6fc;
    border: 1px solid #c3d4e4;
    border-radius: 8px;
    padding: 12px 14px;
    margin-bottom: 18px;
}
.svot-booking__chosen-label {
    font-weight: 700;
    color: #0a4d6e;
    font-size: 14px;
}

.svot-booking__form { display: grid; gap: 14px; }
.svot-booking__label { display: block; }
.svot-booking__label > span {
    display: block;
    font-size: 12px;
    font-weight: 600;
    color: #646970;
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.svot-booking__form input,
.svot-booking__form textarea {
    width: 100%;
    padding: 10px 12px;
    font-size: 14px;
    border: 1.5px solid #d0d7de;
    border-radius: 6px;
    background: #fff;
    color: #1d2327;
    box-sizing: border-box;
    font-family: inherit;
}
.svot-booking__form input:focus,
.svot-booking__form textarea:focus {
    outline: none;
    border-color: #0a4d6e;
    box-shadow: 0 0 0 3px rgba(10,77,110,.15);
}
.svot-booking__form textarea { resize: vertical; min-height: 80px; }

.svot-booking__actions {
    display: flex;
    gap: 10px;
    justify-content: space-between;
    margin-top: 4px;
    flex-wrap: wrap;
}
.svot-booking__error-msg {
    color: #a40000;
    font-size: 13px;
    font-weight: 600;
    margin: 8px 0 0;
    min-height: 1em;
}

/* Buttons (fall-back if theme doesn't define .svot-btn) */
.svot-btn {
    display: inline-block;
    padding: 10px 18px;
    background: #fff;
    border: 1.5px solid #d0d7de;
    border-radius: 6px;
    color: #0a4d6e;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    font-size: 14px;
    transition: background .12s, border-color .12s, color .12s;
    font-family: inherit;
}
.svot-btn:hover { background: #f0f6fc; border-color: #0a4d6e; }
.svot-btn:disabled { opacity: .5; cursor: not-allowed; }
.svot-btn--primary {
    background: #0a4d6e;
    border-color: #0a4d6e;
    color: #fff;
}
.svot-btn--primary:hover { background: #1f5a36; border-color: #1f5a36; }

/* Success */
.svot-booking__success {
    text-align: center;
    padding: 30px 20px;
}
.svot-booking__success-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 18px;
    background: #f0fdf4;
    border: 3px solid #1f5a36;
    color: #1f5a36;
    border-radius: 50%;
    font-size: 44px;
    font-weight: 700;
    line-height: 80px;
}
.svot-booking__success h2 {
    color: #1f5a36;
    margin: 0 0 12px;
}
.svot-booking__success p {
    color: #50575e;
    margin: 8px 0;
}

.svot-booking__error {
    text-align: center;
    padding: 60px 20px;
    color: #50575e;
}
.svot-booking__error h1,
.svot-booking__error h2 {
    color: #1d2327;
    margin: 0 0 12px;
}

/* Customer portal card layout */
.svot-portal {
    max-width: 720px;
    margin: 0 auto;
}
.svot-portal__card {
    background: #fff;
    border: 1px solid #e1e3e5;
    border-radius: 10px;
    padding: 20px 24px;
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
}
.svot-portal__merchant img { flex-shrink: 0; }
.svot-portal__actions { margin: 8px 0; }
.svot-portal__reschedule {
    margin-top: 14px;
    padding: 12px 14px;
    background: #f6f7f7;
    border-radius: 8px;
}
.svot-portal__reschedule summary {
    cursor: pointer;
    font-weight: 600;
    color: #0a4d6e;
    padding: 4px 0;
}
.svot-portal__reschedule[open] summary { margin-bottom: 8px; }

/* Photo uploader on booking form */
.svot-booking__photos {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.svot-booking__photos-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.svot-booking__photos-grid:empty {
    display: none;
}
.svot-booking__photo-item {
    position: relative;
    width: 88px;
    height: 88px;
    margin: 0;
    border: 1.5px solid #d0d7de;
    border-radius: 8px;
    overflow: hidden;
    background: #f6f7f7;
    flex: 0 0 88px;
}
.svot-booking__photo-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.svot-booking__photo-item.is-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #646970;
    font-size: 24px;
    background: #f6f7f7;
}
.svot-booking__photo-remove {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: rgba(0, 0, 0, .65);
    color: #fff;
    border: none;
    font-size: 14px;
    line-height: 1;
    cursor: pointer;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: inherit;
    transition: background .12s;
}
.svot-booking__photo-remove:hover {
    background: #a40000;
}
.svot-booking__photo-add {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 88px;
    height: 88px;
    border: 1.5px dashed #c0c5cb;
    border-radius: 8px;
    background: #fafafa;
    color: #0a4d6e;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: background .12s, border-color .12s;
    flex: 0 0 88px;
    text-align: center;
}
.svot-booking__photo-add:hover {
    background: #f0f6fc;
    border-color: #0a4d6e;
}
.svot-booking__photo-add input[type=file] {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    clip: rect(0 0 0 0);
}
.svot-booking__photo-add.is-disabled {
    opacity: .35;
    pointer-events: none;
}
.svot-booking__photos-hint {
    font-size: 11px;
    color: #646970;
    margin: 4px 0 0;
}
.svot-booking__photos-error {
    font-size: 12px;
    color: #a40000;
    font-weight: 600;
    margin: 4px 0 0;
    min-height: 1em;
}

/* Review-page star picker */
.svot-review__stars {
    display: flex;
    gap: 6px;
    margin: 18px 0 6px;
    justify-content: center;
}
.svot-review__star {
    background: none;
    border: none;
    font-size: 36px;
    line-height: 1;
    cursor: pointer;
    color: #d0d7de;
    padding: 4px 6px;
    transition: color .12s, transform .12s;
    font-family: inherit;
}
.svot-review__star:hover,
.svot-review__star:focus {
    color: #f59e0b;
    transform: scale(1.1);
    outline: none;
}
.svot-review__star.is-active {
    color: #f59e0b;
}
