/* Retreat detail — āshrams Figma */
@import url('https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:ital,wght@0,300;0,400;1,300;1,400&family=Inter:wght@100;200;300;400&family=Manrope:wght@200;300;400&family=Ysabeau+Infant:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap');

body.ashrams-retreat-detail-page {
    background: #fff;
    font-family: 'Cormorant Infant', var(--ashrams-serif);
}

body.ashrams-retreat-detail-page .ashrams-header {
    position: relative;
    background: #fff;
}

body.ashrams-retreat-detail-page .ashrams-header__nav {
    transform: none;
}

body.ashrams-retreat-detail-page .ashrams-footer {
    margin-top: 0;
}

.ard {
    --ard-accent: var(--ashrams-terracotta, #9a4f3a);
    --ard-text: var(--ashrams-text, #1a1a1a);
    --ard-muted: #6d5b52;
    --ard-border: #ece8e3;
    --ard-surface: #f7f5f2;
    --ard-serif: 'Cormorant Infant', var(--ashrams-serif);
    --ard-body: 'Cormorant Infant', var(--ashrams-serif);
    --ard-sans: var(--ashrams-sans);
    color: var(--ard-text);
    padding-bottom: clamp(3rem, 8vw, 5rem);
}

.ard__wrap {
    max-width: min(70rem, 100%);
    width: 100%;
    margin: 0 auto;
    padding-left: clamp(1rem, 4vw, 2rem);
    padding-right: clamp(1rem, 4vw, 2rem);
}

.ard__wrap--wide {
    max-width: min(77.5rem, var(--ashrams-page-max, 1440px));
    width: 100%;
}

/* Typography helpers */
.ard__eyebrow {
    font-family: var(--ard-sans);
    font-size: 0.68rem;
    font-weight: 500;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ard-muted);
    text-align: center;
    margin: 0 0 1rem;
}

.ard__eyebrow strong {
    color: var(--ard-accent);
    font-weight: 600;
}

.ard__heading {
    font-family: var(--ard-serif);
    font-size: clamp(2rem, 5vw, 3.25rem);
    font-weight: 500;
    line-height: 1.08;
    letter-spacing: -0.03em;
    text-align: center;
    margin: 0 0 1rem;
}

.ard__heading em {
    font-style: normal;
    color: var(--ard-accent);
}

.ard__section-title {
    font-family: var(--ard-serif);
    font-size: clamp(2rem, 4.5vw, 2.75rem);
    font-weight: 500;
    letter-spacing: -0.02em;
    text-align: center;
    margin: 0 0 clamp(1.75rem, 4vw, 2.5rem);
}

.ard__section-title em {
    font-style: normal;
    color: var(--ard-accent);
}

.ard__section--about {
    margin-top: 0;
    padding-top: clamp(4rem, 8vw, 6.25rem);
    margin-bottom: 0;
    scroll-margin-top: calc(4.5rem + 6.25rem);
    box-sizing: border-box;
}

.ard__section--highlights {
    margin-top: 0;
    margin-bottom: 0;
    padding-top: 0;
    padding-bottom: clamp(3.5rem, 7vw, 5.5rem);
}

.ard__section--highlights .ard__section-title {
    font-family: var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: clamp(1.875rem, 3.6vw, 2.5rem);
    font-weight: 300;
    line-height: 1.6;
    letter-spacing: -1.8px;
    color: #1a1c1c;
    text-align: center;
    margin-top: 0;
    margin-bottom: clamp(3.75rem, 9vw, 6rem);
}

.ard__section--highlights .ard__section-title em {
    font-family: inherit;
    font-style: normal;
    font-weight: 300;
    color: #1a1c1c;
}

.ard__lead {
    font-family: var(--ard-body);
    font-size: clamp(1rem, 2vw, 1.12rem);
    line-height: 1.65;
    color: var(--ard-muted);
    text-align: center;
    max-width: 42rem;
    margin: 0 auto 2rem;
}

.ard__prose {
    font-family: var(--ard-body);
    font-size: 1.05rem;
    line-height: 1.7;
    color: var(--ard-muted);
}

.ard__prose p {
    margin-bottom: 1rem;
}

.ard__prose p:last-child {
    margin-bottom: 0;
}

/* Sticky side CTAs — Figma left rail */
.ard__side-cta {
    position: fixed;
    left: max(1rem, calc((100vw - 1240px) / 2 - 3.5rem));
    top: 50%;
    transform: translateY(-42%);
    z-index: 40;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.ard__side-btn {
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    border-radius: 999px;
    padding: 1.15rem 0.6rem;
    font-family: var(--ard-sans);
    font-size: 0.58rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    text-decoration: none;
    border: 1px solid var(--ard-accent);
    background: #fff;
    color: var(--ard-accent);
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease;
}

.ard__side-btn:hover {
    background: #fdf8f6;
    color: var(--ard-accent);
}

.ard__side-btn--primary {
    background: var(--ard-accent);
    border-color: var(--ard-accent);
    color: #fff;
}

.ard__side-btn--primary:hover {
    background: var(--ashrams-terracotta-light, #b86b52);
    color: #fff;
}

/* Hero — Figma Part 1 */
.ard__hero {
    padding-top: clamp(1.5rem, 4vw, 2.75rem);
    padding-bottom: 0;
    text-align: center;
}

.ard__hero .ard__eyebrow {
    margin-bottom: clamp(1rem, 2.5vw, 1.35rem);
}

.ard__hero .ard__heading {
    max-width: 63.75rem;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: clamp(0.85rem, 2vw, 1.15rem);
    font-family: var(--ard-serif);
    font-size: clamp(2.25rem, 4.2vw, 4.0625rem);
    font-weight: 500;
    line-height: 1.1077;
    letter-spacing: -1.8px;
    color: #1a1c1c;
}

.ard__hero .ard__heading em {
    display: block;
    font-family: var(--ard-serif);
    font-style: normal;
    font-weight: 500;
    font-size: inherit;
    line-height: inherit;
    letter-spacing: inherit;
    color: #1a1c1c;
}

.ard__hero-sub {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: clamp(0.9375rem, 1.3vw, 1.125rem);
    font-weight: 200;
    line-height: 1.5;
    letter-spacing: 0;
    color: #55433d;
    text-align: center;
    max-width: 41.5625rem;
    margin: 0 auto clamp(2.75rem, 5.5vw, 4rem);
}

.ard__hero-media {
    width: 100%;
    max-width: 54rem;
    padding-left: clamp(0.75rem, 2.5vw, 1.5rem);
    padding-right: clamp(0.75rem, 2.5vw, 1.5rem);
    margin: 0 auto 0;
}

.ard__hero-slider {
    position: relative;
    border-radius: clamp(1.5rem, 4vw, 3.125rem);
    overflow: hidden;
    background: var(--ard-surface);
}

.ard__hero-swiper {
    width: 100%;
    aspect-ratio: 1058 / 706;
    overflow: hidden;
}

.ard__hero-swiper .swiper-slide {
    height: 100%;
    overflow: hidden;
}

.ard__hero-swiper .swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.ard__hero-view-all {
    position: absolute;
    right: 1.25rem;
    bottom: 1.25rem;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    border: none;
    border-radius: 999px;
    padding: 0.55rem 1rem;
    background: rgba(255, 255, 255, 0.97);
    box-shadow: 0 2px 14px rgba(44, 36, 32, 0.1);
    font-family: var(--ard-body);
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    text-transform: none;
    color: var(--ard-text);
    cursor: pointer;
}

.ard__hero-view-all i {
    color: var(--ard-accent);
    font-size: 0.85rem;
}

.ard__hero-controls {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 1.25rem;
    padding: 0;
    min-height: 1.25rem;
}

.ard__hero-dots {
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.ard__hero-dot {
    width: 0.375rem;
    height: 0.375rem;
    border-radius: 999px;
    border: none;
    padding: 0;
    background: #d4ccc6;
    cursor: pointer;
    transition: width 0.25s ease, background 0.25s ease;
}

.ard__hero-dot.is-active {
    background: var(--ard-accent);
    width: 1.25rem;
}

.ard__hero-arrows {
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.ard__hero-arrow {
    width: auto;
    height: auto;
    border: none;
    background: transparent;
    color: #6d5b52;
    font-size: 0.9rem;
    cursor: pointer;
    padding: 0.15rem;
    line-height: 1;
}

.ard__hero-arrow:hover:not(:disabled) {
    color: var(--ard-accent);
}

.ard__hero-arrow:disabled,
.ard__hero-arrow.is-disabled {
    opacity: 0.3;
    cursor: default;
    pointer-events: none;
}

/* Sticky nav — Figma section links (Highlights, Journey, …) */
.ard__nav {
    position: sticky;
    top: 0;
    z-index: 30;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(8px);
    margin-top: clamp(2rem, 4.5vw, 3.5rem);
    margin-bottom: 0;
}

.ard__nav-inner {
    /* Wider than hero image (54rem) and About body copy (58rem) */
    width: min(66rem, calc(100% - 2rem));
    max-width: min(66rem, calc(100% - 2rem));
    margin-left: auto;
    margin-right: auto;
    border-top: 1px solid var(--ard-border);
    border-bottom: 1px solid var(--ard-border);
    padding-left: clamp(1.75rem, 3.5vw, 2.5rem);
    padding-right: clamp(1.75rem, 3.5vw, 2.5rem);
    box-sizing: border-box;
}

.ard__nav ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 0;
    list-style: none;
    margin: 0;
    padding: 0.85rem 0;
}

.ard__nav li {
    display: flex;
    align-items: center;
}

.ard__nav li + li::before {
    content: '•';
    margin: 0 1.375rem;
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: 0.8125rem;
    font-weight: 300;
    line-height: 1.125rem;
    color: #5e5e5e;
    pointer-events: none;
}

.ard__nav a {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: 0.8125rem;
    font-weight: 300;
    line-height: 1.125rem;
    letter-spacing: 0.7px;
    text-transform: uppercase;
    text-decoration: none;
    color: #5e5e5e;
}

.ard__nav a.is-active,
.ard__nav a:hover {
    color: #5e5e5e;
}

/* Sections */
.ard__section {
    margin-bottom: clamp(3rem, 7vw, 4.5rem);
    scroll-margin-top: 4.5rem;
}

/* About journey — Figma Part 2a */
.ard__section--about .ard__section-title {
    font-family: 'Ysabeau Infant', var(--ashrams-nav-font), var(--ashrams-serif), serif;
    font-size: clamp(2rem, 4vw, 2.8125rem);
    font-weight: 300;
    line-height: 0.8889;
    letter-spacing: 0;
    color: #1a1c1c;
    margin-bottom: clamp(1.5rem, 3.5vw, 2rem);
}

.ard__section--about .ard__section-title em {
    font-family: inherit;
    font-style: normal;
    font-weight: 300;
    color: #1a1c1c;
}

.ard__about-copy {
    max-width: 58rem;
    margin: 0 auto calc(9rem + 15px);
    text-align: left;
}

.ard__about-copy.ard__prose {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    line-height: 1.571;
    letter-spacing: 0;
    color: #55433d;
}

.ard__about-copy.ard__prose p {
    margin: 0;
}

.ard__about-copy.ard__prose p + p {
    margin-top: 1.625rem;
}

/* Journey highlights — Figma Part 2b */
.ard__highlights {
    max-width: 66.125rem;
    margin: 0 auto;
    width: 100%;
}

.ard__highlight-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(2.5rem, 5vw, 4.5rem);
    align-items: start;
    margin-bottom: clamp(3.5rem, 7vw, 5rem);
}

@media (min-width: 1000px) {
    .ard__highlight-row {
        --ard-highlight-copy-w: 32.5rem;
        --ard-highlight-img-w: 36.25rem;
        grid-template-columns: minmax(0, var(--ard-highlight-copy-w)) minmax(0, var(--ard-highlight-img-w));
        justify-content: space-between;
        gap: 5rem;
        align-items: start;
    }

    .ard__highlight-row--reverse {
        grid-template-columns: minmax(0, var(--ard-highlight-img-w)) minmax(0, var(--ard-highlight-copy-w));
    }
}

.ard__highlight-row:last-child {
    margin-bottom: 0;
}

.ard__highlight-row--reverse .ard__highlight-copy {
    order: 2;
}

.ard__highlight-row--reverse .ard__highlight-media {
    order: 1;
}

.ard__highlight-copy {
    --ard-highlight-gap-title: clamp(1rem, 1.9vw, 1.4375rem);
    --ard-highlight-gap-para: clamp(1.1875rem, 2.1vw, 1.5rem);
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    text-align: left;
    max-width: 35rem;
    padding-top: 0;
}

@media (min-width: 1000px) {
    .ard__highlight-copy {
        width: 100%;
        max-width: var(--ard-highlight-copy-w, 32.5rem);
        align-self: flex-start;
    }
}

.ard__highlight-media {
    width: 100%;
    display: flex;
    align-items: flex-start;
}


.ard__highlight-row:not(.ard__highlight-row--reverse) .ard__highlight-media {
    justify-content: flex-end;
}

.ard__highlight-row--reverse .ard__highlight-media {
    justify-content: flex-start;
}

.ard__highlight-copy h3 {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: clamp(1.625rem, 2.9vw, 2rem);
    font-weight: 200;
    line-height: 2.625rem;
    letter-spacing: 0;
    margin: 0 0 var(--ard-highlight-gap-title);
    flex-shrink: 0;
    color: #1a1c1c;
    text-align: left;
    max-width: 35rem;
}

@media (min-width: 1000px) {
    .ard__highlight-copy h3 {
        max-width: var(--ard-highlight-copy-w, 32.5rem);
    }
}

.ard__highlight-copy .ard__prose {
    margin-top: 0;
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    line-height: 1.571;
    letter-spacing: 0;
    color: #55433d;
    text-align: left;
    max-width: 35rem;
}

@media (min-width: 1000px) {
    .ard__highlight-copy .ard__prose p {
        font-size: 1rem;
        line-height: 1.625;
        max-width: var(--ard-highlight-copy-w, 32.5rem);
    }
}

.ard__highlight-copy .ard__prose p {
    margin: 0;
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-weight: 300;
}

.ard__highlight-copy .ard__prose p + p {
    margin-top: var(--ard-highlight-gap-para);
}

.ard__highlight-media-frame {
    position: relative;
    width: 100%;
    max-width: 36.25rem;
    aspect-ratio: 580 / 405;
    border-radius: clamp(1.15rem, 2.5vw, 1.75rem);
    overflow: hidden;
}

.ard__highlight-media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    border-radius: 0;
}

@media (min-width: 1000px) {
    .ard__highlight-media-frame {
        width: 100%;
        max-width: var(--ard-highlight-img-w, 36.25rem);
    }
}

.ard__highlight-row:nth-child(2) .ard__highlight-media img {
    object-position: 55% 50%;
}

.ard__highlight-row:nth-child(3) .ard__highlight-media img {
    object-position: 50% 28%;
}

.ard__highlight-row:nth-child(3) .ard__highlight-copy {
    --ard-highlight-gap-title: clamp(0.875rem, 1.55vw, 1.25rem);
    --ard-highlight-gap-para: clamp(1rem, 1.7vw, 1.3125rem);
}

#journey-detail {
    margin-top: 0;
    padding-top: 0;
}

#journey-detail.ard__section {
    margin-bottom: clamp(3.5rem, 7.5vw, 5rem);
}

