/* =========================================================
   FOTOVIBEZ — design tokens
   Palette drawn from Indian wedding materials rather than a
   generic template: ink (mehendi-night), marigold, sindoor,
   mehendi green, warm ivory paper.
   ========================================================= */
:root{
  --ink:        #1B1512;
  --ink-soft:   #4A413A;
  --paper:      #FAF6EF;
  --paper-dim:  #F1E9DC;
  --marigold:   #D9A441;
  --marigold-dk:#B4842E;
  --sindoor:    #6E2A28;
  --maroon-bg:  #5F2422;
  --mehendi:    #4B5D3A;
  --line:       rgba(27,21,18,0.10);
  --line-light: rgba(250,246,239,0.16);
  --shadow-soft: 0 10px 30px rgba(27,21,18,0.06);

  --font-display: "Fraunces", Georgia, serif;
  --font-body:    "Manrope", -apple-system, "Segoe UI", sans-serif;
  --font-mono:    "IBM Plex Mono", ui-monospace, monospace;

  --container: 1180px;
  --radius: 2px;
}

*, *::before, *::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  background: var(--paper);
  color: var(--ink-soft);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}
img{ max-width:100%; height:auto; display:block; }
a{ color: var(--sindoor); text-decoration: none; }
a:hover{ color: var(--marigold-dk); }
.screen-reader-text{ position:absolute !important; clip:rect(1px,1px,1px,1px); width:1px; height:1px; overflow:hidden; }
:focus-visible{ outline: 2px solid var(--marigold); outline-offset: 3px; }

h1,h2,h3,h4,h5,h6{
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.12;
  color: var(--ink);
  margin: 0 0 0.5em;
  letter-spacing: -0.01em;
}
h1{ font-size: clamp(2.4rem, 5vw, 4.2rem); font-weight: 600; }
h2{ font-size: clamp(1.7rem, 3vw, 2.6rem); }
h3{ font-size: clamp(1.2rem, 2vw, 1.5rem); }
p{ margin: 0 0 1.2em; }

.eyebrow{
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--sindoor);
  display: inline-block;
  margin-bottom: 0.9em;
}

.wrap{ max-width: var(--container); margin: 0 auto; padding: 0 28px; }

/* =========================================================
   HEADER / NAV
   ========================================================= */
.site-header{
  position: fixed; top:0; left:0; right:0; z-index: 100;
  padding: 18px 0;
  background: transparent;
  --nav-color: var(--ink);
  color: var(--nav-color);
  transition: background .3s ease, padding .3s ease, box-shadow .3s ease, color .3s ease;
}
.site-header.is-scrolled{
  background: var(--paper);
  border-bottom: 1px solid var(--line);
  padding: 12px 0;
  box-shadow: 0 6px 20px rgba(27,21,18,0.06);
  --nav-color: var(--ink);
}
body.is-front .site-header:not(.is-scrolled){
  --nav-color: var(--paper);
}
.site-header .wrap{ display:flex; align-items:center; justify-content:space-between; gap:20px; }
.site-branding a{
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 600;
  font-size: 1.6rem;
  color: var(--nav-color);
  letter-spacing: 0.01em;
}
.site-branding img{ max-height: 40px; }
.main-nav ul{ list-style:none; display:flex; gap: 30px; margin:0; padding:0; align-items:center; }
.main-nav li{ position: relative; }
.main-nav a{
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--nav-color);
  opacity: 0.88;
  padding: 6px 0;
  border-bottom: 1px solid transparent;
}
.main-nav a:hover, .main-nav .current-menu-item > a{
  color: var(--sindoor);
  border-bottom-color: var(--sindoor);
  opacity: 1;
}
body.is-front .site-header:not(.is-scrolled) .main-nav a:hover,
body.is-front .site-header:not(.is-scrolled) .main-nav .current-menu-item > a{
  color: var(--marigold);
  border-bottom-color: var(--marigold);
}
.main-nav li.menu-item-has-children > a::after{ content:"\25BE"; font-size:0.65em; margin-left:5px; opacity:0.7; }
.main-nav .sub-menu{
  display:none; position:absolute; top:100%; left:0; min-width:230px;
  background: var(--paper); border: 1px solid var(--line); box-shadow: var(--shadow-soft);
  padding: 10px 0; z-index:50; list-style:none; margin:8px 0 0;
}
.main-nav li.menu-item-has-children:hover > .sub-menu,
.main-nav li.menu-item-has-children:focus-within > .sub-menu{ display:block; }
.main-nav .sub-menu li{ position:static; }
.main-nav .sub-menu a{
  display:block; color: var(--ink); opacity:1; font-size: 0.74rem; padding: 9px 22px; border-bottom:none;
}
.main-nav .sub-menu a:hover{ color: var(--sindoor); background: var(--paper-dim); }
.main-nav .children{ list-style:none; margin: 6px 0 0 14px; padding:0; }
.header-cta{
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--marigold);
  padding: 10px 18px;
  border-radius: var(--radius);
  white-space: nowrap;
}
.header-cta:hover{ background: var(--paper); color: var(--ink); }
.menu-toggle{
  display:none; background:none; border:1px solid currentColor; color: var(--nav-color);
  font-family: var(--font-mono); font-size:0.7rem; letter-spacing:.1em; text-transform:uppercase;
  padding: 8px 12px; cursor:pointer; border-radius: var(--radius); opacity:0.85;
}

