@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Cinzel:wght@400;500;600;700&family=EB+Garamond:ital,wght@0,400;0,500;1,400&display=swap');

:root {
  --forest:    #0e392b;
  --forest-dk: #081f18;
  --forest-md: #154d39;
  --forest-lt: #1e6348;
  --leaf:      #2e8b5a;
  --sage:      #a8c5b0;
  --cream:     #ffffff;
  --cream-dim: rgba(255,255,255,0.78);
  --cream-faint: rgba(255,255,255,0.45);
  --gold:      #d4a843;
  --gold-light:#f0c96a;
  --blush:     #f5f0ea;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'EB Garamond',serif;background:var(--blush);color:var(--forest);overflow-x:hidden;}
::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-track{background:var(--forest-dk);}
::-webkit-scrollbar-thumb{background:var(--leaf);}

/* NAV */
#trp-nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 60px;display:flex;align-items:center;justify-content:space-between;height:72px;transition:height .4s,box-shadow .4s;background:rgba(8,31,24,.97);backdrop-filter:blur(20px);border-bottom:1px solid rgba(46,139,90,.2);}
#trp-nav.scrolled{height:62px;box-shadow:0 4px 24px rgba(0,0,0,.25);}
.nav-logo{display:flex;align-items:center;gap:14px;text-decoration:none;}
.nav-logo img{height:54px;width:54px;border-radius:8px;border:2px solid var(--leaf);object-fit:cover;transition:.3s;}
#trp-nav.scrolled .nav-logo img{height:42px;width:42px;}
.nav-brand{font-family:'Cinzel',serif;font-size:12px;letter-spacing:3px;color:var(--cream-dim);line-height:1.4;}
.nav-brand span{display:block;font-size:8px;letter-spacing:5px;color:var(--sage);}
.nav-links{display:flex;gap:32px;list-style:none;}
.nav-links a{font-family:'Cinzel',serif;font-size:9.5px;letter-spacing:2.5px;color:rgba(255,255,255,.65);text-decoration:none;transition:.3s;position:relative;padding-bottom:4px;}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--leaf);transform:scaleX(0);transition:.3s;}
.nav-links a:hover,.nav-links a.active{color:var(--cream);}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);}
.nav-cta{font-family:'Cinzel',serif;font-size:9px;letter-spacing:3px;padding:11px 26px;border:1px solid var(--leaf);color:var(--cream);background:transparent;cursor:pointer;transition:.4s;text-decoration:none;white-space:nowrap;}
.nav-cta:hover{background:var(--leaf);box-shadow:0 0 20px rgba(46,139,90,.4);}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none;}
.hamburger span{display:block;width:22px;height:1px;background:var(--cream);}
.mob-menu{display:none;position:fixed;inset:0;background:rgba(8,31,24,.98);flex-direction:column;align-items:center;justify-content:center;gap:36px;z-index:999;}
.mob-menu.open{display:flex;}
.mob-menu a{font-family:'Cinzel',serif;font-size:16px;letter-spacing:5px;color:var(--cream-dim);text-decoration:none;transition:.3s;}
.mob-menu a:hover{color:var(--leaf);}
.mob-close{position:absolute;top:28px;right:28px;font-size:22px;color:var(--sage);background:none;border:none;cursor:pointer;}

/* ORNAMENT */
.orn{display:flex;align-items:center;gap:12px;justify-content:center;}
.orn::before,.orn::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--leaf),transparent);max-width:100px;}
.orn-d{width:7px;height:7px;background:var(--leaf);transform:rotate(45deg);flex-shrink:0;}
.orn-gold::before,.orn-gold::after{background:linear-gradient(90deg,transparent,var(--gold),transparent);}
.orn-gold .orn-d{background:var(--gold);}

/* SECTION TYPOGRAPHY */
.section-eyebrow{font-family:'Cinzel',serif;font-size:9px;letter-spacing:6px;color:var(--leaf);margin-bottom:14px;text-align:center;}
.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,4vw,56px);font-weight:300;text-align:center;line-height:1.05;color:var(--forest);margin-bottom:18px;}
.section-title em{font-style:italic;color:var(--leaf);}
.section-desc{font-size:17px;line-height:1.9;color:rgba(14,57,43,.68);text-align:center;max-width:640px;margin:20px auto 0;}
section{padding:110px 60px;}

/* PAGE HERO */
.page-hero{padding-top:90px;min-height:48vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--forest-md);}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 70% at 50% 60%,rgba(46,139,90,.1),transparent);}
.page-hero-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.18;}
.page-hero-inner{position:relative;z-index:1;text-align:center;padding:80px 60px;}
.page-hero .section-title{color:var(--cream);}
.page-hero .section-title em{color:var(--gold-light);}
.page-hero .section-eyebrow{color:var(--gold);}
.page-hero .section-desc{color:rgba(255,255,255,.52);}
.page-hero .orn-d{background:var(--gold);}
.page-hero .orn::before,.page-hero .orn::after{background:linear-gradient(90deg,transparent,var(--gold),transparent);}