#journey-detail .ard__audience {
    margin-top: clamp(2rem, 4.5vw, 3.5rem);
}

#journey-detail .ard__rhythm {
    margin-top: clamp(4rem, 9vw, 6.5rem);
    padding-bottom: 0.75rem;
}

/* Who this is for — Figma Section WHO THIS IS FOR */
.ard__audience {
    --ard-audience-bg: #f3f3f4;
    --ard-audience-title: #984629;
    --ard-audience-icon: #d87756;
    --ard-audience-text: #55433d;
    --ard-audience-w: 52rem;
    --ard-audience-list-w: 38.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(1.25rem, 3vw, 1.5rem);
    box-sizing: border-box;
    width: 100%;
    max-width: var(--ard-audience-w);
    margin: 0 auto;
    padding: clamp(1.75rem, 4.5vw, 3rem);
    background: var(--ard-audience-bg);
    border-radius: clamp(1.75rem, 4.5vw, 3rem);
}

@media (min-width: 1000px) {
    .ard__audience {
        width: var(--ard-audience-w);
        padding: 3rem;
        border-radius: 3rem;
        gap: 1.5rem;
    }
}

.ard__audience h3 {
    margin: 0;
    width: 100%;
    max-width: var(--ard-audience-list-w);
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: clamp(1.25rem, 2.5vw, 1.75rem);
    font-weight: 400;
    line-height: 1.1429;
    letter-spacing: -0.0036em;
    color: var(--ard-audience-title);
    text-align: center;
}

@media (min-width: 1000px) {
    .ard__audience h3 {
        font-size: 1.75rem;
        line-height: 1.875rem;
    }
}

.ard__audience ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 1.125rem;
    width: 100%;
    max-width: var(--ard-audience-list-w);
    margin: 0;
    padding: 0;
    align-self: flex-start;
    margin-left: 0;
}

@media (min-width: 1000px) {
    .ard__audience ul {
        margin-left: 0.75rem;
    }
}

.ard__audience li {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    margin: 0;
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    line-height: 1.5714;
    letter-spacing: 0;
    color: var(--ard-audience-text);
}

@media (min-width: 1000px) {
    .ard__audience li {
        font-size: 0.875rem;
        line-height: 1.375rem;
    }
}

.ard__audience-icon {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.25rem;
    height: 1.25rem;
    margin-top: 0;
    line-height: 0;
}

.ard__audience-icon img {
    display: block;
    width: 1.25rem;
    height: 1.25rem;
}

.ard__audience-text {
    flex: 1;
    min-width: 0;
}

@media (min-width: 1000px) {
    .ard__audience-text {
        white-space: nowrap;
    }
}

@media (max-width: 999px) {
    .ard__audience li {
        align-items: flex-start;
    }

    .ard__audience-icon {
        margin-top: 0.1875rem;
    }
}

/* Daily rhythm — Figma */
.ard__rhythm {
    --ard-rhythm-accent: #984629;
    width: 100%;
    max-width: 56rem;
    margin-left: auto;
    margin-right: auto;
}

.ard__rhythm .ard__section-title--rhythm,
.ard__rhythm .ard__section-title {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: clamp(1.875rem, 3.8vw, 2.5rem);
    font-weight: 300;
    line-height: 1;
    letter-spacing: 0;
    color: #1a1c1c;
    text-align: center;
    margin: 0 0 1rem;
}

.ard__rhythm .ard__section-title em {
    font-family: inherit;
    font-style: normal;
    font-weight: inherit;
    color: inherit;
}

.ard__rhythm-note {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-style: italic;
    font-weight: 200;
    font-size: clamp(0.9375rem, 1.6vw, 1rem);
    line-height: 1.5;
    letter-spacing: 0;
    color: #55433d;
    text-align: center;
    max-width: 28.25rem;
    margin: 0 auto clamp(2rem, 4.5vw, 2.75rem);
}

@media (min-width: 1000px) {
    .ard__rhythm-note {
        font-size: 1rem;
        line-height: 1.625rem;
    }
}

.ard__phases {
    --ard-phase-w: 14.25rem;
    --ard-phase-h: 16rem;
    display: grid;
    grid-template-columns: repeat(3, var(--ard-phase-w));
    justify-content: center;
    gap: 2.5rem;
    width: 100%;
    max-width: 56rem;
    margin: 0 auto clamp(3rem, 6vw, 4rem);
    align-items: stretch;
}

.ard__phase {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    text-align: left;
    width: var(--ard-phase-w);
    max-width: 100%;
    height: var(--ard-phase-h);
    min-height: var(--ard-phase-h);
    margin: 0 auto;
    padding: 1.0625rem 1.1875rem 0.8125rem;
    border: none;
    border-radius: 0.5rem;
    background: #fff;
    box-shadow:
        0 8px 10px -6px rgba(0, 0, 0, 0.1),
        0 20px 25px -5px rgba(0, 0, 0, 0.1);
    cursor: pointer;
    transition: background 0.2s, color 0.2s, border-color 0.2s, box-shadow 0.2s;
}

.ard__phase.is-active {
    background: var(--ard-rhythm-accent);
    color: #fff;
    box-shadow:
        0 8px 10px -6px rgba(152, 70, 41, 0.15),
        0 20px 25px -5px rgba(152, 70, 41, 0.2);
}

.ard__phase-label {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: 0.5625rem;
    font-weight: 300;
    line-height: 0.875rem;
    letter-spacing: 0.0625rem;
    text-transform: uppercase;
    color: var(--ard-rhythm-accent);
    margin-bottom: 0.4375rem;
}

.ard__phase.is-active .ard__phase-label {
    color: rgba(255, 255, 255, 0.88);
}

.ard__phase h4 {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 1.125rem;
    font-weight: 300;
    line-height: 1.5rem;
    letter-spacing: 0;
    margin: 0 0 0.9375rem;
    color: #5f5e5b;
}

.ard__phase.is-active h4 {
    color: #fff;
    font-weight: 400;
}

.ard__phase p {
    flex: 1;
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: 0.6875rem;
    font-weight: 300;
    line-height: 1.4;
    letter-spacing: 0;
    margin: 0;
    color: #474741;
}

