/* ── Rumeny Painting — Booking Widget Styles ── */
/* Drop these into the main site or load as a standalone stylesheet */

.booking-form {
    max-width: 640px;
}

.form-section {
    margin-bottom: 32px;
}

.form-section-title {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--color-text, #1a1a1a);
    margin-bottom: 16px;
}

.form-hint {
    font-size: 0.85rem;
    color: var(--color-text-muted, #888);
    margin-bottom: 16px;
}

.form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.form-group.full-width {
    grid-column: 1 / -1;
}

.form-group label {
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--color-text-muted, #888);
}

.form-group .optional {
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
}

.form-group input,
.form-group select,
.form-group textarea {
    padding: 12px 16px;
    border: 1px solid var(--color-border, #d0d0d0);
    border-radius: 8px;
    font-size: 1rem;
    font-family: 'DM Sans', -apple-system, sans-serif;
    color: var(--color-text, #1a1a1a);
    background: var(--color-surface, #fff);
    transition: border-color 0.2s;
}

/* Fix select dropdown — remove browser default arrow artifacts */
.form-group select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239c9690' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    background-size: 16px;
    padding-right: 40px;
    cursor: pointer;
}

/* Fix date input — make calendar icon visible and clickable */
.form-group input[type="date"] {
    cursor: pointer;
    position: relative;
}
.form-group input[type="date"]::-webkit-calendar-picker-indicator {
    cursor: pointer;
    opacity: 0;
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
}
/* Custom calendar icon overlay — centered vertically within the input */
.date-input-wrapper {
    position: relative;
}
.date-input-wrapper input,
.date-input-wrapper .flatpickr-input[type="hidden"] + input {
    width: 100%;
    padding-right: 44px;
}
.date-input-wrapper::after {
    content: '';
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%239c9690' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: contain;
    pointer-events: none;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--color-gold, #c9a86c);
}

.form-group textarea {
    resize: vertical;
}

/* ── Time Slots ── */

.slots-none {
    padding: 20px;
    text-align: center;
    color: #c62828;
    background: #fef2f2;
    border-radius: 8px;
    font-size: 0.9rem;
}

/* ── Submit Button ── */
.booking-submit {
    width: 100%;
    max-width: 640px;
    padding: 16px 32px;
    background: var(--color-gold, #c9a86c);
    color: white;
    border: none;
    border-radius: 8px;
    font-size: 1rem;
    font-weight: 600;
    font-family: 'DM Sans', -apple-system, sans-serif;
    cursor: pointer;
    transition: background 0.2s, opacity 0.2s;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.booking-submit:hover:not(:disabled) {
    background: var(--color-gold-dark, #b8974f);
}

.booking-submit:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* ── Success State ── */
.booking-success {
    text-align: center;
    padding: 48px 24px;
    max-width: 640px;
    margin: 0 auto;
}

.success-icon {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: #065f46;
    color: white;
    font-size: 28px;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
}

.booking-success h3 {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 1.6rem;
    color: var(--color-text, #1a1a1a);
    margin-bottom: 8px;
}

.booking-success p {
    color: var(--color-text-muted, #888);
    font-size: 1rem;
    line-height: 1.6;
}

/* ── ZIP / Field Errors ── */
.field-error {
    font-size: 0.8rem;
    color: #c62828;
    margin-top: 4px;
}

.zip-note {
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
    color: var(--color-text-muted, #888);
    font-size: 0.75rem;
}

.field-hint {
    font-size: 0.78rem;
    color: var(--color-text-faint, #aaa);
    margin-top: 4px;
}

.form-errors {
    background: #fef2f2;
    color: #b03a3a;
    padding: 12px 16px;
    border-radius: 8px;
    font-size: 0.9rem;
    margin-bottom: 16px;
    line-height: 1.5;
}

/* ── Address Autocomplete Dropdown ── */
.ac-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    font-family: 'DM Sans', -apple-system, sans-serif;
    border: 1px solid var(--color-border, #d0d0d0);
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
    margin-top: 4px;
    background: var(--color-surface, #fff);
    z-index: 10000;
    max-height: 280px;
    overflow-y: auto;
}
.ac-item {
    padding: 12px 16px;
    cursor: pointer;
    border-top: 1px solid var(--color-divider, #e5e5e5);
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.ac-item:first-child {
    border-top: none;
}
.ac-item:hover,
.ac-item--active {
    background: var(--color-surface-offset, #f0f0f0);
}
.ac-item-main {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text, #1a1a1a);
    line-height: 1.4;
}
.ac-item-secondary {
    font-size: 13px;
    color: var(--color-text-muted, #888);
    line-height: 1.3;
}

/* ── Custom Flatpickr Calendar Styles ── */
.flatpickr-calendar {
    font-family: 'DM Sans', -apple-system, sans-serif !important;
    border: 1px solid var(--color-border, #d0d0d0) !important;
    border-radius: 12px !important;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15) !important;
    width: 340px !important;
    padding: 8px !important;
    background: var(--color-surface, #fff) !important;
    z-index: 9999 !important;
}
.flatpickr-months {
    padding: 8px 4px !important;
}
.flatpickr-months .flatpickr-month {
    height: 40px !important;
}
.flatpickr-current-month {
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--color-text, #1a1a1a) !important;
}
.flatpickr-current-month .numInputWrapper {
    width: 70px !important;
}
.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month {
    padding: 8px !important;
    fill: var(--color-text-muted, #888) !important;
}
.flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-months .flatpickr-next-month:hover svg {
    fill: var(--color-accent, #c9a86c) !important;
}
span.flatpickr-weekday {
    font-size: 12px !important;
    font-weight: 600 !important;
    color: var(--color-text-muted, #888) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}
.flatpickr-day {
    border-radius: 8px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    height: 40px !important;
    line-height: 40px !important;
    color: var(--color-text, #1a1a1a) !important;
    max-width: 42px !important;
}
.flatpickr-day:hover {
    background: var(--color-surface-offset, #f0f0f0) !important;
    border-color: transparent !important;
}
.flatpickr-day.selected {
    background: var(--color-accent, #c9a86c) !important;
    border-color: var(--color-accent, #c9a86c) !important;
    color: white !important;
}
.flatpickr-day.selected:hover {
    background: var(--color-accent-hover, #b8944f) !important;
}
.flatpickr-day.today {
    border-color: var(--color-accent, #c9a86c) !important;
}
.flatpickr-day.today:not(.selected) {
    color: var(--color-accent, #c9a86c) !important;
}
.flatpickr-day.flatpickr-disabled {
    color: var(--color-text-faint, #a09a93) !important;
    opacity: 0.4 !important;
}
.flatpickr-innerContainer {
    padding-bottom: 4px !important;
}

/* ── Responsive ── */
@media (max-width: 640px) {
    .form-grid {
        grid-template-columns: 1fr;
    }

    .flatpickr-calendar {
        width: min(300px, 90vw) !important;
    }
    .flatpickr-day {
        height: 44px !important;
        line-height: 44px !important;
        -webkit-tap-highlight-color: transparent;
    }

    .form-section { margin-bottom: 24px; }
    .form-section-title { font-size: 1.25rem; margin-bottom: 12px; }
    .booking-submit { padding: 14px 24px; }
    .booking-success { padding: 32px 16px; }
}

@media (max-width: 480px) {
    .form-group input,
    .form-group select,
    .form-group textarea {
        padding: 12px 14px;
        font-size: 16px; /* prevents iOS zoom on focus */
    }
    .form-grid { gap: 12px; }
    .form-section { margin-bottom: 20px; }
    .form-section-title { font-size: 1.15rem; }
    .form-hint { font-size: 0.875rem; }
    .booking-submit { padding: 14px 20px; font-size: 0.9rem; }
    .booking-success h3 { font-size: 1.35rem; }

    .flatpickr-calendar {
        width: min(280px, 92vw) !important;
        padding: 6px !important;
    }

    .ac-item { padding: 10px 14px; }
    .ac-item-main { font-size: 14px; }
    .ac-item-secondary { font-size: 12px; }
}