/* BUTTONS */
.btn-g{font-family:'Cinzel',serif;font-size:10px;letter-spacing:4px;padding:17px 42px;background:var(--forest);color:var(--cream);border:none;cursor:pointer;transition:.4s;text-decoration:none;display:inline-block;}
.btn-g:hover{background:var(--forest-lt);transform:translateY(-2px);box-shadow:0 8px 28px rgba(14,57,43,.35);}
.btn-o{font-family:'Cinzel',serif;font-size:10px;letter-spacing:4px;padding:17px 42px;border:1px solid var(--forest);color:var(--forest);background:transparent;cursor:pointer;transition:.4s;text-decoration:none;display:inline-block;}
.btn-o:hover{background:var(--forest);color:var(--cream);}
.btn-o-w{font-family:'Cinzel',serif;font-size:10px;letter-spacing:4px;padding:17px 42px;border:1px solid rgba(255,255,255,.5);color:var(--cream);background:transparent;cursor:pointer;transition:.4s;text-decoration:none;display:inline-block;}
.btn-o-w:hover{border-color:var(--cream);background:rgba(255,255,255,.1);}
.btn-g-w{font-family:'Cinzel',serif;font-size:10px;letter-spacing:4px;padding:17px 42px;background:var(--leaf);color:var(--cream);border:none;cursor:pointer;transition:.4s;text-decoration:none;display:inline-block;}
.btn-g-w:hover{background:var(--forest-lt);transform:translateY(-2px);box-shadow:0 8px 28px rgba(46,139,90,.4);}

/* EVENT CARDS */
.ev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;max-width:1300px;margin:70px auto 0;}
.ev-card{position:relative;overflow:hidden;aspect-ratio:4/5;cursor:pointer;}
.ev-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .7s ease;}
.ev-card:hover .ev-bg{transform:scale(1.07);}
.ev-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,31,24,.93) 0%,rgba(14,57,43,.35) 55%,rgba(14,57,43,.06) 100%);}
.ev-icon{position:absolute;top:28px;left:28px;width:42px;height:42px;border:1px solid rgba(168,197,176,.45);display:flex;align-items:center;justify-content:center;font-size:18px;transition:.4s;}
.ev-card:hover .ev-icon{background:rgba(46,139,90,.2);border-color:var(--leaf);}
.ev-body{position:absolute;bottom:0;left:0;right:0;padding:32px;transform:translateY(6px);transition:.4s;}
.ev-card:hover .ev-body{transform:none;}
.ev-tag{font-family:'Cinzel',serif;font-size:8px;letter-spacing:3px;color:var(--leaf);margin-bottom:9px;}
.ev-name{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--cream);line-height:1.2;margin-bottom:8px;}
.ev-desc{font-size:13px;line-height:1.7;color:rgba(255,255,255,.5);max-height:0;overflow:hidden;transition:max-height .4s,opacity .4s;opacity:0;}
.ev-card:hover .ev-desc{max-height:80px;opacity:1;}
.ev-link{display:inline-flex;align-items:center;gap:6px;font-family:'Cinzel',serif;font-size:8px;letter-spacing:3px;color:var(--leaf);margin-top:14px;opacity:0;transition:.3s;text-decoration:none;}
.ev-card:hover .ev-link{opacity:1;}

/* GALLERY */
.gal-mosaic{display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:repeat(3,210px);gap:4px;max-width:1320px;margin:70px auto 0;}
.gal-item{overflow:hidden;position:relative;cursor:pointer;}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.gal-item::after{content:'';position:absolute;inset:0;background:rgba(14,57,43,0);transition:.4s;}
.gal-item:hover img{transform:scale(1.06);}
.gal-item:hover::after{background:rgba(14,57,43,.2);}
.gal-item:nth-child(1){grid-column:1/6;grid-row:1/3;}
.gal-item:nth-child(2){grid-column:6/9;grid-row:1/2;}
.gal-item:nth-child(3){grid-column:9/13;grid-row:1/2;}
.gal-item:nth-child(4){grid-column:6/9;grid-row:2/3;}
.gal-item:nth-child(5){grid-column:9/13;grid-row:2/3;}
.gal-item:nth-child(6){grid-column:1/4;grid-row:3/4;}
.gal-item:nth-child(7){grid-column:4/7;grid-row:3/4;}
.gal-item:nth-child(8){grid-column:7/10;grid-row:3/4;}
.gal-item:nth-child(9){grid-column:10/13;grid-row:3/4;}

/* TESTIMONIALS */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1200px;margin:70px auto 0;}
.testi-card{border:1px solid rgba(14,57,43,.15);padding:40px;position:relative;background:rgba(255,255,255,.6);transition:.3s;}
.testi-card:hover{border-color:var(--leaf);background:rgba(255,255,255,.85);}
.testi-card::before{content:'"';font-family:'Cormorant Garamond',serif;font-size:100px;color:rgba(14,57,43,.07);position:absolute;top:8px;left:18px;line-height:1;}
.testi-stars{color:var(--leaf);font-size:11px;margin-bottom:6px;}
.testi-text{font-size:15.5px;line-height:1.9;color:rgba(14,57,43,.72);font-style:italic;position:relative;z-index:1;margin-bottom:24px;}
.testi-sep{border-top:1px solid rgba(14,57,43,.1);padding-top:18px;display:flex;align-items:center;gap:14px;}
.testi-av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--forest),var(--leaf));display:flex;align-items:center;justify-content:center;font-family:'Cinzel',serif;font-size:15px;color:var(--cream);flex-shrink:0;}
.testi-name{font-family:'Cinzel',serif;font-size:10px;letter-spacing:2px;color:var(--forest);}
.testi-ev{font-size:12px;color:var(--leaf);margin-top:2px;}

