@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=Inter:wght@400;500;600&display=swap');

:root{
  --background:#fbf4ea;
  --cream:#fffaf3;
  --warm:#f0dfc8;
  --warm-2:#e8d1ad;
  --text:#33271d;
  --muted:#766557;
  --gold:#b88a44;
  --line:rgba(72,53,34,.14);
  --shadow:0 30px 90px rgba(75,52,28,.13);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:Inter,system-ui,sans-serif;
  background:var(--background);
  color:var(--text);
  line-height:1.75;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

.navbar{
  position:sticky;
  top:0;
  z-index:50;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:12px clamp(20px,5vw,72px);
  background:rgba(251,244,234,.84);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
}

.brand-logo img{
  width:72px;
  height:72px;
  object-fit:contain;
}

nav{display:flex;gap:24px;color:#6c5a4a;font-size:.93rem}
.nav-button{
  border:1px solid var(--gold);
  padding:10px 18px;
  border-radius:999px;
  color:#7a5420;
  font-size:.9rem;
}

.hero{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:92vh;
  background:
    radial-gradient(circle at 82% 20%, rgba(232,209,173,.55), transparent 28%),
    linear-gradient(135deg,#fbf4ea,#f3dfc4);
}

.hero-image{
  min-height:92vh;
  overflow:hidden;
}
.hero-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(.94) contrast(.96);
}

.hero-content{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:80px clamp(28px,6vw,88px);
}

.hero-logo{
  width:170px;
  margin-bottom:26px;
}

.eyebrow{
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.76rem;
  font-weight:600;
  color:#9a6f35;
  margin-bottom:18px;
}

h1,h2,h3{
  font-family:"Cormorant Garamond",serif;
  font-weight:600;
  line-height:1.02;
}

h1{
  font-size:clamp(4.3rem,9vw,8.4rem);
  letter-spacing:-.055em;
  max-width:760px;
}

h2{
  font-size:clamp(2.7rem,5.4vw,5rem);
  letter-spacing:-.045em;
}

h3{font-size:1.55rem}

.lead{
  margin:26px 0 32px;
  max-width:620px;
  font-size:1.13rem;
  color:var(--muted);
}

.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}

.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  border-radius:999px;
  padding:13px 25px;
  font-weight:600;
  transition:.25s ease;
}
.primary{
  background:var(--text);
  color:#fff7ec;
  box-shadow:0 18px 45px rgba(51,39,29,.18);
}
.primary:hover{transform:translateY(-2px);background:#4a392b}
.secondary{
  border:1px solid var(--line);
  background:rgba(255,250,243,.56);
  color:#68513d;
}
.small-note{
  margin-top:18px;
  color:#866e58;
  font-size:.92rem;
}

.philosophy{
  padding:115px clamp(22px,6vw,90px);
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:60px;
  align-items:center;
}

.section-copy p:not(.eyebrow){
  max-width:720px;
  margin-top:22px;
  color:var(--muted);
  font-size:1.03rem;
}

.pills{
  margin-top:30px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.pills span{
  background:var(--cream);
  border:1px solid var(--line);
  padding:10px 15px;
  border-radius:999px;
  color:#6f5d4f;
  font-size:.9rem;
}

.image-grid{
  display:grid;
  grid-template-columns:1fr .82fr;
  gap:18px;
  align-items:end;
}
.image-grid img{
  border-radius:34px;
  box-shadow:var(--shadow);
  height:460px;
  object-fit:cover;
}
.image-grid img:nth-child(2){
  height:360px;
  margin-bottom:-40px;
}

.benefits{
  padding:110px clamp(22px,6vw,90px);
  text-align:center;
  background:var(--cream);
}
.center-text{
  max-width:720px;
  margin:22px auto 48px;
  color:var(--muted);
}
.benefit-grid{
  max-width:1180px;
  margin:auto;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.benefit-grid article{
  text-align:left;
  background:#fffdf9;
  border:1px solid var(--line);
  border-radius:30px;
  padding:30px;
  min-height:190px;
}
.benefit-grid p{color:var(--muted);margin-top:10px}

.experience{
  padding:115px clamp(22px,6vw,90px);
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:62px;
  align-items:center;
}
.experience-image img{
  border-radius:38px;
  box-shadow:var(--shadow);
  height:760px;
  width:100%;
  object-fit:cover;
}
.experience-copy > p:not(.eyebrow){
  color:var(--muted);
  margin:24px 0 34px;
  max-width:690px;
}
.steps{
  display:grid;
  gap:14px;
}
.steps div{
  background:rgba(255,250,243,.72);
  border:1px solid var(--line);
  border-radius:26px;
  padding:24px;
}
.steps span{
  color:#9d6e2b;
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.15em;
}
.steps p{color:var(--muted)}

.kind-words{
  padding:110px clamp(22px,6vw,90px);
  text-align:center;
  background:var(--cream);
}
.testimonial-grid{
  max-width:1120px;
  margin:48px auto 0;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.testimonial-grid article{
  background:#fffdf9;
  border:1px solid var(--line);
  border-radius:32px;
  padding:32px;
  text-align:left;
  box-shadow:0 18px 50px rgba(75,52,28,.06);
}
.testimonial-grid p{
  color:#5f5144;
  font-family:"Cormorant Garamond",serif;
  font-size:1.35rem;
  line-height:1.35;
}
.testimonial-grid span{
  display:block;
  margin-top:22px;
  color:#9a6f35;
  font-size:.9rem;
  font-weight:600;
}

.instagram-section{
  padding:105px clamp(22px,6vw,90px);
  text-align:center;
  background:linear-gradient(180deg,#fbf4ea,#f4e4cf);
}
.instagram-section p{
  color:var(--muted);
  max-width:680px;
  margin:20px auto 28px;
}

.invitation{
  margin:20px clamp(22px,6vw,90px);
  padding:100px 30px;
  border-radius:44px;
  text-align:center;
  background:
    linear-gradient(rgba(51,39,29,.54),rgba(51,39,29,.54)),
    url("https://aethera-soundhealing.lovable.app/assets/space-K-oEhI1a.jpg") center/cover;
  color:#fff9ef;
}
.invitation p{
  color:#f2e6d6;
  max-width:720px;
  margin:22px auto 28px;
}
.invitation .eyebrow{color:#f0d6aa}
.invitation .primary{
  background:#fff9ef;
  color:var(--text);
}

.booking{
  padding:110px clamp(22px,6vw,90px);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:50px;
  align-items:start;
}
.booking p{color:var(--muted);max-width:620px;margin-top:20px}
.booking-card{
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:34px;
  padding:34px;
  box-shadow:var(--shadow);
}
.booking-card p{
  margin:0 0 14px;
}
.booking-card a:not(.button){
  color:#8a6025;
  font-weight:600;
}
.full{
  width:100%;
  margin-top:18px;
}

.faq{
  padding:110px clamp(22px,6vw,90px);
  max-width:980px;
  margin:auto;
}
.faq h2{margin-bottom:30px}
details{
  padding:22px 0;
  border-top:1px solid var(--line);
}
details:last-child{border-bottom:1px solid var(--line)}
summary{
  cursor:pointer;
  font-family:"Cormorant Garamond",serif;
  font-size:1.45rem;
  font-weight:600;
}
details p{
  color:var(--muted);
  margin-top:12px;
  max-width:740px;
}

footer{
  background:#efe0cc;
  padding:70px clamp(22px,6vw,90px) 34px;
  display:grid;
  grid-template-columns:1.4fr .8fr .8fr;
  gap:34px;
  color:#695745;
}
footer img{
  width:112px;
  margin-bottom:16px;
}
footer a, footer p{display:block;margin-top:8px}
.copyright{
  grid-column:1/-1;
  border-top:1px solid var(--line);
  padding-top:24px;
  margin-top:20px;
  font-size:.88rem;
}

@media(max-width:1040px){
  nav{display:none}
}

@media(max-width:920px){
  .brand-logo img{width:60px;height:60px}
  .hero,.philosophy,.experience,.booking{grid-template-columns:1fr}
  .hero-image{min-height:52vh;order:2}
  .hero-content{order:1;padding-top:58px}
  .image-grid img,.experience-image img{height:auto}
  .image-grid img:nth-child(2){margin-bottom:0}
  .benefit-grid,.testimonial-grid{grid-template-columns:1fr 1fr}
  footer{grid-template-columns:1fr}
}

@media(max-width:560px){
  .nav-button{font-size:.8rem;padding:9px 12px}
  .hero-logo{width:130px}
  .hero-actions .button{width:100%}
  .benefit-grid,.testimonial-grid{grid-template-columns:1fr}
  .philosophy,.benefits,.experience,.kind-words,.instagram-section,.booking,.faq{padding:78px 20px}
  .invitation{margin:10px 20px;padding:76px 22px;border-radius:30px}
}
