/* =========================================================
   THE MARQUEE SOCIAL - shared styles
   Palette: Dusty Blue & Slate
   ========================================================= */
:root{
  --slate:#26333c;        /* darkest */
  --blue:#3f5a6b;         /* primary */
  --blue-mid:#7d97a6;     /* mid */
  --blue-light:#b9c7cf;   /* light */
  --mist:#dce4e8;         /* very light blue */
  --cream:#f3f1ec;        /* warm off-white */
  --paper:#faf9f6;
  --white:#ffffff;
  --line:rgba(38,51,60,.12);
  --shadow-sm:0 8px 24px -12px rgba(38,51,60,.28);
  --shadow:0 30px 60px -28px rgba(38,51,60,.45);
  --max:1180px;
  --r:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--slate);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,.serif{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;line-height:1.1;letter-spacing:.005em;color:var(--slate)}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:var(--max);margin:0 auto;padding:0 30px}
.eyebrow{font-size:.74rem;letter-spacing:.34em;text-transform:uppercase;font-weight:600;color:var(--blue-mid);font-family:'Inter',sans-serif}
.lead{font-size:1.12rem;color:var(--blue);font-weight:300}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;padding:15px 30px;border-radius:999px;font-family:'Inter',sans-serif;font-weight:500;font-size:.95rem;text-decoration:none;cursor:pointer;border:1px solid transparent;transition:all .25s ease}
.btn-primary{background:var(--blue);color:var(--white);border-color:var(--blue)}
.btn-primary:hover{background:var(--slate);border-color:var(--slate);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--slate);border-color:var(--blue-light)}
.btn-ghost:hover{border-color:var(--slate);background:var(--mist)}
.btn-light{background:var(--white);color:var(--slate);border-color:var(--white)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn-outline-light{background:transparent;color:var(--white);border-color:rgba(255,255,255,.5)}
.btn-outline-light:hover{border-color:#fff;background:rgba(255,255,255,.1)}

/* ---------- NAV ---------- */
header.nav{position:sticky;top:0;z-index:60;background:rgba(250,249,246,.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;letter-spacing:.02em;text-decoration:none;color:var(--slate);line-height:1}
.brand small{display:block;font-family:'Inter',sans-serif;font-size:.56rem;letter-spacing:.36em;text-transform:uppercase;color:var(--blue-mid);font-weight:600;margin-top:4px}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{font-size:.82rem;letter-spacing:.05em;text-decoration:none;color:var(--blue);transition:color .2s;position:relative;padding:4px 0}
.nav-links a:hover{color:var(--slate)}
.nav-links a.active{color:var(--slate);font-weight:500}
.nav-links a.active:after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--blue-mid)}
.nav-links a.nav-cta{padding:11px 22px;border:1px solid var(--slate);border-radius:999px;color:var(--slate)}
.nav-links a.nav-cta:hover{background:var(--slate);color:var(--white)}
.nav-links a.nav-cta:after{display:none}
.menu-btn{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--slate);line-height:1}
.mobile-menu{display:none;flex-direction:column;gap:4px;padding:10px 30px 22px;border-bottom:1px solid var(--line);background:var(--paper)}
.mobile-menu a{padding:12px 0;text-decoration:none;color:var(--blue);border-bottom:1px solid var(--line);font-size:.95rem}
.mobile-menu.open{display:flex}
@media(max-width:860px){
  .nav-links{display:none}
  .menu-btn{display:block}
}

/* ---------- HERO (interior pages) ---------- */
.page-hero{background:linear-gradient(rgba(31,42,49,.78),rgba(31,42,49,.88)),#26333c url('images/aisle-bw.jpg') center/cover;color:var(--cream);position:relative;overflow:hidden}
.page-hero:before{content:"";position:absolute;inset:0;background:
  radial-gradient(1100px 460px at 80% -20%,rgba(125,151,166,.35),transparent 60%),
  radial-gradient(800px 500px at -10% 120%,rgba(125,151,166,.18),transparent 55%)}
.page-hero-in{position:relative;padding:90px 0 96px;text-align:center}
.page-hero h1{font-size:clamp(2.6rem,6vw,4.6rem);color:var(--cream);margin-top:18px}
.page-hero p{margin:20px auto 0;max-width:56ch;color:rgba(243,241,236,.8);font-weight:300;font-size:1.1rem}
.page-hero .eyebrow{color:var(--blue-light)}

/* ---------- SECTIONS ---------- */
section{padding:96px 0}
.sec-head{max-width:62ch}
.sec-head.center{margin:0 auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,4.6vw,3.3rem);margin-top:14px}
.sec-head p{margin-top:16px;font-size:1.08rem;color:var(--blue)}
.bg-cream{background:var(--cream)}
.bg-mist{background:var(--mist)}
.bg-slate{background:var(--slate);color:var(--cream)}
.bg-slate h2,.bg-slate h3{color:var(--cream)}
.bg-slate .sec-head p{color:rgba(243,241,236,.78)}
.bg-slate .eyebrow{color:var(--blue-light)}

