/* ============================================================
   SWATIOSOPHY — style.css
   ============================================================ */

:root {
  --plum:          #3d1c2e;
  --plum-dark:     #2a1020;
  --plum-mid:      #4e2439;
  --philosophy-bg: #3a1628;
  --rose:          #c4607a;
  --gold:          #d4a84b;
  --gold-light:    #e8c97a;
  --ivory:         #f8f4ed;
  --parchment:     #f2ece0;

  --font-serif:   'Cormorant Garamond', Georgia, serif;
  --font-display: 'IM Fell English', Georgia, serif;
  --font-cinzel:  'Cinzel', serif;
  --font-sans:    'Raleway', system-ui, sans-serif;

  --pad-x: clamp(32px, 6vw, 80px);
  --pad-y: clamp(60px, 8vh, 100px);
  --nav-h: 72px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--font-sans); background: var(--plum-dark); color: var(--ivory); overflow-x: hidden; }
img { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }

.skip-link { position: absolute; left: -9999px; top: 16px; background: var(--gold); color: var(--plum); padding: 8px 16px; font-weight: 700; z-index: 9999; }
.skip-link:focus { left: 16px; }

/* ============================================================
   NAV
   ============================================================ */
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; height: var(--nav-h); transition: background 0.4s, box-shadow 0.4s; }
.nav.is-scrolled { background: rgba(26,10,20,0.97); box-shadow: 0 2px 20px rgba(0,0,0,0.4); }
.nav__inner { max-width: 1400px; margin: 0 auto; padding: 0 var(--pad-x); height: 100%; display: flex; align-items: center; justify-content: space-between; }
.nav__logo { font-family: var(--font-display); font-size: 1.3rem; font-weight: 400; color: var(--ivory); letter-spacing: 0.02em; white-space: nowrap; display: inline; }
.nav__logo em { font-family: var(--font-serif); font-style: italic; color: var(--gold); margin: 0; padding: 0; }
.nav__links { display: flex; gap: 36px; align-items: center; }
.nav__links a { font-family: var(--font-sans); font-size: 0.8rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ivory); opacity: 0.85; transition: color 0.2s, opacity 0.2s; }
.nav__links a:hover { color: var(--gold); opacity: 1; }
.nav__cta { background: transparent; border: 1px solid var(--gold) !important; color: var(--gold) !important; padding: 8px 20px !important; opacity: 1 !important; transition: background 0.2s !important; }
.nav__cta:hover { background: var(--gold) !important; color: var(--plum) !important; }
.nav__toggle { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 4px; }
.nav__toggle span { display: block; width: 24px; height: 2px; background: var(--ivory); transition: transform 0.3s, opacity 0.3s; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn { display: inline-block; font-family: var(--font-sans); font-size: 0.78rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; padding: 14px 28px; border: 1px solid transparent; cursor: pointer; transition: background 0.2s, color 0.2s, border-color 0.2s; }
.btn--gold { background: var(--gold); color: var(--plum); border-color: var(--gold); }
.btn--gold:hover { background: var(--gold-light); border-color: var(--gold-light); }
.btn--outline { background: transparent; color: var(--gold); border-color: var(--gold); }
.btn--outline:hover { background: var(--gold); color: var(--plum); }
.btn--large { padding: 16px 36px; font-size: 0.82rem; }

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
.eyebrow { font-family: var(--font-sans); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ivory); opacity: 0.65; margin-bottom: 16px; }
.eyebrow--gold { color: var(--gold); opacity: 1; }
.eyebrow--dark { color: var(--plum); opacity: 0.6; }
.section-title { font-family: var(--font-serif); font-size: clamp(2rem, 3.5vw, 3.2rem); font-weight: 500; line-height: 1.2; margin-bottom: 28px; }
.section-title em { font-style: italic; color: var(--rose); }
.section-title.light { color: var(--ivory); }
.section-title.dark  { color: var(--plum); }
.body-text { font-family: var(--font-sans); font-size: clamp(0.9rem, 1.1vw, 1.05rem); line-height: 1.85; font-weight: 300; margin-bottom: 20px; }
.body-text.light { color: rgba(248,244,237,0.88); }
.body-text.dark  { color: rgba(42,16,32,0.82); }

/* ============================================================
   HERO
   ============================================================ */
