/* ============================================================
   REFRESH-PAGES.css — additional patterns for inner pages
   ============================================================ */

/* Short hero for inner pages */
.rf-hero--inner {
  min-height: 70vh;
}

/* Pull-quote */
.rf-pullquote {
  font-family: var(--rf-serif);
  font-size: clamp(1.6rem, 2.6vw, 2.4rem);
  line-height: 1.4;
  font-style: italic;
  color: var(--rf-gold);
  text-align: center;
  max-width: 760px;
  margin: 0 auto;
  padding: 2rem 0;
  border-top: 1px solid rgba(201,168,122,.3);
  border-bottom: 1px solid rgba(201,168,122,.3);
}
.rf-section--olive .rf-pullquote,
.rf-section--olive-dark .rf-pullquote {
  color: var(--rf-gold-warm);
  border-color: rgba(201,168,122,.4);
}

/* Story block (about page) */
.rf-story-block {
  max-width: 760px;
  margin: 0 auto clamp(2.5rem, 5vw, 4rem);
}
.rf-story-block .rf-h3 {
  border-left: 3px solid var(--rf-gold);
  padding-left: 1.25rem;
  margin-bottom: 1.5rem;
}

/* Qualification cards */
.rf-quals {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: 3rem;
}
.rf-quals--two { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 880px) {
  .rf-quals { grid-template-columns: 1fr 1fr; }
  .rf-quals--two { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 540px) {
  .rf-quals { grid-template-columns: 1fr; }
  .rf-quals--two { grid-template-columns: 1fr; }
}
.rf-gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .75rem;
  margin-top: 2rem;
}
.rf-gallery-grid__item {
  aspect-ratio: 1 / 1;
  background-size: cover;
  background-position: center;
  border-radius: 4px;
  filter: saturate(.95);
  transition: transform .6s ease, filter .4s ease;
}
.rf-gallery-grid__item:hover {
  transform: scale(1.02);
  filter: saturate(1.1);
}
@media (max-width: 880px) { .rf-gallery-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 540px) { .rf-gallery-grid { grid-template-columns: repeat(2, 1fr); gap: .5rem; } }
.rf-qual {
  background: rgba(255,255,255,.55);
  border-left: 3px solid var(--rf-gold);
  padding: 1.75rem 1.5rem;
}
.rf-section--olive .rf-qual,
.rf-section--olive-dark .rf-qual {
  background: rgba(255,255,255,.06);
}
.rf-qual__title {
  font-family: var(--rf-serif);
  font-weight: 500;
  font-size: 1.25rem;
  margin: 0 0 .5rem;
  color: var(--rf-ink);
}
.rf-section--olive .rf-qual__title,
.rf-section--olive-dark .rf-qual__title { color: var(--rf-cream); }
.rf-qual__text {
  font-family: var(--rf-sans);
  font-size: .92rem;
  line-height: 1.6;
  color: var(--rf-mute);
  margin: 0;
}
.rf-section--olive .rf-qual__text,
.rf-section--olive-dark .rf-qual__text { color: rgba(240,231,213,.85); }

/* Service / pricing tile */
.rf-tiles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: 3rem;
}
@media (max-width: 880px) { .rf-tiles { grid-template-columns: 1fr; } }
.rf-tile {
  background: var(--rf-cream);
  padding: 2.5rem 2rem;
  border: 1px solid rgba(201,168,122,.25);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  position: relative;
  transition: transform .4s var(--rf-ease), box-shadow .4s var(--rf-ease);
}
.rf-tile--featured {
  background: var(--rf-olive);
  color: var(--rf-cream);
  border-color: var(--rf-gold);
}
.rf-tile:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(0,0,0,.08);
}
.rf-tile__badge {
  position: absolute;
  top: -.7rem; left: 1.5rem;
  background: var(--rf-gold);
  color: var(--rf-cream);
  font-family: var(--rf-sans);
  font-size: .65rem;
  font-weight: 500;
  letter-spacing: .25em;
  text-transform: uppercase;
  padding: .35rem .9rem;
  border-radius: 999px;
}
.rf-tile__title {
  font-family: var(--rf-serif);
  font-size: 1.6rem;
  font-weight: 500;
  margin: 0;
}
.rf-tile__meta {
  font-family: var(--rf-sans);
  font-size: .85rem;
  color: var(--rf-mute);
  letter-spacing: .1em;
  text-transform: uppercase;
}
.rf-tile--featured .rf-tile__meta { color: var(--rf-gold-warm); }
.rf-tile__price {
  font-family: var(--rf-serif);
  font-size: 1.15rem;
  font-style: italic;
  color: var(--rf-gold);
  margin: .25rem 0 .5rem;
}
.rf-tile--featured .rf-tile__price { color: var(--rf-gold-warm); }
.rf-tile__list {
  list-style: none; padding: 0; margin: 0 0 1.5rem;
}
.rf-tile__list li {
  position: relative;
  padding: .35rem 0 .35rem 1.25rem;
  font-family: var(--rf-sans);
  font-size: .9rem;
  line-height: 1.5;
  color: var(--rf-mute);
}
.rf-tile--featured .rf-tile__list li { color: rgba(240,231,213,.85); }
.rf-tile__list li::before {
  content: '◦';
  position: absolute; left: 0;
  color: var(--rf-gold);
}
.rf-tile--featured .rf-tile__list li::before { color: var(--rf-gold-warm); }
.rf-tile .rf-btn { margin-top: auto; align-self: flex-start; }

