/* ═══════════════════════════════════════════════════════════════════
   Adria Dreams · Krk Wedding — styles.css
   Aesthetic: Mediterranean editorial luxury.
   Ivory & shell base · deep sage-sea green · terracotta · gold hairlines.
   Display: Fraunces (optical serif) · Body/UI: Hanken Grotesk.
   Signature motif: arch-topped image frames (Krk's stone wedding arch).
═══════════════════════════════════════════════════════════════════ */

/* ── Palette & tokens ─────────────────────────────────────────────── */
:root {
  --ivory:    #FBF6EE;   /* page background          */
  --shell:    #F3EADD;   /* raised panels            */
  --sand:     #E7D9C6;   /* warm fills               */
  --ink:      #26302B;   /* deep sea-charcoal text   */
  --sea:      #3E5B52;   /* primary — Adriatic sage  */
  --sea-deep: #2C443C;   /* dark sea sections        */
  --sea-soft: #6E8B80;
  --clay:     #BC6C4C;   /* terracotta accent        */
  --clay-soft:#D89B7E;
  --gold:     #B08A54;   /* gold hairline / detail   */
  --cream:    #F6EFE3;   /* text on dark sections    */

  --muted:  rgba(38,48,43,.66);
  --faint:  rgba(38,48,43,.42);
  --border: rgba(38,48,43,.14);
  --border-strong: rgba(38,48,43,.26);

  --serif: "Fraunces", "Times New Roman", serif;
  --sans:  "Hanken Grotesk", system-ui, sans-serif;

  --arch: 50% 50% 6px 6px / 28% 28% 6px 6px;  /* the arch curve */
  --maxw: 1240px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ── Reset ────────────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  background:var(--ivory); color:var(--ink);
  font-family:var(--sans); font-weight:400; line-height:1.65;
  font-size:16px; letter-spacing:.005em;
  overflow-x:hidden; position:relative;
  -webkit-font-smoothing:antialiased;
}
img { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; }
a,button,.lang-btn,.gal-filter { -webkit-tap-highlight-color:transparent; touch-action:manipulation; }
::selection { background:var(--clay); color:var(--cream); }