.sec-hero { position: relative; width: 100%; height: 100vh; overflow: hidden; }
.sec-hero__img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.sec-hero__overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(26,10,20,0.92) 0%, rgba(26,10,20,0.72) 35%, rgba(26,10,20,0.08) 70%, transparent 100%); }
.sec-hero__text { position: absolute; top: 50%; left: var(--pad-x); transform: translateY(-50%); z-index: 1; max-width: 560px; }
.hero-title { font-family: var(--font-display); font-size: clamp(3.2rem, 6vw, 6rem); font-weight: 400; color: var(--ivory); line-height: 1.05; margin-bottom: 20px; }
.hero-title em { font-family: var(--font-serif); font-style: italic; font-weight: 500; color: var(--gold); }
.hero-tagline { font-family: var(--font-serif); font-style: italic; font-size: clamp(1.1rem, 1.5vw, 1.3rem); font-weight: 300; color: rgba(248,244,237,0.82); line-height: 1.75; margin-bottom: 36px; }
.sec-hero .eyebrow { font-family: var(--font-cinzel); font-size: 0.65rem; letter-spacing: 0.28em; }
.sec-hero__scroll { position: absolute; bottom: 32px; left: 50%; transform: translateX(-50%); z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 10px; font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(248,244,237,0.5); }
.scroll-line { width: 1px; height: 40px; background: linear-gradient(to bottom, var(--gold), transparent); animation: scrollPulse 2s ease-in-out infinite; }
@keyframes scrollPulse { 0%,100%{opacity:0.3;transform:scaleY(1);} 50%{opacity:0.9;transform:scaleY(1.2);} }

/* ============================================================
   MARQUEE STRIP
   ============================================================ */
.strip { overflow: hidden; background: var(--plum-mid); padding: 16px 0; white-space: nowrap; -webkit-mask-image: linear-gradient(to right, transparent 0%, black 6%, black 94%, transparent 100%); mask-image: linear-gradient(to right, transparent 0%, black 6%, black 94%, transparent 100%); }
.strip__inner { display: inline-block; animation: marquee 40s linear infinite; }
.strip__item { font-family: var(--font-serif); font-style: italic; font-size: 1.05rem; font-weight: 400; letter-spacing: 0.06em; color: var(--gold); padding: 0 8px; }
.strip__dot { display: inline-block; width: 5px; height: 5px; background: rgba(212,168,75,0.6); border-radius: 50%; vertical-align: middle; margin: 0 6px; position: relative; top: -1px; }
@keyframes marquee { from{transform:translateX(0);} to{transform:translateX(-50%);} }

/* ============================================================
   SECTION DIVIDER — pink centre, fades to gold then transparent
   No mask, no dark colours
   ============================================================ */
.sec-divider {
  width: 100%;
  height: 20px;
background: linear-gradient(
    to right,
    #ffffff    0%,
    var(--gold)    10%,
    var(--rose)    28%,
    var(--rose)    72%,
    var(--gold)    90%,
    #ffffff    100%
  );
  box-shadow:
    0 -8px 24px rgba(212, 168, 75,  0.25),
    0  8px 24px rgba(212, 168, 75,  0.25),
    0  0   36px rgba(196,  96, 122, 0.2);
  position: relative;
  z-index: 1;
  border: none;
}

/* ============================================================
   SPLIT SECTIONS
   ============================================================ */
.sec-split { display: flex; width: 100%; min-height: 90vh; }
.sec-split__img { flex: 0 0 50%; width: 50%; position: relative; overflow: hidden; }
.sec-split__img img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; object-position: center center; }
.sec-split__text { flex: 0 0 50%; width: 50%; display: flex; flex-direction: column; justify-content: center; padding: var(--pad-y) var(--pad-x); }
.sec-split__inner { max-width: 520px; }
.sec-split--reverse .sec-split__text { order: 1; }
.sec-split--reverse .sec-split__img  { order: 2; }

.bg-dark        { background: var(--plum-dark); }
.bg-parchment   { background: var(--parchment); }
.bg-plum        { background: var(--plum); }
.bg-philosophy  { background: var(--philosophy-bg); }

.sec-split__img--bg-dark       { background: var(--plum-dark); }
.sec-split__img--bg-parchment  { background: var(--parchment); }
.sec-split__img--bg-philosophy { background: var(--philosophy-bg); }

.sec-split__img--face img { object-fit: cover; object-position: center 15%; }
.sec-split__img--body img { object-fit: cover; object-position: center 55%; }

