/* Spa page styles - scoped and minimal; relies on base.css for resets and typography */
.spa-page { --gold: #d4af37; --midnight: #0a0a0a; --amber: #c9902e; --champagne: #f2eadf; --imperial: #7a0c18; color: var(--champagne); background: #0b0b0b; }
.spa-container { max-width: 1200px; margin: 0 auto; padding: 0 1.25rem; }

/* Hero */
.spa-hero { position: relative; isolation: isolate; }
.spa-hero__media img { width: 100%; height: clamp(52vh, 65vh, 78vh); object-fit: cover; display: block; }
.spa-hero__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,10,10,0.55), rgba(10,10,10,0.85)); z-index: 1; }
.spa-hero__content { position: absolute; inset: 0; z-index: 2; display: grid; align-items: end; padding: 2.5rem 0; }
.spa-hero__title { font-size: clamp(2rem, 3.5vw, 3rem); line-height: 1.15; margin: 0 0 .5rem; color: #fff; }
.spa-hero__subtitle { max-width: 60ch; color: #f7f1e8; margin: 0 0 1rem; }
.spa-hero__actions { display: flex; gap: .75rem; flex-wrap: wrap; }

/* Sections */
.spa-section { padding: clamp(2.5rem, 4vw, 4rem) 0; background: transparent; }
.spa-section--tint { background: linear-gradient(180deg, rgba(212,175,55,0.06), rgba(10,10,10,0)); }
.spa-section__header h2 { font-size: clamp(1.5rem, 2.5vw, 2rem); margin: 0 0 .5rem; color: #fff; }
.spa-section__header p { margin: 0 0 1.25rem; color: #e9e0d6; }

/* Grids */
.spa-grid { display: grid; gap: 1rem; }
.spa-grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.spa-grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
@media (max-width: 920px) { .spa-grid--3 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .spa-grid--2, .spa-grid--3 { grid-template-columns: 1fr; } }

/* Cards */
.spa-card, .spa-package { background: rgba(20,20,20,.7); border: 1px solid rgba(212,175,55,.2); border-radius: 12px; padding: 1rem; backdrop-filter: saturate(130%) blur(4px); transition: transform .3s ease, border-color .3s ease; }
.spa-card:hover, .spa-package:hover { transform: translateY(-2px); border-color: rgba(212,175,55,.45); }
.spa-card__title, .spa-package__title { margin: 0 0 .5rem; color: var(--gold); font-weight: 600; }
.spa-card__text { margin: 0 0 .5rem; color: #e8e1d9; }
.spa-card__meta, .spa-package__price { color: #f0d9a6; font-weight: 600; margin: .25rem 0 .5rem; }

/* Lists */
.spa-list { margin: 0; padding-left: 1rem; color: #e9e0d6; }
.spa-list li { margin: .25rem 0; }

/* Retreat & Facilities */
.spa-retreat, .spa-facilities { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; align-items: center; }
.spa-retreat__media img, .spa-facilities__media img { width: 100%; height: 100%; object-fit: cover; border-radius: 12px; aspect-ratio: 16 / 10; }
.spa-retreat__note { color: #d9c6a2; margin: .5rem 0 1rem; }
.spa-facilities__list { margin-top: .5rem; }
@media (max-width: 920px) { .spa-retreat, .spa-facilities { grid-template-columns: 1fr; } }

/* Testimonials */
.spa-testimonials { display: grid; gap: 1rem; grid-template-columns: repeat(3, minmax(0,1fr)); }
.spa-quote { padding: 1rem; border-left: 3px solid var(--gold); background: rgba(22,22,22,.7); border-radius: 8px; }
.spa-quote p { margin: 0 0 .5rem; }
.spa-quote footer { color: #cdb891; font-style: italic; }
@media (max-width: 920px) { .spa-testimonials { grid-template-columns: 1fr; } }

/* Buttons */
.spa-btn { --btn-bg: transparent; --btn-fg: #fff; display: inline-flex; align-items: center; justify-content: center; gap: .5rem; padding: .7rem 1rem; border-radius: 999px; border: 1px solid rgba(212,175,55,.45); color: var(--btn-fg); background: var(--btn-bg); text-decoration: none; font-weight: 600; transition: background .25s ease, color .25s ease, transform .25s ease; }
.spa-btn--primary { --btn-bg: linear-gradient(135deg, #b88a1e, #d4af37); color: #111!important; border-color: transparent; }
.spa-btn--ghost { --btn-bg: rgba(255,255,255,0.04); color: #fff; }
.spa-btn--inline { padding: .5rem .75rem; font-weight: 500; }
.spa-btn:hover { transform: translateY(-1px); }

/* Form */
.spa-form { background: rgba(18,18,18,.65); border: 1px solid rgba(212,175,55,.25); border-radius: 12px; padding: 1rem; }
.spa-form__field { display: grid; gap: .35rem; }
.spa-form__field--full { grid-column: 1 / -1; }
.spa-form label { color: #f2eadf; font-weight: 600; }
.spa-form input, .spa-form select, .spa-form textarea { background: #121212; color: #f2eadf; border: 1px solid rgba(212,175,55,.25); border-radius: 8px; padding: .65rem .75rem; }
.spa-form input:focus, .spa-form select:focus, .spa-form textarea:focus { outline: 2px solid var(--gold); outline-offset: 1px; }
.spa-form__actions { display: flex; gap: .75rem; flex-wrap: wrap; margin-top: .5rem; }
.spa-form__feedback { margin-top: .75rem; color: #c7f1c7; min-height: 1.25rem; }
.spa-form__consent { display: grid; grid-template-columns: auto 1fr; gap: .5rem; align-items: start; }

/* Inline links */
.spa-section__nav { padding: 1.5rem 0 3rem; }
.spa-inline-links { list-style: none; display: flex; gap: 1rem; flex-wrap: wrap; padding: 0; margin: 0; }
.spa-inline-links a { color: var(--gold); text-decoration: none; border-bottom: 1px dashed rgba(212,175,55,.5); padding-bottom: .05rem; }
.spa-inline-links a:hover { color: #fff; border-bottom-color: #fff; }

/* Motion reduce */
@media (prefers-reduced-motion: reduce) {
  .spa-card, .spa-package, .spa-btn { transition: none; }
}
