/* ============================================
   Mithila Meadows — stylesheet
   Palette inspired by Mithila art + rural earth
============================================ */
:root{
  --green-900:#1f3d2b;
  --green-700:#2f5a3d;
  --green-500:#4f8a5e;
  --green-50:#eef5ef;
  --earth-900:#3a2618;
  --earth-700:#6b4226;
  --earth-500:#a76a3c;
  --cream:#fbf6ec;
  --cream-2:#f3ead7;
  --gold:#c8932b;
  --ink:#1d1a14;
  --muted:#5e5a52;
  --line:rgba(58,38,24,0.12);
  --radius:14px;
  --radius-lg:22px;
  --shadow-sm:0 6px 18px rgba(31,61,43,0.08);
  --shadow-md:0 16px 40px rgba(31,61,43,0.14);
  --max:1180px;
  --font-serif:"Cormorant Garamond", "Georgia", serif;
  --font-sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%; height:auto; display:block;}
/* Safety: any image inside a grid container fills its cell */
.gallery-grid img,
.visit-gallery-grid img,
.review-grid img,
.dignitary-grid img{
  width:100%; height:auto;
}

a{color:inherit; text-decoration:none;}
.container{max-width:var(--max); margin:0 auto; padding:0 24px;}
.section{padding:96px 0;}
.alt-bg{background:var(--cream-2);}
.center{text-align:center;}

/* HEADINGS */
h1,h2,h3,h4{
  font-family:var(--font-serif);
  font-weight:600;
  color:var(--green-900);
  letter-spacing:-0.01em;
  line-height:1.15;
  margin:0 0 16px;
}
h1{font-size:clamp(2.4rem, 5vw, 4.2rem);}
h2{font-size:clamp(2rem, 3.4vw, 2.9rem);}
h3{font-size:1.35rem;}
h4{font-size:1rem; text-transform:uppercase; letter-spacing:0.12em;}

p{margin:0 0 14px; color:var(--muted);}
.lead{font-size:1.1rem; max-width:680px; margin:0 auto;}
.eyebrow{
  display:inline-block;
  text-transform:uppercase;
  letter-spacing:0.22em;
  font-size:0.78rem;
  font-weight:500;
  color:var(--gold);
  margin-bottom:18px;
}
.eyebrow.dark{color:var(--earth-700);}