/* About section taller so the full portrait shows */
.sec-about { min-height: 115vh; }

/* ============================================================
   RETREATS
   ============================================================ */
.sec-fullwidth { position: relative; width: 100%; height: 100vh; overflow: hidden; }
.sec-fullwidth__img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; object-position: center center; }
.sec-fullwidth__overlay { position: absolute; inset: 0; }
.sec-fullwidth__overlay--right { background: linear-gradient(to left, rgba(26,10,20,0.92) 0%, rgba(26,10,20,0.72) 40%, rgba(26,10,20,0.08) 75%, transparent 100%); }
.sec-fullwidth__text { position: absolute; z-index: 1; top: 50%; transform: translateY(-50%); max-width: 540px; }
.sec-fullwidth__text--right { right: var(--pad-x); left: auto; text-align: left; }

/* ============================================================
   CONNECT — full-width centered, deep twilight glow
   ============================================================ */
.sec-contact {
  position: relative;
  width: 100%;
  padding: clamp(90px, 13vh, 140px) var(--pad-x);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  background:
    radial-gradient(ellipse 60% 70% at 50% 50%,
      rgba(140, 50, 95,  0.7) 0%,
      rgba(100, 25, 65,  0.5) 35%,
      transparent            70%
    ),
    radial-gradient(ellipse 100% 100% at 50% 50%,
      #3e1030 0%,
      #2b0b22 45%,
      #1c0717 75%,
      #120514 100%
    );
}
.sec-contact__inner { position: relative; z-index: 1; max-width: 760px; width: 100%; }
.contact-title { font-size: clamp(2.6rem, 4.5vw, 4.2rem) !important; margin-bottom: 20px; }
.contact-body { font-size: clamp(1.05rem, 1.4vw, 1.25rem) !important; max-width: 580px; margin-left: auto; margin-right: auto; margin-bottom: 28px; }
.sec-contact .contact-links { flex-direction: row; flex-wrap: wrap; justify-content: center; align-items: center; gap: 16px; margin-top: 36px; }

/* ============================================================
   TAGS — italic serif, ◆ diamonds, no boxes
   ============================================================ */
.tags { display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-start; row-gap: 12px; margin-top: 24px; }
#philosophy .tags { justify-content: center; }
.sec-contact .tags { justify-content: center; }
.tag { font-family: var(--font-serif); font-style: italic; font-size: 1.1rem; font-weight: 400; letter-spacing: 0.03em; color: rgba(212,168,75,0.85); padding: 0; border: none; background: transparent; cursor: default; white-space: nowrap; }
.tag + .tag::before { content: '◆'; display: inline-block; font-style: normal; font-size: 0.5rem; color: var(--gold); opacity: 0.65; margin: 0 12px; vertical-align: middle; }

/* ============================================================
   PILLARS
   ============================================================ */
.pillars { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 32px; }
.pillar { border-left: 2px solid var(--gold); padding-left: 14px; }
.pillar__word { display: block; font-family: var(--font-serif); font-size: 1.1rem; font-style: italic; color: var(--gold); }
.pillar__meaning { display: block; font-size: 0.72rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(248,244,237,0.55); margin-top: 3px; }
.pillars--on-light .pillar__word    { color: var(--plum); }
.pillars--on-light .pillar__meaning { color: rgba(61,28,46,0.55); }

/* ============================================================
   CONTACT LINKS
   ============================================================ */