/* Dark section overrides */
.testi-dark .testi-card{border-color:rgba(255,255,255,.1);background:rgba(255,255,255,.04);}
.testi-dark .testi-card:hover{border-color:rgba(46,139,90,.4);background:rgba(255,255,255,.07);}
.testi-dark .testi-card::before{color:rgba(255,255,255,.06);}
.testi-dark .testi-stars{color:var(--gold);}
.testi-dark .testi-text{color:rgba(255,255,255,.65);}
.testi-dark .testi-sep{border-top-color:rgba(255,255,255,.1);}
.testi-dark .testi-name{color:var(--cream);}
.testi-dark .testi-ev{color:var(--gold);}

/* STATS */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;max-width:1000px;margin:70px auto 0;}
.s-box{border:1px solid rgba(14,57,43,.15);padding:40px;text-align:center;transition:.4s;background:rgba(255,255,255,.4);}
.s-box:hover{border-color:var(--leaf);background:rgba(255,255,255,.7);}
.s-num{font-family:'Cinzel',serif;font-size:42px;color:var(--forest);font-weight:500;}
.s-lbl{font-family:'Cinzel',serif;font-size:8px;letter-spacing:3px;color:rgba(14,57,43,.52);margin-top:7px;}

.s-box-dark{border-color:rgba(255,255,255,.1) !important;background:rgba(255,255,255,.04) !important;}
.s-box-dark:hover{border-color:rgba(46,139,90,.4) !important;background:rgba(255,255,255,.07) !important;}
.s-box-dark .s-num{color:var(--gold-light);}
.s-box-dark .s-lbl{color:rgba(255,255,255,.4);}

/* FOOTER */
footer{background:var(--forest-dk);border-top:1px solid rgba(46,139,90,.15);padding:80px 60px 36px;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:56px;max-width:1300px;margin:0 auto;}
.f-brand{display:flex;align-items:center;gap:14px;text-decoration:none;margin-bottom:22px;}
.f-brand img{height:50px;width:50px;border-radius:8px;border:1px solid rgba(46,139,90,.4);object-fit:cover;}
.f-brand-name{font-family:'Cinzel',serif;font-size:12px;letter-spacing:3px;color:var(--cream-dim);line-height:1.4;}
.f-brand-name span{display:block;font-size:8px;letter-spacing:4px;color:var(--sage);}
.f-desc{font-size:13.5px;line-height:1.9;color:rgba(255,255,255,.32);margin-bottom:26px;}
.soc-links{display:flex;gap:10px;}
.soc-a{width:34px;height:34px;border:1px solid rgba(46,139,90,.22);display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--sage);text-decoration:none;transition:.3s;}
.soc-a:hover{border-color:var(--leaf);color:var(--cream);}
.f-col h4{font-family:'Cinzel',serif;font-size:8.5px;letter-spacing:4px;color:var(--leaf);margin-bottom:22px;}
.f-links{list-style:none;display:flex;flex-direction:column;gap:11px;}
.f-links a{font-size:13px;color:rgba(255,255,255,.35);text-decoration:none;transition:.3s;}
.f-links a:hover{color:var(--cream);}
.f-bottom{border-top:1px solid rgba(46,139,90,.1);padding-top:28px;margin:56px auto 0;display:flex;justify-content:space-between;align-items:center;max-width:1300px;}
.f-copy{font-family:'Cinzel',serif;font-size:8px;letter-spacing:2px;color:var(--sage);}
.f-tag{font-family:'Cormorant Garamond',serif;font-size:14px;font-style:italic;color:rgba(46,139,90,.38);}

/* REVEAL */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s,transform .7s;}
.reveal.visible{opacity:1;transform:none;}

/* RESPONSIVE */
@media(max-width:960px){
  #trp-nav{padding:0 20px;}
  .nav-links,.nav-cta{display:none;}
  .hamburger{display:flex;}
  section{padding:80px 20px;}
  .ev-grid,.testi-grid,.footer-grid{grid-template-columns:1fr;}
  .stats-row{grid-template-columns:1fr 1fr;}
  .gal-mosaic{grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(4,150px);}
  .gal-item:nth-child(1){grid-column:1/5;grid-row:1/3;}
  .gal-item:nth-child(2){grid-column:5/7;grid-row:1/2;}
  .gal-item:nth-child(3){grid-column:5/7;grid-row:2/3;}
  .gal-item:nth-child(4){grid-column:1/3;grid-row:3/4;}
  .gal-item:nth-child(5){grid-column:3/5;grid-row:3/4;}
  .gal-item:nth-child(6){grid-column:5/7;grid-row:3/4;}
  .gal-item:nth-child(7){grid-column:1/3;grid-row:4/5;}
  .gal-item:nth-child(8){grid-column:3/5;grid-row:4/5;}
  .gal-item:nth-child(9){grid-column:5/7;grid-row:4/5;}
  .f-bottom{flex-direction:column;gap:10px;text-align:center;}
}