/* BUTTONS */
.btn{
  display:inline-block;
  padding:14px 26px;
  border-radius:999px;
  font-weight:500;
  font-size:0.95rem;
  letter-spacing:0.02em;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
  cursor:pointer;
  border:1px solid transparent;
}
.btn-primary{background:var(--green-700); color:#fff; box-shadow:var(--shadow-sm);}
.btn-primary:hover{background:var(--green-900); transform:translateY(-2px); box-shadow:var(--shadow-md);}
.btn-ghost{color:#fff; border-color:rgba(255,255,255,0.6);}
.btn-ghost:hover{background:rgba(255,255,255,0.12);}
.btn.full{width:100%;}

/* TOP UTILITY BAR */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:51;
  background:var(--green-900);
  color:rgba(255,255,255,0.92);
  font-size:0.82rem;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.topbar-inner{
  max-width:var(--max); margin:0 auto;
  padding:7px 24px;
  display:flex; align-items:center; justify-content:space-between;
  gap:16px;
}
.topbar-contact{display:flex; align-items:center; gap:22px;}
.topbar-contact a{
  display:inline-flex; align-items:center; gap:7px;
  color:rgba(255,255,255,0.88);
  transition:color .2s ease;
}
.topbar-contact a:hover{color:var(--gold);}
.topbar-contact svg{flex-shrink:0; color:var(--gold);}

.topbar-social{display:flex; align-items:center; gap:6px;}
.topbar-label{
  margin-right:10px;
  color:rgba(255,255,255,0.55);
  text-transform:uppercase;
  letter-spacing:0.18em;
  font-size:0.7rem;
}
.topbar-social a{
  width:26px; height:26px;
  border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,0.85);
  transition:background .2s ease, color .2s ease, transform .2s ease;
  line-height:0;
  flex-shrink:0;
}
.topbar-social a svg{display:block; width:14px; height:14px;}
.topbar-social a:hover{
  background:rgba(255,255,255,0.12);
  color:var(--gold);
  transform:translateY(-1px);
}
.topbar-social a.topbar-wa{
  width:auto; height:26px;
  padding:0 12px; gap:7px;
  border-radius:999px;
  background:#25D366; color:#fff;
  font-weight:500;
}
.topbar-social a.topbar-wa:hover{
  background:#1ebe5a; color:#fff;
}
.topbar-wa .wa-label{font-size:0.78rem; line-height:1;}

/* NAVIGATION */
.nav{
  position:fixed; top:36px; left:0; right:0; z-index:50;
  background:rgba(251,246,236,0.85);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:var(--max); margin:0 auto; padding:10px 24px;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.logo{display:flex; align-items:center; gap:12px;}
.logo-mark{
  width:140px; height:140px; border-radius:50%;
  object-fit:cover;
  background:#fff; color:var(--gold);
  font-family:var(--font-serif); font-size:1.4rem; font-weight:700;
  display:grid; place-items:center;
  flex-shrink:0;
  border:3px solid var(--gold);
  box-shadow:0 8px 26px rgba(31,61,43,0.32);
}
img.logo-mark{padding:0;}
.footer .logo-mark{
  width:180px; height:180px;
  border-color:rgba(200,147,43,0.8);
  box-shadow:0 10px 36px rgba(0,0,0,0.5);
}
@media (max-width: 980px){
  .logo-mark{width:96px; height:96px;}
  .footer .logo-mark{width:140px; height:140px;}
}
@media (max-width: 640px){
  .logo-mark{width:72px; height:72px; border-width:2px;}
  .footer .logo-mark{width:120px; height:120px;}
}
.logo-name{display:block; font-family:var(--font-serif); font-weight:700; font-size:1.25rem; color:var(--green-900); line-height:1;}
.logo-tag{display:block; font-size:0.7rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--earth-700); margin-top:4px;}

.nav-links{display:flex; align-items:center; gap:28px;}
.nav-links a{font-size:0.93rem; color:var(--ink); position:relative;}
.nav-links a:not(.nav-cta):hover{color:var(--green-700);}
.nav-cta{
  background:var(--green-700); color:#fff !important;
  padding:9px 18px; border-radius:999px;
  font-size:0.88rem;
}
.nav-cta:hover{background:var(--green-900);}
.nav-toggle{
  display:none;
  background:transparent; border:0;
  font-size:1.4rem; color:var(--green-900); cursor:pointer;
}

/* HERO */
.hero{
  position:relative;
  min-height:100vh;
  display:flex; align-items:center;
  overflow:hidden;
  color:#fff;
  padding:220px 24px 80px;
}
.hero-bg{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transform:scale(1.05);
  filter:saturate(1.05);
}
.hero-overlay{
  position:absolute; inset:0;
  background:linear-gradient(120deg, rgba(31,61,43,0.78) 0%, rgba(31,61,43,0.45) 55%, rgba(58,38,24,0.55) 100%);
}
.hero-content{position:relative; max-width:880px; margin:0 auto; text-align:center;}
.hero .eyebrow{color:var(--gold);}
.hero h1{color:#fff; margin-bottom:22px;}
.hero-sub{color:rgba(255,255,255,0.92); font-size:1.15rem; max-width:640px; margin:0 auto 32px;}
.hero-actions{display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-bottom:60px;}
.hero-stats{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:20px;
  max-width:760px; margin:0 auto;
  border-top:1px solid rgba(255,255,255,0.25);
  padding-top:32px;
}
.hero-stats div{display:flex; flex-direction:column; gap:4px;}
.hero-stats strong{font-family:var(--font-serif); font-size:2.2rem; color:#fff; font-weight:600;}
.hero-stats span{font-size:0.78rem; letter-spacing:0.18em; text-transform:uppercase; color:rgba(255,255,255,0.75);}

.scroll-cue{
  position:absolute; bottom:24px; left:50%; transform:translateX(-50%);
  color:rgba(255,255,255,0.7);
  width:38px; height:38px; border:1px solid rgba(255,255,255,0.4);
  border-radius:50%;
  display:grid; place-items:center;
  animation:bob 2s ease-in-out infinite;
}
@keyframes bob{0%,100%{transform:translate(-50%, 0);} 50%{transform:translate(-50%, 8px);}}

/* SECTION HEAD */
.section-head{margin-bottom:60px;}
.section-head.center{margin-left:auto; margin-right:auto; max-width:780px;}

/* TWO-COL */
.two-col{
  display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center;
}
.two-col.reverse .col-image{order:-1;}
.col-text h2{margin-top:0;}
.checks{list-style:none; padding:0; margin:24px 0 0;}
.checks li{
  position:relative; padding-left:30px; margin-bottom:10px; color:var(--ink);
}
.checks li::before{
  content:"✓"; position:absolute; left:0; top:0;
  width:20px; height:20px; border-radius:50%;
  background:var(--green-700); color:#fff;
  font-size:0.7rem; display:grid; place-items:center;
  margin-top:6px;
}

.col-image{position:relative;}
.col-image img{border-radius:var(--radius-lg); box-shadow:var(--shadow-md);}
.col-image.stack{display:grid; gap:18px; grid-template-columns:2fr 1fr;}
.col-image.stack .big{grid-row:1 / 3; height:100%; object-fit:cover;}
.col-image.stack .small{align-self:end; height:220px; object-fit:cover; width:100%;}

.floating-card{
  position:absolute; bottom:-26px; left:-26px;
  background:#fff; padding:18px 22px;
  border-radius:var(--radius); box-shadow:var(--shadow-md);
  max-width:240px;
}
.floating-num{display:block; font-family:var(--font-serif); font-size:1.4rem; color:var(--green-900); font-weight:700;}
.floating-text{display:block; font-size:0.85rem; color:var(--muted); margin-top:4px;}

/* ORCHARDS */
.orchard-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
.orchard-card{
  background:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform .25s ease, box-shadow .25s ease;
  display:flex; flex-direction:column;
}
.orchard-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-md);}
.orchard-card img{height:220px; object-fit:cover; width:100%;}
.orchard-body{padding:22px 22px 26px;}
.center-body{display:flex; flex-direction:column; justify-content:center; height:100%; text-align:center;}
.orchard-card.feature{grid-column:span 1; border:1px solid rgba(200,147,43,0.35);}
.orchard-card.others{
  background:linear-gradient(135deg, var(--green-700), var(--green-900));
  color:#fff;
}
/* When 'And many more' is alone in its last row (7-card layout), stretch it across */
.orchard-grid > .orchard-card:nth-child(7).others:last-child{
  grid-column:1 / -1;
}
.orchard-grid > .orchard-card:nth-child(7).others:last-child .center-body{
  padding:34px 22px;
}
.orchard-card.others h3{color:#fff;}
.orchard-card.others p{color:rgba(255,255,255,0.85);}
.orchard-card.others .season{color:var(--gold);}
.tag{
  display:inline-block; background:var(--cream-2); color:var(--earth-700);
  padding:4px 12px; border-radius:999px; font-size:0.72rem;
  letter-spacing:0.16em; text-transform:uppercase; margin-bottom:10px;
}
.season{
  display:inline-block; margin-top:14px;
  font-size:0.8rem; letter-spacing:0.12em; text-transform:uppercase;
  color:var(--green-700);
}

/* PONDS */
.pond-list{list-style:none; padding:0; margin:24px 0 32px;}
.pond-list li{
  display:flex; align-items:flex-start; gap:14px;
  padding:14px 0; border-bottom:1px solid var(--line);
  color:var(--ink);
}
.pond-list span{
  flex:0 0 32px; height:32px; border-radius:50%;
  background:var(--green-700); color:#fff;
  display:grid; place-items:center;
  font-family:var(--font-serif); font-weight:700; font-size:0.95rem;
}

/* ANGLING SAMPLE GALLERY */
.angling-gallery-wrap{
  margin-top:60px;
  padding-top:36px;
  border-top:1px dashed var(--line);
}
.angling-gallery-title{
  text-align:center;
  font-family:var(--font-serif);
  font-style:italic;
  font-size:1.05rem;
  color:var(--earth-700);
  margin:0 0 22px;
}
.angling-gallery{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}
.angling-gallery img{
  width:100%;
  aspect-ratio:4/3;
  height:auto;
  object-fit:cover;
  object-position:center;
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  transition:transform .3s ease, box-shadow .3s ease;
}
.angling-gallery img:hover{transform:scale(1.02); box-shadow:var(--shadow-md);}
.angling-gallery-note{
  text-align:center;
  margin:18px 0 0;
  font-size:0.82rem;
  color:var(--muted);
  letter-spacing:0.04em;
  font-style:italic;
}

/* EXPERIENCES */
.exp-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:24px;
}
.exp-card{
  background:#fff; border-radius:var(--radius-lg);
  overflow:hidden; box-shadow:var(--shadow-sm);
  display:flex; flex-direction:column;
  transition:transform .25s ease;
}
.exp-card:hover{transform:translateY(-4px);}
.exp-img{
  height:220px; background-size:cover; background-position:center;
}
.exp-card h3{margin:22px 22px 8px;}
.exp-card p{margin:0 22px 22px;}

/* GALLERY */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:14px;
}
.gallery-grid img{
  width:100%; height:240px; object-fit:cover;
  border-radius:var(--radius);
  transition:transform .3s ease, filter .3s ease;
  cursor:zoom-in;
}
.gallery-grid img:hover{transform:scale(1.03); filter:brightness(1.05);}
.gallery-grid img:nth-child(1),
.gallery-grid img:nth-child(7){grid-row:span 2; height:494px;}

