/* ============================================================
   SARIUS PHOTOGRAPHIE — Glamour wedding theme
   Palette : ivoire · vert émeraude · or
   ============================================================ */

:root {
  --ivory:    #f7f2ea;
  --ivory-2:  #efe7da;
  --cream:    #fbf8f3;
  --green:    #0f3d2e;
  --green-2:  #16513c;
  --green-soft:#1d5e46;
  --gold:     #c2a15c;
  --gold-2:   #d8be86;
  --gold-deep:#a8854a;
  --ink:      #2a2622;
  --muted:    #6f6557;
  --line:     rgba(15,61,46,.14);

  --serif: "Cormorant Garamond", Georgia, serif;
  --sans:  "Jost", "Helvetica Neue", Arial, sans-serif;

  --ease: cubic-bezier(.22,1,.36,1);
  --maxw: 1240px;
}

/* ---------- RESET ---------- */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--sans);
  font-weight: 300;
  color: var(--ink);
  background: var(--ivory);
  line-height: 1.6;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--gold); color: #fff; }

/* film grain overlay */
.grain {
  position: fixed; inset: 0; z-index: 9999; pointer-events: none;
  opacity: .035; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- TYPO HELPERS ---------- */
.section__eyebrow {
  font-family: var(--sans);
  font-weight: 400;
  letter-spacing: .42em;
  text-transform: uppercase;
  font-size: .72rem;
  color: var(--gold-deep);
  margin-bottom: 1rem;
}
.section__eyebrow::before {
  content: ""; display: inline-block;
  width: 28px; height: 1px; background: var(--gold);
  vertical-align: middle; margin-right: .8em;
}
.section__title {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(2.2rem, 5vw, 3.8rem);
  line-height: 1.05;
  letter-spacing: -.01em;
  color: var(--green);
}
.section__title em { font-style: italic; color: var(--gold-deep); }
.section__head { text-align: center; max-width: 640px; margin: 0 auto 3.5rem; }
.section__head .section__eyebrow::before { display: none; }
.section__head .section__eyebrow { display: inline-block; }

/* ---------- BUTTONS ---------- */
.btn {
  display: inline-block;
  font-family: var(--sans);
  font-weight: 400;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-size: .74rem;
  padding: 1.05em 2.2em;
  border-radius: 50px;
  transition: all .45s var(--ease);
  cursor: pointer; border: 1px solid transparent;
  position: relative; overflow: hidden;
}
.btn--gold {
  background: linear-gradient(120deg, var(--gold) 0%, var(--gold-2) 50%, var(--gold) 100%);
  background-size: 200% auto;
  color: #fff;
  box-shadow: 0 12px 30px -12px rgba(168,133,74,.7);
}
.btn--gold:hover { background-position: right center; transform: translateY(-3px); }
.btn--ghost { border-color: rgba(255,255,255,.55); color: #fff; }
.btn--ghost:hover { background: #fff; color: var(--green); transform: translateY(-3px); }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  transition: all .5s var(--ease);
  padding: 1.4rem 0;
}
.nav__inner {
  max-width: var(--maxw); margin: 0 auto; padding: 0 2rem;
  display: flex; align-items: center; justify-content: space-between;
}
.nav__brand { display: flex; flex-direction: column; line-height: 1; color: #fff; transition: color .5s; }
.nav__brand-name { font-family: var(--serif); font-size: 1.7rem; font-weight: 600; letter-spacing: .02em; }
.nav__brand-sub  { font-size: .62rem; letter-spacing: .42em; text-transform: uppercase; margin-top: .2em; opacity: .85; }
.nav__links { display: flex; align-items: center; gap: 2.2rem; }
.nav__links a {
  color: #fff; font-size: .82rem; letter-spacing: .12em; text-transform: uppercase;
  position: relative; transition: color .4s;
}
.nav__links a:not(.nav__cta)::after {
  content: ""; position: absolute; left: 0; bottom: -6px; width: 0; height: 1px;
  background: var(--gold); transition: width .4s var(--ease);
}
.nav__links a:not(.nav__cta):hover::after { width: 100%; }
.nav__cta {
  border: 1px solid rgba(255,255,255,.5); padding: .6em 1.4em; border-radius: 40px;
  transition: all .4s var(--ease);
}
.nav__cta:hover { background: var(--gold); border-color: var(--gold); }

/* scrolled state */
.nav.scrolled {
  background: rgba(247,242,234,.82);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 6px 30px -18px rgba(15,61,46,.5);
  padding: .85rem 0;
}
.nav.scrolled .nav__brand,
.nav.scrolled .nav__links a { color: var(--green); }
.nav.scrolled .nav__cta { border-color: var(--green); }
.nav.scrolled .nav__cta:hover { color: #fff; border-color: var(--gold); }
.nav.scrolled .nav__burger span { background: var(--green); }

/* drawer open: drop the blur so the fixed drawer stays anchored to the
   viewport (a backdrop-filter on the nav would clip it). */
.nav.menu-open {
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow: none;
}
.nav.menu-open .nav__burger span { background: #fff; }

.nav__burger { display: none; flex-direction: column; gap: 5px; background: none; border: 0; cursor: pointer; padding: 6px; }
.nav__burger span { width: 26px; height: 2px; background: #fff; transition: all .4s var(--ease); }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative; min-height: 100svh;
  display: flex; align-items: center; justify-content: center;
  text-align: center; overflow: hidden;
}
.hero__bg {
  position: absolute; inset: -12% 0; z-index: 0;
  background: url("../assets/gallery/gallery-01.jpg") center 28%/cover no-repeat;
  will-change: transform;
}
.hero__veil {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(180deg, rgba(15,61,46,.55) 0%, rgba(15,61,46,.30) 35%, rgba(15,61,46,.65) 100%),
    radial-gradient(120% 90% at 50% 40%, transparent 40%, rgba(10,40,30,.55) 100%);
}
.hero__content { position: relative; z-index: 2; max-width: 880px; padding: 0 1.5rem; color: #fff; }
.hero__eyebrow {
  letter-spacing: .5em; text-transform: uppercase; font-size: .76rem; font-weight: 400;
  color: var(--gold-2); margin-bottom: 1.6rem;
}
.hero__title {
  font-family: var(--serif); font-weight: 500;
  font-size: clamp(2.6rem, 7vw, 5.6rem); line-height: 1.04; letter-spacing: -.01em;
  text-shadow: 0 4px 40px rgba(0,0,0,.35);
}
.hero__title em { font-style: italic; color: var(--gold-2); }
.hero__lead {
  max-width: 560px; margin: 1.6rem auto 2.4rem;
  font-size: 1.08rem; font-weight: 300; color: rgba(255,255,255,.9);
}
.hero__actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

.hero__scroll {
  position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%);
  z-index: 3; width: 26px; height: 44px; border: 1px solid rgba(255,255,255,.6);
  border-radius: 20px;
}
.hero__scroll span {
  position: absolute; left: 50%; top: 9px; width: 4px; height: 8px; border-radius: 4px;
  background: var(--gold-2); transform: translateX(-50%);
  animation: scrolldot 1.8s var(--ease) infinite;
}
@keyframes scrolldot { 0%{opacity:0;top:9px} 30%{opacity:1} 70%{opacity:1} 100%{opacity:0;top:26px} }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee {
  background: var(--green); color: var(--ivory);
  overflow: hidden; padding: 1.1rem 0; white-space: nowrap;
  border-top: 1px solid rgba(255,255,255,.06);
}
.marquee__track { display: inline-flex; align-items: center; gap: 2.4rem; animation: scrollx 32s linear infinite; }
.marquee__track span { font-family: var(--serif); font-size: 1.5rem; font-style: italic; letter-spacing: .02em; }
.marquee__track i { color: var(--gold); font-style: normal; }
@keyframes scrollx { to { transform: translateX(-50%); } }

/* ============================================================
   ABOUT
   ============================================================ */
.about {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(5rem, 10vw, 8rem) 2rem;
  display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2.5rem, 6vw, 6rem);
  align-items: center;
}
.about__media { position: relative; }
.about__media img {
  width: 100%; aspect-ratio: 4/5; object-fit: cover; border-radius: 6px;
  box-shadow: 0 40px 80px -40px rgba(15,61,46,.55);
}
.about__media::after {
  content: ""; position: absolute; inset: 18px -18px -18px 18px; z-index: -1;
  border: 1px solid var(--gold); border-radius: 6px;
}
.about__badge {
  position: absolute; right: -14px; bottom: 36px;
  background: var(--green); color: var(--cream);
  padding: 1.1rem 1.4rem; border-radius: 6px; text-align: center;
  box-shadow: 0 20px 40px -20px rgba(0,0,0,.5);
}
.about__badge-num { display: block; font-family: var(--serif); font-size: 2rem; color: var(--gold-2); line-height: 1; }
.about__badge-txt { display: block; font-size: .64rem; letter-spacing: .2em; text-transform: uppercase; margin-top: .4em; }
.about__text p { color: var(--muted); margin-top: 1.3rem; max-width: 46ch; }
.about__text .section__title { margin-bottom: .4rem; }

.about__stats { display: flex; gap: 2.4rem; margin-top: 2.6rem; flex-wrap: wrap; }
.stat { display: flex; flex-direction: column; }
.stat__num { font-family: var(--serif); font-size: 2.6rem; color: var(--green); line-height: 1; display: inline; }
.stat__plus { font-family: var(--serif); font-size: 1.6rem; color: var(--gold-deep); }
.stat__lbl { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin-top: .5em; }

/* ============================================================
   SERVICES
   ============================================================ */
.services {
  background: linear-gradient(180deg, var(--cream), var(--ivory-2));
  padding: clamp(5rem, 10vw, 8rem) 2rem;
}
.services__grid {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.4rem;
}
.card {
  background: var(--cream); border: 1px solid var(--line); border-radius: 8px;
  padding: 2.6rem 1.8rem; transition: all .5s var(--ease);
  position: relative; overflow: hidden;
}
.card::before {
  content: ""; position: absolute; left: 0; top: 0; height: 3px; width: 0;
  background: linear-gradient(90deg, var(--gold), var(--gold-2)); transition: width .5s var(--ease);
}
.card:hover { transform: translateY(-8px); box-shadow: 0 30px 60px -34px rgba(15,61,46,.45); border-color: transparent; }
.card:hover::before { width: 100%; }
.card__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 54px; height: 54px; border-radius: 50%;
  border: 1px solid var(--gold); color: var(--gold-deep);
  font-size: 1.4rem; margin-bottom: 1.4rem;
}
.card h3 { font-family: var(--serif); font-weight: 600; font-size: 1.5rem; color: var(--green); margin-bottom: .6rem; }
.card p { color: var(--muted); font-size: .92rem; }

/* ============================================================
   GALLERY (masonry via columns)
   ============================================================ */
.gallery { padding: clamp(5rem, 10vw, 8rem) 2rem; max-width: var(--maxw); margin: 0 auto; }
.gallery__note { font-size: .82rem; color: var(--muted); font-style: italic; margin-top: .8rem; }
.gallery__grid { column-count: 3; column-gap: 1rem; }
@media (max-width: 880px){ .gallery__grid { column-count: 2; } }
@media (max-width: 520px){ .gallery__grid { column-count: 1; } }

.gallery__item {
  position: relative; margin-bottom: 1rem; border-radius: 6px; overflow: hidden;
  cursor: pointer; break-inside: avoid; background: var(--ivory-2);
  opacity: 0; transform: translateY(26px); transition: opacity .8s var(--ease), transform .8s var(--ease);
}
.gallery__item.in { opacity: 1; transform: none; }
.gallery__item img { width: 100%; transition: transform .8s var(--ease); }
.gallery__item::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(15,61,46,.55));
  opacity: 0; transition: opacity .5s;
}
.gallery__item .gallery__plus {
  position: absolute; inset: 0; z-index: 2; display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 2rem; opacity: 0; transform: scale(.6); transition: all .5s var(--ease);
}
.gallery__item:hover img { transform: scale(1.08); }
.gallery__item:hover::after { opacity: 1; }
.gallery__item:hover .gallery__plus { opacity: 1; transform: scale(1); }

/* ============================================================
   OFFER
   ============================================================ */
.offer {
  background:
    radial-gradient(140% 120% at 80% 0%, var(--green-2), var(--green) 60%);
  color: var(--ivory); position: relative; overflow: hidden;
  padding: clamp(5rem, 10vw, 8rem) 2rem;
}
.offer::before {
  content: ""; position: absolute; inset: 0; opacity: .07; pointer-events: none;
  background-image: radial-gradient(circle at center, var(--gold-2) 1px, transparent 1.6px);
  background-size: 28px 28px;
}
.offer__inner {
  max-width: var(--maxw); margin: 0 auto; position: relative; z-index: 1;
  display: grid; grid-template-columns: .85fr 1fr; gap: clamp(2.5rem, 6vw, 5rem); align-items: center;
}
.offer__media img {
  width: 100%; border-radius: 8px; border: 1px solid rgba(216,190,134,.35);
  box-shadow: 0 40px 80px -40px rgba(0,0,0,.6);
}
.offer__text .section__title { color: var(--ivory); }
.offer__text .section__title em { color: var(--gold-2); }
.offer__text .section__eyebrow { color: var(--gold-2); }
.offer__price { display: flex; align-items: baseline; gap: .8rem; margin: 1.6rem 0; }
.offer__amount { font-family: var(--serif); font-size: clamp(3.4rem, 8vw, 5rem); color: var(--gold-2); line-height: 1; }
.offer__per { font-size: .9rem; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.8); }
.offer__list { list-style: none; margin-bottom: 2.2rem; }
.offer__list li {
  position: relative; padding-left: 1.8em; margin-bottom: .9rem; color: rgba(255,255,255,.9);
}
.offer__list li::before {
  content: "✦"; position: absolute; left: 0; color: var(--gold-2); font-size: .85em; top: .15em;
}