@media (max-width: 900px){
  .main-nav{
    position: fixed; inset: 0; top:0; background: var(--ink);
    display:flex; align-items:center; justify-content:center;
    transform: translateY(-100%); transition: transform .35s ease;
    overflow-y: auto; padding: 90px 24px 40px;
  }
  .main-nav.is-open{ transform: translateY(0); }
  .main-nav > ul{ flex-direction:column; gap: 22px; text-align:center; }
  .main-nav a{ font-size: 1rem; color: var(--paper); opacity: 1; }
  .main-nav li.menu-item-has-children > a::after{ display:none; }
  .main-nav .sub-menu{
    position:static; display:block; background:none; border:none; box-shadow:none;
    padding: 12px 0 0; margin:0;
  }
  .main-nav .sub-menu a{ color: rgba(250,246,239,0.72); font-size: 0.82rem; padding: 7px 0; text-align:center; }
  .main-nav .sub-menu a:hover{ background:none; color: var(--marigold); }
  .menu-toggle{ display:inline-block; z-index: 101; }
  .header-cta{ display:none; }
}

/* =========================================================
   FLOATING CALL / WHATSAPP BUTTONS
   ========================================================= */
.fv-float{
  position: fixed; right: 22px; bottom: 22px; z-index: 150;
  display:flex; flex-direction:column; gap: 12px;
}
.fv-float a{
  width:54px; height:54px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  box-shadow: 0 10px 26px rgba(27,21,18,0.24);
  color:#fff; transition: transform .2s ease, box-shadow .2s ease;
}
.fv-float a:hover{ transform: scale(1.08); box-shadow: 0 12px 30px rgba(27,21,18,0.3); }
.fv-float a svg{ width:24px; height:24px; }
.fv-float__call{ background: var(--ink); }
.fv-float__whatsapp{ background: #25D366; }
@media (max-width: 900px){
  .fv-float{ right: 16px; bottom: 16px; gap: 10px; }
  .fv-float a{ width:48px; height:48px; }
  .fv-float a svg{ width:21px; height:21px; }
}

/* =========================================================
   TICKER — signature element: a wedding-invite ribbon
   ========================================================= */
.ticker{
  background: var(--paper-dim);
  color: var(--ink-soft);
  overflow: hidden;
  white-space: nowrap;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.ticker__track{
  display: inline-flex;
  animation: ticker 32s linear infinite;
  padding: 10px 0;
}
.ticker__track span{
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 0 24px;
  border-right: 1px solid var(--line);
}
.ticker__track span:nth-child(4n+1){ color: var(--sindoor); }
@keyframes ticker{ from{ transform: translateX(0); } to{ transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .ticker__track{ animation: none; } }

/* =========================================================
   HERO (front page) — lighter overlay, slideshow-ready
   ========================================================= */
.hero{
  background: var(--ink);
  background-image:
    radial-gradient(ellipse at 15% 15%, rgba(224,138,30,0.14), transparent 55%),
    radial-gradient(ellipse at 85% 85%, rgba(166,58,46,0.14), transparent 55%);
  color: var(--paper);
  padding: 220px 0 130px;
  position: relative;
  overflow: hidden;
  min-height: 82vh;
  display: flex;
  align-items: flex-end;
}
/* subtle film-grain, tactile texture instead of a flat gradient */
.hero::before{
  content:"";
  position:absolute; inset:0; pointer-events:none; z-index:1;
  opacity: 0.28; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/></svg>");
}
.hero__bg{ position:absolute; inset:0; z-index:0; overflow:hidden; }
.hero__bg video{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0.62;
}
.hero__bg img{
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
  opacity: 0;
  transition: opacity 1.6s ease;
}
.hero__bg img.is-active{
  opacity: 0.62;
  animation: kenburns 9s ease-in-out infinite alternate;
}
.hero__bg::after{
  content:""; position:absolute; inset:0; z-index:1;
  background: linear-gradient(180deg, rgba(27,21,18,0.4) 0%, rgba(27,21,18,0.2) 40%, var(--ink) 96%);
}
@keyframes kenburns{ from{ transform: scale(1) translate(0,0); } to{ transform: scale(1.08) translate(-1%,-1%); } }
@media (prefers-reduced-motion: reduce){ .hero__bg img.is-active{ animation: none; } }

.hero__counter{
  position:absolute; left: 28px; bottom: 28px; z-index:2;
  font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.1em;
  color: rgba(250,246,239,0.75);
}
.hero__counter .cur{ color: var(--marigold); }

.hero .wrap{ max-width: 900px; position: relative; z-index: 2; }
.hero h1{ color: var(--paper); }
.hero h1 em{ font-style: italic; color: var(--marigold); }
.hero__lede{
  font-size: 1.15rem;
  max-width: 560px;
  color: rgba(250,246,239,0.86);
  margin-bottom: 2em;
}
.hero__actions{ display:flex; gap: 16px; flex-wrap: wrap; }
.hero__scroll{
  position:absolute; bottom: 28px; left: 50%; transform: translateX(-50%); z-index: 2;
  font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(250,246,239,0.65); display:flex; flex-direction:column; align-items:center; gap:8px;
}
.hero__scroll span{ width:1px; height: 34px; background: rgba(250,246,239,0.4); position:relative; overflow:hidden; }
.hero__scroll span::after{ content:""; position:absolute; top:-100%; left:0; width:100%; height:100%; background: var(--marigold); animation: scrollline 1.8s ease-in-out infinite; }
@keyframes scrollline{ 0%{ top:-100%; } 60%{ top:100%; } 100%{ top:100%; } }

/* buttons (also styles Gutenberg core button block from imported content) */
.btn, .wp-block-button__link{
  display:inline-block;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 15px 28px;
  border-radius: var(--radius);
  background: var(--marigold);
  color: var(--ink) !important;
  border: 1px solid var(--marigold);
  transition: all .2s ease;
}
.btn:hover, .wp-block-button__link:hover{ background: transparent; color: var(--marigold) !important; }
.btn--outline, .is-style-outline .wp-block-button__link{
  background: transparent; color: var(--paper) !important; border: 1px solid var(--line-light);
}
.btn--outline:hover, .is-style-outline .wp-block-button__link:hover{ background: var(--paper); color: var(--ink) !important; border-color: var(--paper); }
.wp-block-buttons{ display:flex; gap:16px; flex-wrap:wrap; margin: 1.6em 0; list-style:none; padding:0; }

/* =========================================================
   PAGE HERO (inner pages: About, Services, Portfolio, etc.)
   ========================================================= */
.page-hero{
  background: var(--paper-dim);
  color: var(--ink);
  padding: 170px 0 60px;
  text-align: left;
  border-bottom: 1px solid var(--line);
}
.page-hero h1{ color: var(--ink); margin-bottom: 0.2em; }
.page-hero .eyebrow{ color: var(--sindoor); }

/* =========================================================
   CONTENT / ARTICLE TYPOGRAPHY (styles the imported blocks)
   ========================================================= */
.entry{ padding: 70px 0 100px; }
.entry .wrap{ max-width: 800px; }
.entry h2{ margin-top: 1.4em; padding-top: 0.2em; }
.entry h2::after{
  content:"";
  display:block; width: 46px; height: 2px; background: var(--marigold); margin-top: 0.5em;
}
.entry h3{ margin-top: 1.6em; color: var(--sindoor); }
.entry ul{ padding-left: 1.2em; }
.entry li{ margin-bottom: 0.5em; }
.entry a{ text-decoration: underline; text-decoration-color: var(--marigold); text-underline-offset: 3px; }

.wp-block-quote, blockquote{
  border-left: none;
  margin: 2em 0;
  padding: 1.6em 2em;
  background: var(--paper-dim);
  position: relative;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.2rem;
  color: var(--ink);
}
.wp-block-quote::before{
  content: "\201C";
  font-family: var(--font-display);
  color: var(--sindoor);
  font-size: 3.4rem;
  line-height: 0;
  position: absolute;
  top: 1.5em; left: 0.4em;
  opacity: 0.35;
}
.wp-block-quote cite{
  display:block; margin-top: 0.8em; font-family: var(--font-mono);
  font-style: normal; font-size: 0.75rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-soft);
}

.wp-block-columns{ display:flex; gap: 32px; flex-wrap: wrap; margin: 1.8em 0; }
.wp-block-column{ flex:1; min-width: 220px; }

.wp-block-gallery{ display:grid; grid-template-columns: repeat(3,1fr); gap: 14px; list-style:none; padding:0; margin: 1.6em 0; }
.wp-block-gallery figure{ margin:0; overflow:hidden; background: var(--paper-dim); aspect-ratio: 4/5; }
.wp-block-gallery img{ width:100%; height:100%; object-fit:cover; transition: transform .4s ease; }
.wp-block-gallery img:hover{ transform: scale(1.04); }
@media (max-width: 700px){ .wp-block-gallery{ grid-template-columns: repeat(2,1fr); } }

/* =========================================================
   SECTIONS (used on front-page.php)
   ========================================================= */
.section{ padding: 90px 0; }
.section--dim{ background: var(--paper-dim); }
.section--ink{ background: var(--ink); color: var(--paper); }
.section--ink h2{ color: var(--paper); }
.section--maroon{ background: var(--maroon-bg); color: var(--paper); }
.section--maroon h1, .section--maroon h2, .section--maroon h3{ color: var(--paper); }
.section--maroon .eyebrow{ color: var(--marigold); }
.section--maroon p{ color: rgba(250,246,239,0.85); }
.section--maroon a:not(.btn){ color: var(--marigold); text-decoration-color: var(--marigold); }
.section--maroon .service-card{ background: rgba(250,246,239,0.06); border-color: var(--line-light); box-shadow:none; }
.section--maroon .service-card p{ color: rgba(250,246,239,0.75); }
.section__head{ max-width: 640px; margin-bottom: 50px; }

.services-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.service-card{ background: var(--paper); padding: 40px 32px; border: 1px solid var(--line); border-radius: 6px; box-shadow: var(--shadow-soft); }
.service-card .eyebrow{ font-size: 0.68rem; }
.service-card h3{ margin-bottom: 0.4em; }
.service-card p{ color: var(--ink-soft); margin-bottom: 0; font-size: 0.96rem; }
@media (max-width: 820px){ .services-grid{ grid-template-columns: 1fr; } }

.gallery-preview{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.gallery-preview a{ display:block; aspect-ratio: 3/4; overflow:hidden; background: var(--ink); position:relative; }
.gallery-preview img{ width:100%; height:100%; object-fit:cover; transition: transform .5s ease, opacity .3s ease; }
.gallery-preview a:hover img{ transform: scale(1.06); opacity: 0.85; }
@media (max-width: 820px){ .gallery-preview{ grid-template-columns: repeat(2,1fr); } }

.testimonial-block{ max-width: 720px; margin: 0 auto; text-align:center; }
.testimonial-block q{
  display:block; font-family: var(--font-display); font-style: italic;
  font-size: clamp(1.4rem, 2.6vw, 2rem); color: var(--paper); quotes: none; margin-bottom: 0.8em;
}
.testimonial-block cite{ font-family: var(--font-mono); font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--marigold); font-style: normal; }

.cta-band{ background: var(--marigold); color: var(--ink); text-align:center; padding: 80px 0; }
.cta-band h2{ color: var(--ink); }
.cta-band .btn{ background: var(--ink); color: var(--paper) !important; border-color: var(--ink); }
.cta-band .btn:hover{ background: transparent; color: var(--ink) !important; }

/* =========================================================
   BLOG LIST
   ========================================================= */
.post-list{ display:flex; flex-direction:column; gap: 44px; max-width: 800px; margin: 0 auto; }
.post-card{ padding-bottom: 44px; border-bottom: 1px solid var(--line); }
.post-card__meta{ font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--sindoor); margin-bottom: 0.6em; }
.post-card h2{ font-size: 1.6rem; margin-bottom: 0.4em; }
.post-card h2 a{ color: var(--ink); }
.post-card h2 a:hover{ color: var(--sindoor); }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{ background: var(--maroon-bg); color: rgba(250,246,239,0.78); padding: 70px 0 30px; }
.footer-grid{ display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 40px; margin-bottom: 50px; }
.footer-brand a{ font-family: var(--font-display); font-style: italic; font-size: 1.6rem; color: var(--paper); }
.footer-brand p{ margin-top: 14px; max-width: 320px; color: rgba(250,246,239,0.6); font-size: 0.92rem; }
.footer-col h4{ font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--marigold); margin-bottom: 1em; }
.footer-col ul{ list-style:none; margin:0; padding:0; }
.footer-col li{ margin-bottom: 0.6em; }
.footer-col a{ color: rgba(250,246,239,0.75); font-size: 0.92rem; }
.footer-col a:hover{ color: var(--marigold); }
.footer-social{ display:flex; gap: 14px; margin-top: 10px; }
.footer-social a{ border:1px solid var(--line-light); padding: 8px 14px; font-family: var(--font-mono); font-size:0.7rem; letter-spacing:.06em; text-transform:uppercase; border-radius: var(--radius); }
.footer-social a:hover{ border-color: var(--marigold); color: var(--marigold); }
.footer-bottom{ border-top: 1px solid var(--line-light); padding-top: 24px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.04em; color: rgba(250,246,239,0.5); }
@media (max-width: 780px){ .footer-grid{ grid-template-columns: 1fr; } }

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
.reveal{ opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.reveal.is-visible{ opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* =========================================================
   STATS COUNTER
   ========================================================= */
.stats-grid{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 30px; text-align:center; }
.stat-item strong{
  display:block; font-family: var(--font-display); font-weight: 600;
  font-size: clamp(2.2rem, 4vw, 3.4rem); color: var(--sindoor); line-height:1;
}
.stat-item span{ display:block; margin-top: 10px; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-soft); }
.section--ink .stat-item span{ color: rgba(250,246,239,0.7); }
.section--ink .stat-item strong{ color: var(--marigold); }
@media (max-width: 700px){ .stats-grid{ grid-template-columns: repeat(2,1fr); gap: 34px 20px; } }

/* =========================================================
   TESTIMONIAL CAROUSEL
   ========================================================= */
.t-carousel{ position: relative; max-width: 760px; margin: 0 auto; min-height: 190px; }
.t-slide{ display:none; text-align:center; }
.t-slide.is-active{ display:block; animation: fadein .6s ease; }
@keyframes fadein{ from{ opacity:0; transform: translateY(8px); } to{ opacity:1; transform:none; } }
.t-slide q{
  display:block; font-family: var(--font-display); font-style: italic;
  font-size: clamp(1.3rem, 2.4vw, 1.9rem); color: var(--paper); quotes: none; margin-bottom: 0.7em;
}
.t-slide cite{ font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--marigold); font-style: normal; }
.t-dots{ display:flex; justify-content:center; gap:10px; margin-top: 34px; }
.t-dots button{
  width:8px; height:8px; border-radius:50%; border:1px solid rgba(250,246,239,0.4); background:transparent; padding:0; cursor:pointer;
}
.t-dots button.is-active{ background: var(--marigold); border-color: var(--marigold); }