/* ═══════════════════════════════════════════════════════
   COMPREHENSIVE RESPONSIVE FIXES
   All breakpoints: 1200px, 960px, 768px, 600px, 480px, 375px
═══════════════════════════════════════════════════════ */

/* ── Global section padding fix ── */
@media(max-width:960px){
  section{padding:80px 24px;}
  .page-hero-inner{padding:80px 24px;}
}
@media(max-width:600px){
  section{padding:60px 16px;}
  .page-hero-inner{padding:60px 16px;}
  .page-hero{min-height:38vh;}
}

/* ── NAV responsive enhancements ── */
@media(max-width:960px){
  .hamburger{display:flex;}
  .nav-links,.nav-cta{display:none;}
  #trp-nav{padding:0 20px;}
}
.mob-menu a{padding:8px 0;}
@media(max-width:480px){
  .mob-menu a{font-size:13px;letter-spacing:3px;}
  .mob-menu{gap:24px;}
}

/* ── Hero section (home) responsive ── */
@media(max-width:900px){
  #hero{flex-direction:column !important;min-height:auto !important;}
  #hero > div:first-child{flex:none !important;width:100% !important;min-height:360px;padding:60px 24px !important;}
  #hero > div:last-child{flex:none !important;width:100% !important;padding:60px 24px !important;}
}
@media(max-width:600px){
  #hero > div:first-child{min-height:280px;padding:50px 16px !important;}
  #hero > div:last-child{padding:50px 16px !important;gap:28px !important;}
  #hero p{max-width:100% !important;}
}
@media(max-width:480px){
  #hero > div:first-child{min-height:220px;}
  #hero .btn-g-w,#hero .btn-o-w{padding:14px 28px;font-size:8px !important;}
}

/* ── Intro section ── */
@media(max-width:600px){
  .intro-sec .section-title{font-size:28px;}
  .section-desc{font-size:15px;}
}

/* ── Stats row ── */
@media(max-width:960px){
  .stats-row{grid-template-columns:1fr 1fr;}
}
@media(max-width:480px){
  .stats-row{grid-template-columns:1fr 1fr;gap:2px;}
  .s-box{padding:24px 16px;}
  .s-num{font-size:32px;}
}

/* ── Event cards ── */
@media(max-width:960px){
  .ev-grid{grid-template-columns:1fr;max-width:520px;margin-left:auto;margin-right:auto;}
  .ev-card{aspect-ratio:16/9;}
}
@media(max-width:600px){
  .ev-grid{max-width:100%;}
  .ev-card{aspect-ratio:4/3;}
  .ev-body{padding:20px;}
  .ev-name{font-size:20px;}
}
@media(max-width:480px){
  .ev-card{aspect-ratio:3/2;}
}

/* ── Why us section responsive (already has some, enhance) ── */
@media(max-width:700px){
  .whyus-text-col{padding-right:0;}
  .whyus-text-col .btn-o-w{align-self:center;}
  .why-list li{font-size:13px;}
}

/* ── Gallery peek slider ── */
@media(max-width:960px){
  .gal-slide{flex:0 0 82vw;width:82vw;height:380px;}
  .gallery-sec{padding:70px 0 70px !important;}
  .gallery-sec > div:first-child{padding:0 24px;}
  .gal-ctrl{padding:0 24px;}
  .gallery-sec > div:last-child{padding:0 24px;}
}
@media(max-width:600px){
  .gal-slide{flex:0 0 90vw;width:90vw;height:260px;}
  .gallery-sec{padding:60px 0 60px !important;}
  .gallery-sec > div:first-child{padding:0 16px;}
  .gal-ctrl{padding:0 16px;}
  .gallery-sec > div:last-child{padding:0 16px;}
}
@media(max-width:480px){
  .gal-slide{flex:0 0 94vw;width:94vw;height:210px;}
  .gal-prev,.gal-next{width:40px;height:40px;font-size:14px;}
}

/* ── Testimonials ── */
@media(max-width:960px){
  .testi-grid{grid-template-columns:1fr;max-width:520px;margin-left:auto;margin-right:auto;}
}
@media(max-width:600px){
  .testi-grid{max-width:100%;}
  .testi-card{padding:28px 20px;}
  .testi-text{font-size:14px;}
}

/* ── Home contact form (hc) ── */
@media(max-width:960px){
  .hc-inner{grid-template-columns:1fr;margin-top:40px;}
  .hc-img-wrap{min-height:260px;border-radius:2px 2px 0 0;}
  .hc-form-box{padding:36px 24px;border-radius:0 0 2px 2px;}
  .hc-grid2{grid-template-columns:1fr;}
}
@media(max-width:600px){
  .hc-form-box{padding:28px 16px;}
}