/* ---------- PACKS (formules) ---------- */
.packs {
  max-width: var(--maxw); margin: clamp(4rem, 8vw, 6rem) auto 0;
  position: relative; z-index: 1;
}
.packs__head { text-align: center; margin-bottom: 3rem; }
.packs__head .section__eyebrow { display: inline-block; color: var(--gold-2); }
.packs__head .section__eyebrow::before { display: none; }
.packs__head .section__title { color: var(--ivory); }
.packs__head .section__title em { color: var(--gold-2); }

.packs__grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1.6rem; align-items: stretch;
}

.pack {
  --tier: var(--gold-2);
  --tier-soft: rgba(216,190,134,.16);
  position: relative; display: flex; flex-direction: column;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px; padding: 2.6rem 2rem 2.4rem;
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  transition: transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease);
  overflow: hidden;
}
.pack::before {
  content: ""; position: absolute; left: 0; top: 0; right: 0; height: 4px;
  background: linear-gradient(90deg, transparent, var(--tier), transparent);
}
.pack::after {
  content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .5;
  background: radial-gradient(120% 70% at 50% -10%, var(--tier-soft), transparent 60%);
}
.pack:hover {
  transform: translateY(-10px);
  border-color: var(--tier);
  box-shadow: 0 36px 70px -34px rgba(0,0,0,.7), 0 0 0 1px var(--tier-soft);
}

