.ayana-front-wrapper {
    --ayana-front-cream: #faf6f1;
    --ayana-front-card: #ffffff;
    --ayana-front-ink: #1f1814;
    --ayana-front-muted: #6e6156;
    --ayana-front-gold: #b48a57;
    --ayana-front-line: rgba(31, 24, 20, 0.08);
    --ayana-front-shadow: 0 18px 38px rgba(31, 24, 20, 0.08);
    max-width: 1180px;
    margin: 0 auto;
    padding: 24px 16px 56px;
    color: var(--ayana-front-ink);
}

.ayana-front-header {
    text-align: center;
    max-width: 820px;
    margin: 0 auto 32px;
}

.ayana-front-header-left {
    text-align: left;
    margin: 0 0 24px;
}

.ayana-front-eyebrow {
    display: inline-block;
    font-size: 12px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--ayana-front-gold);
    font-weight: 700;
    margin-bottom: 10px;
}

.ayana-front-header h1 {
    margin: 0 0 10px;
    font-size: clamp(2rem, 4vw, 3.4rem);
    line-height: 1.05;
}

.ayana-front-header p,
.ayana-front-copy-card p,
.ayana-front-copy-card li,
.ayana-front-card-body p {
    color: var(--ayana-front-muted);
}

.ayana-front-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 24px;
}

.ayana-front-card,
.ayana-front-copy-card,
.ayana-front-side-card,
.ayana-front-image-wrap {
    background: var(--ayana-front-card);
    border: 1px solid var(--ayana-front-line);
    border-radius: 24px;
    box-shadow: var(--ayana-front-shadow);
    overflow: hidden;
}

.ayana-front-card-media {
    display: block;
    aspect-ratio: 4 / 3;
    background: linear-gradient(135deg, #f2e7da, #e5d3c0);
}

.ayana-front-card-image,
.ayana-front-single-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.ayana-front-card-placeholder {
    display: block;
    width: 100%;
    height: 100%;
}

.ayana-front-card-body {
    padding: 20px;
}

.ayana-front-card-body h2 {
    margin: 0 0 10px;
    font-size: 1.35rem;
}

.ayana-front-card-body a,
.ayana-front-link,
.ayana-front-button {
    text-decoration: none;
}

.ayana-front-link {
    font-weight: 700;
    color: var(--ayana-front-gold);
}

.ayana-front-single-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.65fr) minmax(280px, 0.9fr);
    gap: 28px;
    align-items: start;
}

.ayana-front-image-wrap {
    margin-bottom: 24px;
}

.ayana-front-single-image {
    aspect-ratio: 16 / 10;
}

.ayana-front-copy-card {
    padding: 24px;
}

.ayana-front-copy-card h2,
.ayana-front-side-card h3 {
    margin-top: 0;
}

.ayana-front-list {
    margin: 0;
    padding-left: 18px;
}

.ayana-front-list li + li {
    margin-top: 10px;
}

.ayana-front-side-card {
    padding: 24px;
    position: sticky;
    top: 24px;
    background: linear-gradient(180deg, #fffdfb 0%, #f8f1ea 100%);
}

.ayana-front-price-label {
    font-weight: 700;
    margin: 0 0 16px;
}

.ayana-front-price-row + .ayana-front-price-row {
    margin-top: 18px;
    padding-top: 18px;
    border-top: 1px solid var(--ayana-front-line);
}

.ayana-front-price-row h3 {
    margin: 0 0 8px;
    font-size: 1.1rem;
}

.ayana-front-price-row p {
    margin: 0 0 14px;
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--ayana-front-ink);
}

.ayana-front-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 20px;
    border-radius: 999px;
    background: #1f1814;
    color: #fff;
    font-weight: 700;
}

.ayana-empty-state {
    text-align: center;
    color: var(--ayana-front-muted);
}

@media (max-width: 900px) {
    .ayana-front-single-shell {
        grid-template-columns: 1fr;
    }

    .ayana-front-side-card {
        position: static;
    }
}