/* ── Footer ── */
@media(max-width:960px){
  footer{padding:60px 24px 28px;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px;}
}
@media(max-width:600px){
  footer{padding:50px 16px 24px;}
  .footer-grid{grid-template-columns:1fr;gap:28px;}
  .f-bottom{flex-direction:column;gap:10px;text-align:center;}
}

/* ── Buttons global mobile ── */
@media(max-width:480px){
  .btn-g,.btn-o,.btn-o-w,.btn-g-w{
    padding:14px 28px;
    font-size:9px;
    letter-spacing:3px;
  }
}

/* ── Section title global ── */
@media(max-width:600px){
  .section-title{font-size:clamp(26px,7vw,38px);}
  .section-eyebrow{font-size:8px;letter-spacing:4px;}
}

/* ── Page hero inner ── */
@media(max-width:480px){
  .page-hero .section-title{font-size:clamp(24px,8vw,36px);}
}

/* ── Gallery mosaic page ── */
@media(max-width:960px){
  .gal-mosaic{
    grid-template-columns:repeat(6,1fr);
    grid-template-rows:repeat(4,150px);
  }
  .gal-item:nth-child(1){grid-column:1/5;grid-row:1/3;}
  .gal-item:nth-child(2){grid-column:5/7;grid-row:1/2;}
  .gal-item:nth-child(3){grid-column:5/7;grid-row:2/3;}
  .gal-item:nth-child(4){grid-column:1/3;grid-row:3/4;}
  .gal-item:nth-child(5){grid-column:3/5;grid-row:3/4;}
  .gal-item:nth-child(6){grid-column:5/7;grid-row:3/4;}
  .gal-item:nth-child(7){grid-column:1/3;grid-row:4/5;}
  .gal-item:nth-child(8){grid-column:3/5;grid-row:4/5;}
  .gal-item:nth-child(9){grid-column:5/7;grid-row:4/5;}
}
@media(max-width:600px){
  .gal-mosaic{
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto;
    gap:3px;
  }
  .gal-item{min-height:140px;}
  .gal-item:nth-child(1){grid-column:1/3;grid-row:1/2;}
  .gal-item:nth-child(2){grid-column:1/2;grid-row:2/3;}
  .gal-item:nth-child(3){grid-column:2/3;grid-row:2/3;}
  .gal-item:nth-child(4){grid-column:1/2;grid-row:3/4;}
  .gal-item:nth-child(5){grid-column:2/3;grid-row:3/4;}
  .gal-item:nth-child(6){grid-column:1/3;grid-row:4/5;}
  .gal-item:nth-child(7){grid-column:1/2;grid-row:5/6;}
  .gal-item:nth-child(8){grid-column:2/3;grid-row:5/6;}
  .gal-item:nth-child(9){grid-column:1/3;grid-row:6/7;}
}

/* ── Venues page ── */
@media(max-width:900px){
  .venue-card{grid-template-columns:1fr !important;direction:ltr !important;min-height:auto;}
  .venue-card:nth-child(even){direction:ltr !important;}
  .vc-image{min-height:280px;}
  .venues-header{padding:0 24px;}
}
@media(max-width:600px){
  .venues-intro{padding:60px 16px !important;}
  .venues-sec{padding:60px 0 !important;}
  .venues-header{padding:0 16px;}
  .vc-image{min-height:220px;}
}

/* ── Contact page ── */
@media(max-width:960px){
  .contact-grid{grid-template-columns:1fr !important;}
}

/* ── Gastronomy page ── */
@media(max-width:960px){
  .gastro-grid{grid-template-columns:1fr !important;}
}

/* ── Events page ── */
@media(max-width:960px){
  .events-hero-split{flex-direction:column !important;}
}

/* ── Video intro section ── */
@media(max-width:600px){
  #video-intro{height:100svh;}
  .vi-logo img{width:clamp(100px,28vw,150px);}
  .vi-brand-name{font-size:clamp(10px,3vw,14px);letter-spacing:5px;}
  .vi-brand-sub{font-size:clamp(8px,2vw,11px);letter-spacing:3px;}
}

/* ── Ornament ── */
@media(max-width:600px){
  .orn::before,.orn::after{max-width:60px;}
}

/* ── About grid already responsive, just enhance small sizes ── */
@media(max-width:480px){
  .about-grid{gap:28px;}
}

/* ── Fix smooth scroll on touch devices (disable inertia scroll) ── */
@media(hover:none),(pointer:coarse){
  body{overflow:auto !important;height:auto !important;}
  #smooth-wrapper{position:static !important;transform:none !important;}
}

/* ── Form fields on mobile ── */
@media(max-width:480px){
  .hc-field{font-size:16px;} /* prevent iOS zoom */
  input[type="text"],input[type="email"],input[type="tel"],input[type="date"],select,textarea{
    font-size:16px !important; /* prevent iOS zoom */
  }
}

/* ── Why us btn on mobile ── */
@media(max-width:700px){
  .whyus-text-col .btn-o-w{
    align-self:flex-start;
  }
}

/* ── Gallery section padding override for mobile ── */
@media(max-width:960px){
  section.gallery-sec{padding-left:0 !important;padding-right:0 !important;}
}