.ard__phase.is-active p {
    color: rgba(255, 255, 255, 0.92);
}

.ard__phase-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: auto;
    padding-top: 0.625rem;
    border-top: 1px solid rgba(71, 71, 65, 0.12);
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: 0.5625rem;
    font-weight: 300;
    line-height: 0.875rem;
    letter-spacing: 0;
    text-transform: uppercase;
    color: var(--ard-rhythm-accent);
}

.ard__phase.is-active .ard__phase-footer {
    color: #fff;
    border-top-color: rgba(255, 255, 255, 0.22);
}

.ard__phase-footer-arrow {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 0.65625rem;
    height: 0.65625rem;
    line-height: 0;
}

.ard__phase-footer-arrow img {
    display: block;
    width: 0.65625rem;
    height: 0.65625rem;
}

.ard__phase.is-active .ard__phase-footer-arrow img {
    filter: brightness(0) invert(1);
}

.ard__days {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.875rem;
    width: 100%;
    max-width: 56rem;
    margin: clamp(0.75rem, 2vw, 1.25rem) auto clamp(1.75rem, 3.5vw, 2.25rem);
}

.ard__days-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: center;
    max-width: 100%;
}

.ard__days-row--tail {
    max-width: 20rem;
}

.ard__day-pill {
    width: 2.125rem;
    height: 2.125rem;
    border-radius: 999px;
    border: 1px solid #e8e2dd;
    background: #fff;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    color: #b77e6a;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s, color 0.2s, box-shadow 0.2s;
}

/* In active phase range but not the current day (e.g. 2–5 when day 1 selected) */
.ard__day-pill.is-active {
    background: #b77e6a;
    border-color: #b77e6a;
    color: #fff;
    box-shadow: none;
}

/* Current selected day (e.g. day 1) — darkest terracotta */
.ard__day-pill.is-active.is-current {
    background: var(--ard-rhythm-accent);
    border-color: var(--ard-rhythm-accent);
    color: #fff;
}

.ard__day-detail {
    width: 100%;
    max-width: 50rem;
    margin: clamp(0.75rem, 2vw, 1.25rem) auto clamp(1rem, 2vw, 1.5rem);
}

.ard__day-detail-card {
    padding: clamp(1.375rem, 2.8vw, 1.75rem);
    padding-bottom: clamp(1.875rem, 3.5vw, 2.25rem);
    background: #fff;
    border: 1px solid #e8e4df;
    border-radius: 0.75rem;
    box-shadow:
        0 8px 10px -6px rgba(0, 0, 0, 0.06),
        0 20px 25px -5px rgba(0, 0, 0, 0.05);
}

.ard__day-head {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    column-gap: 0.75rem;
    row-gap: 0.75rem;
    align-items: center;
    margin-bottom: clamp(1.25rem, 2.8vw, 1.75rem);
}

.ard__day-badge {
    grid-column: 1;
    grid-row: 1;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1.5rem;
    padding: 0.25rem 0.75rem;
    border-radius: 999px;
    background: var(--ard-rhythm-accent, #984629);
    color: #fff;
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin: 0;
}

.ard__day-head-copy {
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
}

.ard__day-head h4,
.ard__day-head-copy h4 {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: clamp(1.0625rem, 1.85vw, 1.375rem);
    font-weight: 600;
    line-height: 1.35;
    letter-spacing: 0;
    margin: 0;
    color: #1e293b;
}

.ard__day-body {
    grid-column: 1 / -1;
    grid-row: 2;
    max-width: 100%;
    margin: 0;
}

.ard__day-body p {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    line-height: 1.5;
    color: #5e5e5e;
    margin: 0;
}

.ard__day-schedule {
    grid-column: 1 / -1;
    grid-row: 3;
}

.ard__day-block-label {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ard-rhythm-accent, #984629);
}

.ard__day-block-label i {
    font-size: 0.85rem;
}

.ard__day-block-label h5 {
    font-family: var(--ard-sans);
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: none;
    color: var(--ard-text);
    margin: 0;
}

.ard__day-schedule {
    margin: 1rem 0 0;
    padding: 0.85rem 1rem;
    border-radius: 12px;
    background: #f7f5f2;
    font-family: var(--ard-sans);
    font-size: 0.72rem;
    line-height: 1.65;
    color: #6d5b52;
}

.ard__day-schedule[hidden] {
    display: none !important;
}

.ard__day-transfer {
    margin-top: 1.375rem;
}

.ard__day-transfer[hidden] {
    display: none !important;
}

.ard__day-transfer .ard__day-block-label--transfer {
    gap: 0.5rem;
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.75rem;
    font-weight: 400;
    line-height: 1.3333;
    letter-spacing: 0.01875rem;
    text-transform: uppercase;
    color: #5e5e5e;
}

.ard__transfer-car-icon {
    flex-shrink: 0;
    display: block;
    width: 1.125rem;
    height: 1rem;
}

.ard__transfer-type {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: clamp(0.9375rem, 1.55vw, 1rem);
    font-weight: 600;
    margin: 0.375rem 0 1rem;
    color: #1e293b;
}

.ard__transfer-route {
    --ard-transfer-rail: 0.55rem;
    --ard-transfer-pin: url('../img/ashram/retreat-detail/icon-transfer-pin.svg');
    --ard-transfer-icon-earth: 0.8125rem;
    --ard-transfer-icon-home: 0.8125rem;
    --ard-transfer-icon-pin-w: 0.875rem;
    --ard-transfer-icon-pin-h: 1.05rem;
    position: relative;
}

.ard__transfer-route::before {
    content: '';
    position: absolute;
    left: var(--ard-transfer-rail);
    top: 0;
    bottom: 0;
    width: 0;
    border-left: 1px dashed #d1d5db;
    transform: translateX(-50%);
    z-index: 0;
}

.ard__transfer-stop {
    position: relative;
    padding-left: 1.55rem;
    margin-bottom: 0.75rem;
}

.ard__transfer-stop:last-child {
    margin-bottom: 0;
}

.ard__transfer-stop::before {
    content: '';
    position: absolute;
    top: 50%;
    z-index: 1;
    transform: translateY(-50%);
}

.ard__transfer-stop--start::before,
.ard__transfer-stop--to::before {
    left: calc(var(--ard-transfer-rail) - (var(--ard-transfer-icon-pin-w) / 2));
    width: var(--ard-transfer-icon-pin-w);
    height: var(--ard-transfer-icon-pin-h);
    border: none;
    border-radius: 0;
    background: var(--ard-transfer-pin) center / contain no-repeat;
}

.ard__transfer-stop--mid::before {
    left: calc(var(--ard-transfer-rail) - 0.25rem);
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background: #fff;
    border: 1px solid #d1d5db;
}

.ard__transfer-box {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    min-height: 2.25rem;
    padding: 0.45rem 0.65rem;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    background: #fff;
}

.ard__transfer-box--field {
    position: relative;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    min-height: 2.5rem;
    margin-top: 0.35rem;
    padding: 0.7rem 0.75rem 0.55rem;
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 1px 3px rgba(15, 23, 42, 0.03);
}

.ard__transfer-label {
    position: absolute;
    top: 0;
    left: 0.6rem;
    z-index: 1;
    padding: 0 0.3rem;
    background: #fff;
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.625rem;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #984629;
    margin: 0;
    transform: translateY(-50%);
}

.ard__transfer-box-content {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    min-width: 0;
    width: 100%;
}

.ard__transfer-box-content--to {
    flex-wrap: nowrap;
    justify-content: space-between;
    gap: 0;
}

.ard__transfer-box-main {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex: 0 0 auto;
    min-width: 0;
}

.ard__transfer-box-content--to .ard__transfer-box-text {
    flex: 0 0 auto;
    white-space: nowrap;
}

.ard__transfer-box-tail {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    flex-shrink: 0;
}

/* Figma horizontal divider: 48×2px, dash 2/2, #D1D5DB — scaled ~41×2 for 1230px */
.ard__transfer-box-rail {
    flex: 0 0 2.5625rem;
    width: 2.5625rem;
    min-width: 2.5625rem;
    max-width: 2.5625rem;
    height: 2px;
    margin: 0;
    border: none;
    background: repeating-linear-gradient(
        90deg,
        #d1d5db 0 2px,
        transparent 2px 4px
    );
    align-self: center;
}

.ard__transfer-box--to {
    width: 100%;
}

.ard__transfer-box--to .ard__transfer-box-content--to {
    padding-right: 0.15rem;
}

.ard__transfer-box-icon {
    flex-shrink: 0;
    display: block;
}

.ard__transfer-box-icon--earth,
.ard__transfer-box-icon--home {
    width: var(--ard-transfer-icon-earth);
    height: var(--ard-transfer-icon-home);
}

.ard__transfer-box-text {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    line-height: 1.0625rem;
    letter-spacing: 0;
    color: #334155;
    text-decoration: underline;
    text-decoration-color: #d1d5db;
    text-decoration-thickness: 1px;
    text-underline-offset: 0.2em;
}

.ard__transfer-row {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.ard__transfer-row .ard__transfer-box {
    flex: 1;
    min-width: 10rem;
}

.ard__transfer-nights {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    flex-shrink: 0;
    padding: 0.2rem 0.5rem;
    border: 1px solid #e5e7eb;
    border-radius: 999px;
    background: #fff;
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.625rem;
    font-weight: 600;
    line-height: 1;
    color: #475569;
    white-space: nowrap;
}

.ard__transfer-moon-icon {
    flex-shrink: 0;
    display: block;
    width: 0.478125rem;
    height: 0.478125rem;
}

.ard__transfer-link {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    line-height: 1.0625rem;
    color: #334155;
    text-decoration: underline;
    text-underline-offset: 0.12em;
    white-space: nowrap;
}

.ard__transfer-link i {
    font-size: 0.62rem;
    margin-left: 0.15rem;
}

.ard__day-experiences {
    margin-top: clamp(1.75rem, 3vw, 2.25rem);
    padding-top: 0;
    border-top: none;
}

.ard__day-detail-card .ard__day-experiences {
    border-top: none;
}

.ard__day-experiences[hidden] {
    display: none !important;
}

.ard__day-experiences-nav {
    display: flex;
    gap: 0.35rem;
}

.ard__day-experiences-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1rem;
}

.ard__day-experiences-nav .ard__hero-arrow {
    width: 1.75rem;
    height: 1.75rem;
    border: 1px solid #e5e0db;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.62rem;
    color: #9a8f88;
    padding: 0;
}

.ard__exp-swiper {
    overflow: hidden;
}

.ard__day-experiences .swiper-slide {
    height: auto;
}

.ard__day-experiences .swiper-slide img {
    display: block;
    width: 100%;
    aspect-ratio: 266 / 224;
    height: auto;
    object-fit: cover;
    border-radius: 12px;
}

.ard__day-experiences .ard__day-block-label h5 {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0;
    color: #334155;
}

.ard__day-experiences-copy {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.8125rem;
    font-weight: 300;
    line-height: 1.25rem;
    letter-spacing: 0;
    color: #5e5e5e;
    margin: 1rem 0 0;
}

.ard__day-meals {
    margin-top: clamp(1.75rem, 3vw, 2.25rem);
    padding-top: 0;
    padding-bottom: 0.625rem;
    border-top: none;
}

.ard__day-meals[hidden] {
    display: none !important;
}

.ard__day-meals-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 2rem;
}

