.calendar-section { padding: clamp(4.5rem, 7vw, 7rem) 0; }
.calendar-section--tight { padding-top: clamp(3rem, 5vw, 5rem); }
.calendar-content { width: min(1040px, calc(100% - 48px)); margin-inline: auto; }
.calendar-copy { width: min(900px, 100%); margin-inline: auto; }
.calendar-detail-hero { text-align: center; }
.calendar-detail-hero .hero__grid { display: block; }
.calendar-detail-hero .eyebrow { justify-content: center; }
.calendar-detail-hero h1, .calendar-detail-hero .hero__lead { margin-left: auto; margin-right: auto; }
.calendar-copy--center { text-align: center; }
.calendar-copy--center .eyebrow { justify-content: center; }
.calendar-copy--center ul { display: inline-block; text-align: left; }
.calendar-copy h2 { margin-bottom: 1.2rem; }
.calendar-copy p { color: rgba(242,239,233,0.82); font-size: 1.04rem; line-height: 1.85; }
.calendar-gallery-section .section-heading { text-align: center; }
.calendar-gallery-section .section-heading .eyebrow { justify-content: center; }
.calendar-overview-feature { display: grid; grid-template-columns: minmax(220px, 0.38fr) minmax(0, 0.62fr); gap: clamp(1.4rem, 4vw, 3rem); align-items: center; margin-bottom: clamp(3rem, 6vw, 5rem); padding: clamp(1.2rem, 3vw, 2rem); border: 1px solid var(--color-line); background: var(--color-surface-soft); }
.calendar-overview-feature__image img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; display: block; }
.calendar-overview-feature__body p:not(.eyebrow) { color: var(--color-muted); font-size: 1.05rem; line-height: 1.75; }
.calendar-overview-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; }
.calendar-overview-card { border: 1px solid var(--color-line); background: var(--color-surface-soft); overflow: hidden; }
.calendar-overview-card a { display: grid; gap: 0.65rem; }
.calendar-overview-card img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; display: block; }
.calendar-overview-card span, .calendar-overview-card strong, .calendar-overview-card small { padding-inline: 1rem; }
.calendar-overview-card span { color: var(--color-accent); font-size: 0.72rem; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; }
.calendar-overview-card strong { font-size: 1.15rem; line-height: 1.15; }
.calendar-overview-card small { padding-bottom: 1rem; color: var(--color-muted); font-size: 0.92rem; line-height: 1.5; }
.calendar-gallery-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 0.9rem; margin-inline: auto; }
.calendar-tile { border: 1px solid var(--color-line); background: var(--color-surface-soft); overflow: hidden; box-shadow: none; text-align: left; }
.calendar-tile a { display: block; background: #090c11; }
.calendar-tile img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; display: block; transition: transform 0.45s ease; }
.calendar-tile:hover img { transform: scale(1.035); }
.calendar-tile__body { padding: 0.85rem; }
.calendar-tile__body .eyebrow { margin-bottom: 0.45rem; font-size: 0.62rem; letter-spacing: 0.22em; }
.calendar-tile__body h3 { margin: 0 0 0.25rem; font-size: 0.98rem; letter-spacing: -0.02em; }
.calendar-tile__body p { margin: 0; color: var(--color-muted); font-size: 0.86rem; line-height: 1.45; }
.calendar-order { width: min(900px, 100%); margin-inline: auto; text-align: center; }
.calendar-order h2 { text-align: center; }
.calendar-buy-grid { display: grid; grid-template-columns: repeat(2, minmax(280px, 1fr)); gap: 1.35rem; align-items: stretch; margin-top: 1.6rem; }
.calendar-buy-card { display: grid; grid-template-rows: auto auto 1fr; justify-items: center; border: 1px solid var(--color-line); background: var(--color-surface-soft); padding: 1.35rem; text-align: center; }
.calendar-buy-card h3 { margin-bottom: 0.25rem; }
.calendar-buy-card__price { margin-bottom: 1rem; color: var(--color-muted); font-weight: 800; }
.calendar-buy-card stripe-buy-button { width: min(100%, 360px); }
.calendar-security-note { margin: 1.7rem auto 0; max-width: 720px; color: var(--color-muted); font-size: 0.94rem; line-height: 1.7; text-align: center; }
.calendar-security-footnote { margin: 1rem auto 0; max-width: 760px; color: rgba(164,167,173,0.72); font-size: 0.84rem; line-height: 1.65; text-align: center; }
.calendar-lightbox { position: fixed; inset: 0; z-index: 80; display: none; align-items: center; justify-content: center; padding: 2rem; background: rgba(0,0,0,0.86); }
.calendar-lightbox.is-open { display: flex; }
.calendar-lightbox img { max-width: min(1200px, 92vw); max-height: 82vh; object-fit: contain; }
.calendar-lightbox__caption { position: fixed; left: 2rem; right: 2rem; bottom: 1.2rem; color: #fff; text-align: center; }
.calendar-lightbox__close { position: fixed; top: 1rem; right: 1rem; width: 44px; height: 44px; border: 1px solid rgba(255,255,255,0.28); border-radius: 999px; background: rgba(7,9,13,0.7); color: #fff; font-size: 1.6rem; cursor: pointer; }
@media (max-width: 980px) { .calendar-gallery-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } .calendar-buy-grid, .calendar-overview-feature { grid-template-columns: 1fr; } .calendar-content { width: min(100% - 32px, 1040px); } .calendar-overview-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .calendar-overview-feature__image { max-width: 360px; margin-inline: auto; } }
@media (max-width: 560px) { .calendar-gallery-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0.35rem; } .calendar-tile__body { padding: 0.55rem; } .calendar-tile__body p { display: none; } .calendar-buy-card { padding: 1rem; } .calendar-overview-grid { grid-template-columns: 1fr; } }