/* ── Ensure images don't overflow ── */
img{max-width:100%;height:auto;}

/* ── Fix hero frame on small screens ── */
@media(max-width:480px){
  .hero-frame{inset:10px;}
  .h-title{font-size:clamp(36px,11vw,60px);}
  .h-title em{font-size:clamp(26px,8vw,44px);}
  .h-sub{font-size:12px;margin-bottom:28px;}
  .h-btns{flex-direction:column;align-items:center;gap:12px;}
}

/* ── Instagram section ── */
@media(max-width:600px){
  .insta-sec{padding:60px 16px !important;}
}

/* ── Home contact section ── */
@media(max-width:600px){
  .home-contact-sec{padding:60px 16px !important;}
}

/* ── Events section ── */
@media(max-width:600px){
  .events-sec{padding:60px 16px !important;}
}

/* ── Whyus section ── */
@media(max-width:600px){
  .whyus-sec{padding:60px 16px !important;}
}

/* ── Testimonials section ── */
@media(max-width:600px){
  .testi-sec{padding:60px 16px !important;}
}


/* ── Gallery header padding override ── */
@media(max-width:960px){
  .gal-header-pad{padding:0 24px !important;}
}
@media(max-width:600px){
  .gal-header-pad{padding:0 16px !important;}
}

/* ── Venues inner cards padding ── */
@media(max-width:600px){
  .venue-cards{margin-top:50px;}
}

/* ── Ensure no horizontal scroll globally ── */
html,body{overflow-x:hidden;}

/* ── Nav logo on very small screens ── */
@media(max-width:360px){
  .nav-logo img{height:42px;width:42px;}
  .nav-brand{font-size:10px;letter-spacing:2px;}
  .nav-brand span{font-size:7px;}
}

/* ── Fix for smooth scroll wrapper on mobile ── */
@media(hover:none),(pointer:coarse){
  html{scroll-behavior:smooth;}
  body{overflow-y:auto !important;overflow-x:hidden !important;height:auto !important;}
  #smooth-wrapper{
    position:relative !important;
    transform:translateY(0) !important;
    width:100% !important;
  }
}


/* ════════════════════════════════════════════════════════
   DEEP RESPONSIVE — PASS 2  (all pages, all breakpoints)
════════════════════════════════════════════════════════ */

/* ─── CONTACT PAGE ─────────────────────────────────── */
/* inline-grid 2-col name row inside contact form */
@media(max-width:600px){
  .contact-grid > div:last-child > div[style*="grid-template-columns:1fr 1fr"]{
    display:block !important;
  }
  .contact-grid > div:last-child{
    padding:28px 16px !important;
  }
  .contact-grid{gap:44px;}
}
@media(max-width:480px){
  .contact-grid > div:last-child{
    padding:20px 12px !important;
  }
}

/* ─── EVENTS PAGE ──────────────────────────────────── */
@media(max-width:700px){
  .ev-mosaic{
    display:grid !important;
    grid-template-columns:1fr !important;
    grid-template-rows:none !important;
    gap:10px;
  }
  .evm-card{height:280px !important;}
  .evm-card:nth-child(1){height:340px !important;}
  /* Always show panel on mobile (no hover) */
  .evm-panel{
    max-height:140px !important;
    opacity:1 !important;
    transition:none !important;
  }
  .evm-stats{
    opacity:1 !important;
    transform:none !important;
    transition:none !important;
  }
  .evm-body{padding:0 20px 22px !important;}
  .evm-card:nth-child(1) .evm-body{padding:0 20px 22px !important;}
  .ev-filter-btn{padding:8px 14px;font-size:7px;letter-spacing:2px;}
  .ev-filters{gap:7px;margin-top:28px;}
}
@media(max-width:480px){
  .evm-card{height:240px !important;}
  .evm-card:nth-child(1){height:300px !important;}
  .evm-name{font-size:16px !important;}
  .evm-card:nth-child(1) .evm-name{font-size:20px !important;}
}