.ard__day-meals .ard__day-block-label {
    color: var(--ard-rhythm-accent, #984629);
}

.ard__day-meals .ard__day-block-label span {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.75rem;
    font-weight: 400;
    line-height: 1.0625rem;
    letter-spacing: 0;
    text-transform: none;
    color: #475569;
}

.ard__day-meals-link {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.625rem;
    font-weight: 600;
    line-height: 1rem;
    color: #1e293b;
    text-decoration: underline;
    text-underline-offset: 0.12em;
    white-space: nowrap;
}

.ard__day-meals-link i {
    font-size: 0.5625rem;
    margin-left: 0.15rem;
}

.ard__meals-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.0625rem;
    align-items: stretch;
    padding: 0;
    border: none;
    background: transparent;
}

.ard__meal-card {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    padding: 1.125rem;
    min-height: 8.125rem;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    background: #fdfdfd;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.ard__meal-label {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.5rem;
    font-weight: 600;
    line-height: 0.84375rem;
    letter-spacing: 0.05625rem;
    text-transform: uppercase;
    color: #6b7280;
    margin: 0;
}

.ard__meal-status {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.65625rem;
    font-weight: 600;
    line-height: 1.0625rem;
    margin: 0;
}

.ard__meal-dot {
    flex-shrink: 0;
    width: 0.375rem;
    height: 0.375rem;
    border-radius: 50%;
    background: currentColor;
}

.ard__meal-status--yes {
    color: #984629;
}

.ard__meal-status--yes .ard__meal-dot {
    background: #984629;
}

.ard__meal-status--no {
    color: #1e293b;
}

.ard__meal-status--no .ard__meal-dot {
    background: #d1d5db;
    border: none;
}

.ard__meal-type {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.5rem;
    font-weight: 600;
    line-height: 0.84375rem;
    letter-spacing: 0.05625rem;
    text-transform: uppercase;
    color: #6b7280;
    margin: 0;
}

.ard__meal-desc {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.6875rem;
    font-weight: 300;
    line-height: 1.0625rem;
    color: #5e5e5e;
    margin: 0;
}

/* Spaces coverflow */
.ard__spaces {
    padding-top: 0.5rem;
}

.ard__spaces-title {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: clamp(1.875rem, 3.4vw, 2.375rem);
    font-weight: 300;
    font-style: normal;
    line-height: 1.76;
    letter-spacing: -0.032em;
    color: #1a1c1c;
    text-align: center;
    max-width: 27.75rem;
    margin: 0 auto clamp(1rem, 2.5vw, 1.35rem);
}

.ard__spaces-title em {
    font-family: inherit;
    font-style: normal;
    font-weight: inherit;
    color: inherit;
}

@media (min-width: 1000px) {
    .ard__spaces-title {
        font-size: 2.375rem;
        letter-spacing: -0.076rem;
        line-height: 4.15rem;
    }
}

.ard__spaces-lead {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: clamp(0.875rem, 1.5vw, 0.9609375rem);
    font-weight: 300;
    font-style: italic;
    line-height: 1.625;
    letter-spacing: 0.01em;
    color: #474741;
    text-align: center;
    max-width: 58.75rem;
    margin: 0 auto clamp(1.25rem, 2.5vw, 1.65rem);
}

@media (min-width: 1000px) {
    .ard__spaces-lead {
        font-size: 0.9609375rem;
        line-height: 1.56rem;
        letter-spacing: 0.01125rem;
    }
}

.ard__spaces-carousel {
    position: relative;
    display: flex;
    align-items: center;
    gap: clamp(0.35rem, 1.2vw, 0.75rem);
    min-height: clamp(18.5rem, 45vw, 35rem);
    max-width: 65rem;
    margin: -0.5rem auto 0;
}

.ard__spaces-carousel .ard__spaces-swiper {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    padding: 0.35rem 0 0.35rem;
}

.ard__spaces-arrow {
    flex-shrink: 0;
    width: 2rem;
    height: 2rem;
    border: 1px solid #e5e0db;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.92);
    color: #9a8f88;
    font-size: 0.65rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: color 0.2s ease, border-color 0.2s ease;
}

.ard__spaces-arrow:hover:not(:disabled) {
    color: var(--ard-accent);
    border-color: #d4c9c0;
}

.ard__spaces-arrow:disabled,
.ard__spaces-arrow.swiper-button-disabled {
    opacity: 0.35;
    cursor: default;
    pointer-events: none;
}

.ard__spaces .swiper-slide {
    width: clamp(14.5rem, 29vw, 24rem);
    border-radius: 1.15rem;
    overflow: hidden;
    position: relative;
    transition: opacity 0.35s ease;
}

.ard__spaces .swiper-slide:not(.swiper-slide-active) {
    opacity: 0.45;
}

.ard__spaces .swiper-slide-active {
    opacity: 1;
}

.ard__spaces img {
    display: block;
    width: 100%;
    height: clamp(16.25rem, 35vw, 25.5rem);
    object-fit: cover;
}

.ard__spaces-caption {
    position: absolute;
    left: 0.75rem;
    right: 0.75rem;
    bottom: 0.75rem;
    padding: 0.65rem 0.8rem;
    border-radius: 0.7rem;
    background: rgba(255, 255, 255, 0.72);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.55);
}

.ard__spaces-tag {
    display: inline-block;
    padding: 0.28rem 0.65rem;
    margin-bottom: 0.45rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    font-family: var(--ard-sans);
    font-size: 0.58rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #6d5b52;
}

.ard__spaces-caption strong {
    display: block;
    font-family: var(--ard-serif);
    font-size: clamp(0.92rem, 1.8vw, 1.02rem);
    font-weight: 600;
    line-height: 1.3;
    color: var(--ard-text);
}

.ard__spaces-pagination {
    position: static !important;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.45rem;
    margin-top: -0.55rem;
}

.ard__spaces-pagination .swiper-pagination-bullet {
    width: 0.45rem;
    height: 0.45rem;
    margin: 0 !important;
    background: #d8d0ca;
    opacity: 1;
    transition: background 0.2s ease, transform 0.2s ease;
}

.ard__spaces-pagination .swiper-pagination-bullet-active {
    background: var(--ard-accent);
    transform: scale(1.15);
}

.ard__spaces-note {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: clamp(0.5625rem, 1vw, 0.6375rem);
    font-weight: 500;
    line-height: 1.625;
    letter-spacing: 0.075rem;
    color: rgba(71, 71, 65, 0.6);
    text-align: center;
    max-width: 42rem;
    margin: 1.85rem auto 0;
}

@media (min-width: 1000px) {
    .ard__spaces-note {
        font-size: 0.6375rem;
        line-height: 1.035rem;
        letter-spacing: 0.075rem;
        max-width: 41.875rem;
    }
}

/* Retreat space */
.ard__retreat-space {
    margin-top: clamp(2.5rem, 5vw, 3.5rem);
}

.ard__retreat-space-title {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: clamp(1.875rem, 3.4vw, 2.375rem);
    font-weight: 300;
    font-style: normal;
    line-height: 1.6;
    letter-spacing: -0.04em;
    color: #1a1c1c;
    text-align: center;
    max-width: 33.5rem;
    margin: 0 auto clamp(0.85rem, 2vw, 1rem);
}

@media (min-width: 1000px) {
    .ard__retreat-space-title {
        font-size: 2.375rem;
        line-height: 3.825rem;
        letter-spacing: -0.096rem;
    }
}

.ard__retreat-space-lead {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: clamp(0.9375rem, 1.6vw, 1.125rem);
    font-weight: 200;
    font-style: normal;
    line-height: 1.4;
    letter-spacing: 0;
    color: #55433d;
    text-align: center;
    max-width: 35rem;
    margin: 0 auto clamp(2.25rem, 4.5vw, 3.25rem);
}

@media (min-width: 1000px) {
    .ard__retreat-space-lead {
        font-size: 1.125rem;
        line-height: 1.575rem;
    }
}

.ard__retreat-space-divider {
    border: none;
    border-top: 1px solid var(--ard-border);
    margin: 0 0 clamp(1.75rem, 3.5vw, 2.25rem);
}

.ard__space-panel {
    width: min(64rem, 100%);
    max-width: 64rem;
    margin: 0 auto;
    border-top: 1px solid var(--ard-border);
    border-bottom: 1px solid var(--ard-border);
    border-left: none;
    border-right: none;
    padding: clamp(1.75rem, 3.5vw, 2.5rem) 0;
    box-sizing: border-box;
}

.ard__space-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(1rem, 2vw, 1.5rem);
    align-items: start;
}

@media (min-width: 1000px) {
    .ard__space-grid {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        gap: 0.85rem;
        width: 100%;
        margin: 0 auto;
    }

    .ard__space-copy {
        width: 100%;
        min-width: 0;
    }
}

.ard__space-media {
    min-width: 0;
}

.ard__space-slider {
    width: 100%;
    max-width: 100%;
}

.ard__space-slider img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: 1rem;
    display: block;
}

@media (min-width: 1000px) {
    .ard__space-slider,
    .ard__space-slider-foot {
        width: 92%;
        max-width: 92%;
    }
}

.ard__space-slider-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 0.85rem;
    gap: 0.75rem;
}

.ard__space-slider-pagination {
    position: static !important;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    width: auto !important;
}

.ard__space-slider-pagination .swiper-pagination-bullet {
    width: 0.45rem;
    height: 0.45rem;
    margin: 0 !important;
    background: #d8d0ca;
    opacity: 1;
}

.ard__space-slider-pagination .swiper-pagination-bullet-active {
    background: var(--ard-accent);
}

.ard__space-slider-nav {
    display: flex;
    align-items: center;
    gap: 1.125rem;
}

.ard__space-slider-arrow {
    width: auto;
    height: auto;
    border: none;
    border-radius: 0;
    background: transparent;
    color: #5c4f48;
    font-size: 1.125rem;
    line-height: 1;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.15rem;
    transition: color 0.2s ease;
}

.ard__space-slider-arrow:hover:not(:disabled) {
    color: var(--ard-accent);
}

