/* Global styles */
:root{
  --sage:#9EB39B;
  --sage-dark:#7f9b7a;
  --cream:#F7F6F2;
  --ink:#1E1E1E;
  --muted:#6b6f6d;
  --border:#e5e7e6;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Lato",system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(1100px 600px at 10% 0%, rgba(158,179,155,.15), transparent),
    radial-gradient(900px 600px at 100% 100%, rgba(158,179,155,.12), transparent),
    var(--cream);
}

.container{width:min(1100px,92vw);margin:0 auto;padding:24px}

.site-header{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:12px 24px;background:rgba(247,246,242,.7);
  backdrop-filter: blur(6px); border-bottom:1px solid var(--border);
}
.brand{display:flex;align-items:center;gap:10px;color:inherit;text-decoration:none;font-weight:700}
.brand img{width:38px;height:auto}
.brand span{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:1.1rem;letter-spacing:.4px}
.nav a{color:#2b2f2d;text-decoration:none;margin:0 10px;padding:8px 10px;border-radius:10px}
.nav a:hover,.nav a.active{background:#fff;border:1px solid var(--border)}

.hero{
  position:relative;min-height:62vh;
  display:grid;place-items:center;text-align:center;
  background-image:url('images/bg.jpg');
  background-size:cover;background-position:center;
}
.hero .overlay{
  background:rgba(255,255,255,.65);
  padding:28px;border-radius:24px;border:1px solid var(--border);
  backdrop-filter: blur(3px);
  animation:fadeInUp .7s ease both;
}
.hero h1{font-family:"Cormorant Garamond",serif;font-size:3rem;margin:6px 0 4px 0}
.hero .date{color:var(--sage-dark);font-weight:700;margin:4px 0 10px 0}
.hero .intro{color:#37413b;max-width:700px;margin:0 auto 14px auto}
.btn{
  display:inline-block;padding:12px 16px;border-radius:12px;text-decoration:none;
  background:var(--sage);color:#fff;font-weight:700;border:1px solid var(--sage);
}
.btn.ghost{background:transparent;color:#2b2f2d;border-color:var(--border)}
.btn:hover{filter:brightness(.95)}

.cards{
  width:min(1100px,92vw);margin:28px auto;display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
}
.card{
  background:#fff;border:1px solid var(--border);border-radius:16px;padding:20px;
  box-shadow:0 10px 20px rgba(0,0,0,.04);
}
.card h3{font-family:"Cormorant Garamond",serif;margin:0 0 6px 0}
.card .link{display:inline-block;margin-top:8px;color:#1f3c2a;text-decoration:none;font-weight:700}

.site-footer{padding:26px;text-align:center;color:var(--muted);border-top:1px solid var(--border);background:#fff7;backdrop-filter: blur(3px)}

/* Gallery */
.grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap:14px;
}
.grid a{
  display:block;
  border-radius:14px;
  overflow:hidden;
  border:1px solid var(--border);
  background:#fff;
}
.grid img{
  width:100%;
  height:auto;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  display:block;
  transition:transform .2s ease, box-shadow .2s ease;
}
.grid a:hover img{transform:scale(1.02); box-shadow:0 12px 18px rgba(0,0,0,.08)}

.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;padding:24px;z-index:9999;}
.lightbox img{max-width:92vw;max-height:90vh;border-radius:12px}
.lightbox.show{display:flex}
.lightbox .close{position:absolute;top:14px;right:18px;border:none;background:#fff;border-radius:999px;width:36px;height:36px;font-size:22px;cursor:pointer}

/* Videos */
.video-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;padding:0 24px}
.video{position:relative;padding-top:56.25%;border-radius:16px;overflow:hidden;border:1px solid var(--border);background:#fff}
.video iframe{position:absolute;inset:0;width:100%;height:100%}

/* Guestbook */
.gb-form{display:grid;gap:10px;padding:0 24px}
.gb-form .row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.gb-form input,.gb-form textarea{
  width:100%;padding:12px;border:1px solid var(--border);border-radius:12px;background:#fff
}
.gb-form textarea{min-height:120px;resize:vertical}
.gb-list{list-style:none;padding:10px 24px 24px 24px;margin:0;display:grid;gap:10px}
.gb-list li{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px}
.gb-list .meta{color:var(--muted);font-size:.9rem;margin-bottom:6px}

.muted{color:var(--muted)}
@keyframes fadeInUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* Lightbox controls */
.download-btn{
  position:absolute;bottom:20px;right:20px;
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:999px;
  background:#ffffff; border:1px solid var(--border);
  text-decoration:none; cursor:pointer;
  box-shadow:0 10px 20px rgba(0,0,0,.25);
}
.download-btn:hover{filter:brightness(.97)}
.no-scroll{overflow:hidden}

/* Responsive additions */
:root{
  --fs-h1: clamp(1.8rem, 2.5vw + 1rem, 3rem);
  --fs-text: clamp(0.95rem, 0.4vw + 0.8rem, 1.05rem);
}
body{font-size:var(--fs-text)}
.hero h1{font-size:var(--fs-h1)}
.site-header{gap:8px}
.hamburger{display:none; width:42px; height:42px; border:none; background:transparent; border-radius:10px; align-items:center; justify-content:center; gap:5px}
.hamburger span{display:block;width:22px;height:2px;background:#2b2f2d;border-radius:2px}
.nav{display:flex; align-items:center}
@media (max-width: 820px){
  .hamburger{display:inline-flex}
  .nav{position:absolute; top:62px; right:14px; background:#fff; border:1px solid var(--border); border-radius:14px; box-shadow:0 20px 40px rgba(0,0,0,.12); padding:10px; display:none; flex-direction:column; min-width:180px}
  .nav a{margin:4px 0; width:100%; text-align:left}
  .nav.show{display:flex}
}
.hero{min-height:55vh}
.lightbox img{max-width:98vw; max-height:86vh}
.video-grid{grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));}
.cards{grid-template-columns:repeat(auto-fit, minmax(240px,1fr));}
.container{padding:18px}