/* ─── GALLERY PAGE ─────────────────────────────────── */
@media(max-width:960px){
  .mem-mosaic{
    grid-template-columns:repeat(6,1fr);
    grid-template-rows:260px 220px 260px;
    gap:8px;
  }
  .mem-tile:nth-child(1){grid-column:1/5;grid-row:1/2;}
  .mem-tile:nth-child(2){grid-column:5/7;grid-row:1/2;}
  .mem-tile:nth-child(3){grid-column:1/3;grid-row:2/3;}
  .mem-tile:nth-child(4){grid-column:3/5;grid-row:2/3;}
  .mem-tile:nth-child(5){grid-column:5/7;grid-row:2/3;}
  .mem-tile:nth-child(6){grid-column:1/3;grid-row:3/4;}
  .mem-tile:nth-child(7){grid-column:3/5;grid-row:3/4;}
  .mem-tile:nth-child(8){grid-column:5/7;grid-row:3/4;}
  .mem-tile:nth-child(9){grid-column:1/4;grid-row:4/5;}
  .mem-tile:nth-child(10){grid-column:4/7;grid-row:4/5;}
}
@media(max-width:600px){
  .mem-mosaic{
    grid-template-columns:1fr 1fr;
    grid-template-rows:none;
    gap:6px;
  }
  .mem-tile{min-height:160px;}
  .mem-tile:nth-child(1){grid-column:1/3;grid-row:auto;}
  .mem-tile:nth-child(2){grid-column:1/2;grid-row:auto;}
  .mem-tile:nth-child(3){grid-column:2/3;grid-row:auto;}
  .mem-tile:nth-child(4){grid-column:1/2;grid-row:auto;}
  .mem-tile:nth-child(5){grid-column:2/3;grid-row:auto;}
  .mem-tile:nth-child(6){grid-column:1/3;grid-row:auto;}
  .mem-tile:nth-child(7){grid-column:1/2;grid-row:auto;}
  .mem-tile:nth-child(8){grid-column:2/3;grid-row:auto;}
  .mem-tile:nth-child(9){grid-column:1/2;grid-row:auto;}
  .mem-tile:nth-child(10){grid-column:2/3;grid-row:auto;}
  /* Show labels on mobile always */
  .mem-tile::before{opacity:1 !important;}
  .mem-tile-label{opacity:1 !important;transform:none !important;}
  .mem-filters{gap:6px;margin-top:24px;}
  .mem-filter-btn{padding:8px 14px;font-size:7px;}
}

/* ─── GASTRONOMY PAGE ──────────────────────────────── */
@media(max-width:960px){
  .g-grid{
    grid-template-columns:1fr 1fr !important;
    grid-template-rows:auto !important;
  }
  .g-card[style*="grid-row:1/3"]{grid-row:auto !important;grid-column:1/3 !important;}
}
@media(max-width:600px){
  .g-grid{
    grid-template-columns:1fr !important;
  }
  .g-card[style*="grid-row:1/3"]{grid-column:auto !important;}
  .g-card{padding:28px 20px !important;}
}

/* ─── ABOUT PAGE ───────────────────────────────────── */
@media(max-width:640px){
  .vcn{padding:28px 20px 24px !important;}
  .vcn-feat{transform:translateY(-8px) !important;}
  .vcn-num{font-size:56px !important;}
}

/* ─── VENUES PAGE — additional ─────────────────────── */
@media(max-width:640px){
  .venues-sec{padding-top:60px !important;padding-bottom:60px !important;}
  .venues-intro{padding:60px 16px !important;}
  .venues-features-sec{padding:60px 16px !important;}
  .venues-cta{padding:60px 16px !important;}
  .vc-content{padding:28px 18px !important;}
  .vc-stats{gap:16px !important;flex-wrap:wrap;}
  .vc-name{font-size:clamp(22px,5vw,34px) !important;}
  .vf-card{padding:28px 20px !important;}
  .vc-feat-tag{font-size:6px;padding:4px 9px;}
}
@media(max-width:480px){
  .vc-image{height:220px !important;}
  .venue-card{min-height:auto !important;}
  .vc-stat-val{font-size:17px !important;}
}

/* ─── GLOBAL section inline style overrides ─────────── */
/* These target sections with hardcoded inline padding:110px 60px */
@media(max-width:960px){
  [style*="padding:110px 60px"]{padding:80px 24px !important;}
  [style*="padding: 110px 60px"]{padding:80px 24px !important;}
}
@media(max-width:600px){
  [style*="padding:110px 60px"]{padding:60px 16px !important;}
  [style*="padding: 110px 60px"]{padding:60px 16px !important;}
}

/* ─── Gastronomy chef quote block ────────────────────── */
@media(max-width:600px){
  .gastro-quote-wrap{padding:36px 20px !important;max-width:100% !important;}
}
/* Target inline style on the quote div */
@media(max-width:600px){
  [style*="max-width:780px"][style*="padding:64px"]{
    padding:36px 20px !important;
    max-width:100% !important;
  }
}

/* ─── Contact inline grid → stacked on mobile ─────────── */
@media(max-width:600px){
  [style*="display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px"]{
    display:block !important;
  }
  [style*="display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px"] > div{
    margin-bottom:16px;
  }
  .trp-input{font-size:16px !important;}
}

/* ─── Fix nav scrolled transform on mobile ───────────── */
@media(hover:none),(pointer:coarse){
  #trp-nav{
    transform:none !important;
    top:0 !important;
  }
  #smooth-wrapper{
    position:static !important;
    transform:none !important;
    width:100% !important;
    will-change:auto !important;
  }
  body{
    overflow-x:hidden !important;
    overflow-y:auto !important;
    height:auto !important;
  }
}

/* ─── Mobile menu improvements ─────────────────────── */
.mob-menu{
  padding:80px 24px 40px;
  overflow-y:auto;
}
@media(max-width:380px){
  .mob-menu a{font-size:14px;letter-spacing:4px;}
  .mob-close{top:20px;right:20px;font-size:20px;}
}

/* ─── Fix hero frame corners at small sizes ─────────── */
@media(max-width:400px){
  .hero-frame::before,.hero-frame::after{width:36px;height:36px;}
}