.ard__space-slider-arrow:disabled {
    opacity: 0.35;
    cursor: default;
}

.ard__space-copy h3 {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: clamp(1.125rem, 2.1vw, 1.5rem);
    font-weight: 500;
    font-style: normal;
    line-height: 1;
    letter-spacing: 0.025rem;
    color: rgba(85, 67, 61, 0.7);
    margin: 0 0 0.35rem;
}

@media (min-width: 1000px) {
    .ard__space-copy h3 {
        font-size: 1.5rem;
        letter-spacing: 0.025rem;
    }
}

.ard__space-prose {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: clamp(0.8125rem, 1.35vw, 0.875rem);
    font-weight: 300;
    line-height: 1.65;
    color: #6f625a;
}

@media (min-width: 1000px) {
    .ard__space-prose {
        font-size: 0.875rem;
        line-height: 1.55;
    }

    .ard__space-prose--figma {
        font-size: 0.875rem;
        line-height: 1.5;
        letter-spacing: 0.01em;
    }

    .ard__space-prose--figma p {
        overflow-wrap: normal;
        hyphens: none;
    }
}

.ard__space-prose p {
    margin-bottom: 0.65rem;
}

.ard__space-prose--figma p {
    margin-bottom: 0.75rem;
}

.ard__space-prose--figma p:last-child {
    margin-bottom: 0;
}

.ard__space-location {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: clamp(0.9375rem, 1.6vw, 1.125rem);
    font-weight: 300;
    line-height: 1.4;
    color: #9a8f88;
    margin-bottom: 0.85rem;
}

.ard__space-prose p:last-child {
    margin-bottom: 0;
}

.ard__space-certs {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    align-items: center;
    justify-items: center;
    gap: clamp(0.35rem, 1.25vw, 0.75rem);
    width: 100%;
    margin: 1.35rem 0 1rem;
}

.ard__space-cert-logo {
    width: auto;
    height: auto;
    max-width: clamp(3.25rem, 8vw, 5.0625rem);
    max-height: clamp(3.3rem, 8.2vw, 5.125rem);
    object-fit: contain;
    object-position: center;
    display: block;
}

@media (min-width: 1000px) {
    .ard__space-cert-logo {
        width: 5.0625rem;
        height: 5.125rem;
        max-width: 5.0625rem;
        max-height: 5.125rem;
    }
}

.ard__space-cert-wordmark {
    display: inline-flex;
    align-items: center;
    min-height: 1.65rem;
    font-family: var(--ard-sans);
    font-size: 0.58rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: #5c4f48;
    white-space: nowrap;
}

.ard__space-info {
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
    margin-top: 0.35rem;
    padding: 0.9375rem 2rem;
    border-radius: 0.9375rem;
    background: rgba(229, 231, 235, 0.3);
    width: 100%;
    max-width: 33.375rem;
    box-sizing: border-box;
}

.ard__space-info-text {
    margin: 0;
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.75rem;
    font-weight: 400;
    font-style: normal;
    line-height: 1.896;
    letter-spacing: 0;
    color: #4b5563;
}

.ard__space-info-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    align-self: flex-start;
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: 0.625rem;
    font-weight: 500;
    line-height: 2;
    letter-spacing: 0;
    color: rgba(152, 70, 41, 0.78);
    text-decoration: underline;
    text-decoration-thickness: 0.5px;
    text-underline-offset: 0.15em;
    transition: color 0.2s ease;
}

.ard__space-info-link:hover {
    color: var(--ard-accent);
}

.ard__space-info-link i {
    display: inline-block;
    width: 0.667rem;
    height: 0.667rem;
    font-size: 0.667rem;
    line-height: 1;
    color: #ad6d57;
    flex-shrink: 0;
}

/* Landscape — Figma ~1119px content in 1440 frame; fit-width centered like space panel */
.ard__landscape-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(1.25rem, 2.5vw, 2rem);
    width: min(64rem, 100%);
    max-width: 64rem;
    margin: clamp(1.75rem, 3.5vw, 2.25rem) auto 0;
    align-items: stretch;
}

.ard__landscape-copy {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    gap: clamp(1.25rem, 2.5vw, 1.5rem);
    width: 100%;
    min-width: 0;
    min-height: 0;
}

.ard__landscape-block {
    min-width: 0;
}

.ard__landscape-label {
    font-family: 'Inter', var(--ashrams-inter, 'Inter'), system-ui, sans-serif;
    font-size: clamp(1.375rem, 2.5vw, 1.59375rem);
    font-weight: 200;
    font-style: normal;
    line-height: 1.2;
    letter-spacing: 0;
    color: #1a1c1c;
    margin: 0 0 1.5rem;
}

@media (min-width: 1000px) {
    .ard__landscape-label {
        font-size: 1.59375rem;
        line-height: 1.2;
        margin-bottom: 1.375rem;
    }
}

/* Figma grid ~425×168 hug — tight rows, wider columns, icon + label centered */
.ard__landscape-block .ard__icon-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-auto-rows: min-content;
    align-items: center;
    row-gap: 1rem;
    column-gap: 0.75rem;
}

.ard__icon-grid--activities {
    margin-bottom: 0;
}

.ard__landscape-block .ard__icon-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    min-width: 0;
    /* Same row stride in both grids (landscape 2-line vs activities 1-line) */
    min-height: 1.875rem;
}

.ard__landscape-icon {
    flex-shrink: 0;
    width: 1.125rem;
    height: 1.125rem;
    margin-top: 0;
    object-fit: contain;
}

.ard__icon-label {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0;
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: 0.8125rem;
    font-weight: 300;
    font-style: normal;
    line-height: 1.1;
    letter-spacing: 0;
    color: #55433d;
}

.ard__icon-label-line {
    display: block;
    line-height: 1.1;
    margin: 0;
    padding: 0;
}

.ard__icon-label-line + .ard__icon-label-line {
    margin-top: 0;
}

.ard__icon-label-line--single {
    white-space: nowrap;
}

.ard__map-wrap,
.ard__map {
    width: 100%;
    min-height: 18rem;
    border-radius: 1.5rem;
    overflow: hidden;
    background: #e8eaed;
}

.ard__map-wrap {
    align-self: stretch;
}

.ard__map-frame {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 18rem;
    border: 0;
}

/* Desktop: lists nudged slightly toward map; map size + right edge unchanged */
@media (min-width: 1000px) {
    .ard__landscape-grid {
        --ard-landscape-list-width: 21rem;
        --ard-landscape-nudge: 1.5rem;
        --ard-map-slot-width: calc(64rem - 26.583rem - 2rem);
        grid-template-columns: var(--ard-landscape-nudge) var(--ard-landscape-list-width) minmax(0, 1fr);
        width: 100%;
        max-width: 64rem;
        gap: 1.75rem;
        margin-left: auto;
        margin-right: auto;
        align-items: stretch;
    }

    .ard__landscape-copy {
        grid-column: 2;
        width: var(--ard-landscape-list-width);
        max-width: var(--ard-landscape-list-width);
        align-self: start;
        justify-content: flex-start;
        gap: 1.5rem;
    }

    .ard__landscape-block .ard__icon-grid {
        width: 100%;
        max-width: 100%;
        row-gap: 1.125rem;
        column-gap: 0.75rem;
    }

    .ard__map-wrap {
        grid-column: 3;
        width: var(--ard-map-slot-width);
        max-width: var(--ard-map-slot-width);
        justify-self: end;
        margin-left: 0;
        height: 28.125rem;
        min-height: 28.125rem;
        aspect-ratio: 694 / 450;
        flex-shrink: 0;
    }

    .ard__map-frame {
        min-height: 28.125rem;
        height: 100%;
    }
}

/* Hosts */
.ard__hosts {
    --ard-host-photo-size: calc(15rem - 2px);
    --ard-host-copy-max: 26rem;
    --ard-host-quote-max: 30rem;
    --ard-host-bio-max: 29rem;
    --ard-host-bio-chars: 53ch;
    --ard-host-gap: 250px;
    margin-top: clamp(10rem, 22vw, 16rem);
    margin-bottom: 200px;
    max-width: 56rem;
    margin-left: auto;
    margin-right: auto;
}

/* Figma — Guided by Wisdom: Ysabeau 45/40 #1A1C1C; lead Manrope 18/28 #55433D */
.ard__hosts .ard__hosts-title {
    font-family: 'Ysabeau Infant', var(--ashrams-nav-font, 'Ysabeau Infant'), serif;
    font-size: clamp(1.875rem, 4vw, 2.5rem);
    font-weight: 300;
    font-style: normal;
    line-height: 2.125rem;
    letter-spacing: 0;
    color: #1a1c1c;
    text-align: center;
    max-width: 22.625rem;
    margin: 0 auto clamp(1.25rem, 3vw, 1.75rem);
}

.ard__hosts .ard__hosts-title em {
    font-family: inherit;
    font-style: normal;
    font-weight: 300;
    color: #1a1c1c;
}

.ard__hosts .ard__hosts-lead {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: 1rem;
    font-weight: 200;
    font-style: normal;
    line-height: 1.625rem;
    letter-spacing: 0;
    color: #55433d;
    text-align: center;
    max-width: 15.0625rem;
    margin: 0 auto clamp(2rem, 4vw, 2.75rem);
}

.ard__host-row {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: var(--ard-host-gap);
    margin-bottom: clamp(2.5rem, 5vw, 3.5rem);
}

.ard__host-row:last-child {
    margin-bottom: 0;
}

.ard__host-copy {
    flex: 0 1 var(--ard-host-bio-max);
    min-width: 0;
    max-width: var(--ard-host-bio-max);
}

/* Figma 1440 — host name: Manrope 36/56, -0.48px, #333128 (scaled down slightly) */
.ard__host-name {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: clamp(1.625rem, 3vw, 2rem);
    font-weight: 300;
    font-style: normal;
    line-height: clamp(2.25rem, 3.6vw, 3.125rem);
    letter-spacing: -0.03rem;
    margin: 0 0 0.65rem;
    color: #333128;
}

.ard__host-role {
    font-family: var(--ard-sans);
    font-size: 0.675rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ard-accent);
    margin: 0 0 1.2rem;
}

.ard__host-bio {
    font-family: var(--ard-sans);
    font-size: 0.875rem;
    line-height: 1.65;
    color: #6f625a;
    max-width: none;
    width: auto;
}

.ard__host-bio p {
    margin: 0 0 0.75rem;
    max-width: var(--ard-host-bio-chars);
    width: var(--ard-host-bio-chars);
}

.ard__host-bio p:last-child {
    margin-bottom: 0;
}