/* subtle paper grain over everything */
body::after {
  content:""; 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='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ── Typography helpers ───────────────────────────────────────────── */
.eyebrow {
  font-family:var(--sans); font-size:11px; font-weight:600;
  letter-spacing:.34em; text-transform:uppercase; color:var(--clay);
  display:inline-flex; align-items:center; gap:.85em;
}
.eyebrow::before {
  content:""; width:30px; height:1px; background:var(--gold); display:inline-block;
}
.eyebrow.center { justify-content:center; }
.eyebrow.center::after {
  content:""; width:30px; height:1px; background:var(--gold); display:inline-block;
}

h1,h2,h3 { font-family:var(--serif); font-weight:400; line-height:1.05; letter-spacing:-.01em; }
h2.display { font-size:clamp(2.1rem,5.2vw,4rem); font-optical-sizing:auto; }
h2.display em, h1 em { font-style:italic; color:var(--sea); font-weight:300; }
.lead { font-size:clamp(1.05rem,1.7vw,1.25rem); color:var(--muted); font-weight:300; line-height:1.7; }

.section { padding:clamp(72px,10vw,140px) 0; }
.container { width:90%; max-width:var(--maxw); margin:0 auto; }
.narrow { max-width:760px; }

/* ── Buttons ──────────────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:.7em; cursor:pointer;
  font-family:var(--sans); font-size:12px; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase;
  padding:16px 30px; border-radius:40px; border:1px solid transparent;
  transition:transform .3s var(--ease), background .3s, color .3s, border-color .3s, box-shadow .3s;
}
.btn svg { width:15px; height:15px; }
.btn--solid { background:var(--sea); color:var(--cream); }
.btn--solid:hover { background:var(--sea-deep); transform:translateY(-2px); box-shadow:0 14px 30px -14px rgba(44,68,60,.7); }
.btn--ghost { border-color:var(--border-strong); color:var(--ink); }
.btn--ghost:hover { border-color:var(--sea); color:var(--sea); transform:translateY(-2px); }
.btn--clay { background:var(--clay); color:var(--cream); }
.btn--clay:hover { background:#a85b3d; transform:translateY(-2px); box-shadow:0 14px 30px -14px rgba(188,108,76,.7); }
.btn--light { background:var(--cream); color:var(--sea-deep); }
.btn--light:hover { transform:translateY(-2px); box-shadow:0 14px 34px -14px rgba(0,0,0,.5); }

/* ════════════════════════════════════════════════════════════════════
   HEADER / NAV
════════════════════════════════════════════════════════════════════ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px clamp(20px,5vw,56px);
  transition:background .4s, padding .4s, box-shadow .4s, border-color .4s;
  border-bottom:1px solid transparent;
}
.nav--scrolled {
  background:rgba(251,246,238,.86); backdrop-filter:blur(14px);
  padding-top:14px; padding-bottom:14px;
  border-bottom:1px solid var(--border);
  box-shadow:0 8px 30px -22px rgba(38,48,43,.5);
}
.brand { display:flex; flex-direction:column; line-height:1; z-index:120; }
.brand-name {
  font-family:var(--serif); font-size:24px; font-weight:500; letter-spacing:.02em;
  color:var(--ink);
}
.brand-name em { font-style:italic; color:var(--sea); }
.brand-sub {
  font-family:var(--sans); font-size:9.5px; font-weight:600; letter-spacing:.42em;
  text-transform:uppercase; color:var(--clay); margin-top:5px;
}
/* nav appears light when over the dark hero (home) */
.nav--over-hero:not(.nav--scrolled) .brand-name { color:var(--cream); }
.nav--over-hero:not(.nav--scrolled) .nav-link { color:rgba(246,239,227,.82); }
.nav--over-hero:not(.nav--scrolled) .nav-link:hover { color:var(--cream); }
.nav--over-hero:not(.nav--scrolled) .lang-btn { color:rgba(246,239,227,.7); }
.nav--over-hero:not(.nav--scrolled) .lang-btn.active { color:var(--cream); }
.nav--over-hero:not(.nav--scrolled) .hamburger span { background:var(--cream); }

.nav-links { display:flex; align-items:center; gap:30px; }
.nav-link {
  position:relative; font-family:var(--sans); font-size:12px; font-weight:600;
  letter-spacing:.14em; text-transform:uppercase; color:var(--muted);
  padding:4px 0; transition:color .25s;
}
.nav-link::after {
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px;
  background:var(--clay); transition:width .3s var(--ease);
}
.nav-link:hover,.nav-link.current { color:var(--ink); }
.nav-link.current::after,.nav-link:hover::after { width:100%; }

.nav-right { display:flex; align-items:center; gap:24px; }

/* language switcher */
.lang-sw { display:flex; align-items:center; gap:2px; }
.lang-btn {
  background:none; border:none; cursor:pointer;
  font-family:var(--sans); font-size:11px; font-weight:700; letter-spacing:.1em;
  color:var(--faint); padding:5px 7px; border-radius:6px; transition:color .2s, background .2s;
}
.lang-btn:hover { color:var(--ink); }
.lang-btn.active { color:var(--clay); }

/* hamburger */
.hamburger {
  display:none; flex-direction:column; gap:5px; background:none; border:none;
  cursor:pointer; padding:6px; z-index:120;
}
.hamburger span { width:26px; height:2px; background:var(--ink); transition:.3s var(--ease); border-radius:2px; }
.nav.open .hamburger span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav.open .hamburger span:nth-child(2) { opacity:0; }
.nav.open .hamburger span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ════════════════════════════════════════════════════════════════════
   HERO (home)
════════════════════════════════════════════════════════════════════ */
.hero {
  position:relative; min-height:100vh; min-height:100svh; display:flex; align-items:center;
  color:var(--cream); overflow:hidden;
}
.hero-bg { position:absolute; inset:0; z-index:0; }
.hero-bg img { width:100%; height:100%; object-fit:cover; }
.hero-bg::after {
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(28,40,34,.55) 0%, rgba(28,40,34,.30) 40%, rgba(28,40,34,.72) 100%);
}
.hero-inner { position:relative; z-index:2; width:90%; max-width:var(--maxw); margin:0 auto; padding-top:80px; }
.hero .eyebrow { color:var(--clay-soft); }
.hero .eyebrow::before { background:var(--clay-soft); }
.hero-title {
  font-family:var(--serif); font-weight:300;
  font-size:clamp(2.8rem,9vw,7rem); line-height:.96; letter-spacing:-.02em;
  margin:22px 0 26px; max-width:14ch;
}
.hero-title em { font-style:italic; font-weight:300; }
.hero-sub { font-size:clamp(1.05rem,1.7vw,1.3rem); font-weight:300; max-width:46ch; color:rgba(246,239,227,.9); }
.hero-actions { display:flex; flex-wrap:wrap; gap:14px; margin-top:38px; }
.hero-scroll {
  position:absolute; bottom:34px; left:50%; transform:translateX(-50%); z-index:2;
  font-family:var(--sans); font-size:10px; font-weight:600; letter-spacing:.3em;
  text-transform:uppercase; color:rgba(246,239,227,.75);
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.hero-scroll i { width:1px; height:46px; background:linear-gradient(rgba(246,239,227,.7),transparent);
  display:block; animation:scrollPulse 2.4s var(--ease) infinite; }
@keyframes scrollPulse { 0%,100%{transform:scaleY(.4);opacity:.4;transform-origin:top} 50%{transform:scaleY(1);opacity:1;transform-origin:top} }

/* ── Inner page header (non-home) ─────────────────────────────────── */
.page-head {
  position:relative; padding:clamp(150px,20vw,230px) 0 clamp(56px,8vw,96px);
  text-align:center; overflow:hidden;
  background:
    radial-gradient(120% 90% at 50% 0%, var(--shell), var(--ivory) 70%);
  border-bottom:1px solid var(--border);
}
.page-head::before,.page-head::after {
  content:""; position:absolute; bottom:-1px; width:46%; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.page-head::before { left:0; } .page-head::after { right:0; }
.page-head h1 { font-size:clamp(2.6rem,7vw,5rem); font-weight:300; margin:20px auto 0; }
.page-head .lead { margin:22px auto 0; max-width:60ch; }

/* monogram ampersand ornament */
.monogram {
  font-family:var(--serif); font-style:italic; font-size:clamp(2.4rem,5vw,3.4rem);
  color:var(--gold); line-height:1; display:block; opacity:.85;
}

/* ════════════════════════════════════════════════════════════════════
   INTRO / SPLIT
════════════════════════════════════════════════════════════════════ */
.split { display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,7vw,100px); align-items:center; }
.split.reverse .split-media { order:2; }
.split-body h2 { margin:18px 0 22px; }
.split-body .lead + .lead { margin-top:18px; }

/* arch-framed image — the signature motif */
.arch {
  position:relative; border-radius:var(--arch); overflow:hidden;
  box-shadow:0 40px 70px -40px rgba(38,48,43,.55);
}
.arch img { width:100%; height:100%; object-fit:cover; aspect-ratio:4/5; }
.arch::after {
  content:""; position:absolute; inset:9px; border-radius:var(--arch);
  border:1px solid rgba(246,239,227,.35); pointer-events:none;
}
.arch--tall img { aspect-ratio:3/4.4; }
.media-tag {
  position:absolute; left:50%; bottom:22px; transform:translateX(-50%);
  background:rgba(38,48,43,.55); backdrop-filter:blur(6px);
  color:var(--cream); font-family:var(--sans); font-size:10px; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; padding:9px 18px; border-radius:30px;
  z-index:3; white-space:nowrap;
}

/* ════════════════════════════════════════════════════════════════════
   TEAM
════════════════════════════════════════════════════════════════════ */
.section-head { text-align:center; max-width:680px; margin:0 auto clamp(48px,6vw,72px); }
.section-head h2 { margin-top:18px; }
.section-head .lead { margin-top:18px; }

.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:26px; }
.team-card { text-align:center; }
.team-photo {
  position:relative; border-radius:var(--arch); overflow:hidden; margin-bottom:20px;
  box-shadow:0 26px 50px -34px rgba(38,48,43,.6);
}
.team-photo img { width:100%; aspect-ratio:330/360; object-fit:cover; transition:transform .7s var(--ease); filter:saturate(.96); }
.team-card:hover .team-photo img { transform:scale(1.05); }
.team-photo::after { content:""; position:absolute; inset:7px; border-radius:var(--arch); border:1px solid rgba(246,239,227,.3); }
.team-name { font-family:var(--serif); font-size:1.4rem; font-weight:500; }
.team-role { font-family:var(--sans); font-size:10.5px; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:var(--clay); margin:5px 0 13px; }
.team-bio { font-size:.92rem; color:var(--muted); line-height:1.6; }