/* =========================================================
   GALLERY HOVER TAG + LIGHTBOX
   ========================================================= */
.gallery-preview, .wp-block-gallery{ position: relative; }
.fv-cursor-tag{
  position: fixed; pointer-events:none; z-index: 999;
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--marigold); color: var(--ink); padding: 8px 14px; border-radius: 999px;
  opacity: 0; transform: translate(-50%,-50%) scale(0.8); transition: opacity .15s ease, transform .15s ease;
}
.fv-cursor-tag.is-active{ opacity: 1; transform: translate(-50%,-50%) scale(1); }
@media (max-width: 900px){ .fv-cursor-tag{ display:none; } }

.fv-lightbox{
  position: fixed; inset:0; z-index: 1000; background: rgba(15,11,9,0.94);
  display:flex; align-items:center; justify-content:center; padding: 40px;
  opacity:0; visibility:hidden; transition: opacity .25s ease;
}
.fv-lightbox.is-open{ opacity:1; visibility:visible; }
.fv-lightbox img{ max-width: 92vw; max-height: 86vh; object-fit:contain; box-shadow: 0 20px 60px rgba(0,0,0,0.5); }
.fv-lightbox__close{
  position:absolute; top: 24px; right: 30px; background:none; border:1px solid var(--line-light); color: var(--paper);
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing:.08em; text-transform:uppercase; padding: 8px 14px; cursor:pointer; border-radius: var(--radius);
}
.fv-lightbox__close:hover{ border-color: var(--marigold); color: var(--marigold); }
.wp-block-gallery img, .gallery-preview img{ cursor: zoom-in; }