.ard__host-media {
    position: relative;
    flex: 0 0 var(--ard-host-photo-size);
    align-self: start;
    transform: translateY(5px);
    box-sizing: border-box;
    width: var(--ard-host-photo-size);
    height: var(--ard-host-photo-size);
    min-width: var(--ard-host-photo-size);
    max-width: var(--ard-host-photo-size);
    min-height: var(--ard-host-photo-size);
    max-height: var(--ard-host-photo-size);
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border-radius: 999px;
}

/* Absolute fill — overrides Bootstrap / ashrams-responsive img { height: auto } */
body.ashrams-retreat-detail-page .ard__host-media img {
    position: absolute;
    inset: 0;
    display: block;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    max-width: none;
    max-height: none;
    border-radius: 999px;
    object-fit: cover;
    object-position: center center;
    filter: grayscale(100%);
}

.ard__host-quote {
    position: relative;
    max-width: var(--ard-host-quote-max);
    width: var(--ard-host-quote-max);
    border-left: none;
    padding-left: 1.35rem;
    margin: 1.75rem 0 clamp(2rem, 4vw, 2.75rem);
    font-family: 'Be Vietnam Pro', var(--ashrams-sans, 'Manrope'), system-ui, sans-serif;
    font-weight: 300;
    font-style: italic;
    font-size: 0.875rem;
    line-height: 1.5rem;
    color: #984629;
}

.ard__host-quote::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: calc(100% + 0.5rem);
    background-color: #4a473e;
}

/* Dining */
.ard__dining {
    --ard-dining-copy-max: 24rem;
    --ard-dining-lead-max: 21rem;
    --ard-dining-meta-max: 21rem;
    --ard-dining-media-offset-x: 2.75rem;
    --ard-dining-media-offset-y: 3rem;
    --ard-dining-media-width-bump: 0.75rem;
    margin-top: clamp(4rem, 8vw, 5.5rem);
    max-width: 56rem;
    margin-left: auto;
    margin-right: auto;
}

.ard__dining-copy {
    max-width: var(--ard-dining-copy-max);
}

/* Figma — Retreat Dining: Ysabeau 45/56; lead Manrope 18/32 #49473F */
.ard__dining-title {
    font-family: 'Ysabeau Infant', var(--ashrams-nav-font, 'Ysabeau Infant'), serif;
    font-size: 2.5rem;
    font-weight: 300;
    font-style: normal;
    line-height: 3rem;
    letter-spacing: 0;
    color: var(--ard-text);
    text-align: left;
    max-width: var(--ard-dining-copy-max);
    margin: 0 0 1.5rem;
}

.ard__dining-title em {
    font-family: inherit;
    font-style: normal;
    font-weight: 300;
    color: inherit;
}

.ard__stays-title {
    font-family: var(--ashrams-inter, 'Inter', system-ui, sans-serif);
    font-size: clamp(1.75rem, 3.5vw, 2.8125rem);
    font-weight: 400;
    line-height: clamp(2.1875rem, 4.375vw, 3.5rem);
    letter-spacing: -0.48px;
    text-align: center;
    margin: 0 0 clamp(1.75rem, 3.5vw, 2.25rem);
    color: var(--ard-text);
}

.ard__stays-title em {
    font-style: normal;
    color: var(--ard-accent);
}

.ard__dining-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(1.5rem, 3vw, 2.25rem);
    align-items: start;
}

.ard__dining-lead {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: 1rem;
    font-weight: 300;
    line-height: 1.75rem;
    letter-spacing: 0;
    color: #49473f;
    max-width: var(--ard-dining-lead-max);
    margin-bottom: 2.25rem;
}

.ard__dining-lead p {
    margin: 0;
    font-family: inherit;
}

.ard__dining-label {
    font-family: var(--ard-sans);
    font-size: 0.58rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #9a8f88;
    margin: 0 0 0.65rem;
}

.ard__dining-lead + .ard__dining-label {
    font-size: 0.75rem;
    margin-bottom: 0.9rem;
    max-width: var(--ard-dining-meta-max);
}

.ard__meal-icons {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem 1rem;
    max-width: var(--ard-dining-meta-max);
    margin: 0;
    padding-bottom: 1.15rem;
    border-bottom: 1px solid #e8e5df;
}

.ard__meal-icons + .ard__dining-label {
    font-size: 0.75rem;
    max-width: var(--ard-dining-meta-max);
    margin-top: 1.15rem;
    margin-bottom: 0.85rem;
}

.ard__meal-icons span {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0.65rem;
    font-family: 'Be Vietnam Pro', var(--ashrams-sans, 'Manrope'), system-ui, sans-serif;
    font-size: 0.8rem;
    font-weight: 400;
    font-style: normal;
    color: #1a1c1b;
    text-align: left;
    white-space: nowrap;
}

.ard__meal-icons i {
    flex-shrink: 0;
    font-size: 1.25rem;
    color: var(--ard-accent);
}

.ard__diet-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    max-width: var(--ard-dining-meta-max);
}

.ard__diet-tags span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 1 1 0;
    min-width: 0;
    padding: 0.4rem 0.55rem;
    border-radius: 0.35rem;
    background: var(--ard-accent);
    color: #fff;
    font-family: var(--ard-sans);
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-align: center;
}

.ard__dining-media {
    min-width: 0;
    position: relative;
    overflow: visible;
}

.ard__dining-slider,
.ard__dining-slider-foot {
    width: 100%;
}

@media (min-width: 1000px) {
    .ard__meal-icons,
    .ard__diet-tags {
        flex-wrap: nowrap;
    }

    .ard__dining-media {
        left: var(--ard-dining-media-offset-x);
        top: var(--ard-dining-media-offset-y);
    }

    .ard__dining-slider,
    .ard__dining-slider-foot {
        width: calc(100% + var(--ard-dining-media-width-bump));
    }
}

.ard__dining-slider img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: 1rem;
    display: block;
    /* Figma drop shadow — X 0, Y 25, blur 50, spread -12, #000 25% */
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

.ard__dining-slider-foot,
.ard__room-slider-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 0.85rem;
    gap: 0.75rem;
}

.ard__dining-slider-pagination,
.ard__room-slider-pagination {
    position: static !important;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    width: auto !important;
}

.ard__dining-slider-pagination .swiper-pagination-bullet,
.ard__room-slider-pagination .swiper-pagination-bullet {
    width: 0.45rem;
    height: 0.45rem;
    margin: 0 !important;
    background: #d8d0ca;
    opacity: 1;
}

.ard__dining-slider-pagination .swiper-pagination-bullet-active,
.ard__room-slider-pagination .swiper-pagination-bullet-active {
    background: var(--ard-accent);
}

.ard__dining-slider-nav,
.ard__room-slider-nav {
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.ard__dining-slider-arrow,
.ard__room-slider-arrow {
    width: 1.75rem;
    height: 1.75rem;
    border: 1px solid #e5e0db;
    border-radius: 50%;
    background: #fff;
    color: #9a8f88;
    font-size: 0.62rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}

.ard__dining-slider-arrow:hover:not(:disabled),
.ard__room-slider-arrow:hover:not(:disabled) {
    color: var(--ard-accent);
    border-color: #d4c9c0;
}

/* Stays */
.ard__stays {
    margin-top: clamp(7rem, 15vw, 11rem);
    max-width: 56rem;
    margin-left: auto;
    margin-right: auto;
}

.ard__room {
    border-top: 1px solid var(--ard-border);
}

.ard__room:last-child {
    border-bottom: 1px solid var(--ard-border);
}

.ard__room-toggle {
    width: 100%;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 0.75rem;
    padding: 1.15rem 0;
    border: none;
    background: transparent;
    text-align: left;
    cursor: pointer;
}

.ard__room.is-open .ard__room-toggle {
    display: none;
}

.ard__room-toggle-name {
    font-family: var(--ashrams-inter, 'Inter', system-ui, sans-serif);
    font-size: 1.05rem;
    font-weight: 400;
    color: var(--ard-text);
}

.ard__room-toggle-price {
    display: inline-flex;
    align-items: baseline;
    gap: 0.35rem;
    white-space: nowrap;
}

.ard__room-toggle-price .ard__room-price-from {
    font-family: var(--ashrams-inter, 'Inter', system-ui, sans-serif);
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0;
    text-transform: none;
    color: var(--ard-muted);
}

.ard__room-toggle-price .ard__room-price-amount {
    font-family: var(--ard-serif);
    font-size: 1.05rem;
    font-weight: 500;
    color: var(--ard-text);
}

.ard__room-toggle i {
    color: #9a8f88;
    font-size: 0.75rem;
}

.ard__room-panel {
    display: none;
    padding: 0 0 1.75rem;
}

.ard__room.is-open .ard__room-panel {
    display: block;
}

.ard__room-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.ard__room-name {
    font-family: var(--ashrams-inter, 'Inter', system-ui, sans-serif);
    font-size: clamp(1.15rem, 2.2vw, 1.35rem);
    font-weight: 400;
    margin: 0;
    color: var(--ard-text);
}

.ard__room-close {
    width: 1.75rem;
    height: 1.75rem;
    border: none;
    background: transparent;
    color: #9a8f88;
    font-size: 0.85rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}

.ard__room-close:hover {
    color: var(--ard-accent);
}

.ard__room-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(1.25rem, 3vw, 2rem);
    align-items: start;
}

.ard__room-desc {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: clamp(0.95rem, 2.2vw, 1.125rem);
    font-weight: 400;
    line-height: clamp(1.65rem, 3.8vw, 2rem);
    letter-spacing: 0;
    color: #6f625a;
    margin-bottom: 1.15rem;
}

.ard__room-desc p {
    margin: 0;
}

.ard__room-amenities {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem 0.85rem;
    margin-bottom: 0;
}

.ard__room-amenities span {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    font-family: var(--ashrams-inter, 'Inter', system-ui, sans-serif);
    font-size: 0.68rem;
    font-weight: 400;
    color: var(--ard-accent);
    line-height: 1.35;
}

.ard__room-amenities i {
    flex-shrink: 0;
    width: 0.85rem;
    text-align: center;
    font-size: 0.68rem;
}

.ard__room-media {
    min-width: 0;
}

.ard__room-slider img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    border-radius: 1rem;
    display: block;
}

.ard__room-actions {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 1.5rem;
}