/* ════════════════════════════════════════════════════════════════════
   SERVICES (information page)
════════════════════════════════════════════════════════════════════ */
.svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.svc-card {
  position:relative; background:var(--shell); border:1px solid var(--border);
  border-radius:18px; padding:38px 32px; overflow:hidden;
  transition:transform .4s var(--ease), box-shadow .4s, border-color .4s;
}
.svc-card::before {
  content:""; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--sea),var(--clay)); transform:scaleX(0);
  transform-origin:left; transition:transform .5s var(--ease);
}
.svc-card:hover { transform:translateY(-6px); box-shadow:0 30px 60px -40px rgba(38,48,43,.55); border-color:transparent; }
.svc-card:hover::before { transform:scaleX(1); }
.svc-num { font-family:var(--serif); font-style:italic; font-size:1.3rem; color:var(--gold); }
.svc-card h3 { font-size:1.45rem; margin:14px 0 14px; font-weight:500; }
.svc-card p { font-size:.95rem; color:var(--muted); line-height:1.65; }
.svc-price {
  display:inline-block; margin-top:18px; font-family:var(--sans); font-size:12px;
  font-weight:700; letter-spacing:.1em; color:var(--sea);
  background:rgba(62,91,82,.1); padding:6px 14px; border-radius:30px;
}