/* =========================================================
   GOOGLE REVIEWS
   ========================================================= */
.google-reviews{ text-align:center; }
.google-reviews__summary{ margin-bottom: 40px; }
.g-wordmark{ font-family: var(--font-body); font-weight: 700; font-size: 1.1rem; display:inline-block; margin-bottom: 6px; }
.google-reviews__score{ display:block; font-family: var(--font-display); font-weight:600; font-size: 2.4rem; color: var(--ink); }
.g-stars{ color: var(--marigold); letter-spacing: 2px; font-size: 1.1rem; }
.google-reviews__count{ display:block; font-family: var(--font-mono); font-size: 0.75rem; letter-spacing: 0.06em; color: var(--ink-soft); margin-top: 4px; }
.google-reviews__grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 20px; text-align:left; }
.review-card{ background: var(--paper); border: 1px solid var(--line); padding: 26px; border-radius: 6px; box-shadow: var(--shadow-soft); }
.review-card__head{ display:flex; align-items:center; gap: 12px; margin-bottom: 12px; }
.review-card__avatar{
  width:38px; height:38px; border-radius:50%; background: var(--sindoor); color: var(--paper);
  display:flex; align-items:center; justify-content:center; font-family: var(--font-display); font-weight:600; flex-shrink:0;
}
.review-card p{ font-size: 0.92rem; color: var(--ink-soft); margin-bottom: 0.6em; }
.review-card__time{ font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.05em; text-transform: uppercase; color: rgba(74,65,58,0.55); }
.section--ink .review-card{ background: rgba(250,246,239,0.05); border-color: var(--line-light); }
.section--ink .review-card p{ color: rgba(250,246,239,0.78); }
.section--ink .review-card__time{ color: rgba(250,246,239,0.45); }
@media (max-width: 820px){ .google-reviews__grid{ grid-template-columns: 1fr; } }