.ard__room-price {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.ard__room-price-from {
    font-family: var(--ashrams-inter, 'Inter', system-ui, sans-serif);
    font-size: 0.58rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #9a8f88;
}

.ard__room-price-amount {
    font-family: var(--ard-serif);
    font-size: clamp(1.45rem, 2.5vw, 1.875rem);
    font-weight: 500;
    line-height: 1.1;
    color: var(--ard-text);
}

.ard__select-btn {
    display: inline-block;
    padding: 0.65rem 1.75rem;
    border-radius: 999px;
    background: var(--ard-accent);
    color: #fff;
    font-family: var(--ashrams-inter, 'Inter', system-ui, sans-serif);
    font-size: 0.875rem;
    font-weight: 400;
    letter-spacing: 0;
    text-transform: none;
    text-decoration: none;
    border: none;
    cursor: pointer;
    flex-shrink: 0;
}

.ard__availability .ard__room-from {
    font-family: var(--ard-serif);
    font-size: 1.15rem;
}

/* Approach */
.ard__approach {
    padding-top: clamp(1rem, 3vw, 2rem);
}

/* Figma: Ysabeau Infant 45px / 72px lh, #18181B, centered */
.ard__approach-title {
    font-family: 'Ysabeau Infant', var(--ashrams-nav-font, 'Ysabeau Infant'), serif;
    font-size: clamp(1.75rem, 3.2vw, 2.8125rem);
    font-weight: 400;
    font-style: normal;
    line-height: 1.6;
    letter-spacing: 0;
    text-align: center;
    max-width: 42.625rem;
    margin: 0 auto clamp(1rem, 2.5vw, 1.35rem);
    color: #18181b;
}

.ard__approach-sub {
    font-family: var(--ashrams-inter, 'Inter', system-ui, sans-serif);
    font-size: clamp(0.9375rem, 1.6vw, 1.125rem);
    font-weight: 200;
    font-style: normal;
    line-height: 1.5;
    text-align: center;
    text-transform: lowercase;
    color: #71717a;
    max-width: 38rem;
    margin: 0 auto clamp(3.75rem, 7vw, 5rem);
}

.ard__steps {
    --ard-steps-gap: clamp(1.5rem, 2.5vw, 2.25rem);
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    column-gap: var(--ard-steps-gap);
    row-gap: 0;
    max-width: 52rem;
    margin: 0 auto;
    transform: translateX(clamp(0.75rem, 1.5vw, 1.25rem));
}

.ard__steps-rail {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: subgrid;
    align-items: center;
    margin-bottom: 1.375rem;
}

.ard__steps-rail-cell {
    display: flex;
    align-items: center;
    min-width: 0;
}

.ard__steps-rail-cell::after {
    content: '';
    flex: 1;
    height: 1px;
    margin-left: 0.5rem;
    margin-right: calc(-1 * var(--ard-steps-gap) + 0.5rem);
    background: #ece8e3;
}

.ard__steps-rail-cell:last-child::after {
    margin-right: 0;
}

.ard__step {
    min-width: 0;
}

.ard__step-num {
    font-family: var(--ashrams-inter, 'Inter', system-ui, sans-serif);
    font-size: 0.75rem;
    font-weight: 400;
    line-height: 1;
    letter-spacing: 0;
    color: #d87756;
}

/* Figma step title: Inter ~17px/26px 400 #18181B */
.ard__step h4 {
    font-family: var(--ashrams-inter, 'Inter', system-ui, sans-serif);
    font-size: clamp(0.9375rem, 1.3vw, 1.0625rem);
    font-weight: 400;
    line-height: 1.529412;
    letter-spacing: 0;
    color: #18181b;
    margin: 0 0 0.45rem;
}

/* Figma step body: Manrope ~13px/21px 200 #71717A */
.ard__step p {
    font-family: var(--ashrams-manrope, 'Manrope', system-ui, sans-serif);
    font-size: 0.8125rem;
    font-weight: 200;
    line-height: 1.615385;
    letter-spacing: 0;
    color: #71717a;
    max-width: 10rem;
    margin: 0;
}

/* Coverage */
.ard__coverage {
    margin-top: clamp(8rem, 16vw, 12rem);
}

/* Figma: Ysabeau Infant 45px / 72px lh, #18181B, centered */
.ard__coverage-title {
    font-family: 'Ysabeau Infant', var(--ashrams-nav-font, 'Ysabeau Infant'), serif;
    font-size: clamp(1.75rem, 3.2vw, 2.8125rem);
    font-weight: 300;
    font-style: normal;
    line-height: 1.6;
    letter-spacing: 0;
    text-align: center;
    max-width: 55.9375rem;
    margin: 0 auto clamp(1.75rem, 3.5vw, 2.25rem);
    color: #18181b;
}

/* Figma Background+Border+Shadow — slightly narrower than 960 for balance */
.ard__coverage-card {
    width: min(100%, 54rem);
    max-width: 54rem;
    margin: 0 auto;
    border: 1px solid #f3f4f6;
    border-radius: 2.5rem;
    background: #ffffff;
    box-shadow: 0 8px 30px 0 rgba(0, 0, 0, 0.06);
    overflow: hidden;
}

.ard__coverage-panel {
    --ard-coverage-pad-y: clamp(2rem, 4vw, 2.75rem);
    --ard-coverage-pad-x: clamp(2.35rem, 4.4vw, 3.15rem);
    --ard-coverage-pad-left: clamp(2.65rem, 4.8vw, 3.85rem);
    --ard-coverage-badge-size: 2rem;
    --ard-coverage-list-icon-w: 1.159375rem;
    --ard-coverage-label-gap: 0.75rem;
    --ard-coverage-divider: rgba(227, 221, 213, 0.3);
    border-bottom: 1px solid var(--ard-coverage-divider);
}

.ard__coverage-panel:last-child {
    border-bottom: none;
}

/* Figma: [top] → 70px → line → 20px → Including */
.ard__coverage-panel:first-child {
    padding-top: 70px;
}

.ard__coverage-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: var(--ard-coverage-pad-y) var(--ard-coverage-pad-x) var(--ard-coverage-pad-y) var(--ard-coverage-pad-left);
    border: none;
    background: #fff;
    text-align: left;
    cursor: pointer;
}

.ard__coverage-panel:first-child .ard__coverage-toggle {
    border-top: 1px solid var(--ard-coverage-divider);
    padding-top: 20px;
}

.ard__coverage-panel.is-open .ard__coverage-toggle {
    padding-bottom: 0;
}

.ard__coverage-toggle-main {
    display: flex;
    align-items: center;
    gap: var(--ard-coverage-label-gap);
    min-width: 0;
}

.ard__coverage-badge {
    width: var(--ard-coverage-badge-size);
    height: var(--ard-coverage-badge-size);
    flex-shrink: 0;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: var(--ard-accent);
    color: #fff;
    font-size: 0.8125rem;
}

/* Figma: Inter, #2D2A26 — slightly smaller than 24px */
.ard__coverage-toggle-label {
    font-family: var(--ashrams-inter, 'Inter', system-ui, sans-serif);
    font-size: clamp(1rem, 1.75vw, 1.25rem);
    font-weight: 300;
    line-height: 1.333333;
    letter-spacing: 0;
    color: #2d2a26;
}

.ard__coverage-toggle-icon {
    flex-shrink: 0;
    font-size: 0.85rem;
    color: #999;
}

.ard__coverage-panel-body {
    display: none;
    padding: 0 var(--ard-coverage-pad-x) var(--ard-coverage-pad-y);
    padding-left: var(--ard-coverage-pad-left);
}

.ard__coverage-panel.is-open .ard__coverage-panel-body {
    display: block;
    padding-top: 50px;
}

.ard__coverage-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

/* Figma: icons align with badge; text aligns with "Including" label */
.ard__coverage-list li {
    display: flex;
    align-items: flex-start;
    gap: calc(var(--ard-coverage-badge-size) + var(--ard-coverage-label-gap) - var(--ard-coverage-list-icon-w));
    margin-bottom: 1.75rem;
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: clamp(0.875rem, 1.25vw, 1rem);
    font-weight: 300;
    line-height: 2;
    color: #707070;
}

.ard__coverage-list li:last-child {
    margin-bottom: 0;
}

.ard__coverage-list-icon {
    width: var(--ard-coverage-list-icon-w);
    height: 0.826875rem;
    flex-shrink: 0;
    margin-top: calc((2em - 0.826875rem) / 2);
    display: block;
}

.ard__coverage-list li > i {
    color: #707070;
    width: 0.75rem;
    margin-top: calc((2em - 0.75rem) / 2);
    font-size: 0.75rem;
    flex-shrink: 0;
    text-align: center;
}

.ard__reviews {
    margin-top: clamp(8rem, 16vw, 12rem);
}

/* Figma: Ysabeau Infant 45px / 72px lh, #18181B, centered */
.ard__reviews-title {
    font-family: 'Ysabeau Infant', var(--ashrams-nav-font, 'Ysabeau Infant'), serif;
    font-size: clamp(1.75rem, 3.2vw, 2.8125rem);
    font-weight: 300;
    font-style: normal;
    line-height: 1.6;
    letter-spacing: 0;
    text-align: center;
    max-width: 55.9375rem;
    margin: 0 auto clamp(1.75rem, 3.5vw, 2.25rem);
    color: #18181b;
}

.ard__testimonials {
    display: flex;
    flex-direction: column;
    gap: clamp(1.75rem, 3.5vw, 2.25rem);
    max-width: min(100%, 52rem);
    margin: 0 auto;
}

/* Testimonials — Figma layout; slightly stronger soft grey shadow for white page */
.ard__testimonial {
    display: flex;
    flex-direction: column;
    padding: clamp(1.35rem, 3.33vw, 3rem);
    border: none;
    border-radius: 20px;
    background: #ffffff;
    box-shadow:
        0 12px 32px 0 rgba(24, 24, 27, 0.08),
        0 2px 8px 0 rgba(24, 24, 27, 0.04);
}

.ard__testimonial-content {
    width: 94%;
    max-width: 94%;
    margin: 0 auto;
}

.ard__testimonial blockquote {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: clamp(0.9375rem, 1.35vw, 1rem);
    font-weight: 400;
    line-height: 1.65;
    color: #1b1c1c;
    margin-bottom: clamp(1rem, 2vw, 1.15rem);
}

.ard__testimonial blockquote::before,
.ard__testimonial blockquote::after {
    font-weight: 400;
    color: #1b1c1c;
}

.ard__testimonial blockquote::before {
    content: '"';
}

.ard__testimonial blockquote::after {
    content: '"';
}

.ard__testimonial-gallery {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(0.5rem, 1.25vw, 1.25rem);
    margin-bottom: clamp(1rem, 2vw, 1.15rem);
}

.ard__testimonial-gallery-cell {
    position: relative;
    min-width: 0;
    overflow: hidden;
    border-radius: 12px;
    aspect-ratio: 256 / 160;
}

.ard__testimonial-gallery img {
    width: 100%;
    height: 100%;
    aspect-ratio: 256 / 160;
    object-fit: cover;
    display: block;
    border-radius: 12px;
}

