/* ============================
   ELYSI Events — Site Stylesheet
   ============================ */

:root{
  --cream:#f5ecdf;
  --cream-deep:#ede0cd;
  --sage:#9ba98a;
  --sage-deep:#7d8b6c;
  --blue:#9bb1c4;
  --taupe:#a89180;
  --mauve:#c9b3ad;
  --mauve-deep:#a89089;
  --oxblood:#7a3338;
  --oxblood-deep:#5e2429;
  --gold:#b8907a;
  --espresso:#2c1f17;
  --ink:#1a120c;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{
  background-color:var(--cream);
  background-image:url("brand/wallpaper-large.jpg");
  background-size:1100px auto;
  background-repeat:repeat;
  background-attachment:fixed;
  color:var(--espresso);font-family:"Lato",sans-serif;font-weight:300;line-height:1.65;-webkit-font-smoothing:antialiased
}
body::before{
  content:"";position:fixed;inset:0;
  background:rgba(245,236,223,.78);
  pointer-events:none;z-index:0;
}
.layout{position:relative;z-index:1}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.script{font-family:"Pinyon Script",cursive;font-weight:400}
.serif{font-family:"Cormorant Garamond",serif}

/* LAYOUT */
.layout{display:grid;grid-template-columns:280px 1fr;min-height:100vh}

/* SIDEBAR */
aside.sidebar{
  position:sticky;top:0;height:100vh;
  background:rgba(245,236,223,.92);
  backdrop-filter:blur(6px);
  border-right:1px solid rgba(168,145,128,.25);
  display:flex;flex-direction:column;align-items:center;
  padding:34px 28px 24px;text-align:center;
  overflow-y:auto;
}
aside.sidebar .logo{width:170px;margin-bottom:22px}
aside.sidebar .addr{font-size:11px;letter-spacing:.18em;color:var(--espresso);line-height:1.7;margin-bottom:6px}
aside.sidebar .addr a{display:block}
aside.sidebar .addr a:hover{color:var(--oxblood)}
aside.sidebar .order{
  margin:22px 0 28px;
  display:inline-block;padding:12px 28px;
  border:1.5px solid var(--oxblood);color:var(--oxblood);
  font-size:11px;letter-spacing:.36em;text-transform:uppercase;
  border-radius:999px;font-weight:500;
  transition:all .25s;
}
aside.sidebar .order:hover{background:var(--oxblood);color:var(--cream)}

aside.sidebar nav{margin-top:8px;width:100%}
aside.sidebar nav ul{list-style:none}
aside.sidebar nav li{margin:14px 0}
aside.sidebar nav a{
  font-family:"Cormorant Garamond",serif;
  font-size:18px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--espresso);
  padding-bottom:3px;border-bottom:1px solid transparent;
  transition:all .2s;
}
aside.sidebar nav a:hover,
aside.sidebar nav a.is-active{color:var(--oxblood);border-bottom-color:var(--oxblood)}

aside.sidebar .signup{
  margin-top:28px;width:100%;
  padding:18px 12px;
  border-top:1px solid rgba(168,145,128,.3);
  border-bottom:1px solid rgba(168,145,128,.3);
}
aside.sidebar .signup .title{
  font-family:"Pinyon Script",cursive;
  font-size:32px;color:var(--oxblood);line-height:1;
}
aside.sidebar .signup .sub{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--taupe);margin-top:4px}
aside.sidebar .signup form{margin-top:12px;display:flex;flex-direction:column;gap:6px}
aside.sidebar .signup input{
  border:1px solid rgba(168,145,128,.5);background:transparent;
  padding:8px 10px;font-size:11px;font-family:"Lato",sans-serif;
  color:var(--espresso);border-radius:0;
}
aside.sidebar .signup button{
  border:1px solid var(--oxblood);background:transparent;color:var(--oxblood);
  padding:8px;font-size:10px;letter-spacing:.32em;text-transform:uppercase;cursor:pointer;
  transition:all .2s;font-family:"Lato",sans-serif;font-weight:500;
}
aside.sidebar .signup button:hover{background:var(--oxblood);color:var(--cream)}