.pack__tier {
  display: inline-block; align-self: flex-start;
  font-size: .68rem; letter-spacing: .32em; text-transform: uppercase;
  color: var(--tier); border: 1px solid var(--tier);
  padding: .4em 1em; border-radius: 40px; margin-bottom: 1.4rem;
}
.pack__name {
  font-family: var(--serif); font-weight: 600; font-size: 1.7rem;
  color: var(--ivory); margin-bottom: 1rem;
}
.pack__price { display: flex; align-items: baseline; gap: .4rem; }
.pack__amount {
  font-family: var(--serif); font-size: clamp(2.8rem, 6vw, 3.6rem);
  line-height: 1; color: var(--tier);
}
.pack__duration {
  display: block; font-size: .78rem; letter-spacing: .22em; text-transform: uppercase;
  color: rgba(255,255,255,.75); margin: .6rem 0 1.6rem;
}
.pack__list { list-style: none; margin-bottom: 2rem; flex: 1; }
.pack__list li {
  position: relative; padding-left: 1.7em; margin-bottom: .8rem;
  color: rgba(255,255,255,.88); font-size: .92rem;
}
.pack__list li::before {
  content: "✦"; position: absolute; left: 0; top: .1em; color: var(--tier); font-size: .8em;
}
.pack__list-hl { color: var(--tier) !important; font-weight: 500; }