/* ─── Lightbox mobile fix ─────────────────────────── */
@media(max-width:600px){
  #mem-lb-img{max-width:96vw;max-height:80vh;}
  #mem-lb-prev{left:8px;}
  #mem-lb-next{right:8px;}
  #mem-lb-close{top:12px;right:12px;padding:6px 12px;font-size:9px;}
}

/* ─── Gallery section header padding (page) ─────────── */
@media(max-width:960px){
  [style*="padding:110px 60px 80px"]{padding:70px 24px 50px !important;}
}
@media(max-width:600px){
  [style*="padding:110px 60px 80px"]{padding:60px 16px 40px !important;}
}

/* ─── Testimonials dark section ─────────────────────── */
@media(max-width:600px){
  .testi-dark .testi-card{padding:24px 16px;}
  .testi-dark .testi-text{font-size:14px;}
}

/* ─── Stats dark boxes ───────────────────────────────── */
@media(max-width:480px){
  .s-box-dark{padding:22px 12px;}
  .s-box-dark .s-num{font-size:30px;}
}

/* ─── Video intro — very small phones ─────────────────── */
@media(max-width:375px){
  .vi-brand-name{letter-spacing:3px;font-size:11px;}
  .vi-brand-sub{letter-spacing:2px;}
}

/* ─── Ensure CTA button rows wrap properly ────────────── */
[style*="display:flex;gap:18px;justify-content:center"]{
  flex-wrap:wrap;
}
[style*="display:flex;gap:16px;flex-wrap:wrap"]{
  justify-content:center;
}
@media(max-width:480px){
  [style*="display:flex;gap:18px;justify-content:center"]{
    flex-direction:column;
    align-items:center;
    gap:12px !important;
  }
}

/* ─── Page hero desc text ────────────────────────────── */
@media(max-width:480px){
  .page-hero .section-desc{
    font-size:14px;
    line-height:1.7;
  }
}


/* ════════════════════════════════════════════════════════
   FINAL POLISH — typography, spacing, touch targets
════════════════════════════════════════════════════════ */

/* Touch targets — min 44px */
.hamburger{min-width:44px;min-height:44px;align-items:center;justify-content:center;}
.mob-close{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;}
.gal-prev,.gal-next{min-width:44px;min-height:44px;}
.h-dot{min-width:22px;min-height:22px;}

/* ─── Section headings — fluid on tiny screens ──────── */
@media(max-width:375px){
  .section-title{font-size:clamp(22px,8vw,28px);}
  h1.section-title{font-size:clamp(24px,9vw,32px);}
}

/* ─── Nav padding — very small ──────────────────────── */
@media(max-width:380px){
  #trp-nav{padding:0 14px;}
}

/* ─── Venue card stats — no wrap on medium ──────────── */
@media(min-width:641px) and (max-width:900px){
  .vc-stats{flex-wrap:nowrap;gap:20px;}
}

/* ─── Pillar section vcn-feat mobile ───────────────── */
@media(max-width:640px){
  .vcn-feat{transform:translateY(0) !important;}
}

/* ─── Inline about-grid image ──────────────────────── */
@media(max-width:480px){
  .about-grid img{border-radius:2px;}
}

/* ─── footer grid col gap ──────────────────────────── */
@media(max-width:700px) and (min-width:601px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:24px;}
}

/* ─── Events filter tab wrapping ───────────────────── */
@media(max-width:500px){
  .ev-filter-btn{padding:8px 12px;letter-spacing:2px;}
  .ev-filters{gap:6px;}
}

/* ─── Orn line max-width on mobile ─────────────────── */
@media(max-width:480px){
  .orn::before,.orn::after{max-width:40px;}
}

/* ─── Ensure no content overflow ───────────────────── */
*{box-sizing:border-box;}
.ev-mosaic,.mem-mosaic,.gal-mosaic,.ev-grid,.testi-grid,.footer-grid,.stats-row{
  min-width:0;
}

/* ─── Smooth scroll chevron on mobile ───────────────── */
@media(max-width:600px){
  .vi-scroll{bottom:28px;}
  .vi-chevron,.vi-chevron2{width:12px;height:12px;}
}

/* ─── Venue CTA flex on mobile ──────────────────────── */
@media(max-width:480px){
  .venues-cta [style*="display:flex"]{
    flex-direction:column !important;
    align-items:center !important;
  }
}

/* ─── WHY US list mobile ────────────────────────────── */
@media(max-width:480px){
  .why-list li{font-size:13px;line-height:1.5;}
  .why-dot{margin-top:5px;}
}

/* ─── s-lbl label text ──────────────────────────────── */
@media(max-width:480px){
  .s-lbl{font-size:7px;letter-spacing:2px;margin-top:4px;}
}

/* ─── Gallery page filter pills spacing ─────────────── */
@media(max-width:480px){
  .mem-filter-btn{padding:7px 11px;font-size:6.5px;letter-spacing:2px;}
  .mem-filters{gap:5px;margin-top:20px;}
}

/* ─── Lightbox prev/next on tiny phones ─────────────── */
@media(max-width:400px){
  #mem-lb-prev,#mem-lb-next{width:38px;height:38px;font-size:16px;}
}