.contact-links { display: flex; flex-direction: column; gap: 16px; margin-top: 32px; align-items: flex-start; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: #0e0509; padding: 60px var(--pad-x) 40px; }
.footer__inner { max-width: 1400px; margin: 0 auto; }
.footer__top { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 32px; padding-bottom: 40px; border-bottom: 1px solid rgba(201,169,110,0.15); margin-bottom: 40px; }
.footer__logo { font-family: var(--font-display); font-size: 1.4rem; color: var(--ivory); margin-bottom: 6px; display: block; }
.footer__logo em { font-family: var(--font-serif); font-style: italic; color: var(--gold); }
.footer__tagline { font-size: 0.75rem; letter-spacing: 0.15em; text-transform: uppercase; color: rgba(248,244,237,0.45); }
.footer__nav { display: flex; flex-wrap: wrap; gap: 20px 32px; align-items: center; }
.footer__nav a { font-size: 0.75rem; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 500; color: rgba(248,244,237,0.55); transition: color 0.2s; }
.footer__nav a:hover { color: var(--gold); }

/* Logo stamp (80px) + disclaimer + credits */
.footer__bottom-row { display: flex; align-items: flex-start; gap: 24px; margin-bottom: 32px; }
.footer__logo-img { width: 80px; height: auto; flex-shrink: 0; mix-blend-mode: screen; opacity: 0.85; margin-top: 2px; }
.footer__bottom-text { display: flex; flex-direction: column; gap: 12px; flex: 1; }
.footer__disclaimer { font-size: 0.9rem; line-height: 1.75; color: rgba(248,244,237,0.5); }
.footer__photo-credits { font-size: 0.78rem; line-height: 1.7; color: rgba(248,244,237,0.38); font-style: italic; }
.footer__copy { font-size: 0.72rem; letter-spacing: 0.1em; color: rgba(248,244,237,0.3); }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal { opacity: 0; transform: translateY(32px); transition: opacity 0.8s ease, transform 0.8s ease; }
.reveal.is-visible { opacity: 1; transform: none; }

/* ============================================================
   MOBILE (≤900px)
   ============================================================ */
@media (max-width: 900px) {

  .sec-split { flex-direction: column; min-height: auto; }
  .sec-about { min-height: auto; }

  .sec-split__img { flex: none; width: 100%; height: 75vw; min-height: 300px; max-height: 420px; }
  .sec-split__img img { object-position: center center; }
  .sec-split__img--face img { object-position: center 20%; }

  #practice .sec-split__img { height: 95vw; min-height: 380px; max-height: none; }
  #practice .sec-split__img img { object-position: center top; }

  #about .sec-split__img { height: 130vw; min-height: 500px; max-height: none; }
  #about .sec-split__img img { object-position: center 55%; }

  .sec-split__text { flex: none; width: 100%; padding: 48px 28px; }
  .sec-split--reverse .sec-split__text { order: 2; }
  .sec-split--reverse .sec-split__img  { order: 1; }

  .sec-fullwidth { height: auto; display: flex; flex-direction: column; }
  .sec-fullwidth__img { position: relative; width: 100%; height: 70vw; min-height: 300px; object-fit: cover; object-position: center 30%; }
  .sec-fullwidth__overlay { display: none; }
  .sec-fullwidth__text { position: relative; top: auto; left: auto; right: auto; transform: none; max-width: 100%; width: 100%; background: var(--philosophy-bg); padding: 48px 28px; text-align: left; }

  #philosophy .tags { justify-content: center; }

  .sec-contact { padding: 64px 28px; }
  .contact-title { font-size: clamp(2.2rem, 8vw, 3.2rem) !important; }
  .contact-body  { font-size: 1.05rem !important; }
  .sec-contact .contact-links { flex-direction: column; align-items: stretch; margin-top: 28px; }
  .sec-contact .contact-links .btn { text-align: center; }
  .tag { font-size: 1rem; }

  .nav__links { display: none; position: fixed; top: var(--nav-h); left: 0; right: 0; background: rgba(26,10,20,0.98); flex-direction: column; gap: 0; padding: 16px 0 32px; }
  .nav__links.is-open { display: flex; }
  .nav__links li { width: 100%; }
  .nav__links a { display: block; padding: 14px 32px; font-size: 0.85rem; border-bottom: 1px solid rgba(201,169,110,0.08); }
  .nav__cta { margin: 16px 32px 0 !important; padding: 12px 20px !important; text-align: center; border: 1px solid var(--gold) !important; }
  .nav__toggle { display: flex; }

  .sec-hero__text { left: 24px; right: 24px; max-width: 100%; }
  .sec-hero__img { object-position: 70% center; }
  .sec-hero__overlay { background: rgba(26,10,20,0.65); }

  .pillars { grid-template-columns: 1fr 1fr; gap: 12px; }

  .contact-links { align-items: stretch; }
  .contact-links .btn { text-align: center; }

  .footer__top { flex-direction: column; }
  .footer__nav { gap: 14px 24px; }
  .footer__bottom-row { flex-direction: column; align-items: center; gap: 16px; }
  .footer__logo-img { width: 80px; }
  .footer__bottom-text { text-align: center; }
  .footer__photo-credits { font-size: 0.75rem; }
}

@media (max-width: 480px) {
  .hero-title { font-size: 2.6rem; }
  .pillars { grid-template-columns: 1fr; }
  .sec-hero__scroll { display: none; }
}