/* DIGNITARIES */
.dignitaries{margin-top:80px; padding-top:60px; border-top:1px solid var(--line);}
.dignitary-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
/* When exactly 5 cards: use flex so the last row of 2 centers nicely */
.dignitary-grid-5{
  display:flex; flex-wrap:wrap; justify-content:center;
  gap:24px;
}
.dignitary-grid-5 .dignitary-card{
  flex:0 1 calc((100% - 48px) / 3);
  min-width:240px;
  max-width:340px;
}
.dignitary-card{
  background:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  display:flex; flex-direction:column;
  text-align:center;
  transition:transform .25s ease, box-shadow .25s ease;
  border-bottom:3px solid var(--gold);
}
.dignitary-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-md);}
.dignitary-photo{
  height:280px;
  background-size:cover; background-position:center top;
  background-color:var(--cream-2);
}
.dignitary-body{padding:22px 22px 26px;}
.dignitary-body h3{
  margin:0 0 6px;
  font-size:1.25rem;
  color:var(--green-900);
}
.dignitary-body .role{
  margin:0 0 10px;
  color:var(--earth-700);
  font-size:0.92rem;
  font-weight:500;
}
.dignitary-body .visit{
  margin:0;
  font-size:0.78rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--muted);
}
.dignitary-card.featured{
  border-bottom-width:4px;
  border-bottom-color:var(--green-700);
  box-shadow:0 12px 32px rgba(31,61,43,0.14);
}
.dignitary-card.featured .dignitary-photo{height:300px;}

