/* styles.css - soft, nature-inspired, responsive */
:root{
  --bg: #ffffff;
  --text: #23303a;
  --muted: #6c7a80;
  --accent: #145A32;
  --gold: #FFD89B;
  --maxwidth: 1100px;
}

*{box-sizing:border-box}
body{
  font-family: "Open Sans", Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
  margin:0;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.55;
}

.site-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 24px;
  max-width:var(--maxwidth);
  margin:0 auto;
}

.logo{height:72px; width:auto}

.nav a{
  margin-left:14px;
  color:var(--muted);
  text-decoration:none;
  font-weight:600;
  transition:color 240ms ease, transform 240ms ease;
}
.nav a:hover{color:var(--accent); transform:translateY(-2px)}

/* Hero */
.hero{
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  background:linear-gradient(180deg, rgba(255,250,246,0.8), rgba(240,255,246,0.8));
  padding:28px 12px 80px;
}
.banner{max-width:100%; height:auto; display:block; margin:0 auto; border-radius:12px; box-shadow:0 8px 24px rgba(34,48,58,0.08);}
.hero-text{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  text-align:center;
  top:36%;
  mix-blend-mode:normal;
}
.hero-text h1{
  font-family: "Playfair Display", serif;
  font-size:38px;
  margin:0;
  color:var(--text);
  letter-spacing:0.6px;
}
.tagline{color:var(--muted); margin-top:8px; font-size:16px}
.cta{
  display:inline-block;
  margin-top:14px;
  padding:10px 18px;
  border-radius:999px;
  background:var(--accent);
  color:white;
  text-decoration:none;
  font-weight:600;
  transition:transform 200ms ease, box-shadow 200ms ease;
}
.cta:hover{transform:translateY(-4px); box-shadow:0 10px 26px rgba(20,90,50,0.12)}

/* About */
.about, .gallery, .quote{
  max-width:var(--maxwidth);
  margin:48px auto;
  padding:0 18px;
}
.about h2, .gallery h2{font-family:"Playfair Display", serif; font-size:28px; margin-bottom:12px}
.poem{font-size:16px; color:var(--muted); max-width:900px}

/* Gallery grid */
.grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:18px;
}
.grid img{width:100%; height:auto; border-radius:8px; box-shadow:0 8px 20px rgba(34,48,58,0.06)}

/* Quote */
.quote{display:flex; justify-content:center; align-items:center}
blockquote{
  font-family:"Playfair Display", serif;
  font-size:22px;
  color:var(--accent);
  margin:12px;
  padding:18px 24px;
  border-left:4px solid var(--gold);
  background:linear-gradient(180deg, rgba(255,250,246,0.65), rgba(240,255,246,0.65));
  border-radius:8px;
}

/* Footer */
.site-footer{padding:28px 18px; text-align:center; color:var(--muted); font-size:14px; border-top:1px solid #f0f0f0}

/* Responsive */
@media (max-width:900px){
  .grid{grid-template-columns:repeat(2, 1fr)}
  .hero-text h1{font-size:28px}
  .logo{height:56px}
}
@media (max-width:560px){
  .grid{grid-template-columns:1fr}
  .nav{display:none}
  .hero{padding-bottom:56px}
  .hero-text{top:30%}
}