/* =========================================================
   VIDEO BLOCK (YouTube facade)
   ========================================================= */
.video-block{
  position: relative; aspect-ratio: 16/9; overflow:hidden;
  border-radius: 6px; background: var(--ink); margin: 1.8em 0; box-shadow: var(--shadow-soft);
}
.video-block__play{ position:absolute; inset:0; width:100%; height:100%; border:0; padding:0; margin:0; cursor:pointer; background:none; }
.video-block__play img{ width:100%; height:100%; object-fit:cover; filter: brightness(0.72); transition: filter .3s ease; }
.video-block__play:hover img{ filter: brightness(0.58); }
.video-block__icon{
  position:absolute; top:50%; left:50%; transform: translate(-50%,-50%);
  width:72px; height:72px; border-radius:50%; background: var(--marigold); color: var(--ink);
  display:flex; align-items:center; justify-content:center; font-size:1.2rem; padding-left:4px;
  transition: transform .25s ease;
}
.video-block__play:hover .video-block__icon{ transform: translate(-50%,-50%) scale(1.08); }
.video-block iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.video-block--empty{
  background: var(--paper-dim); border: 1px dashed var(--line);
  display:flex; align-items:center; justify-content:center; text-align:center; padding: 40px; box-shadow:none;
}
.video-block__placeholder p{ margin: 0.6em 0 0; font-size: 0.9rem; color: var(--ink-soft); }
.video-block__placeholder code{ font-family: var(--font-mono); font-size: 0.72rem; background: rgba(27,21,18,0.06); padding: 2px 8px; border-radius: 3px; display:inline-block; margin-top:6px; }