/* Visit highlight gallery */
.visit-gallery{
  margin-top:48px;
  padding-top:36px;
  border-top:1px dashed var(--line);
}
.visit-gallery-title{
  text-align:center;
  font-family:var(--font-serif);
  font-style:italic;
  font-size:1.05rem;
  color:var(--earth-700);
  margin:0 0 22px;
}
.visit-gallery-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:14px;
}
.visit-gallery-grid img{
  width:100%;
  aspect-ratio:3/4;
  height:auto;
  object-fit:cover;
  object-position:center 30%;
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  transition:transform .3s ease, box-shadow .3s ease;
  cursor:zoom-in;
}
.visit-gallery-grid img:hover{transform:scale(1.03); box-shadow:var(--shadow-md);}
/* Single-photo visit gallery: one centered image at natural aspect */
.visit-gallery-grid-single{
  grid-template-columns:minmax(300px, 760px);
  justify-content:center;
}
.visit-gallery-grid-single img{
  aspect-ratio:auto;
  object-fit:contain;
  object-position:center;
  height:auto;
  background:var(--cream-2);
}
/* Two-photo visit gallery: two centered images */
.visit-gallery-grid-two{
  grid-template-columns:repeat(2, minmax(280px, 420px));
  justify-content:center;
}
.visit-gallery-grid-two img{aspect-ratio:4/5;}