/* ---------- HOME HERO ---------- */
.home-hero{background:linear-gradient(rgba(31,42,49,.74),rgba(31,42,49,.86)),#26333c url('images/hero.jpg') center/cover;color:var(--cream);position:relative;overflow:hidden}
.home-hero:before{content:"";position:absolute;inset:0;background:
  radial-gradient(1200px 520px at 78% -10%,rgba(125,151,166,.4),transparent 60%),
  radial-gradient(900px 600px at -5% 120%,rgba(125,151,166,.16),transparent 55%)}
.home-hero-in{position:relative;padding:120px 0 128px;text-align:center}
.home-hero h1{font-size:clamp(3rem,8vw,6.4rem);color:var(--cream);margin:22px auto 0;max-width:15ch}
.home-hero h1 em{font-style:italic;color:var(--blue-light)}
.home-hero p.lead{margin:24px auto 0;max-width:54ch;color:rgba(243,241,236,.82)}
.home-hero .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:38px}
.home-hero .meta{margin-top:44px;font-size:.76rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(243,241,236,.5)}

/* ---------- CARDS GRID ---------- */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:920px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:36px 32px;transition:transform .3s ease,box-shadow .3s ease;text-decoration:none;color:inherit;display:block}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .num{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:var(--blue-mid)}
.card h3{font-size:1.65rem;margin:10px 0 10px}
.card p{color:var(--blue);font-size:.98rem}
.card .more{display:inline-block;margin-top:16px;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-mid);font-weight:600}

/* ---------- IMAGE TILES (gradient placeholders) ---------- */
.tile{border-radius:var(--r);position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:24px;color:#fff;min-height:280px;text-decoration:none;transition:transform .35s ease}
.tile:hover{transform:scale(1.015)}
.tile:before{content:"";position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(20,30,36,.62))}
.tile span{position:relative;z-index:1;font-family:'Cormorant Garamond',serif;font-size:1.4rem}
/* Curated stock photos - swap these URLs for your own event photography.
   t1=weddings · t2=corporate/gala · t3=dinner/banquet · t4=florals/design · t5=reception · t6=celebration
   The #26333c color is a clean slate fallback so a slow/blocked image never looks broken. */