/* =========================================================
   ACCOLADES / AS FEATURED IN STRIP
   ========================================================= */
.accolades{ padding: 34px 0; text-align:center; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.accolades .eyebrow{ margin-bottom: 6px; }
.accolades__row{ display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap: 14px 38px; margin-top: 10px; }
.accolades__row span{
  font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-soft); opacity: 0.55;
}

/* =========================================================
   REAL WEDDING STORY CARDS
   ========================================================= */
.story-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.story-card{
  position: relative; aspect-ratio: 4/5; overflow:hidden; border-radius: 6px;
  background: var(--paper-dim); box-shadow: var(--shadow-soft);
}
.story-card img{ width:100%; height:100%; object-fit:cover; transition: transform .5s ease; }
.story-card:hover img{ transform: scale(1.05); }
.story-card::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 40%, rgba(27,21,18,0.85) 100%);
}
.story-card__text{ position:absolute; left:0; right:0; bottom:0; padding: 22px; z-index:2; color: var(--paper); }
.story-card__text .eyebrow{ color: var(--marigold); margin-bottom: 4px; }
.story-card__text h3{ color: var(--paper); font-size: 1.25rem; margin-bottom: 0.2em; }
.story-card__text a{ color: var(--paper); text-decoration: none; }
.story-card__text a::after{ content:""; position:absolute; inset:0; }
@media (max-width: 820px){ .story-grid{ grid-template-columns: 1fr; } }

/* =========================================================
   ACCORDION FAQ (native <details>/<summary>, no JS required)
   ========================================================= */
.entry details{ border-bottom: 1px solid var(--line); padding: 6px 0; margin: 0 0 4px; }
.entry summary{
  cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; gap: 16px;
  font-family: var(--font-display); font-weight:500; font-size: 1.05rem; color: var(--ink); padding: 14px 4px;
}
.entry summary::-webkit-details-marker{ display:none; }
.entry summary::after{
  content:"+"; font-family: var(--font-body); font-size: 1.3rem; color: var(--marigold); flex-shrink:0; transition: transform .25s ease;
}
.entry details[open] summary::after{ transform: rotate(45deg); }
.entry details p{ padding: 0 4px 16px; color: var(--ink-soft); }

/* =========================================================
   404 / misc
   ========================================================= */
.not-found{ padding: 220px 0 140px; text-align:center; }
