/* Availability search */
.availability-search {
    width: 100%;
    position: relative;
    z-index: 8;
}

.availability-search__shell {
    position: relative;
    width: min(100%, 1120px);
    margin: 0 auto;
}

.availability-search__form {
    display: grid;
    grid-template-columns: minmax(150px, 1fr) minmax(150px, 1fr) minmax(130px, 0.8fr) auto;
    align-items: center;
    background: #fff;
    border: 1px solid rgba(17, 24, 39, 0.08);
    border-radius: var(--radius-control) !important;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.12);
    overflow: visible;
    text-align: left;
    padding: 0.5rem;
}

.availability-search__item {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    padding: 0 1.5rem;
    border-right: 1px solid rgba(17, 24, 39, 0.1);
    text-align: left;
}

.availability-search__item--guests {
    position: relative;
    border-right: 0;
}

.availability-search__item--date {
    padding-left: 30px;
    justify-content: center;
}

.availability-search__label {
    color: var(--dahu-style-text, #222);
    font-size: var(--type-ui-label);
    font-weight: 800;
    letter-spacing: 0.02em;
    line-height: 1.15;
}

.availability-search input {
    width: 100%;
    min-width: 0;
    border: 0;
    outline: 0;
    background: transparent;
    color: var(--dahu-style-muted, #717171);
    font-size: var(--type-body-md);
    line-height: 1.25;
}

.availability-search input::-webkit-calendar-picker-indicator {
    opacity: 0.62;
    cursor: pointer;
}

.availability-search__trigger {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: 1.6rem;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--dahu-style-text, #222);
    cursor: pointer;
    text-align: left;
}

.availability-search__value {
    display: block;
    flex: 1 1 auto;
    min-width: 0;
    color: var(--dahu-style-muted, #717171);
    font-size: var(--type-body-md);
    line-height: 1.2;
}

.availability-search__value.is-filled {
    color: var(--dahu-style-text, #222);
    font-weight: 700;
    font-size: var(--type-body-lg);
}

.availability-search__trigger-icon {
    flex: 0 0 auto;
    margin-left: auto;
    color: var(--dahu-style-muted, #717171);
}

.availability-search__picker-input {
    position: absolute;
    top: 1px;
    left: 1px;
    width: 1px;
    height: 1px;
    padding: 0;
    border: 0;
    opacity: 0;
    pointer-events: none;
    overflow: hidden;
}

.availability-search__actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
}

.availability-search__error {
    margin: 0.75rem 1.5rem 0;
    color: var(--color-error, #c0392b);
    font-size: var(--type-body-md);
    font-weight: 700;
    text-align: left;
}

.availability-search__mobile-launch,
.availability-search__guests-trigger-mobile,
.availability-search__mobile-sheet {
    display: none;
}

.availability-search__guests-input-desktop {
    display: none;
}

.availability-search__guests-trigger-desktop {
    min-height: 2rem;
}

.availability-search__desktop-guests-panel {
    position: absolute;
    top: calc(100% + 1rem);
    right: 0;
    z-index: 20;
    width: min(420px, 92vw);
    padding: 1.35rem;
    border: 1px solid rgba(34, 34, 34, 0.12);
    border-radius: var(--radius-control);
    background: #fff;
    box-shadow: 0 24px 52px rgba(15, 23, 42, 0.14);
}

.availability-search__desktop-guests-panel-header h4 {
    margin: 0;
    font-size: var(--type-booking-title);
    font-weight: 850;
    line-height: 1.05;
}

.availability-search__desktop-guests-panel-header p {
    margin: 0.4rem 0 0;
    color: var(--dahu-style-muted, #717171);
    font-size: var(--type-body-md);
}

.availability-search__desktop-guests-panel-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.9rem;
    margin-top: 1.25rem;
}

.availability-search__desktop-guests-panel .availability-search__guest-rows {
    margin-top: 0.9rem;
}

.availability-search__mobile-link {
    border: 0;
    background: transparent;
    color: var(--dahu-style-text, #222);
    font-size: var(--type-body-md);
    font-weight: 800;
    text-decoration: underline;
}

.availability-search__mobile-apply {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    min-height: 48px;
    padding: 0 1.2rem;
    border: 0;
    border-radius: var(--radius-control) !important;
    background: var(--dahu-style-primary, #ff385c);
    color: #fff;
    font-size: var(--type-body-md);
    font-weight: 800;
    white-space: nowrap;
}

.availability-search__guest-rows {
    margin-top: 0.8rem;
}

.availability-search__guest-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.2rem 0;
    border-bottom: 1px solid rgba(34, 34, 34, 0.08);
}

.availability-search__guest-row:last-child {
    border-bottom: 0;
}

.availability-search__guest-copy strong {
    display: block;
    margin-bottom: 0.15rem;
    color: var(--dahu-style-text, #222);
    font-size: var(--type-body-md);
    font-weight: 800;
}

.availability-search__guest-copy span,
.availability-search__guest-copy a {
    color: var(--dahu-style-muted, #717171);
    font-size: var(--type-card-copy);
}

.availability-search__guest-controls {
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.availability-search__guest-stepper {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border: 1px solid rgba(34, 34, 34, 0.16);
    border-radius: var(--radius-control) !important;
    background: #fff;
    color: var(--dahu-style-text, #222);
    font-size: var(--type-section-subtitle);
    line-height: 1;
}

.availability-search__guest-stepper:disabled {
    opacity: 0.32;
}

.availability-search__guest-count {
    min-width: 1.25rem;
    color: var(--dahu-style-text, #222);
    font-size: var(--type-body-lg);
    font-weight: 700;
    text-align: center;
}

.availability-search__mobile-card-value.is-filled {
    color: var(--dahu-style-text, #222);
}

.availability-search--hero {
    margin-top: clamp(1.75rem, 4vw, 3rem);
}

.availability-search--hero .availability-search__shell {
    width: min(100%, 1060px);
}

.availability-search__intro {
    display: grid;
    justify-items: center;
    gap: 0.7rem;
    max-width: 780px;
    margin: 0 auto clamp(2.5rem, 5vw, 4.25rem);
    color: var(--color-text);
    text-align: center;
}

.availability-search__intro-eyebrow {
    color: var(--color-secondary);
    font-size: var(--type-ui-label);
    font-weight: 800;
    letter-spacing: 0.12em;
    line-height: 1.2;
    text-transform: uppercase;
}

.availability-search__intro-title {
    max-width: 760px;
    margin: 0;
    color: var(--color-text);
    font-family: var(--font-heading);
    font-size: clamp(2.7rem, 5vw, 5.25rem);
    font-weight: 400;
    letter-spacing: 0;
    line-height: 0.95;
    text-wrap: balance;
}

.availability-search__intro-text {
    max-width: 620px;
    margin: 0;
    color: var(--color-text-light);
    font-size: var(--type-body-md);
    line-height: var(--leading-body);
}

.availability-search__trust {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.55rem;
    margin: 0.25rem 0 0;
}

.availability-search__trust li {
    display: inline-flex;
    align-items: center;
    gap: 0.42rem;
    min-height: 2rem;
    padding: 0.38rem 0.7rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 76%, #fff);
    border-radius: var(--radius-sm);
    background: rgba(255, 255, 255, 0.58);
    color: var(--color-text);
    font-size: 0.78rem;
    font-weight: 800;
    line-height: 1.2;
}

.availability-search__trust li::before {
    content: '';
    width: 0.42rem;
    height: 0.42rem;
    border-radius: 2px;
    background: var(--color-accent);
}

.availability-search--archive {
    --archive-booking-ink: var(--color-primary);
    --archive-booking-accent: var(--color-secondary);
    --archive-booking-muted: var(--color-text-light);
    --archive-booking-line: var(--color-border);
    --archive-booking-paper: #fffdfa;
    --archive-booking-soft: rgba(240, 237, 230, 0.78);
    --archive-booking-range: color-mix(in srgb, var(--archive-booking-accent) 16%, #fff);
    margin-top: 0;
    padding: 0 clamp(1.25rem, 5vw, 5rem) 0;
}

.availability-search--archive .availability-search__shell {
    width: min(100%, var(--container-max));
}

.availability-search--archive .availability-search__intro {
    max-width: 860px;
}

.availability-search--archive .availability-search__trust {
    margin-top: 0.45rem;
}

.availability-search--archive .availability-search__form {
    grid-template-columns: minmax(170px, 1fr) minmax(170px, 1fr) minmax(170px, 1fr) 76px;
    min-height: 86px;
    padding: 0;
    border: 1px solid color-mix(in srgb, var(--color-border) 74%, var(--color-secondary));
    border-radius: var(--radius-md) !important;
    background: color-mix(in srgb, var(--color-white) 96%, #ffffff);
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.08);
}

.availability-search--archive .availability-search__item {
    min-height: 86px;
    justify-content: center;
    gap: 0.45rem;
    padding: 1rem clamp(1.1rem, 2vw, 1.75rem);
    border-right-color: color-mix(in srgb, var(--color-border) 78%, var(--color-secondary));
}

.availability-search--archive .availability-search__item--date {
    padding-left: clamp(1.1rem, 2vw, 1.75rem);
}

.availability-search--archive .availability-search__label {
    color: var(--color-text);
    font-size: 0.82rem;
    font-weight: 500;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.availability-search--archive .availability-search__trigger {
    gap: 0.35rem 0.8rem;
    min-height: 2.25rem;
}

.availability-search--archive .availability-search__value {
    color: var(--color-text-light);
    font-size: 0.9rem;
    font-weight: 400;
    letter-spacing: 0;
}

.availability-search--archive .availability-search__value.is-filled {
    color: var(--color-text);
    font-size: 0.95rem;
    font-weight: 600;
}

.availability-search--archive .availability-search__trigger-icon {
    width: 22px;
    height: 22px;
    color: var(--color-secondary);
    stroke-width: 1.9;
}

.availability-search--archive .availability-search__actions {
    align-self: stretch;
    padding: 0.9rem 0.9rem 0.9rem 0;
}

.availability-search--archive .availability-search__submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    border-radius: var(--radius-sm) !important;
    background: var(--color-secondary);
    color: var(--color-white);
    transition: background-color 0.2s ease, transform 0.2s ease;
}

.availability-search--archive .availability-search__submit:hover,
.availability-search--archive .availability-search__submit:focus-visible {
    background: var(--color-white);
    color: var(--color-secondary);
    transform: translateY(-1px);
}

.availability-search--archive .availability-search__submit span {
    white-space: nowrap;
}

.availability-search--archive .availability-search__submit svg {
    width: 24px;
    height: 24px;
    stroke-width: 2.2;
}

.rooms-availability-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem 1.5rem;
    width: 100%;
    margin: 0 0 1.75rem;
}

.rooms-availability-summary__text {
    display: flex;
    flex-wrap: nowrap;
    align-items: baseline;
    flex: 1 1 560px;
    gap: 0.45rem 0.9rem;
    min-width: 0;
}

.rooms-availability-summary__text strong {
    color: var(--dahu-style-text, #222);
    font-size: var(--type-body-featured);
}

.rooms-availability-summary__text span {
    color: var(--dahu-style-muted, #717171);
    font-size: var(--type-body-md);
}

.rooms-availability-summary__reset {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 1.1rem;
    border: 1px solid var(--color-primary);
    border-radius: 2px;
    background: transparent;
    color: var(--color-primary);
    font-size: var(--type-body-md);
    font-weight: 800;
    text-decoration: none;
    white-space: nowrap;
    flex: 0 0 auto;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.rooms-availability-summary__reset:hover,
.rooms-availability-summary__reset:focus-visible {
    border-color: var(--color-primary);
    background: color-mix(in srgb, var(--color-primary) 6%, transparent);
    color: var(--color-primary);
}

.availability-search .datepicker {
    position: absolute;
    top: calc(100% + 1rem);
    left: 50%;
    z-index: 35;
    width: min(960px, calc(100vw - 2rem));
    max-width: none;
    padding: 1.25rem;
    border: 1px solid var(--dahu-style-border, #ddd);
    border-radius: var(--radius-control);
    background: #fff;
    box-shadow: 0 28px 70px rgba(15, 23, 42, 0.18);
    transform: translateX(-50%);
    animation: none !important;
}

.availability-search .datepicker__months {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem 1.5rem;
}

.availability-search .datepicker__month {
    width: 100%;
}

.availability-search .datepicker__month-caption {
    margin-bottom: 1rem;
    color: var(--dahu-style-text, #222);
    font-size: var(--type-booking-title);
    font-weight: 800;
}

.availability-search .datepicker__month-button {
    width: 42px;
    height: 42px;
    border-radius: var(--radius-control);
    background: var(--dahu-style-surface, #f7f7f7);
    color: var(--dahu-style-text, #222);
}

.availability-search .datepicker__week-name {
    color: var(--dahu-style-muted, #717171);
    font-size: var(--type-ui-label);
    font-weight: 700;
    text-transform: capitalize;
}

.availability-search .datepicker__month-day {
    border-radius: var(--radius-control);
    font-weight: 600;
}

.availability-search .datepicker__month-day--first-day-selected,
.availability-search .datepicker__month-day--last-day-selected {
    background: var(--dahu-style-text, #222);
    color: #fff;
}

.availability-search .datepicker__month-day--selected,
.availability-search .datepicker__month-day--hovering {
    background: rgba(255, 56, 92, 0.12);
    color: var(--dahu-style-text, #222);
}

.availability-search .datepicker__month-day--selected .datepicker__day-price,
.availability-search .datepicker__month-day--hovering .datepicker__day-price {
    color: #fff;
}

.availability-search .datepicker__month-day--invalid,
.availability-search .datepicker__month-day--disabled {
    color: rgba(113, 113, 113, 0.4);
}

.availability-search .datepicker__month-day--today {
    color: var(--dahu-style-primary, #ff385c);
}

.availability-search .datepicker__info-text {
    color: var(--dahu-style-muted, #717171);
}

.availability-search--archive .availability-search__desktop-guests-panel {
    top: calc(100% + 0.9rem);
    width: min(440px, calc(100vw - 2rem));
    padding: 0;
    border: 1px solid color-mix(in srgb, var(--color-border) 74%, var(--color-secondary));
    border-radius: var(--radius-lg);
    background: #fff;
    box-shadow: 0 26px 70px rgba(0, 0, 0, 0.14);
    overflow: hidden;
}

.availability-search--archive .availability-search__desktop-guests-panel::before {
    content: '';
    position: absolute;
    top: -9px;
    right: 40px;
    width: 18px;
    height: 18px;
    border-top: 1px solid color-mix(in srgb, var(--color-border) 74%, var(--color-secondary));
    border-left: 1px solid color-mix(in srgb, var(--color-border) 74%, var(--color-secondary));
    background: color-mix(in srgb, var(--color-warm-cream) 86%, #fff);
    transform: rotate(45deg);
}

.availability-search--archive .availability-search__desktop-guests-panel-header {
    position: relative;
    padding: 1.35rem 1.45rem 1.1rem;
    background: color-mix(in srgb, var(--color-warm-cream) 86%, #fff);
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 78%, var(--color-secondary));
}

.availability-search--archive .availability-search__desktop-guests-panel-header h4 {
    color: var(--color-text);
    font-size: var(--type-section-subtitle);
    font-weight: 400;
    letter-spacing: 0;
}

.availability-search--archive .availability-search__desktop-guests-panel-header p {
    color: var(--color-text-light);
    font-size: 0.92rem;
    line-height: 1.45;
}

.availability-search--archive .availability-search__desktop-guests-panel .availability-search__guest-rows {
    margin-top: 0;
    padding: 0.1rem 1.45rem;
}

.availability-search--archive .availability-search__guest-row {
    padding: 1.05rem 0;
    border-bottom-color: color-mix(in srgb, var(--color-border) 82%, var(--color-secondary));
}

.availability-search--archive .availability-search__guest-copy strong {
    color: var(--color-text);
    font-size: 0.98rem;
    font-weight: 600;
}

.availability-search--archive .availability-search__guest-copy span,
.availability-search--archive .availability-search__guest-copy a {
    color: var(--color-text-light);
    font-size: 0.86rem;
}

.availability-search--archive .availability-search__guest-stepper {
    width: 36px;
    height: 36px;
    border-color: color-mix(in srgb, var(--color-border) 70%, var(--color-secondary));
    border-radius: var(--radius-sm) !important;
    color: var(--color-text);
    font-size: 1.15rem;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.availability-search--archive .availability-search__guest-stepper:hover:not(:disabled) {
    border-color: var(--color-secondary);
    background: var(--color-secondary);
    color: var(--color-white);
}

.availability-search--archive .availability-search__guest-count {
    color: var(--color-text);
    font-size: 1rem;
    font-weight: 600;
}

.availability-search--archive .availability-search__desktop-guests-panel-actions {
    margin-top: 0;
    padding: 1.05rem 1.45rem 1.25rem;
    border-top: 1px solid color-mix(in srgb, var(--color-border) 78%, var(--color-secondary));
    background: color-mix(in srgb, var(--color-warm-cream) 82%, #fff);
}

.availability-search--archive .availability-search__mobile-link {
    color: var(--color-secondary);
    font-size: 0.92rem;
    font-weight: 600;
    text-underline-offset: 4px;
}

.availability-search--archive .availability-search__mobile-apply {
    min-height: 44px;
    padding: 0 1.2rem;
    border-radius: var(--radius-sm) !important;
    background: var(--color-primary);
    font-size: 0.92rem;
    font-weight: 700;
    transition: background-color 0.2s ease;
}

.availability-search--archive .availability-search__mobile-apply:hover,
.availability-search--archive .availability-search__mobile-apply:focus-visible {
    background: var(--color-secondary);
}

.availability-search--archive .datepicker {
    top: calc(100% + 0.9rem);
    left: 0;
    width: 100%;
    min-width: 0;
    padding: 1.35rem clamp(1rem, 2vw, 1.55rem) 1.15rem;
    border: 1px solid var(--archive-booking-line);
    border-radius: 2px;
    background:
        radial-gradient(circle at top right, var(--archive-booking-soft) 0, rgba(240, 237, 230, 0) 34%),
        linear-gradient(180deg, var(--archive-booking-paper) 0%, #ffffff 100%);
    box-shadow: 0 24px 50px rgba(22, 30, 22, 0.08), 0 3px 10px rgba(22, 30, 22, 0.05);
    transform: none;
}

.availability-search--archive .datepicker__inner {
    display: grid;
    gap: 1rem;
}

.availability-search--archive .datepicker__months {
    gap: clamp(1rem, 2.5vw, 2rem);
}

.availability-search--archive .datepicker__month {
    padding: 0;
    border-collapse: collapse;
    border-spacing: 0;
    table-layout: fixed;
    overflow: hidden;
}

.availability-search--archive .datepicker__month-caption {
    margin-bottom: 0.9rem;
    padding-bottom: 0.8rem;
    border-bottom: 1px solid var(--archive-booking-line);
    color: var(--archive-booking-ink);
    font-family: var(--font-heading);
    font-size: clamp(1.05rem, 1.4vw, 1.35rem);
    font-weight: 700;
    letter-spacing: 0.01em;
    text-transform: uppercase;
}

.availability-search--archive .datepicker__month-button {
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 0;
    border-radius: var(--radius-control) !important;
    background: var(--dahu-style-surface, #f7f7f7);
    color: var(--archive-booking-ink);
    font-size: 0;
    font-weight: inherit;
    line-height: inherit;
    text-indent: 0;
    box-shadow: none;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.availability-search--archive .datepicker__month-button::before {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1;
}

.availability-search--archive .datepicker__month-button--prev::before {
    content: '<';
}

.availability-search--archive .datepicker__month-button--next::before {
    content: '>';
}

.availability-search--archive .datepicker__month-button:hover {
    background: var(--dahu-style-surface, #f7f7f7);
    color: var(--archive-booking-ink);
}

.availability-search--archive .datepicker__month-button:disabled,
.availability-search--archive .datepicker__month-button[disabled],
.availability-search--archive .datepicker__month-button--disabled {
    opacity: 0.38;
    cursor: not-allowed;
}

.availability-search--archive .datepicker__week-name {
    color: var(--archive-booking-muted);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.availability-search--archive .datepicker__month-day {
    min-width: 42px;
    height: 42px;
    border: 1px solid color-mix(in srgb, var(--archive-booking-line) 88%, #fff);
    border-radius: 0 !important;
    color: var(--archive-booking-ink);
    font-weight: 700;
    line-height: 42px;
    box-sizing: border-box;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.availability-search--archive .datepicker__month-day:hover:not(.datepicker__month-day--disabled):not(.datepicker__month-day--invalid):not([disabled]):not([aria-disabled="true"]) {
    background: color-mix(in srgb, var(--archive-booking-accent) 10%, #fff);
}

.availability-search--archive .datepicker__month-day--selected,
.availability-search--archive .datepicker__month-day--hovering {
    border-radius: 0 !important;
    background: var(--archive-booking-range);
    color: var(--archive-booking-ink);
    font-weight: 700;
}

.availability-search--archive .datepicker__month-day--first-day-selected,
.availability-search--archive .datepicker__month-day--last-day-selected,
.availability-search--archive .datepicker__month-day--first-day-selected.datepicker__month-day--selected,
.availability-search--archive .datepicker__month-day--last-day-selected.datepicker__month-day--selected,
.availability-search--archive .datepicker__month-day--first-day-selected.datepicker__month-day--hovering,
.availability-search--archive .datepicker__month-day--last-day-selected.datepicker__month-day--hovering {
    background: var(--archive-booking-accent) !important;
    color: var(--color-white) !important;
    font-weight: 800;
}

.availability-search--archive .datepicker__month-day--today {
    color: var(--archive-booking-accent);
}

.availability-search--archive .datepicker__month-day--invalid,
.availability-search--archive .datepicker__month-day--disabled {
    background: color-mix(in srgb, var(--archive-booking-paper) 94%, #fff);
    color: color-mix(in srgb, var(--archive-booking-muted) 78%, #fff);
    opacity: 0.42;
}

.availability-search--archive .datepicker__topbar,
.availability-search--archive .datepicker__buttons {
    border-color: var(--archive-booking-line);
}

.availability-search--archive .datepicker__info-text {
    color: var(--archive-booking-muted);
    font-size: 0.92rem;
    font-weight: 600;
}

.availability-search--archive .datepicker__clear-button,
.availability-search--archive .datepicker__close-button,
.availability-search--archive .datepicker__submit-button {
    border-radius: 4px !important;
    font-weight: 700;
}

.availability-search--archive .datepicker__submit-button {
    background: var(--archive-booking-accent);
    color: var(--color-white);
}

.availability-search__mobile-error {
    margin: 1rem 0 0;
    color: var(--color-error, #c0392b);
    font-size: var(--type-body-md);
    font-weight: 700;
}

.availability-search__mobile-sheet[hidden],
.availability-search__mobile-panel[hidden] {
    display: none !important;
}

@media (max-width: 900px) {
    .rooms-availability-summary {
        align-items: flex-start;
        flex-direction: column;
    }

    .rooms-availability-summary__text {
        flex-wrap: wrap;
    }

    .availability-search__form {
        display: none;
    }

    .availability-search__mobile-launch {
        position: fixed;
        right: 1rem;
        bottom: calc(1rem + env(safe-area-inset-bottom, 0px));
        z-index: 45;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 0.6rem;
        min-height: 56px;
        padding: 0 1.4rem;
        border: 0;
        border-radius: var(--radius-control) !important;
        background: var(--dahu-style-primary, #ff385c);
        color: #fff;
        box-shadow: 0 14px 34px rgba(255, 56, 92, 0.35);
        font-size: var(--type-body-md);
        font-weight: 800;
    }

    .availability-search--archive {
        padding: clamp(3rem, 12vw, 5rem) 1rem clamp(2.5rem, 10vw, 4rem);
    }

    .availability-search--archive .availability-search__intro {
        justify-items: start;
        margin-bottom: 1.75rem;
        text-align: left;
    }

    .availability-search--archive .availability-search__intro-title {
        font-size: clamp(1.75rem, 8vw, 2.35rem);
        line-height: 0.98;
        overflow-wrap: break-word;
    }

    .availability-search--archive .availability-search__intro-text {
        max-width: 32ch;
        font-size: 0.94rem;
    }

    .availability-search--archive .availability-search__trust {
        justify-content: flex-start;
    }

    .availability-search--archive .availability-search__mobile-launch {
        position: static;
        z-index: 1;
        justify-content: space-between;
        width: 100%;
        min-height: 64px;
        padding: 0 1.2rem;
        border: 1px solid color-mix(in srgb, var(--color-border) 74%, var(--color-secondary));
        border-radius: var(--radius-md) !important;
        background: #fff;
        color: var(--color-text);
        box-shadow: 0 18px 48px rgba(0, 0, 0, 0.1);
        font-weight: 700;
    }

    .availability-search--archive .availability-search__mobile-launch svg {
        color: var(--color-secondary);
    }

    .availability-search__mobile-sheet {
        position: fixed;
        inset: 0;
        z-index: 1300;
        display: block;
    }

    .availability-search__mobile-backdrop {
        position: absolute;
        inset: 0;
        background: rgba(15, 23, 42, 0.5);
        backdrop-filter: blur(6px);
    }

    .availability-search__mobile-dialog {
        position: relative;
        display: flex;
        flex-direction: column;
        width: 100%;
        height: 100%;
        padding: max(1rem, env(safe-area-inset-top, 0px)) 1rem max(1rem, env(safe-area-inset-bottom, 0px));
        background: #f7f7f2;
        overflow: auto;
    }

    .availability-search--archive .availability-search__mobile-backdrop {
        background: rgba(0, 0, 0, 0.48);
        backdrop-filter: blur(8px);
    }

    .availability-search--archive .availability-search__mobile-dialog {
        height: auto;
        max-height: calc(92dvh - env(safe-area-inset-bottom, 0px));
        margin-top: auto;
        padding: 1rem 1rem max(1rem, env(safe-area-inset-bottom, 0px));
        border: 1px solid color-mix(in srgb, var(--color-border) 74%, var(--color-secondary));
        border-bottom: 0;
        border-radius: var(--radius-lg) var(--radius-lg) 0 0;
        background:
            linear-gradient(180deg, color-mix(in srgb, var(--color-warm-cream) 78%, #fff) 0%, #fff 45%),
            #fff;
        box-shadow: 0 -24px 70px rgba(0, 0, 0, 0.22);
    }

    .availability-search__mobile-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        margin-bottom: 1rem;
    }

    .availability-search__mobile-title {
        margin: 0;
        font-size: var(--type-body-lg);
        font-weight: 800;
    }

    .availability-search__mobile-close {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 48px;
        height: 48px;
        border: 1px solid var(--dahu-style-border, #ddd);
        border-radius: var(--radius-control) !important;
        background: #fff;
        color: var(--dahu-style-text, #222);
        box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
    }

    .availability-search--archive .availability-search__mobile-title {
        color: var(--color-text);
        font-size: var(--type-section-subtitle);
        font-weight: 400;
        letter-spacing: 0;
    }

    .availability-search--archive .availability-search__mobile-close {
        width: 42px;
        height: 42px;
        border-color: color-mix(in srgb, var(--color-border) 70%, var(--color-secondary));
        border-radius: var(--radius-sm) !important;
        box-shadow: none;
    }

    .availability-search__mobile-body {
        display: flex;
        flex: 1;
        flex-direction: column;
        min-height: 0;
    }

    .availability-search__mobile-cards {
        display: grid;
        gap: 0.9rem;
    }

    .availability-search__mobile-card {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        width: 100%;
        padding: 1.25rem 1.35rem;
        border: 1px solid rgba(34, 34, 34, 0.12);
        background: #fff;
        color: var(--dahu-style-text, #222);
        text-align: left;
        box-shadow: 0 12px 32px rgba(15, 23, 42, 0.06);
    }

    .availability-search--archive .availability-search__mobile-card {
        border-color: color-mix(in srgb, var(--color-border) 74%, var(--color-secondary));
        border-radius: var(--radius-md);
        box-shadow: none;
    }

    .availability-search__mobile-card.is-active {
        border-color: var(--dahu-style-text, #222);
        box-shadow: 0 16px 36px rgba(15, 23, 42, 0.1);
    }

    .availability-search--archive .availability-search__mobile-card.is-active {
        border-color: var(--color-secondary);
        box-shadow: 0 14px 34px rgba(74, 50, 18, 0.1);
    }

    .availability-search__mobile-card-label {
        color: var(--dahu-style-muted, #717171);
        font-size: var(--type-body-md);
        font-weight: 700;
    }

    .availability-search__mobile-card-value {
        color: var(--dahu-style-text, #222);
        font-size: var(--type-body-lg);
        font-weight: 800;
        text-align: right;
    }

    .availability-search__mobile-panel {
        display: block;
        flex: 1;
        margin-top: 1rem;
        padding: 1.35rem;
        border: 1px solid rgba(34, 34, 34, 0.12);
        background: #fff;
        box-shadow: 0 16px 40px rgba(15, 23, 42, 0.07);
    }

    .availability-search--archive .availability-search__mobile-panel {
        border-color: color-mix(in srgb, var(--color-border) 74%, var(--color-secondary));
        border-radius: var(--radius-md);
        box-shadow: none;
    }

    .availability-search__mobile-panel-header h4 {
        margin: 0;
        font-size: var(--type-section-subtitle);
        font-weight: 850;
        line-height: 1;
    }

    .availability-search--archive .availability-search__mobile-panel-header h4 {
        color: var(--color-text);
        font-weight: 400;
        letter-spacing: 0;
    }

    .availability-search__mobile-panel-header p {
        margin: 0.4rem 0 0;
        color: var(--dahu-style-muted, #717171);
        font-size: var(--type-body-md);
    }

    .availability-search__mobile-picker-host {
        margin-top: 1rem;
    }

    .availability-search__mobile-picker-input {
        position: absolute;
        width: 1px;
        height: 1px;
        opacity: 0;
        pointer-events: none;
    }

    .availability-search__mobile-picker-host .datepicker {
        position: static;
        width: 100%;
        padding: 0;
        border: 0;
        border-radius: 0;
        box-shadow: none;
        transform: none;
    }

    .availability-search--archive .availability-search__mobile-picker-host .datepicker {
        background: transparent;
    }

    .availability-search--archive .availability-search__mobile-picker-host .datepicker__month-caption {
        padding-bottom: 0.75rem;
        border-bottom: 1px solid var(--archive-booking-line);
        color: var(--archive-booking-ink);
        font-family: var(--font-heading);
        font-size: 1.05rem;
        font-weight: 700;
        letter-spacing: 0.01em;
        text-transform: uppercase;
    }

    .availability-search__mobile-picker-host .datepicker__months {
        grid-template-columns: 1fr;
        gap: 1.25rem;
    }

    .availability-search__mobile-picker-host .datepicker__month-caption {
        font-size: var(--type-body-lg);
        text-transform: uppercase;
        text-align: center;
    }

    .availability-search__mobile-picker-host .datepicker__month-day {
        min-height: 44px;
        border-radius: var(--radius-control);
    }

    .availability-search--archive .availability-search__mobile-picker-host .datepicker__month-day {
        min-height: 42px;
        border: 1px solid color-mix(in srgb, var(--archive-booking-line) 88%, #fff);
        border-radius: 0 !important;
        color: var(--archive-booking-ink);
        font-weight: 700;
    }

    .availability-search--archive .availability-search__mobile-picker-host .datepicker__month-day--selected,
    .availability-search--archive .availability-search__mobile-picker-host .datepicker__month-day--hovering {
        border-radius: 0 !important;
        background: var(--archive-booking-range);
        color: var(--archive-booking-ink);
    }

    .availability-search--archive .availability-search__mobile-picker-host .datepicker__month-day--first-day-selected,
    .availability-search--archive .availability-search__mobile-picker-host .datepicker__month-day--last-day-selected,
    .availability-search--archive .availability-search__mobile-picker-host .datepicker__month-day--first-day-selected.datepicker__month-day--selected,
    .availability-search--archive .availability-search__mobile-picker-host .datepicker__month-day--last-day-selected.datepicker__month-day--selected,
    .availability-search--archive .availability-search__mobile-picker-host .datepicker__month-day--first-day-selected.datepicker__month-day--hovering,
    .availability-search--archive .availability-search__mobile-picker-host .datepicker__month-day--last-day-selected.datepicker__month-day--hovering {
        background: var(--archive-booking-accent) !important;
        color: var(--color-white) !important;
    }

    .availability-search--archive .availability-search__room-dates-summary {
        margin: 1rem 0 0;
        padding: 0.9rem 1rem;
        border: 1px solid color-mix(in srgb, var(--color-border) 78%, var(--color-secondary));
        border-radius: var(--radius-sm);
        background: color-mix(in srgb, var(--color-warm-cream) 72%, #fff);
        color: var(--color-text-light);
        font-size: 0.92rem;
        font-weight: 600;
    }

    .availability-search__mobile-panel-actions,
    .availability-search__mobile-footer {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.9rem;
        margin-top: 1.25rem;
    }

    .availability-search--archive .availability-search__mobile-panel-actions,
    .availability-search--archive .availability-search__mobile-footer {
        padding-top: 1rem;
        border-top: 1px solid color-mix(in srgb, var(--color-border) 78%, var(--color-secondary));
    }

    .availability-search--archive .availability-search__mobile-submit {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 0.55rem;
        min-height: 48px;
        padding: 0 1.1rem;
        border-radius: var(--radius-sm) !important;
        background: var(--color-primary);
        color: var(--color-white);
        font-size: 0.95rem;
        font-weight: 700;
    }

    .availability-search--archive .availability-search__mobile-submit:hover,
    .availability-search--archive .availability-search__mobile-submit:focus-visible {
        background: var(--color-secondary);
    }

    .availability-search__mobile-sheet[data-active-panel=""] .availability-search__mobile-panel {
        display: none;
    }

    .availability-search__mobile-sheet[data-active-panel=""] .availability-search__mobile-footer {
        display: flex;
    }

    .availability-search__mobile-sheet[data-active-panel]:not([data-active-panel=""]) .availability-search__mobile-cards,
    .availability-search__mobile-sheet[data-active-panel]:not([data-active-panel=""]) .availability-search__mobile-footer {
        display: none;
    }

    .availability-search__desktop-guests-panel {
        display: none;
    }

    .availability-search-mobile-open {
        overflow: hidden;
    }
}

/* Final premium search overrides */
.availability-search__form,
.availability-search--archive .availability-search__form {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md) !important;
    background: var(--color-white);
    box-shadow: var(--shadow-card);
}

.availability-search__item {
    border-right-color: var(--color-border);
}

.availability-search__label {
    letter-spacing: 0;
    text-transform: uppercase;
}

.availability-search__value.is-filled {
    font-size: var(--type-body-md);
}

.availability-search__desktop-guests-panel,
.availability-search--archive .availability-search__desktop-guests-panel,
.availability-search .datepicker,
.availability-search--archive .datepicker {
    border-color: var(--color-border);
    border-radius: var(--radius-md) !important;
    box-shadow: var(--shadow-elevated);
}

.availability-search__guest-stepper,
.availability-search__mobile-apply,
.availability-search__mobile-launch,
.availability-search .datepicker__month-button,
.availability-search .datepicker__month-day,
.availability-search--archive .datepicker__month-button {
    border-radius: var(--radius-sm) !important;
}

.availability-search__guest-stepper {
    border-color: var(--color-border);
}

.availability-search__mobile-apply,
.availability-search--archive .availability-search__mobile-apply,
.availability-search--archive .availability-search__submit {
    background: var(--color-primary);
}

.availability-search__mobile-apply:hover,
.availability-search__mobile-apply:focus-visible,
.availability-search--archive .availability-search__mobile-apply:hover,
.availability-search--archive .availability-search__mobile-apply:focus-visible,
.availability-search--archive .availability-search__submit:hover,
.availability-search--archive .availability-search__submit:focus-visible {
    background: var(--color-secondary);
}

.availability-search__intro-eyebrow,
.availability-search--archive .availability-search__label,
.availability-search--archive .availability-search__trigger-icon {
    color: var(--color-secondary);
}

.availability-search__intro-title {
    letter-spacing: 0;
    line-height: var(--leading-heading);
}

.rooms-availability-summary__reset {
    border-radius: var(--radius-sm);
    font-weight: 700;
}

@media (max-width: 900px) {
    .availability-search__mobile-launch,
    .availability-search--archive .availability-search__mobile-launch,
    .availability-search__mobile-card,
    .availability-search--archive .availability-search__mobile-card,
    .availability-search__mobile-panel,
    .availability-search--archive .availability-search__mobile-panel,
    .availability-search__mobile-close,
    .availability-search--archive .availability-search__mobile-close {
        border-radius: var(--radius-md) !important;
    }

    .availability-search--archive .availability-search__mobile-dialog {
        border-radius: var(--radius-md) var(--radius-md) 0 0;
        box-shadow: 0 -18px 46px rgba(33, 28, 24, 0.18);
    }

    .availability-search--archive .availability-search__mobile-launch {
        box-shadow: var(--shadow-card);
    }
}

/* Montagnettes-inspired search and listing header */
.availability-search--archive.availability-search--with-intro {
    margin-top: 0;
    padding: 72px 0 0;
    border-bottom: 0;
    background: #f1f0ee;
}

.availability-search--archive.availability-search--with-intro .availability-search__shell {
    width: min(100%, 1600px);
}

.availability-search--archive.availability-search--with-intro .availability-search__intro {
    gap: 16px;
    max-width: 1018px;
    margin: 0 auto 42px;
    color: #2f2b28;
    text-align: center;
}

.availability-search--archive.availability-search--with-intro .availability-search__intro-title {
    max-width: 1000px;
    color: #2f2b28;
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(2.75rem, 4.1vw, 3.8125rem);
    font-weight: 400;
    line-height: 1;
    letter-spacing: 0;
    text-wrap: balance;
}

.availability-search--archive.availability-search--with-intro .availability-search__intro-text {
    max-width: 760px;
    color: #665f5a;
    font-size: 17px;
    font-weight: 400;
    line-height: 1.5;
    text-wrap: balance;
}

.availability-search--archive.availability-search--contextual .availability-search__shell {
    width: 100%;
}

.rooms-listing-search .availability-search--archive.availability-search--contextual .availability-search__shell {
    width: 100%;
    max-width: var(--container-max);
    padding-inline: clamp(1.5rem, 6vw, 8rem);
}

.availability-search--archive.availability-search--contextual .availability-search__form {
    display: grid;
    grid-template-columns: repeat(3, minmax(180px, 1fr)) minmax(142px, 160px);
    gap: 0;
    align-items: center;
    min-height: 90px;
    padding: 0;
    border: 0;
    border-radius: 0 !important;
    background: #f9f9f8;
    box-shadow:
        0 18px 20px rgba(0, 0, 0, 0.01),
        0 73px 36.5px rgba(0, 0, 0, 0.01),
        0 165px 49.5px rgba(0, 0, 0, 0.01);
    backdrop-filter: blur(11.5px);
}

.availability-search--archive.availability-search--contextual .availability-search__lead {
    display: flex;
    align-items: center;
    align-self: stretch;
    min-width: 0;
    height: 100%;
    padding: 0 clamp(1.75rem, 3vw, 3rem);
    border-right: 1px solid #e4e3e0;
    border-left: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    color: #2f2b28;
    text-align: left;
}

.availability-search--archive.availability-search--contextual .availability-search__lead span {
    display: block;
    max-width: 12ch;
    font-family: var(--font-heading);
    font-size: clamp(1.35rem, 2vw, 1.45rem);
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0;
}

.availability-search--archive.availability-search--contextual .availability-search__lead + .availability-search__item {
    border-left: 0;
}

.availability-search--archive.availability-search--contextual .availability-search__form:has(.availability-search__lead) {
    grid-template-columns: minmax(250px, 0.8fr) repeat(3, minmax(180px, 1fr)) minmax(142px, 160px);
}

.availability-search--archive.availability-search--contextual .availability-search__item {
    align-self: stretch;
    min-height: 0;
    height: 100%;
    justify-content: center;
    gap: 0;
    margin: 0;
    border-right: 1px solid #e4e3e0;
    border-bottom: 1px solid var(--color-border);
    padding: 0 clamp(1.4rem, 2.2vw, 2.4rem);
}

.availability-search--archive.availability-search--contextual .availability-search__label {
    color: #2f2b28;
    font-size: 17px;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: 0;
    text-transform: none;
}

.availability-search--archive.availability-search--contextual .availability-search__value,
.availability-search--archive.availability-search--contextual .availability-search__value.is-filled {
    color: #665f5a;
    font-size: 13px;
    font-weight: 400;
    line-height: 1.4;
    letter-spacing: 0;
}

.availability-search--archive.availability-search--contextual .availability-search__trigger {
    min-height: 18px;
    gap: 0.5rem;
    justify-content: space-between;
}

.availability-search--archive.availability-search--contextual .availability-search__trigger-icon {
    display: none;
}

.availability-search__date-range {
    display: flex;
    align-items: center;
    gap: 0.32rem;
    min-width: 0;
}

.availability-search__date-trigger {
    display: inline-flex;
    flex: 0 1 auto;
    width: auto;
    min-width: 0;
}

.availability-search__date-separator {
    flex: 0 0 auto;
    color: #665f5a;
    font-size: 13px;
    line-height: 1.4;
}

.availability-search--archive.availability-search--contextual .availability-search__actions {
    align-self: stretch;
    padding: 0;
}

.availability-search--archive.availability-search--contextual .availability-search__submit {
    width: 100%;
    height: 100%;
    min-height: 90px;
    padding: 0 1rem;
    border-radius: 0 !important;
    background: var(--color-secondary);
    color: var(--color-white);
    transform: none;
    gap: 0.45rem;
    font-size: var(--type-ui-label);
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.availability-search--archive.availability-search--contextual .availability-search__submit:hover,
.availability-search--archive.availability-search--contextual .availability-search__submit:focus-visible {
    background: var(--color-white);
    color: var(--color-secondary);
    transform: none;
}

.banner-section__search .availability-search--archive.availability-search--contextual .availability-search__form {
    background: rgba(249, 249, 248, 0.97);
    box-shadow:
        0 18px 20px rgba(0, 0, 0, 0.01),
        0 28px 48px rgba(33, 28, 24, 0.14);
}

@media (max-width: 1180px) {
    .availability-search--archive.availability-search--contextual .availability-search__form {
        grid-template-columns: minmax(210px, 0.72fr) repeat(3, minmax(150px, 1fr)) minmax(142px, 160px);
    }
}

@media (max-width: 900px) {
    .availability-search--archive.availability-search--with-intro {
        padding: clamp(3.5rem, 12vw, 4.5rem) 1rem clamp(2.5rem, 10vw, 4rem);
    }

    .availability-search--archive.availability-search--with-intro .availability-search__intro {
        justify-items: center;
        margin-bottom: 1.75rem;
        text-align: center;
    }

    .availability-search--archive.availability-search--with-intro .availability-search__intro-title {
        font-size: clamp(2.2rem, 10vw, 3rem);
        line-height: 1;
    }

    .availability-search--archive.availability-search--with-intro .availability-search__intro-text {
        max-width: 34rem;
        font-size: 0.98rem;
    }

    .availability-search--archive.availability-search--contextual .availability-search__form {
        grid-template-columns: 1fr;
        gap: 0;
        min-height: 0;
        padding: 18px;
    }

    .availability-search--archive.availability-search--contextual .availability-search__mobile-launch {
        display: none;
    }

    .availability-search--archive.availability-search--contextual .availability-search__item {
        min-height: 0;
        padding: 12px 0;
        border-right: 0;
        border-bottom: 1px solid #d6d0c7;
    }

    .availability-search--archive.availability-search--contextual .availability-search__lead {
        min-height: 0;
        padding: 0 0 14px;
        border-right: 0;
        border-bottom: 1px solid #d6d0c7;
    }

    .availability-search--archive.availability-search--contextual .availability-search__lead span {
        max-width: none;
        font-size: 1.25rem;
    }

    .availability-search--archive.availability-search--contextual .availability-search__item--guests {
        border-bottom: 0;
    }

    .availability-search--archive.availability-search--contextual .availability-search__submit {
        width: 100%;
        height: 48px;
        min-height: 48px;
        padding: 0 24px;
        gap: 8px;
    }
}

.availability-search--archive.availability-search--contextual .datepicker__month--month1 .datepicker__month-button--next,
.availability-search--archive.availability-search--contextual .datepicker__month--month2 .datepicker__month-button--prev {
    display: none;
}

.availability-search--archive.availability-search--contextual .datepicker__month--month1 .datepicker__month-button--prev,
.availability-search--archive.availability-search--contextual .datepicker__month--month2 .datepicker__month-button--next {
    display: inline-flex;
    visibility: visible !important;
}

body.home .banner-section__search .availability-search--archive.availability-search--contextual .availability-search__lead {
    border-bottom: 0;
}

/* Global square design direction. Loaded late to neutralize legacy radii. */
body :not(#dahu-radius-reset),
body :not(#dahu-radius-reset)::before,
body :not(#dahu-radius-reset)::after {
    border-radius: 0 !important;
}