.t1{background:#26333c url('images/roses.jpg') center/cover}
.t2{background:#26333c url('https://images.unsplash.com/photo-1505373877841-8d25f7d46678?auto=format&fit=crop&w=900&q=80') center/cover}
.t3{background:#26333c url('https://images.unsplash.com/photo-1464366400600-7168b8af9bc3?auto=format&fit=crop&w=900&q=80') center/cover}
.t4{background:#26333c url('images/placesetting.jpg') center/cover}
.t5{background:#26333c url('images/lakeside.jpg') center/cover}
.t6{background:#26333c url('https://images.unsplash.com/photo-1492684223066-81342ee5ff30?auto=format&fit=crop&w=900&q=80') center/cover}

/* ---------- SPLIT / ABOUT ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:36px}}
.panel{background:var(--slate);color:var(--cream);border-radius:20px;padding:50px 44px;box-shadow:var(--shadow)}
.panel h3{color:var(--cream);font-size:2rem;margin:12px 0 14px}
.panel p{color:rgba(243,241,236,.82);font-weight:300}
.stats{display:flex;gap:38px;flex-wrap:wrap;margin-top:30px}
.stat .n{font-family:'Cormorant Garamond',serif;font-size:2.3rem;color:var(--blue-light);display:block;line-height:1}
.stat .l{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(243,241,236,.6)}

/* ---------- CTA BAND ---------- */
.cta-band{background:var(--blue);color:#fff;text-align:center}
.cta-band h2{color:#fff;font-size:clamp(2rem,4.5vw,3rem)}
.cta-band p{color:rgba(255,255,255,.85);margin:14px auto 26px;max-width:48ch;font-weight:300}

/* ---------- BLOG ---------- */
.post-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;text-decoration:none;color:inherit;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.post-thumb{min-height:200px;display:flex;align-items:flex-end;padding:20px;color:#fff}
.post-thumb .tag{background:rgba(255,255,255,.92);color:var(--slate);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;padding:5px 12px;border-radius:999px}
.post-body{padding:26px 28px}
.post-body .date{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-mid);font-weight:600}
.post-body h3{font-size:1.5rem;margin:10px 0 8px}
.post-body p{color:var(--blue);font-size:.95rem}
.post-body .more{display:inline-block;margin-top:14px;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-mid);font-weight:600}

/* ---------- ARTICLE ---------- */
.article{max-width:760px;margin:0 auto;padding:70px 30px 96px}
.article .back{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-mid);text-decoration:none;font-weight:600}
.article h1{font-size:clamp(2.2rem,5vw,3.4rem);margin:22px 0 14px}
.article .meta{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-mid);font-weight:600;margin-bottom:30px}
.article .hero-img{min-height:320px;border-radius:var(--r);margin-bottom:40px}
.article p{font-size:1.08rem;color:var(--slate);margin-bottom:22px}
.article h2{font-size:1.9rem;margin:38px 0 14px}
.article ul{margin:0 0 22px 22px}
.article li{margin-bottom:10px;font-size:1.05rem}
.article blockquote{margin:40px auto;padding:0 20px;max-width:48ch;text-align:center;font-family:'Cormorant Garamond',serif;font-size:1.7rem;line-height:1.35;font-style:italic;color:var(--blue)}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:start}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr;gap:36px}}
.call-card{margin-top:30px;border:1px solid rgba(255,255,255,.2);border-radius:var(--r);padding:26px;display:flex;flex-direction:column;gap:6px}
.call-card .eyebrow{color:rgba(243,241,236,.55)}
.call-card a.phone{font-family:'Cormorant Garamond',serif;font-size:2rem;color:var(--blue-light);text-decoration:none}
.call-btn{margin-top:14px;background:var(--blue-light);color:var(--slate);border:0;padding:14px 22px;border-radius:999px;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:10px;width:fit-content}
.call-btn:hover{background:#fff}
.contact-email{margin-top:22px;font-size:.95rem;color:rgba(243,241,236,.78)}
.contact-email a{color:var(--blue-light)}
form.inquiry{background:var(--paper);color:var(--slate);border-radius:20px;padding:38px 34px;box-shadow:var(--shadow)}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:540px){.f-row{grid-template-columns:1fr}}
.field{margin-bottom:16px}
label{display:block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;color:var(--blue);margin-bottom:7px}
input,select,textarea{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem;background:#fff;color:var(--slate);transition:border .2s,box-shadow .2s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue-mid);box-shadow:0 0 0 3px rgba(125,151,166,.2)}
textarea{min-height:120px;resize:vertical}
.submit{width:100%;margin-top:4px;background:var(--slate);color:var(--cream);border:0;padding:16px;border-radius:999px;font-weight:600;font-size:1rem;cursor:pointer;transition:background .25s}
.submit:hover{background:var(--blue)}
.form-ok{display:none;background:#e5eef0;border:1px solid var(--blue-light);color:var(--blue);border-radius:12px;padding:18px;margin-bottom:18px;font-size:.95rem}

/* ---------- FOOTER ---------- */
footer.site{background:#1b252c;color:rgba(243,241,236,.6);padding:60px 0 40px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:36px}
@media(max-width:700px){.footer-grid{grid-template-columns:1fr;gap:28px}}
footer.site .brand{color:var(--cream);font-size:1.5rem;display:inline-block;margin-bottom:10px}
footer.site h4{color:var(--cream);font-family:'Inter',sans-serif;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px}
footer.site a{display:block;color:rgba(243,241,236,.65);text-decoration:none;padding:5px 0;font-size:.9rem}
footer.site a:hover{color:var(--blue-light)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;text-align:center;font-size:.82rem}
.social-row{display:flex;gap:26px;justify-content:center;margin:4px 0 26px}
.social-row a{color:rgba(243,241,236,.6);display:flex;align-items:center;justify-content:center;transition:color .22s ease,transform .22s ease}
.social-row a:hover{color:var(--blue-light);transform:translateY(-2px)}
.social-row svg{width:24px;height:24px;fill:currentColor;display:block}
.nav-social{display:flex;gap:10px;align-items:center;margin-left:8px}
.nav-social a{color:var(--blue);display:flex;transition:color .2s}
.nav-social a:hover{color:var(--slate)}
.nav-social svg{width:17px;height:17px;fill:currentColor}
@media(max-width:860px){.nav-social{display:none}}

/* ---------- SCROLL REVEAL ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- MOBILE STICKY CALL ---------- */
.mobile-call{display:none;position:fixed;bottom:0;left:0;right:0;z-index:70;background:var(--blue);color:#fff;padding:14px;text-align:center;font-weight:600;text-decoration:none;box-shadow:0 -8px 24px rgba(0,0,0,.2)}
@media(max-width:640px){.mobile-call{display:block}body{padding-bottom:54px}}

/* ---------- MOBILE POLISH ---------- */
@media(max-width:600px){
  .wrap{padding:0 22px}
  section{padding:62px 0}
  .home-hero-in{padding:84px 0 88px}
  .page-hero-in{padding:60px 0 64px}
  .home-hero h1{font-size:2.6rem;line-height:1.12;max-width:18ch}
  .home-hero p.lead{font-size:1.04rem}
  .page-hero h1{font-size:2.2rem}
  .sec-head h2{font-size:2rem}
  .panel{padding:36px 26px}
  .price-card{padding:26px 24px}
  .article{padding:48px 22px 72px}
  .article blockquote{font-size:1.45rem}
  .split .tile{min-height:300px!important}
  .split > div[style*="background"]{min-height:340px!important}
  .btn{padding:14px 2