/* VIDEOS */
.video-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
.video-card{
  background:#fff;
  border:0; padding:0; margin:0;
  text-align:left;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  cursor:pointer;
  font:inherit; color:inherit;
  transition:transform .25s ease, box-shadow .25s ease;
  display:flex; flex-direction:column;
}
.video-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-md);}
.video-card:hover .play-btn{background:var(--green-700); color:#fff; transform:translate(-50%, -50%) scale(1.08);}
.video-thumb{
  position:relative;
  height:220px;
  background-size:cover; background-position:center;
}
.video-thumb::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(0,0,0,0.55) 100%);
}
.play-btn{
  position:absolute; top:50%; left:50%;
  transform:translate(-50%, -50%);
  width:64px; height:64px;
  border-radius:50%;
  background:rgba(255,255,255,0.92);
  color:var(--green-900);
  display:grid; place-items:center;
  font-size:1.4rem;
  padding-left:5px;
  box-shadow:0 8px 24px rgba(0,0,0,0.3);
  transition:background .2s ease, transform .25s ease, color .2s ease;
}
.video-duration{
  position:absolute; bottom:12px; right:12px;
  background:rgba(0,0,0,0.65); color:#fff;
  padding:3px 8px; border-radius:6px;
  font-size:0.78rem; font-weight:500;
  letter-spacing:0.04em;
}
.video-body{padding:20px 22px 24px;}
.video-body h3{margin-bottom:6px;}
.video-body p{margin:0;}
.video-cta{
  text-align:center; margin-top:36px; color:var(--ink);
  font-size:0.95rem;
}
.video-cta a{color:var(--green-700); font-weight:500;}
.video-cta a:hover{color:var(--green-900); text-decoration:underline;}

/* VIDEO MODAL */
.video-modal{
  position:fixed; inset:0;
  background:rgba(10,15,12,0.88);
  display:none;
  align-items:center; justify-content:center;
  z-index:1000;
  padding:24px;
  animation:fadeIn .2s ease;
}
.video-modal.open{display:flex;}
.video-frame{
  position:relative;
  width:100%; max-width:980px;
  aspect-ratio:16/9;
  background:#000;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,0.6);
}
.video-frame iframe{width:100%; height:100%; border:0;}
.video-close{
  position:absolute; top:18px; right:24px;
  background:transparent; border:0;
  color:#fff; font-size:2.4rem; line-height:1;
  cursor:pointer; padding:8px;
  opacity:0.85; transition:opacity .2s ease, transform .2s ease;
  z-index:1;
}
.video-close:hover{opacity:1; transform:rotate(90deg);}
@keyframes fadeIn{from{opacity:0;} to{opacity:1;}}

/* SOCIAL ICONS */
.social-row{
  display:flex; gap:10px;
  margin:6px 0 12px;
}
.social-row a{
  width:40px; height:40px;
  border-radius:50%;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.12);
  color:rgba(255,255,255,0.85);
  display:inline-flex; align-items:center; justify-content:center;
  margin:0;
  line-height:0;
  flex-shrink:0;
  transition:background .2s ease, color .2s ease, transform .2s ease;
}
.social-row a svg{display:block; width:18px; height:18px;}
.social-row a:hover{
  background:var(--gold); color:var(--earth-900);
  transform:translateY(-2px);
}
.social-note{
  color:rgba(255,255,255,0.55);
  font-size:0.85rem;
  margin:0;
}

/* TESTIMONIAL */
.testimonial{
  background:var(--green-900);
  color:#fff;
  text-align:center;
}
.testimonial .container{max-width:820px;}
.quote-mark{
  font-family:var(--font-serif); font-size:6rem; line-height:0.6;
  color:var(--gold); margin:0 0 10px;
}
.testimonial blockquote{
  font-family:var(--font-serif);
  font-size:clamp(1.4rem, 2.4vw, 1.9rem);
  line-height:1.5; color:#fff;
  margin:0 0 26px; font-weight:500;
}
.cite{color:rgba(255,255,255,0.7); letter-spacing:0.15em; text-transform:uppercase; font-size:0.82rem;}