/* album option note */
.packs__option {
  display: flex; align-items: center; justify-content: center; gap: .8em;
  max-width: 620px; margin: 2.4rem auto 0; text-align: center;
  color: rgba(255,255,255,.88); font-size: .95rem;
  background: rgba(255,255,255,.04); border: 1px solid rgba(216,190,134,.3);
  border-radius: 50px; padding: 1em 1.8em;
}
.packs__option strong { color: var(--gold-2); font-weight: 500; }
.packs__note {
  text-align: center; margin: 1.2rem auto 0; max-width: 620px;
  font-size: .82rem; font-style: italic; color: rgba(255,255,255,.6);
}
.packs__option-icon {
  flex: 0 0 auto; width: 30px; height: 30px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: linear-gradient(120deg, #e6c878, #c2a15c); color: var(--green);
  font-weight: 600;
}
.pack__btn {
  align-self: stretch; text-align: center;
  background: transparent; color: var(--tier);
  border: 1px solid var(--tier);
}
.pack__btn:hover {
  background: var(--tier);
  color: var(--green);
  transform: translateY(-3px);
}

/* tier colours */
.pack--bronze { --tier: #d18f55; --tier-soft: rgba(209,143,85,.16); }
.pack--silver { --tier: #c8cdd4; --tier-soft: rgba(200,205,212,.16); }
.pack--gold   { --tier: #e6c878; --tier-soft: rgba(230,200,120,.20); }

/* premium highlight */
.pack--gold {
  background: rgba(230,200,120,.07);
  border-color: rgba(230,200,120,.4);
}
.pack__badge {
  position: absolute; top: 0; right: 0;
  background: linear-gradient(120deg, #e6c878, #c2a15c);
  color: var(--green); font-size: .62rem; letter-spacing: .18em; text-transform: uppercase;
  font-weight: 500; padding: .5em 1.1em; border-bottom-left-radius: 12px;
}
@media (min-width: 901px) {
  .pack--gold { transform: scale(1.04); }
  .pack--gold:hover { transform: scale(1.04) translateY(-10px); }
}

@media (max-width: 900px){
  .packs__grid { grid-template-columns: 1fr; max-width: 440px; margin: 0 auto; }
  .pack--gold { transform: none; }
}

/* ============================================================
   CONTACT
   ============================================================ */
.contact { padding: clamp(5rem, 10vw, 8rem) 2rem; }
.contact__inner {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: 1fr .8fr; gap: clamp(2.5rem, 6vw, 5rem); align-items: center;
}
.contact__text p { color: var(--muted); margin: 1.3rem 0; max-width: 48ch; }
.contact__handle {
  display: flex; align-items: center; gap: .5em; width: fit-content;
  font-family: var(--serif); font-size: 1.5rem; font-style: italic; color: var(--green);
  margin-bottom: .7rem; transition: color .4s;
}
.contact__handle:last-of-type { margin-bottom: 1.8rem; }
.contact__handle { max-width: 100%; }
.contact__handle--mail { font-size: 1.25rem; word-break: break-word; }
.contact__handle:hover { color: var(--gold-deep); }
.contact__ig { font-style: normal; color: var(--gold-deep); }
.contact__icon {
  width: 30px; height: 30px; flex: 0 0 auto;
  transition: transform .4s var(--ease);
}
.contact__handle:hover .contact__icon { transform: scale(1.12); }
.contact__socials { display: flex; gap: .9rem; flex-wrap: wrap; }
.btn--dark { border-color: var(--green); color: var(--green); }
.btn--dark:hover { background: var(--green); color: #fff; transform: translateY(-3px); }
.btn--icon { display: inline-flex; align-items: center; gap: .6em; }
.btn--icon img { width: 20px; height: 20px; }

/* footer social icons */
.footer__socials { display: flex; gap: 1rem; justify-content: center; margin-top: 1.2rem; }
.footer__socials a { display: inline-flex; transition: transform .4s var(--ease); }
.footer__socials a:hover { transform: translateY(-4px); }
.footer__socials img { width: 38px; height: 38px; }

.contact__qr { display: flex; justify-content: center; }
.contact__qr-card {
  background: #fff; padding: 1rem; border-radius: 14px; text-align: center;
  box-shadow: 0 30px 60px -30px rgba(15,61,46,.4);
  transition: transform .5s var(--ease); max-width: 280px;
}
.contact__qr-card:hover { transform: translateY(-6px) rotate(-1deg); }
.contact__qr-card img { border-radius: 10px; width: 100%; }
.contact__qr-card p { font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--muted); margin-top: .9rem; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  background: var(--green); color: var(--ivory);
  padding: 3.5rem 2rem 2rem; text-align: center;
}
.footer__inner { max-width: var(--maxw); margin: 0 auto 1.6rem; }
.footer__brand { font-family: var(--serif); font-size: 2rem; color: #fff; }
.footer__brand span { color: var(--gold-2); font-weight: 600; }
.footer__tag { font-size: .74rem; letter-spacing: .28em; text-transform: uppercase; color: rgba(255,255,255,.6); margin: .8rem 0 1.2rem; }
.footer__ig { color: var(--gold-2); letter-spacing: .12em; transition: color .4s; }
.footer__ig:hover { color: #fff; }
.footer__copy { font-size: .74rem; color: rgba(255,255,255,.4); border-top: 1px solid rgba(255,255,255,.1); padding-top: 1.6rem; }

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox {
  position: fixed; inset: 0; z-index: 5000;
  background: rgba(10,28,21,.94); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden; transition: opacity .4s, visibility .4s;
}
.lightbox.open { opacity: 1; visibility: visible; }
.lightbox__img {
  max-width: 88vw; max-height: 86vh; border-radius: 4px;
  box-shadow: 0 30px 80px rgba(0,0,0,.6); transform: scale(.94); transition: transform .4s var(--ease);
}
.lightbox.open .lightbox__img { transform: scale(1); }
.lightbox__close, .lightbox__nav {
  position: absolute; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.25);
  color: #fff; cursor: pointer; transition: all .35s var(--ease);
  display: flex; align-items: center; justify-content: center;
}
.lightbox__close {
  top: 22px; right: 22px; width: 48px; height: 48px; border-radius: 50%; font-size: 1.6rem;
}
.lightbox__nav { top: 50%; transform: translateY(-50%); width: 54px; height: 54px; border-radius: 50%; font-size: 2rem; }
.lightbox__prev { left: 22px; } .lightbox__next { right: 22px; }
.lightbox__close:hover, .lightbox__nav:hover { background: var(--gold); border-color: var(--gold); }

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal { opacity: 0; transform: translateY(34px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in { opacity: 1; transform: none; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px){
  .nav__links {
    position: fixed; inset: 0 0 0 auto; width: min(78vw, 340px);
    flex-direction: column; justify-content: center; gap: 2rem;
    background: var(--green); padding: 3rem;
    transform: translateX(100%); transition: transform .5s var(--ease);
  }
  .nav__links.open { transform: translateX(0); }
  .nav__links a { color: #fff !important; font-size: 1rem; }
  .nav__burger { display: flex; }
  .nav__burger.open span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
  .nav__burger.open span:nth-child(2){ opacity: 0; }
  .nav__burger.open span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

  .about { grid-template-columns: 1fr; }
  .about__media { max-width: 460px; margin: 0 auto; }
  .services__grid { grid-template-columns: repeat(2, 1fr); }
  .offer__inner { grid-template-columns: 1fr; }
  .offer__media { max-width: 420px; margin: 0 auto; }
  .contact__inner { grid-template-columns: 1fr; }
  .contact__text .btn { margin: 0 auto; }
  .contact__text { text-align: center; }
  .contact__text p { margin-left: auto; margin-right: auto; }
  .contact__handle { margin-left: auto; margin-right: auto; }
  .contact__socials { justify-content: center; }
}
@media (max-width: 520px){
  .services__grid { grid-template-columns: 1fr; }
  .nav__inner { padding: 0 1.3rem; }
  .hero__actions .btn { width: 100%; max-width: 280px; }
}

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after { animation: none !important; transition: none !important; }
  .reveal, .gallery__item { opacity: 1 !important; transform: none !important; }
}