/* highlight (consultation / next step) panel */
.panel {
  background:var(--sea-deep); color:var(--cream); border-radius:22px;
  padding:clamp(40px,5vw,64px); text-align:center; position:relative; overflow:hidden;
}
.panel::before {
  content:"&"; position:absolute; font-family:var(--serif); font-style:italic;
  font-size:clamp(14rem,30vw,26rem); color:rgba(246,239,227,.05);
  right:-2%; top:50%; transform:translateY(-50%); line-height:0; pointer-events:none;
}
.panel h2 { color:var(--cream); position:relative; }
.panel h2 em { color:var(--clay-soft); }
.panel p { color:rgba(246,239,227,.82); max-width:50ch; margin:18px auto 0; position:relative; }
.panel .btn { margin-top:30px; position:relative; }

/* ════════════════════════════════════════════════════════════════════
   PHOTOGRAPHY packages
════════════════════════════════════════════════════════════════════ */
.pkg-list { display:flex; flex-direction:column; gap:0; border-top:1px solid var(--border); }
.pkg {
  display:grid; grid-template-columns:auto 1fr auto; gap:30px; align-items:center;
  padding:34px 8px; border-bottom:1px solid var(--border);
  transition:padding-left .35s var(--ease);
}
.pkg:hover { padding-left:22px; }
.pkg-idx { font-family:var(--serif); font-style:italic; font-size:1.6rem; color:var(--gold); }
.pkg-main h3 { font-size:1.6rem; font-weight:500; }
.pkg-main p { font-size:.95rem; color:var(--muted); margin-top:6px; max-width:56ch; }
.pkg-price { font-family:var(--serif); font-size:1.7rem; color:var(--sea); white-space:nowrap; }
.pkg-price small { font-family:var(--sans); font-size:11px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--faint); display:block; }