aside.sidebar .socials{margin-top:auto;padding-top:24px;display:flex;gap:14px;justify-content:center}
aside.sidebar .socials a{
  width:34px;height:34px;border-radius:50%;
  border:1px solid var(--taupe);color:var(--espresso);
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
aside.sidebar .socials a:hover{background:var(--oxblood);border-color:var(--oxblood);color:var(--cream)}
aside.sidebar .socials svg{width:14px;height:14px}

main{min-width:0}

/* TAGLINE STRIP */
.tag-strip{
  background:var(--oxblood);color:var(--cream);
  text-align:center;padding:22px 24px;
  font-family:"Allura","Great Vibes",cursive;
  font-size:42px;line-height:1;letter-spacing:.01em;
  font-weight:400;
}

/* HERO (homepage rotator) */
.hero{position:relative;width:100%;margin:0;height:min(78vh,820px);min-height:520px;background:var(--mauve,#c8a8a0);overflow:hidden}
.hero .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.4s ease}
.hero .slide.active{opacity:1}
.hero .slide img{width:100%;height:100%;object-fit:cover;object-position:center 35%}
/* per-photo focus tuning so the subject stays in frame */
.hero .slide img[src*="hero-tulips-tablescape"]{object-position:center 60%}
.hero .slide img[src*="hobbit-arch"]{object-position:center 50%}
.hero .slide img[src*="fairy-tea-1"]{object-position:center 45%}
.hero .slide img[src*="fairy-girl"]{object-position:center 30%}
.hero .slide img[src*="board-pink-roses-cabbage-dip-detail"]{object-position:center 50%}
.hero .slide img[src*="triptych-fairy"]{object-position:center 50%;transform:scale(1.18);transform-origin:center center}
.hero .arr{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;background:rgba(245,236,223,.85);color:var(--espresso);display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;transition:all .25s;z-index:3}
.hero .arr:hover{background:var(--cream);transform:translateY(-50%) scale(1.05)}
.hero .arr svg{width:18px;height:18px}
.hero .prev{left:28px}
.hero .next{right:28px}

/* PAGE HERO (sub-pages — single image with title pill) */
.page-hero{position:relative;width:100%;margin:0;height:60vh;min-height:480px;overflow:hidden}
.page-hero img{width:100%;height:100%;object-fit:cover}
.page-hero .pill{
  position:absolute;left:50%;bottom:36px;transform:translateX(-50%);
  background:var(--cream);padding:14px 32px;border-radius:999px;
  font-family:"Pinyon Script",cursive;font-size:42px;color:var(--oxblood);
  border:1px solid rgba(168,145,128,.45);
  box-shadow:0 18px 40px -20px rgba(44,31,23,.4);
  white-space:nowrap;
}

/* SERVICE ROW (homepage) */
.service{position:relative;padding:70px 60px;background:transparent}
.service-row{
  position:relative;
  max-width:1180px;margin:0 auto;
  min-height:560px;
  display:flex;align-items:center;
}
.service-row .photo{
  width:70%;aspect-ratio:5/4;overflow:hidden;
  position:relative;z-index:1;border-radius:4px;
}
.service-row .photo img{width:100%;height:100%;object-fit:cover;transition:transform 6s ease}
.service-row:hover .photo img{transform:scale(1.04)}
.service-row .card{
  position:absolute;top:50%;transform:translateY(-50%);
  width:46%;max-width:480px;
  background:var(--mauve);color:#3a2820;
  padding:50px 44px;
  text-align:center;border-radius:22px;
  box-shadow:0 24px 70px -30px rgba(120,90,80,.45);
  z-index:2;
}
.service-row.left{justify-content:flex-end}
.service-row.left .card{left:2%}
.service-row.right{justify-content:flex-start}
.service-row.right .card{right:2%}

.service-row .card .num{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:14px;letter-spacing:.4em;color:rgba(58,40,32,.6);text-transform:uppercase;margin-bottom:14px}
.service-row .card h2{
  font-family:"Pinyon Script",cursive;font-weight:400;
  font-size:64px;line-height:.95;color:var(--oxblood);
  margin-bottom:20px;
}
.service-row .card p{font-size:14.5px;line-height:1.75;color:#3a2820;margin-bottom:28px;max-width:380px;margin-left:auto;margin-right:auto}

/* generic outline pill button */
.btn-outline{
  display:inline-block;padding:13px 32px;
  border:1.5px solid var(--oxblood);color:var(--oxblood);
  border-radius:999px;font-size:11px;letter-spacing:.36em;text-transform:uppercase;font-weight:500;
  transition:all .25s;cursor:pointer;background:transparent;
  font-family:"Lato",sans-serif;
}
.btn-outline:hover{background:var(--oxblood);color:var(--cream)}
.btn-cream{
  display:inline-block;padding:13px 32px;
  border:1.5px solid var(--cream);color:var(--cream);
  border-radius:999px;font-size:11px;letter-spacing:.36em;text-transform:uppercase;font-weight:500;
  transition:all .25s;
}
.btn-cream:hover{background:var(--cream);color:var(--oxblood)}

/* MARQUEE — auto-scrolling photo strip */
.marquee{
  padding:90px 0;background:transparent;overflow:hidden;
}
.marquee .head{text-align:center;margin-bottom:48px;padding:0 24px}
.marquee .head .script{font-size:64px;color:var(--oxblood);line-height:1}
.marquee .head .sub-wrap{margin-top:14px;display:flex;justify-content:center}
.marquee .head .sub{font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--espresso);background:var(--cream);padding:8px 18px;border-radius:999px;border:1px solid rgba(168,145,128,.4);display:inline-block}
.marquee-track{
  display:flex;gap:18px;width:max-content;
  animation:slide 80s linear infinite;
}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track figure{flex:0 0 auto;width:280px;height:280px;overflow:hidden;border-radius:4px;margin:0;box-shadow:0 12px 30px -20px rgba(44,31,23,.3)}
.marquee-track figure img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s}
.marquee-track figure:hover img{transform:scale(1.06)}
@keyframes slide{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.marquee .footer-link{text-align:center;margin-top:36px;font-size:13px;letter-spacing:.16em}
.marquee .footer-link a{border-bottom:1px solid var(--taupe);padding-bottom:3px;color:var(--espresso)}
.marquee .footer-link a:hover{color:var(--oxblood);border-bottom-color:var(--oxblood)}

/* ABOUT */
.about{padding:100px 24px;background:transparent}
.about-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:center}
.about-grid .img{aspect-ratio:4/5;overflow:hidden;border-radius:4px}
.about-grid .img img{width:100%;height:100%;object-fit:cover}
.about-grid .card{
  background:var(--mauve);color:#3a2820;
  padding:60px 48px;border-radius:22px;
  margin-left:-40px;
  box-shadow:0 24px 70px -30px rgba(120,90,80,.45);
}
.about-grid .card .label{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:14px;letter-spacing:.36em;color:rgba(58,40,32,.6);text-transform:uppercase;margin-bottom:14px}
.about-grid .card h2{font-family:"Pinyon Script",cursive;font-size:64px;line-height:1;color:var(--oxblood);margin-bottom:20px}
.about-grid .card p{font-size:14.5px;line-height:1.85;margin-bottom:14px;color:#3a2820}
.about-grid .card p em{font-family:"Cormorant Garamond",serif;font-style:italic;color:var(--oxblood);font-size:16px;font-weight:400}

/* WALLPAPER ZONE — since wallpaper is now sitewide, this just adds a subtle band */
.wallpaper-zone{
  background:rgba(201,179,173,.12);
  position:relative;
}

/* REVIEWS */
.reviews{padding:110px 24px;text-align:center}
.reviews .lede{max-width:780px;margin:0 auto 56px}
.reviews .lede .stars{font-size:20px;letter-spacing:.32em;color:var(--gold);margin-bottom:18px}
.reviews .lede .script{font-family:"Pinyon Script",cursive;font-size:64px;color:var(--oxblood);line-height:1;margin-bottom:8px;font-weight:400}
.reviews .lede .sub{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:16px;letter-spacing:.04em;color:var(--taupe)}

.review-grid{
  max-width:1240px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;text-align:left;
}
.review-card{
  background:var(--cream);
  border:1px solid rgba(168,145,128,.3);
  border-radius:12px;
  padding:32px 30px 28px;
  display:flex;flex-direction:column;gap:16px;
  box-shadow:0 16px 40px -28px rgba(44,31,23,.4);
}
.review-card .stars{font-size:13px;letter-spacing:.32em;color:var(--gold)}
.review-card blockquote{
  font-family:"Cormorant Garamond",serif;font-style:italic;font-weight:400;
  font-size:17px;line-height:1.55;color:var(--espresso);
  margin:0;flex:1;
}
.review-card cite{
  font-style:normal;display:flex;flex-direction:column;gap:4px;
  border-top:1px solid rgba(168,145,128,.3);padding-top:14px;
}
.review-card cite .name{font-family:"Pinyon Script",cursive;font-size:28px;color:var(--oxblood);line-height:1;font-weight:400}
.review-card cite .role{font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--taupe)}

.reviews .source{
  margin-top:42px;font-family:"Cormorant Garamond",serif;font-style:italic;font-size:14px;letter-spacing:.04em;color:var(--espresso);
}
.reviews .source a{border-bottom:1px solid var(--taupe);padding-bottom:2px;color:var(--espresso)}
.reviews .source a:hover{color:var(--oxblood);border-bottom-color:var(--oxblood)}

@media (max-width:1100px){
  .review-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
  .review-grid{grid-template-columns:1fr}
}

/* CONTACT */
.contact{padding:110px 24px;background:transparent}
.contact .head{text-align:center;margin-bottom:46px}
.contact .head .script{font-size:74px;color:var(--oxblood);line-height:1}
.contact .head p{margin-top:14px;font-size:14.5px;color:var(--espresso);max-width:520px;margin-left:auto;margin-right:auto}
.contact form{max-width:580px;margin:0 auto;display:flex;flex-direction:column;gap:18px}
.contact label{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--taupe);margin-bottom:6px;display:block}
.contact input,.contact textarea{
  width:100%;border:1.5px solid rgba(168,145,128,.5);
  background:transparent;padding:14px 18px;font-size:14px;
  border-radius:999px;font-family:"Lato",sans-serif;color:var(--espresso);
  transition:border-color .2s;
}
.contact textarea{border-radius:18px;resize:vertical;min-height:120px}
.contact input:focus,.contact textarea:focus{outline:none;border-color:var(--oxblood)}
.contact .send{
  align-self:center;margin-top:8px;
  padding:14px 50px;border:1.5px solid var(--oxblood);background:transparent;
  color:var(--oxblood);border-radius:999px;
  font-size:11px;letter-spacing:.4em;text-transform:uppercase;font-weight:500;cursor:pointer;
  transition:all .25s;font-family:"Lato",sans-serif;
}
.contact .send:hover{background:var(--oxblood);color:var(--cream)}