.ard__testimonial-author {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.ard__testimonial-avatar {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 999px;
    background: var(--ard-accent);
    color: #fff;
    display: grid;
    place-items: center;
    flex-shrink: 0;
    font-size: 0.9rem;
}

.ard__testimonial-author strong {
    display: block;
    font-family: var(--ashrams-inter, 'Inter', system-ui, sans-serif);
    font-size: clamp(0.875rem, 1.3vw, 0.9375rem);
    font-weight: 600;
    line-height: 1.3;
    color: var(--ard-text);
}

.ard__testimonial-author span {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: clamp(0.8125rem, 1.2vw, 0.875rem);
    line-height: 1.4;
    color: #707070;
}

/* FAQ + CTA */
.ard__faqs {
    margin-top: clamp(8rem, 16vw, 12rem);
}

/* Figma: Ysabeau Infant 45px / 72px lh, #18181B, centered */
.ard__faq-title {
    font-family: 'Ysabeau Infant', var(--ashrams-nav-font, 'Ysabeau Infant'), serif;
    font-size: clamp(1.75rem, 3.2vw, 2.8125rem);
    font-weight: 300;
    font-style: normal;
    line-height: 1.6;
    letter-spacing: 0;
    text-align: center;
    max-width: 55.9375rem;
    margin: 0 auto clamp(2.5rem, 5vw, 3.75rem);
    color: #18181b;
}

.ard__faq-card {
    max-width: 52rem;
    margin: 0 auto;
    border: 1px solid var(--ard-border);
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 10px 32px rgba(44, 36, 32, 0.06);
    overflow: hidden;
}

.ard__faq-item {
    --ard-faq-pad-y: clamp(1.45rem, 3vw, 1.9rem);
    --ard-faq-pad-x: clamp(1.65rem, 3.2vw, 2.35rem);
    --ard-faq-pad-left: clamp(1.95rem, 3.6vw, 3rem);
    --ard-faq-q-icon-size: 2rem;
    border-bottom: 1px solid var(--ard-border);
}

.ard__faq-item:last-child {
    border-bottom: none;
}

.ard__faq-q {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: var(--ard-faq-pad-y) var(--ard-faq-pad-x) var(--ard-faq-pad-y) var(--ard-faq-pad-left);
    border: none;
    background: #fff;
    text-align: left;
    cursor: pointer;
}

.ard__faq-item.is-open .ard__faq-q {
    padding-bottom: clamp(0.5rem, 1vw, 0.65rem);
}

.ard__faq-q-icon {
    width: var(--ard-faq-q-icon-size);
    height: var(--ard-faq-q-icon-size);
    flex-shrink: 0;
    border-radius: 999px;
    background: var(--ard-accent);
    color: #fff;
    display: grid;
    place-items: center;
    font-family: var(--ashrams-inter, 'Inter', system-ui, sans-serif);
    font-size: 0.8125rem;
    font-weight: 600;
    line-height: 1;
}

.ard__faq-q-text {
    flex: 1;
    min-width: 0;
    font-family: var(--ashrams-inter, 'Inter', system-ui, sans-serif);
    font-size: clamp(1.125rem, 2.1vw, 1.3125rem);
    font-weight: 300;
    line-height: 1.4;
    color: var(--ard-text);
}

.ard__faq-toggle {
    flex-shrink: 0;
    font-size: 0.85rem;
    color: var(--ard-muted);
}

.ard__faq-a {
    display: none;
    padding: 0 var(--ard-faq-pad-x) var(--ard-faq-pad-y);
    padding-left: calc(var(--ard-faq-pad-left) + var(--ard-faq-q-icon-size) + 0.75rem);
}

/* ~4.5 lines for packing-list answer (Figma) */
.ard__faq-a p {
    margin: 0;
    max-width: 36rem;
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: clamp(0.75rem, 1.15vw, 0.875rem);
    font-weight: 300;
    line-height: 1.65;
    color: #707070;
}

.ard__faq-item.is-open .ard__faq-a {
    display: block;
}

.ard__cta-box {
    max-width: 38rem;
    margin: clamp(9rem, 20vw, 18rem) auto 0;
    padding: clamp(2.35rem, 4.6vw, 3.15rem) clamp(2rem, 4vw, 2.75rem);
    border: 1.2px solid #984629;
    border-radius: 48px;
    background: #fff;
    text-align: center;
}

.ard__cta-lead {
    font-family: var(--ashrams-manrope, 'Manrope'), system-ui, sans-serif;
    font-size: clamp(0.9375rem, 1.4vw, 1rem);
    font-weight: 400;
    line-height: 1.65;
    color: #707070;
    margin: 0 0 clamp(1.35rem, 2.5vw, 1.65rem);
}

.ard__cta-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
}

.ard__faqs .ard__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 9.5rem;
    padding: 0.9rem 1.75rem;
    border-radius: 999px;
    font-family: var(--ashrams-inter, 'Inter', system-ui, sans-serif);
    font-size: 0.875rem;
    font-weight: 400;
    letter-spacing: 0;
    text-transform: none;
    text-decoration: none;
    border: 1px solid var(--ard-accent);
    cursor: pointer;
    transition: opacity 0.2s ease;
}

.ard__faqs .ard__btn:hover {
    opacity: 0.92;
}

.ard__faqs .ard__btn--fill {
    background: var(--ard-accent);
    color: #fff;
}

.ard__faqs .ard__btn--outline {
    background: #fff;
    color: var(--ard-accent);
}

.ard__availability {
    display: none;
    max-width: 28rem;
    margin: 2rem auto 0;
    padding: 1.15rem;
    border: 1px solid var(--ard-border);
    border-radius: 14px;
    background: #fff;
}

.ard__availability.is-revealed {
    display: block;
}

.ard__availability label {
    display: block;
    font-family: var(--ard-sans);
    font-size: 0.72rem;
    font-weight: 600;
    margin-bottom: 0.45rem;
}

.ard__date-input,
.ard__date-select {
    width: 100%;
    border: 1px solid var(--ard-border);
    border-radius: 10px;
    padding: 0.65rem 0.75rem;
    font-family: var(--ard-sans);
    font-size: 0.78rem;
    margin-bottom: 0.75rem;
}

.ard__date-display {
    font-family: var(--ard-sans);
    font-size: 0.78rem;
    color: var(--ard-muted);
    margin-bottom: 0.5rem;
}

/* Mobile bar */
.ard__mobile-bar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 50;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem 1rem calc(0.75rem + env(safe-area-inset-bottom));
    background: rgba(255, 255, 255, 0.98);
    border-top: 1px solid var(--ard-border);
    box-shadow: 0 -4px 20px rgba(44, 36, 32, 0.08);
}

.ard__mobile-price {
    font-family: var(--ard-sans);
    font-size: 0.95rem;
    font-weight: 600;
    margin: 0;
}

.ard__mobile-meta {
    font-family: var(--ard-sans);
    font-size: 0.72rem;
    color: var(--ard-muted);
    margin: 0;
}

/* Modal */
.ard__modal .modal-content {
    border: none;
    border-radius: 16px;
}

.ard__modal-gallery img {
    width: 100%;
    max-height: 70vh;
    object-fit: contain;
}

/* Responsive */
@media (min-width: 992px) {
    .ard__meal-card {
        min-height: 8.125rem;
    }
}

@media (max-width: 999px) {
    .ard__side-cta {
        display: none;
    }

    .ard__highlight-row,
    .ard__space-certs {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        row-gap: 1rem;
        max-width: 20rem;
        margin-left: auto;
        margin-right: auto;
    }

    .ard__space-grid,
    .ard__landscape-grid,
    .ard__dining-grid,
    .ard__room-grid,
    .ard__phases {
        grid-template-columns: 1fr;
        gap: 1.5rem;
        align-items: stretch;
    }

    .ard__phases {
        max-width: none;
    }

    .ard__phase,
    .ard__phase.is-active {
        height: auto;
        min-height: auto;
        padding: clamp(1rem, 2.2vw, 1.25rem);
    }

    .ard__days {
        max-width: none;
    }

    .ard__highlight-row--reverse .ard__highlight-copy,
    .ard__highlight-row--reverse .ard__highlight-media {
        order: unset;
    }

    .ard__highlight-row--reverse .ard__highlight-media {
        order: -1;
    }

    .ard__highlight-copy,
    .ard__highlight-row--reverse .ard__highlight-copy {
        display: block;
        max-width: none;
        margin-left: 0;
        padding-top: 0;
    }

    .ard__highlight-copy .ard__prose {
        display: block;
        flex: none;
        margin-top: 0;
    }

    .ard__highlight-row {
        margin-bottom: clamp(2.75rem, 6vw, 3.5rem);
    }

    .ard__steps {
        grid-template-columns: 1fr 1fr;
    }

    .ard__steps-rail-cell:nth-child(2n)::after {
        display: none;
    }

    .ard__meals-grid {
        grid-template-columns: 1fr;
    }

    .ard__spaces-carousel {
        min-height: auto;
    }

    .ard__spaces-arrow {
        display: none;
    }

    .ard__hosts {
        --ard-host-photo-size: calc(11.5rem - 2px);
        --ard-host-copy-max: min(22rem, 100%);
        --ard-host-bio-max: min(24rem, 100%);
        --ard-host-bio-chars: 53ch;
        --ard-host-gap: 80px;
    }

    .ard__host-row {
        flex-direction: column;
        align-items: center;
        gap: var(--ard-host-gap);
    }

    .ard__host-copy {
        margin-left: auto;
        margin-right: auto;
    }

    .ard__host-media {
        order: -1;
        align-self: center;
        transform: none;
    }

    .ard__hosts {
        margin-top: clamp(4rem, 10vw, 6rem);
        margin-bottom: clamp(3rem, 8vw, 5rem);
    }

    .ard__dining {
        max-width: 100%;
    }

    .ard__dining-copy,
    .ard__dining-title,
    .ard__dining-lead,
    .ard__dining-lead + .ard__dining-label,
    .ard__meal-icons,
    .ard__meal-icons + .ard__dining-label,
    .ard__diet-tags {
        max-width: 100%;
    }

    .ard__meal-icons,
    .ard__diet-tags {
        flex-wrap: wrap;
        gap: 0.65rem 0.85rem;
    }

    .ard__diet-tags span {
        flex: 0 1 auto;
        min-width: 4.75rem;
    }

    .ard__dining-slider,
    .ard__dining-slider-foot {
        width: 100%;
        max-width: 100%;
    }

    body.ashrams-retreat-detail-page {
        padding-bottom: 4.5rem;
    }
}

@media (max-width: 480px) {
    .ard__steps {
        grid-template-columns: 1fr;
    }

    .ard__steps-rail-cell::after {
        display: none;
    }

    .ard__reviews-title {
        white-space: normal;
    }

    .ard__landscape-block .ard__icon-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .ard__testimonial-gallery {
        gap: 0.5rem;
    }

    .ard__faq-a p {
        max-width: 100%;
    }
}