/* REVIEWS */
.reviews{background:var(--cream-2);}
.rating-overall{
  display:inline-flex; align-items:center; gap:14px;
  margin-top:18px;
  background:#fff;
  padding:12px 20px;
  border-radius:999px;
  box-shadow:var(--shadow-sm);
}
.rating-overall .stars{color:var(--gold); letter-spacing:2px; font-size:1.05rem;}
.rating-overall span{color:var(--ink); font-size:0.95rem;}
.rating-overall strong{color:var(--green-900); font-weight:600;}

.review-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px;
}
.review-card{
  background:#fff;
  border-radius:var(--radius-lg);
  padding:26px 26px 22px;
  box-shadow:var(--shadow-sm);
  display:flex; flex-direction:column;
  border-top:3px solid var(--gold);
  transition:transform .25s ease, box-shadow .25s ease;
}
.review-card:hover{transform:translateY(-3px); box-shadow:var(--shadow-md);}
.review-card .stars{
  color:var(--gold);
  letter-spacing:3px;
  font-size:1rem;
  margin-bottom:12px;
}
.review-card .stars .dim{color:rgba(200,147,43,0.25);}
.review-card p{
  font-family:var(--font-serif);
  font-size:1.08rem;
  color:var(--ink);
  line-height:1.55;
  font-weight:500;
  flex:1;
  margin-bottom:22px;
}
.review-author{
  display:flex; align-items:center; gap:12px;
  border-top:1px solid var(--line);
  padding-top:16px;
}
.avatar{
  width:42px; height:42px;
  border-radius:50%;
  display:grid; place-items:center;
  color:#fff; font-weight:600; font-size:0.92rem;
  font-family:var(--font-sans);
  letter-spacing:0.04em;
  flex-shrink:0;
}
.review-author strong{
  display:block;
  color:var(--green-900);
  font-family:var(--font-sans);
  font-size:0.95rem;
}
.review-author span{
  display:block;
  font-size:0.8rem;
  color:var(--muted);
  margin-top:2px;
}

.review-platforms{
  margin-top:54px;
  text-align:center;
}
.review-platforms > p{
  text-transform:uppercase;
  letter-spacing:0.2em;
  font-size:0.78rem;
  color:var(--earth-700);
  margin-bottom:18px;
}
.platform-row{
  display:flex; justify-content:center; gap:18px; flex-wrap:wrap;
}
.platform{
  display:flex; flex-direction:column; align-items:center; gap:6px;
  padding:14px 28px;
  background:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  min-width:160px;
  transition:transform .2s ease, box-shadow .2s ease;
}
.platform:hover{transform:translateY(-3px); box-shadow:var(--shadow-md);}
.platform-name{
  font-family:var(--font-serif);
  font-weight:600; font-size:1.1rem;
  color:var(--green-900);
}
.platform-rating{
  display:flex; align-items:center; gap:8px;
  font-size:0.9rem; color:var(--ink); font-weight:500;
}
.platform-rating .stars{color:var(--gold); letter-spacing:1px; font-size:0.85rem;}

/* CONTACT */
.contact-info{list-style:none; padding:0; margin:24px 0 0;}
.contact-info li{
  padding:14px 0;
  border-bottom:1px solid var(--line);
  display:grid; grid-template-columns:160px 1fr; gap:20px;
  align-items:baseline;
}
.contact-info strong{
  font-size:0.78rem; letter-spacing:0.2em; text-transform:uppercase;
  color:var(--earth-700);
}
.contact-info span{color:var(--ink);}

.contact-form{
  background:#fff; border-radius:var(--radius-lg);
  padding:34px; box-shadow:var(--shadow-md);
  display:flex; flex-direction:column; gap:16px;
}
.contact-form label{display:flex; flex-direction:column; gap:6px;}
.contact-form span{font-size:0.78rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--earth-700);}
.contact-form input,
.contact-form textarea{
  font-family:var(--font-sans);
  font-size:0.98rem;
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius:10px;
  background:var(--cream);
  color:var(--ink);
  transition:border-color .2s ease, background .2s ease;
}
.contact-form input:focus,
.contact-form textarea:focus{
  outline:none;
  border-color:var(--green-500);
  background:#fff;
}