/* FOOTER */
.foot{
  background:var(--oxblood);color:var(--cream);
  padding:48px 24px 28px;text-align:center;
}
.foot .script{font-size:48px;color:var(--cream);line-height:1;margin-bottom:8px}
.foot .small{font-size:11px;letter-spacing:.34em;text-transform:uppercase;opacity:.78}
.foot .links{
  margin:18px auto 14px;display:flex;gap:24px;justify-content:center;flex-wrap:wrap;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
}
.foot .links a{color:var(--cream);opacity:.78;border-bottom:1px solid rgba(245,236,223,.25);padding-bottom:2px}
.foot .links a:hover{opacity:1;border-bottom-color:rgba(245,236,223,.7)}

/* LEGAL / TEXT PAGES (Privacy, Terms, FAQ) */
.legal{padding:70px 60px 90px}
.legal-inner{
  max-width:780px;margin:0 auto;
  background:var(--cream);
  padding:64px 64px 56px;
  border-radius:18px;
  box-shadow:0 24px 70px -30px rgba(120,90,80,.32);
}
.legal .label{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:13px;letter-spacing:.4em;color:var(--taupe);text-transform:uppercase;margin-bottom:14px;text-align:center}
.legal h1{
  font-family:"Pinyon Script",cursive;font-weight:400;
  font-size:clamp(48px,6vw,72px);
  color:var(--oxblood);line-height:.95;margin-bottom:8px;text-align:center;
}
.legal .updated{
  font-family:"Cormorant Garamond",serif;font-style:italic;
  font-size:14px;color:var(--taupe);text-align:center;margin-bottom:42px;
}
.legal h2{
  font-family:"Cormorant Garamond",serif;font-style:italic;font-weight:400;
  font-size:28px;color:var(--oxblood);
  margin:42px 0 14px;line-height:1.2;
  border-top:1px solid rgba(168,145,128,.4);padding-top:32px;
}
.legal h2:first-of-type{border-top:0;padding-top:0;margin-top:0}
.legal h3{
  font-family:"Cormorant Garamond",serif;font-weight:500;
  font-size:18px;color:var(--espresso);
  margin:24px 0 8px;letter-spacing:.01em;
}
.legal p, .legal li{
  font-size:15px;line-height:1.8;color:#3a2820;margin-bottom:14px;
}
.legal ul{padding-left:22px;margin-bottom:18px}
.legal li{margin-bottom:8px}
.legal a{color:var(--oxblood);border-bottom:1px solid rgba(120,30,20,.3);padding-bottom:1px}
.legal a:hover{border-bottom-color:var(--oxblood)}
.legal strong{color:var(--espresso);font-weight:600}
.legal em{font-style:italic;color:var(--oxblood)}
.legal .toc{
  background:rgba(245,236,223,.6);
  border:1px solid rgba(168,145,128,.35);
  border-radius:10px;padding:24px 28px;margin:0 0 38px;
}
.legal .toc-title{
  font-family:"Cormorant Garamond",serif;font-style:italic;
  font-size:13px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--taupe);margin-bottom:12px;
}
.legal .toc ol{padding-left:20px;margin:0;counter-reset:toc}
.legal .toc li{font-size:14px;line-height:1.7;margin-bottom:4px}