/* ════════════════════════════════════════════════════════════════════
   GALLERY
════════════════════════════════════════════════════════════════════ */
.gal-filters { display:flex; justify-content:center; flex-wrap:wrap; gap:10px; margin-bottom:48px; }
.gal-filter {
  background:none; border:1px solid var(--border); cursor:pointer;
  font-family:var(--sans); font-size:11px; font-weight:600; letter-spacing:.18em;
  text-transform:uppercase; color:var(--muted); padding:11px 22px; border-radius:30px;
  transition:.25s var(--ease);
}
.gal-filter:hover { border-color:var(--sea); color:var(--sea); }
.gal-filter.active { background:var(--sea); border-color:var(--sea); color:var(--cream); }

.masonry { columns:3; column-gap:18px; }
.masonry .gal-item {
  break-inside:avoid; margin-bottom:18px; border-radius:12px; overflow:hidden;
  position:relative; box-shadow:0 16px 34px -28px rgba(38,48,43,.6);
}
.masonry .gal-item img { width:100%; transition:transform .7s var(--ease); }
.masonry .gal-item:hover img { transform:scale(1.04); }
.gal-item.hide { display:none; }

/* home preview — fixed grid (no multicol reflow / flicker) */
.gal-preview { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.gp-item { position:relative; border-radius:12px; overflow:hidden; box-shadow:0 16px 34px -28px rgba(38,48,43,.6); }
.gp-item img { width:100%; height:100%; object-fit:cover; aspect-ratio:4/5; transition:transform .7s var(--ease); }
.gp-item::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(38,48,43,.4)); opacity:0; transition:opacity .4s; }
.gp-item:hover img { transform:scale(1.05); }
.gp-item:hover::after { opacity:1; }
@media (max-width:1000px){ .gal-preview{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .gal-preview{ grid-template-columns:1fr 1fr; gap:12px; } }

/* lightbox */
.lightbox {
  position:fixed; inset:0; z-index:1000; background:rgba(20,28,24,.94);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:opacity .35s, visibility .35s;
}
.lightbox.open { opacity:1; visibility:visible; }
.lightbox img { max-width:90vw; max-height:86vh; border-radius:8px; box-shadow:0 30px 80px -30px #000; }
.lb-btn {
  position:absolute; background:rgba(246,239,227,.1); border:1px solid rgba(246,239,227,.25);
  color:var(--cream); width:52px; height:52px; border-radius:50%; cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition:.25s;
}
.lb-btn:hover { background:rgba(246,239,227,.22); }
.lb-close { top:26px; right:26px; }
.lb-prev { left:24px; top:50%; transform:translateY(-50%); }
.lb-next { right:24px; top:50%; transform:translateY(-50%); }
.lb-btn svg { width:20px; height:20px; }

/* ════════════════════════════════════════════════════════════════════
   TESTIMONIALS
════════════════════════════════════════════════════════════════════ */
.testi-section { background:var(--shell); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.testi-card {
  background:var(--ivory); border:1px solid var(--border); border-radius:18px; padding:34px;
  position:relative;
}
.testi-card .quote-mark { font-family:var(--serif); font-style:italic; font-size:3.6rem; color:var(--gold); line-height:.5; opacity:.5; }
.testi-text { font-family:var(--serif); font-size:1.18rem; line-height:1.5; font-weight:400; margin:14px 0 24px; color:var(--ink); }
.testi-author { display:flex; align-items:center; gap:14px; }
.testi-author img { width:50px; height:50px; border-radius:50%; object-fit:cover; }
.testi-author b { font-family:var(--sans); font-size:13px; font-weight:700; letter-spacing:.04em; }
.testi-author span { display:block; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--clay); margin-top:2px; }

/* ── Testimonial carousel ── */
.testi-carousel { display:grid; }
.testi-page {
  grid-column:1; grid-row:1;
  opacity:0; transition:opacity .7s ease;
  pointer-events:none; z-index:0;
}
.testi-page--active { opacity:1; pointer-events:auto; z-index:1; }
.testi-dots { display:flex; justify-content:center; gap:10px; margin-top:32px; }
.testi-dot {
  width:9px; height:9px; border-radius:50%;
  border:none; background:var(--border);
  cursor:pointer; padding:0;
  transition:background .3s, transform .3s;
}
.testi-dot--active { background:var(--sea); transform:scale(1.35); }

/* ════════════════════════════════════════════════════════════════════
   CTA band
════════════════════════════════════════════════════════════════════ */
.cta-band {
  position:relative; text-align:center; color:var(--cream); overflow:hidden;
  padding:clamp(80px,11vw,150px) 0;
}
.cta-band .cta-bg { position:absolute; inset:0; z-index:0; }
.cta-band .cta-bg img { width:100%; height:100%; object-fit:cover; }
.cta-band .cta-bg::after { content:""; position:absolute; inset:0; background:rgba(28,40,34,.72); }
.cta-band .container { position:relative; z-index:2; }
.cta-band h2 { color:var(--cream); }
.cta-band h2 em { color:var(--clay-soft); }
.cta-band p { color:rgba(246,239,227,.85); margin:18px auto 32px; max-width:48ch; }

/* ════════════════════════════════════════════════════════════════════
   CONTACT
════════════════════════════════════════════════════════════════════ */
.contact-grid { display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(40px,6vw,80px); align-items:start; }
.contact-info .info-row { display:flex; gap:18px; padding:22px 0; border-bottom:1px solid var(--border); align-items:flex-start; }
.info-row .ic { width:42px; height:42px; flex-shrink:0; border-radius:50%; border:1px solid var(--border-strong);
  display:flex; align-items:center; justify-content:center; color:var(--sea); }
.info-row .ic svg { width:18px; height:18px; }
.info-row .k { font-family:var(--sans); font-size:10px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--faint); }
.info-row .v { font-family:var(--serif); font-size:1.25rem; color:var(--ink); margin-top:3px; }
.info-row .v:hover { color:var(--sea); }
.socials { display:flex; gap:12px; margin-top:30px; }
.socials a { width:46px; height:46px; border-radius:50%; border:1px solid var(--border-strong);
  display:flex; align-items:center; justify-content:center; color:var(--ink); transition:.25s; }
.socials a:hover { background:var(--sea); border-color:var(--sea); color:var(--cream); transform:translateY(-3px); }
.socials svg { width:19px; height:19px; }

.contact-form { background:var(--shell); border:1px solid var(--border); border-radius:22px; padding:clamp(30px,4vw,46px); }
.contact-form h3 { font-size:1.6rem; font-weight:500; margin-bottom:24px; }
.field { margin-bottom:18px; }
.field label { display:block; font-family:var(--sans); font-size:11px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.field input,.field textarea {
  width:100%; font-family:var(--sans); font-size:16px; color:var(--ink);
  background:var(--ivory); border:1px solid var(--border); border-radius:12px;
  padding:14px 16px; transition:border-color .25s, box-shadow .25s;
}
.field input:focus,.field textarea:focus { outline:none; border-color:var(--sea); box-shadow:0 0 0 3px rgba(62,91,82,.12); }
.field textarea { resize:vertical; min-height:130px; }
.contact-form .btn { width:100%; justify-content:center; }
.form-note { font-size:.82rem; color:var(--faint); margin-top:14px; text-align:center; }

/* closing quote */
.quote-block { text-align:center; max-width:760px; margin:0 auto; }
.quote-block p { font-family:var(--serif); font-style:italic; font-size:clamp(1.5rem,3.2vw,2.3rem);
  line-height:1.35; font-weight:300; color:var(--ink); }
.quote-block .monogram { margin:0 auto 22px; }

/* ════════════════════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════════════════════ */
.footer { background:var(--sea-deep); color:rgba(246,239,227,.78); padding:72px 0 36px; }
.footer-top { display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:48px; padding-bottom:44px; border-bottom:1px solid rgba(246,239,227,.14); }
.footer .brand-name { color:var(--cream); }
.footer .brand-name em { color:var(--clay-soft); }
.footer-tag { margin-top:16px; max-width:38ch; font-size:.95rem; line-height:1.7; }
.footer h4 { font-family:var(--sans); font-size:11px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--clay-soft); margin-bottom:18px; }
.footer-col a { display:block; padding:6px 0; font-size:.95rem; transition:color .2s; }
.footer-col a:hover { color:var(--cream); }
.footer-bottom { padding-top:28px; text-align:center; font-size:.82rem; color:rgba(246,239,227,.5); line-height:1.7; }
.footer-bottom a:hover { color:var(--cream); }

/* ── Scroll reveal ────────────────────────────────────────────────── */
[data-reveal] { opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
[data-reveal].in { opacity:1; transform:none; }
[data-reveal-delay="1"]{ transition-delay:.1s; }
[data-reveal-delay="2"]{ transition-delay:.2s; }
[data-reveal-delay="3"]{ transition-delay:.3s; }
[data-reveal-delay="4"]{ transition-delay:.4s; }
@media (prefers-reduced-motion:reduce){ [data-reveal]{opacity:1;transform:none;transition:none;} .hero-scroll i{animation:none;} .testi-page{transition:none;} }

/* ── Responsive ───────────────────────────────────────────────────── */
@media (max-width:1000px){
  .team-grid{ grid-template-columns:repeat(2,1fr); gap:30px; }
  .svc-grid{ grid-template-columns:repeat(2,1fr); }
  .testi-grid{ grid-template-columns:1fr; }
  .testi-page.testi-grid{ max-width:none; margin:0; }
  .masonry{ columns:2; }
}
@media (max-width:860px){
  .nav-links{
    position:fixed; inset:0; flex-direction:column; justify-content:center; gap:30px;
    background:rgba(251,246,238,.97); backdrop-filter:blur(16px);
    transform:translateX(100%); transition:transform .45s var(--ease); padding:60px;
  }
  .nav.open .nav-links{ transform:none; }
  .nav-link{ font-size:19px; padding:11px 18px; }
  .hamburger{ display:flex; }
  /* prevent the page behind the open menu from scrolling */
  body.menu-open{ overflow:hidden; }
  .split{ grid-template-columns:1fr; gap:44px; }
  .split.reverse .split-media{ order:0; }
  .contact-grid{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr; gap:32px; }
  .pkg{ grid-template-columns:auto 1fr; }
  .pkg-price{ grid-column:2; text-align:left; margin-top:4px; }
}
@media (max-width:560px){
  .team-grid{ grid-template-columns:1fr; max-width:340px; margin:0 auto; }
  .svc-grid{ grid-template-columns:1fr; }
  .masonry{ columns:1; }
  /* full-width stacked CTAs — never crowd or clip on narrow phones */
  .hero-actions{ flex-direction:column; align-items:stretch; }
  .hero-actions .btn{ width:100%; justify-content:center; }
  /* roomier footer tap targets */
  .footer-col a{ padding:9px 0; }
  /* lightbox controls sized & inset for thumbs */
  .lb-btn{ width:46px; height:46px; }
  .lb-close{ top:16px; right:16px; }
  .lb-prev{ left:10px; }
  .lb-next{ right:10px; }
}
