.iro-reservation-shell {
    padding-bottom: 56px;
}

#iro-app-container.iro-reservation-app {
    max-width: 1180px;
    margin: 12px auto 0;
    padding: 0 20px;
    box-sizing: border-box;
    color: #0f172a;
}

.iro-reservation-hero-subtitle {
    margin: 18px auto 0;
    max-width: 720px;
    color: #dbeafe;
    font: 500 16px/1.7 Inter, Arial, sans-serif;
    text-align: center;
    text-wrap: balance;
}

.iro-reservation-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(280px, 0.8fr);
    gap: 20px;
    margin-top: 22px;
}

.iro-reservation-card {
    border-radius: 24px;
    border: 1px solid rgba(148, 163, 184, 0.22);
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.08);
    padding: 28px;
}

.iro-reservation-shell.is-submitted .iro-reservation-form,
.iro-reservation-shell.is-submitted .iro-reservation-card--info {
    display: none;
}

.iro-reservation-form {
    display: grid;
    gap: 20px;
}

.iro-reservation-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.iro-reservation-field {
    display: grid;
    gap: 8px;
    font: 600 14px/1.4 Inter, Arial, sans-serif;
    color: #1e293b;
}

.iro-reservation-field--full {
    grid-column: 1 / -1;
}

.iro-reservation-field input,
.iro-reservation-field select,
.iro-reservation-field textarea {
    width: 100%;
    border-radius: 14px;
    border: 1px solid #dbe2ea;
    background: #ffffff;
    padding: 14px 16px;
    color: #0f172a;
    font: 500 15px/1.5 Inter, Arial, sans-serif;
    box-sizing: border-box;
    transition: border-color 0.16s ease, box-shadow 0.16s ease, background 0.16s ease;
}

.iro-reservation-field input:focus,
.iro-reservation-field select:focus,
.iro-reservation-field textarea:focus {
    outline: none;
    border-color: color-mix(in srgb, var(--iro-gemini-c2, #ff7207) 55%, #ffffff);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--iro-gemini-c2, #ff7207) 18%, transparent);
}

.iro-reservation-field textarea {
    resize: vertical;
    min-height: 110px;
}

.iro-reservation-slots {
    display: grid;
    gap: 14px;
    padding: 18px;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.92));
    border: 1px solid #e2e8f0;
}

.iro-reservation-slots__head {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
    align-items: baseline;
    justify-content: space-between;
}

.iro-reservation-slots__head span {
    font: 500 13px/1.5 Inter, Arial, sans-serif;
    color: #64748b;
}

.iro-reservation-slots__grid {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.iro-reservation-slot {
    border: 1px solid #dbe2ea;
    background: #ffffff;
    color: #0f172a;
    border-radius: 999px;
    padding: 10px 14px;
    font: 600 14px/1 Inter, Arial, sans-serif;
    cursor: pointer;
    transition: transform 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.iro-reservation-slot:hover {
    transform: translateY(-1px);
    border-color: var(--iro-gemini-c3, #ff28b4);
}

.iro-reservation-slot.is-selected {
    border-color: transparent;
    background: linear-gradient(-45deg, var(--iro-gemini-c1, #e81212), var(--iro-gemini-c2, #ff7207), var(--iro-gemini-c3, #ff28b4), var(--iro-gemini-c2, #ff7207));
    background-size: 400% 400%;
    animation: iroReservationGradient 15s ease infinite;
    color: #ffffff;
    box-shadow: 0 16px 30px rgba(15, 23, 42, 0.18);
}

.iro-reservation-slot.is-empty {
    cursor: default;
    border-style: dashed;
    color: #64748b;
}

.iro-reservation-message {
    border-radius: 16px;
    padding: 14px 16px;
    font: 600 14px/1.5 Inter, Arial, sans-serif;
}

.iro-reservation-message--error {
    background: #fff1f2;
    color: #b91c1c;
    border: 1px solid #fecdd3;
}

.iro-reservation-message--success {
    background: #ecfdf5;
    color: #047857;
    border: 1px solid #bbf7d0;
}

.iro-reservation-actions {
    display: flex;
    justify-content: flex-end;
}

.iro-reservation-submit {
    border: 0;
    border-radius: 999px;
    padding: 14px 24px;
    background: linear-gradient(-45deg, var(--iro-gemini-c1, #e81212), var(--iro-gemini-c2, #ff7207), var(--iro-gemini-c3, #ff28b4), var(--iro-gemini-c2, #ff7207));
    background-size: 400% 400%;
    animation: iroReservationGradient 15s ease infinite;
    color: #ffffff;
    font: 700 15px/1 Inter, Arial, sans-serif;
    cursor: pointer;
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.18);
}

.iro-reservation-submit[disabled] {
    opacity: 0.7;
    cursor: wait;
}

.iro-reservation-card--info h2 {
    margin: 0 0 12px;
    font: 700 1.2rem/1.2 Outfit, Inter, Arial, sans-serif;
}

.iro-reservation-info-list {
    margin: 0;
    padding-left: 18px;
    display: grid;
    gap: 10px;
    color: #334155;
    font: 500 14px/1.6 Inter, Arial, sans-serif;
}

@keyframes iroReservationGradient {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

html[data-lp-color-scheme="dark"] #iro-app-container.iro-reservation-app {
    color: #f8fafc;
}

html[data-lp-color-scheme="dark"] .iro-reservation-hero-subtitle {
    color: #cbd5e1;
}

html[data-lp-color-scheme="dark"] .iro-reservation-card {
    background: rgba(15, 23, 42, 0.88);
    border-color: rgba(71, 85, 105, 0.56);
    box-shadow: none;
}

html[data-lp-color-scheme="dark"] .iro-reservation-field {
    color: #e2e8f0;
}

html[data-lp-color-scheme="dark"] .iro-reservation-field input,
html[data-lp-color-scheme="dark"] .iro-reservation-field select,
html[data-lp-color-scheme="dark"] .iro-reservation-field textarea {
    background: #0f172a;
    border-color: #334155;
    color: #f8fafc;
}

html[data-lp-color-scheme="dark"] .iro-reservation-slots {
    background: linear-gradient(180deg, rgba(15,23,42,0.94), rgba(30,41,59,0.86));
    border-color: #334155;
}

html[data-lp-color-scheme="dark"] .iro-reservation-slots__head span,
html[data-lp-color-scheme="dark"] .iro-reservation-info-list {
    color: #94a3b8;
}

html[data-lp-color-scheme="dark"] .iro-reservation-slot {
    background: #0f172a;
    border-color: #334155;
    color: #f8fafc;
}

html[data-lp-color-scheme="dark"] .iro-reservation-slot.is-empty {
    color: #94a3b8;
}

@media (max-width: 920px) {
    .iro-reservation-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 680px) {
    #iro-app-container.iro-reservation-app {
        padding: 0 14px;
    }

    .iro-reservation-card {
        padding: 22px 18px;
        border-radius: 22px;
    }

    .iro-reservation-grid {
        grid-template-columns: 1fr;
    }

    .iro-reservation-actions {
        justify-content: stretch;
    }

    .iro-reservation-submit {
        width: 100%;
    }
}