@media (max-width:720px){
  .legal{padding:40px 18px 60px}
  .legal-inner{padding:42px 26px 36px;border-radius:14px}
  .legal h2{font-size:24px;margin:32px 0 12px;padding-top:24px}
}

/* SUB-PAGE LAYOUT BLOCKS */
.intro{padding:80px 60px 60px;background:transparent}
.intro-inner{
  max-width:880px;margin:0 auto;text-align:center;
  background:var(--mauve);color:#3a2820;
  padding:60px 56px 54px;
  border-radius:22px;
  box-shadow:0 24px 70px -30px rgba(120,90,80,.45);
}
.intro .label{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:14px;letter-spacing:.4em;color:rgba(58,40,32,.6);text-transform:uppercase;margin-bottom:18px}
.intro h1{
  font-family:"Pinyon Script",cursive;font-weight:400;
  font-size:clamp(54px,7vw,82px);
  color:var(--oxblood);line-height:.95;margin-bottom:26px;
}
.intro h1 em.serif{display:block;margin-top:14px}
.intro p{font-size:15.5px;line-height:1.85;color:#3a2820;margin-bottom:14px;max-width:580px;margin-left:auto;margin-right:auto}
.intro p.tag-lines{
  font-family:"Cormorant Garamond",serif;font-style:italic;
  font-size:clamp(28px,3.4vw,42px);line-height:1.15;
  color:var(--taupe);
  margin:-8px auto 28px;max-width:none;
  letter-spacing:.005em;
}
.intro .meta{
  margin-top:32px;padding-top:26px;
  border-top:1px solid rgba(58,40,32,.22);
  display:flex;gap:40px;justify-content:center;flex-wrap:wrap;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:#3a2820;
}
.intro .meta span{display:inline-flex;flex-direction:column;gap:6px;align-items:center}
.intro .meta b{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:18px;color:var(--oxblood);text-transform:none;letter-spacing:.04em;font-weight:400}
.intro h1 em{font-style:italic;display:block;font-size:.92em}
.intro p.intro-note{
  font-family:"Cormorant Garamond",serif;font-style:italic;
  font-size:18px;line-height:1.6;
  color:#3a2820;
  opacity:.78;
  margin-top:18px;
}

/* Board pricing tiers */
.board-tiers{
  max-width:880px;margin:-20px auto 0;
  display:flex;align-items:center;justify-content:center;gap:0;
  padding:50px 56px 60px;
  background:#fefaf6;
  border-radius:22px;
  border:1px solid rgba(108,28,46,.12);
  box-shadow:0 18px 50px -28px rgba(120,90,80,.35);
  text-align:center;
}
.board-tiers .tier{flex:1;min-width:0;padding:0 24px}
.board-tiers .tier-size{
  font-family:"Cormorant Garamond",serif;font-style:italic;
  font-size:clamp(32px,4vw,44px);
  color:var(--taupe);
  letter-spacing:.01em;
  line-height:1;margin-bottom:14px;
}
.board-tiers .tier-size .quote{font-style:normal;letter-spacing:0;margin-left:-2px}
.board-tiers .tier-price{
  font-family:"Pinyon Script",cursive;
  font-size:clamp(54px,7vw,76px);
  color:var(--oxblood);
  line-height:1;margin-bottom:16px;
}
.board-tiers .tier-serves{
  font-family:"Lato",sans-serif;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:#3a2820;
}
.board-tiers .tier-divider{
  flex-shrink:0;width:80px;height:24px;
  color:rgba(108,28,46,.45);
  display:flex;align-items:center;justify-content:center;
}
.board-tiers .tier-divider svg{width:60px;height:auto;display:block}
@media (max-width: 720px){
  .board-tiers{flex-direction:column;gap:32px;padding:42px 28px}
  .board-tiers .tier-divider{width:24px;height:60px;transform:rotate(90deg)}
}

.gallery{padding:60px 60px 100px;background:transparent}
.gallery-grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
}
.gallery-grid figure{
  margin:0;aspect-ratio:1/1;overflow:hidden;cursor:pointer;
  position:relative;border-radius:4px;background:var(--cream-deep);
}
.gallery-grid figure.tall{aspect-ratio:1/1.5;grid-row:span 1}
.gallery-grid figure.wide{aspect-ratio:2/1.2;grid-column:span 2}
.gallery-grid figure img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s}
.gallery-grid figure:hover img{transform:scale(1.05)}
.gallery-grid figure::after{
  content:"";position:absolute;inset:0;background:rgba(122,51,56,0);transition:background .3s;
}
.gallery-grid figure:hover::after{background:rgba(122,51,56,.18)}
.gallery-grid figure .badge{
  position:absolute;top:12px;left:12px;background:var(--cream);color:var(--oxblood);
  font-family:"Cormorant Garamond",serif;font-style:italic;font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;border:1px solid rgba(168,145,128,.4);z-index:2;
}