/* FAQ accordion */
.rf-faq { max-width: 800px; margin: 3rem auto 0; }
.rf-faq__item {
  border-bottom: 1px solid rgba(201,168,122,.25);
}
.rf-faq__q {
  width: 100%;
  background: none; border: none; cursor: pointer;
  text-align: left;
  padding: 1.5rem 2.5rem 1.5rem 0;
  position: relative;
  font-family: var(--rf-serif);
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--rf-ink);
}
.rf-faq__q::after {
  content: '+';
  position: absolute; right: .25rem; top: 50%;
  transform: translateY(-50%);
  font-size: 1.5rem; color: var(--rf-gold);
  transition: transform .3s var(--rf-ease);
}
.rf-faq__item--open .rf-faq__q::after { transform: translateY(-50%) rotate(45deg); }
.rf-faq__a {
  max-height: 0; overflow: hidden;
  transition: max-height .4s var(--rf-ease), padding .4s var(--rf-ease);
  padding: 0 0 0;
  font-family: var(--rf-sans);
  color: var(--rf-mute); font-size: .95rem; line-height: 1.7;
}
.rf-faq__item--open .rf-faq__a {
  max-height: 400px;
  padding: 0 0 1.5rem;
}

/* Retreat hero card */
.rf-retreat {
  background: var(--rf-cream);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin-bottom: 3rem;
  overflow: hidden;
  border: 1px solid rgba(201,168,122,.2);
}
@media (max-width: 880px) { .rf-retreat { grid-template-columns: 1fr; } }
.rf-retreat__photo,
.rf-retreat__body { min-width: 0; }
.rf-retreat__photo {
  aspect-ratio: 4/3;
  background-size: cover;
  background-position: center;
}
/* In two-column layout the photo stretches to the body's height; aspect-ratio
   would otherwise derive its WIDTH from that height and blow out the grid. */
@media (min-width: 881px) { .rf-retreat__photo { aspect-ratio: auto; } }
.rf-retreat__body {
  padding: 2.5rem;
  display: flex; flex-direction: column; gap: 1rem;
}
.rf-retreat__meta {
  font-family: var(--rf-sans);
  font-size: .75rem;
  font-weight: 500;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--rf-gold);
}

/* Calendly placeholder fallback notice */
.rf-cal-note {
  background: rgba(201,168,122,.12);
  border-left: 3px solid var(--rf-gold);
  padding: 1.25rem 1.5rem;
  font-family: var(--rf-sans);
  font-size: .9rem;
  line-height: 1.6;
  color: var(--rf-mute);
  margin: 1.5rem 0;
}
.rf-cal-note strong { color: var(--rf-ink); }

/* Contact form */
.rf-contact-form {
  display: flex; flex-direction: column; gap: 1.25rem;
}
.rf-contact-form label {
  font-family: var(--rf-sans);
  font-size: .72rem;
  font-weight: 500;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--rf-gold);
}
.rf-contact-form input,
.rf-contact-form textarea {
  width: 100%;
  padding: 1rem 1.25rem;
  border: 1px solid rgba(201,168,122,.3);
  background: rgba(255,255,255,.95);
  font-family: var(--rf-sans);
  font-size: 1rem;
  color: var(--rf-ink);
  border-radius: 4px;
  outline: none;
  transition: border-color .3s var(--rf-ease);
}
.rf-contact-form input:focus,
.rf-contact-form textarea:focus { border-color: var(--rf-gold); }
.rf-contact-form textarea { min-height: 160px; resize: vertical; }

/* Contact cards (whatsapp/telegram/email) */
.rf-contact-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}
.rf-contact-card {
  background: rgba(255,255,255,.9);
  padding: 1.5rem;
  text-align: center;
  text-decoration: none;
  color: var(--rf-ink);
  border: 1px solid rgba(201,168,122,.2);
  transition: all .3s var(--rf-ease);
  display: block;
}
.rf-contact-card:hover {
  border-color: var(--rf-gold);
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(0,0,0,.06);
}
.rf-contact-card svg { color: var(--rf-gold); margin-bottom: .5rem; }
.rf-contact-card__title {
  font-family: var(--rf-serif);
  font-size: 1.2rem;
  margin: 0 0 .25rem;
}
.rf-contact-card__handle {
  font-family: var(--rf-sans);
  font-size: .85rem;
  color: var(--rf-mute);
}

/* L99 mobile overrides for inner-page components — must live here to win the cascade */
@media (max-width: 540px) {
  .rf-contact-cards { grid-template-columns: 1fr; gap: .85rem; }
  .rf-contact-card {
    padding: 1.25rem;
    text-align: left;
    display: flex;
    align-items: center;
    gap: 1rem;
  }
  .rf-contact-card svg { margin: 0; flex-shrink: 0; }
  .rf-contact-card__title { font-size: 1.1rem; margin: 0; }
  .rf-contact-card__handle { font-size: .82rem; margin: 0; }
  .rf-tile { padding: 2rem 1.5rem; gap: .85rem; }
  .rf-tile__title { font-size: 1.4rem; }
  .rf-tile__badge { left: 1rem; font-size: .6rem; padding: .3rem .75rem; }
  .rf-retreat__body { padding: 1.75rem 1.25rem; }
  .rf-qual { padding: 1.5rem 1.25rem; }
  .rf-tile__list li { font-size: .95rem; line-height: 1.6; }
  .rf-qual__text { font-size: 1rem; line-height: 1.65; }
  .rf-pullquote { font-size: clamp(1.15rem, 4.8vw, 1.5rem); padding: 1.5rem 0; line-height: 1.5; }
  .rf-contact-form input, .rf-contact-form textarea { padding: .95rem 1.1rem; border-radius: 6px; font-size: 16px; }
  .calendly-inline-widget { height: 560px !important; min-height: 560px !important; }
}
@media (max-width: 880px) and (min-width: 541px) {
  .calendly-inline-widget { height: 620px !important; min-height: 620px !important; }
}