/* FOOTER */
.footer{
  background:var(--earth-900);
  color:rgba(255,255,255,0.75);
  padding:72px 0 0;
}
.footer .logo-name{color:#fff;}
.footer .logo-tag{color:var(--gold);}
.footer .logo-mark{background:var(--gold); color:var(--earth-900);}
.footer-grid{
  display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:40px;
  padding-bottom:48px;
}
.footer h4{color:#fff; margin-bottom:18px;}
.footer-grid a{display:block; margin-bottom:8px; color:rgba(255,255,255,0.7); font-size:0.93rem;}
.footer-grid a:hover{color:var(--gold);}
.footer-tag{color:rgba(255,255,255,0.65); margin-top:16px; max-width:340px;}
.footer-logo{margin-bottom:6px;}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.1);
  padding:22px 24px;
  max-width:var(--max);
  margin:0 auto;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
  font-size:0.82rem;
  color:rgba(255,255,255,0.55);
}

/* Topbar visibility helpers */
.hide-sm{display:inline-flex;}
.hide-md{display:inline;}
@media (max-width: 760px){
  .hide-md{display:none;}
}
@media (max-width: 560px){
  .hide-sm{display:none !important;}
  .topbar-inner{padding:7px 16px; gap:8px;}
  .topbar-contact{gap:0;}
  .topbar-social{gap:4px;}
  .topbar-wa{padding:0 9px;}
}

/* RESPONSIVE */
@media (max-width: 980px){
  .section{padding:72px 0;}
  .two-col{grid-template-columns:1fr; gap:40px;}
  .two-col.reverse .col-image{order:0;}
  .orchard-grid{grid-template-columns:repeat(2, 1fr);}
  .exp-grid{grid-template-columns:repeat(2, 1fr);}
  .video-grid{grid-template-columns:repeat(2, 1fr);}
  .review-grid{grid-template-columns:repeat(2, 1fr);}
  .dignitary-grid{grid-template-columns:repeat(2, 1fr);}
  .visit-gallery-grid{grid-template-columns:repeat(2, 1fr);}
  .angling-gallery{grid-template-columns:repeat(2, 1fr);}
  .gallery-grid{grid-template-columns:repeat(2, 1fr);}
  .gallery-grid img:nth-child(1),
  .gallery-grid img:nth-child(6){grid-row:auto; height:240px;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .col-image.stack{grid-template-columns:1fr;}
  .col-image.stack .big{grid-row:auto;}
  .floating-card{left:auto; right:16px; bottom:-20px;}
  .hero-stats{grid-template-columns:repeat(2, 1fr); gap:24px;}
}

@media (max-width: 640px){
  .nav-links{
    display:none;
    position:absolute; top:100%; left:0; right:0;
    background:var(--cream);
    flex-direction:column; align-items:flex-start;
    padding:18px 24px; gap:14px;
    border-bottom:1px solid var(--line);
  }
  .nav-links.open{display:flex;}
  .nav-toggle{display:block;}
  .orchard-grid, .exp-grid, .video-grid, .review-grid, .dignitary-grid{grid-template-columns:1fr;}
  .orchard-grid > .orchard-card:nth-child(7).others:last-child{grid-column:auto;}
  .visit-gallery-grid{grid-template-columns:1fr 1fr;}
  .angling-gallery{grid-template-columns:1fr 1fr; gap:10px;}
  .contact-info li{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  /* Tighter header on mobile so hero starts higher */
  .nav-inner{padding:8px 16px; gap:12px;}
  .logo-mark{width:54px; height:54px; border-width:2px;}
  .logo-name{font-size:1.05rem;}
  .logo-tag{font-size:0.62rem; letter-spacing:0.18em; margin-top:3px;}
  .hero{padding:170px 20px 60px; min-height:auto;}
  .hero h1{font-size:2rem;}
  .hero-sub{font-size:1rem; margin-bottom:24px;}
  .hero-stats{grid-template-columns:1fr 1fr; gap:18px; padding-top:24px;}
  .hero-stats strong{font-size:1.7rem;}
  .hero-stats span{font-size:0.7rem;}
  /* Section padding tighter */
  .section{padding:56px 0;}
  .container{padding:0 18px;}
  /* Reviews & dignitaries minor */
  .review-card p{font-size:1rem;}
}