/* LIGHTBOX */
.lightbox{
  position:fixed;inset:0;background:rgba(28,18,12,.94);
  display:none;align-items:center;justify-content:center;z-index:999;
  padding:60px;
}
.lightbox.open{display:flex}
.lightbox img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px;box-shadow:0 24px 70px -20px rgba(0,0,0,.5)}
.lightbox button{
  position:absolute;background:rgba(245,236,223,.92);color:var(--espresso);
  border:none;width:54px;height:54px;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .25s;
}
.lightbox button:hover{background:var(--cream);transform:scale(1.05)}
.lightbox button svg{width:20px;height:20px}
.lightbox .lb-close{top:24px;right:24px}
.lightbox .lb-prev{left:30px;top:50%;transform:translateY(-50%)}
.lightbox .lb-next{right:30px;top:50%;transform:translateY(-50%)}
.lightbox .lb-prev:hover,.lightbox .lb-next:hover{transform:translateY(-50%) scale(1.05)}
.lightbox .counter{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  color:var(--cream);font-size:11px;letter-spacing:.4em;text-transform:uppercase;
}

/* CTA STRIP */
.cta-strip{
  background:var(--mauve);color:#3a2820;text-align:center;padding:80px 24px;
}
.cta-strip .script{font-family:"Pinyon Script",cursive;font-size:64px;color:var(--oxblood);line-height:1;margin-bottom:14px}
.cta-strip p{font-size:15px;line-height:1.8;max-width:560px;margin:0 auto 28px;color:#3a2820}

/* SCROLL ANIMATIONS */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s ease, transform 1s ease}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal.delay-1{transition-delay:.12s}
.reveal.delay-2{transition-delay:.24s}
.reveal.delay-3{transition-delay:.36s}

/* RESPONSIVE */
@media (max-width:1100px){
  .layout{grid-template-columns:1fr}
  aside.sidebar{
    position:relative;height:auto;
    border-right:none;border-bottom:1px solid rgba(168,145,128,.3);
    padding:18px 24px;
    flex-direction:row;flex-wrap:wrap;
    justify-content:space-between;gap:14px;
  }
  aside.sidebar .logo{width:120px;margin-bottom:0}
  aside.sidebar .addr{display:none}
  aside.sidebar .order{margin:0;padding:9px 22px;font-size:10px}
  aside.sidebar nav{margin:0;width:auto;flex-basis:100%}
  aside.sidebar nav ul{display:flex;flex-wrap:wrap;justify-content:center;gap:18px}
  aside.sidebar nav li{margin:0}
  aside.sidebar nav a{font-size:13px;letter-spacing:.14em}
  aside.sidebar .signup,aside.sidebar .socials{display:none}
  .hero{height:60vh;min-height:420px;width:100%;margin:0}
  .page-hero{height:46vh;min-height:340px;width:100%;margin:0}
  .service{padding:50px 20px}
  .service-row,.service-row.left,.service-row.right{display:block;min-height:auto}
  .service-row .photo{width:100%}
  .service-row .card,.service-row.left .card,.service-row.right .card{
    position:relative;top:auto;left:auto;right:auto;transform:none;
    width:88%;max-width:480px;margin:-60px auto 0;padding:42px 30px;
  }
  .marquee-track figure{width:200px;height:200px}
  .about-grid{grid-template-columns:1fr}
  .about-grid .card{margin:-60px 24px 0;padding:42px 30px}
  .tag-strip{font-size:24px}
  .gallery,.intro{padding-left:20px;padding-right:20px}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid figure.wide{grid-column:span 2}
  .page-hero .pill{font-size:30px;padding:10px 22px}
}
@media (max-width:560px){
  aside.sidebar nav ul{gap:10px}
  aside.sidebar nav a{font-size:11px;letter-spacing:.12em}
  aside.sidebar .order{display:none}
}
