/* Wedding Monogram Bar — "heirloom-letters" theme (bespoke, 2026-07-04)
   Palette: parchment bg, warm mocha accent, linen tan, espresso ink.
   Motif: embossed-letter watermarks + linen texture panels.
   Type: Sentient (display serif, Fontshare) / Jost (body). */

:root{
  --bg:#fbf6f0;
  --surface:#fffefb;
  --accent:#8c6a5d;
  --accent-deep:#6f5248;
  --accent2:#c3b299;
  --ink:#332e29;
  --ink-soft:#5d554c;
  --line:#e6dccd;
  --linen:repeating-linear-gradient(0deg,rgba(140,106,93,.035) 0 1px,transparent 1px 3px),
          repeating-linear-gradient(90deg,rgba(195,178,153,.05) 0 1px,transparent 1px 3px);
  --shadow-frame:0 14px 34px -18px rgba(51,46,41,.4);
  --font-display:"Sentient",Georgia,"Times New Roman",serif;
  --font-body:"Jost","Avenir Next",Avenir,system-ui,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  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(--accent-deep)}
h1,h2,h3{font-family:var(--font-display);font-weight:500;line-height:1.15;color:var(--ink)}
h1{font-size:clamp(2.1rem,5.6vw,3.6rem);letter-spacing:-.01em}
h2{font-size:clamp(1.55rem,3.4vw,2.3rem)}
h3{font-size:1.18rem}
h1 em,h2 em{font-style:italic;color:var(--accent)}
p{color:var(--ink-soft)}
strong{color:var(--ink)}

.scroll-progress{position:fixed;top:0;left:0;right:0;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:0 50%;z-index:1200}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:1100;
  display:flex;align-items:center;gap:1rem;
  padding:.8rem clamp(1rem,4vw,2.6rem);
  background:rgba(251,246,240,.94);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--ink);margin-right:auto}
.brand-mark{
  width:42px;height:42px;flex:none;display:grid;place-items:center;
  font-family:var(--font-display);font-style:italic;font-size:1.25rem;
  color:var(--surface);background:var(--accent);border-radius:50%;
  box-shadow:inset 0 0 0 2px var(--surface),0 0 0 1px var(--accent);
}
.brand strong{font-family:var(--font-display);font-weight:500;font-size:1.06rem;display:block;line-height:1.1}
.brand small{display:block;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.nav-toggle{display:none;font:600 .8rem/1 var(--font-body);letter-spacing:.14em;text-transform:uppercase;background:none;border:1px solid var(--accent2);border-radius:999px;padding:.55rem 1rem;color:var(--ink);cursor:pointer}
.site-nav{display:flex;align-items:center;gap:clamp(.7rem,1.6vw,1.4rem)}
.site-nav a{font-size:.86rem;letter-spacing:.09em;text-transform:uppercase;text-decoration:none;color:var(--ink-soft);padding:.3rem 0;border-bottom:2px solid transparent}
.site-nav a:hover{color:var(--accent-deep);border-bottom-color:var(--accent2)}
.site-nav a.nav-cta{background:var(--accent);color:var(--surface);padding:.55rem 1.15rem;border-radius:999px;border-bottom:none}
.site-nav a.nav-cta:hover{background:var(--accent-deep)}

@media(max-width:880px){
  .nav-toggle{display:block}
  .site-nav{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--surface);border-bottom:1px solid var(--line);
    display:none;padding:.5rem 0 1rem;
  }
  .site-nav.is-open{display:flex}
  .site-nav a{padding:.75rem clamp(1rem,4vw,2.6rem);border-bottom:1px solid var(--line)}
  .site-nav a.nav-cta{margin:.9rem clamp(1rem,4vw,2.6rem) 0;text-align:center}
}

/* ---------- shared section shell ---------- */
main{overflow-x:hidden}
.section{position:relative;padding:clamp(3rem,7vw,5.5rem) clamp(1rem,4vw,2.6rem)}
.section-inner{max-width:1080px;margin:0 auto;position:relative;z-index:1}
.section-tight .section-inner{max-width:820px}
.eyebrow{
  font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1rem;display:flex;align-items:center;gap:.8rem;
}
.eyebrow::before,.eyebrow.center::after{content:"";height:1px;width:34px;background:var(--accent2);flex:none}
.eyebrow.center{justify-content:center}
.section-title{margin-bottom:1rem}
.section-lede{max-width:62ch;margin-bottom:1.4rem}

/* embossed letter watermark */
.wm{position:relative}
.wm::before{
  content:attr(data-letter);
  position:absolute;z-index:0;pointer-events:none;
  top:-.12em;right:-.05em;
  font-family:var(--font-display);font-style:italic;font-weight:500;
  font-size:clamp(11rem,30vw,24rem);line-height:1;
  color:var(--bg);
  text-shadow:-1px -1px 0 rgba(255,255,255,.85),2px 2px 3px rgba(140,106,93,.18);
  opacity:.8;
}
.wm-left::before{right:auto;left:-.06em}

/* linen texture panel */
.panel{
  background:var(--surface);background-image:var(--linen);
  border:1px solid var(--line);border-radius:14px;
  padding:clamp(1.3rem,3vw,2.2rem);
}
.band{background:var(--surface);background-image:var(--linen);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.band-accent{background:var(--accent);border:none}
.band-accent h2,.band-accent p{color:var(--surface)}
.band-accent .eyebrow{color:var(--accent2)}

/* ---------- hero (tall, centered, vows-style) ---------- */
.hero{padding:clamp(3.4rem,8vw,6rem) clamp(1rem,4vw,2.6rem) clamp(2.6rem,6vw,4.4rem);text-align:center;position:relative}
.hero .section-inner{max-width:880px}
.hero-rule{width:52px;height:1px;background:var(--accent2);margin:1.3rem auto}
.hero h1{margin:0 auto;max-width:19ch}
.hero .vow{display:block;font-style:italic;font-size:.52em;color:var(--accent);letter-spacing:.02em;margin-bottom:.45em}
.hero-lede{max-width:56ch;margin:1.3rem auto 1.8rem}
.hero-actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-bottom:.9rem}
.hero-note{font-size:.85rem;color:var(--accent);letter-spacing:.04em}

/* framed photo pair */
.frame-pair{
  display:flex;justify-content:center;gap:clamp(1rem,4vw,2.6rem);
  padding:clamp(1.6rem,4vw,3rem) clamp(1rem,4vw,2.6rem) clamp(2.4rem,5vw,3.6rem);
  flex-wrap:wrap;position:relative;
}
.frame{
  background:var(--surface);border:1px solid var(--line);
  padding:14px 14px 40px;max-width:330px;width:min(78vw,330px);
  box-shadow:var(--shadow-frame);position:relative;
}
.frame img{border:1px solid var(--accent2);aspect-ratio:3/4;object-fit:cover;width:100%}
.frame figcaption{
  position:absolute;left:0;right:0;bottom:10px;text-align:center;
  font-family:var(--font-display);font-style:italic;font-size:.92rem;color:var(--accent);
}
.frame-a{transform:rotate(-1.6deg)}
.frame-b{transform:rotate(1.3deg) translateY(12px)}

/* ---------- buttons ---------- */
.button{
  display:inline-block;background:var(--accent);color:var(--surface);
  font:600 .88rem/1 var(--font-body);letter-spacing:.1em;text-transform:uppercase;
  padding:1rem 1.7rem;border-radius:999px;text-decoration:none;border:1px solid var(--accent);
  transition:background .2s;
}
.button:hover{background:var(--accent-deep)}
.button-ghost{background:transparent;color:var(--accent-deep);border-color:var(--accent2)}
.button-ghost:hover{background:var(--surface)}

/* ---------- grids / cards ---------- */
.grid{display:grid;gap:1.2rem}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(min(100%,250px),1fr))}
.card{
  background:var(--surface);background-image:var(--linen);
  border:1px solid var(--line);border-radius:12px;padding:1.5rem;
  position:relative;
}
.card h3{margin-bottom:.5rem}
.card .init{
  font-family:var(--font-display);font-style:italic;font-size:2rem;color:var(--accent2);
  display:block;margin-bottom:.4rem;line-height:1;
}
.card-link{display:block;text-decoration:none;color:inherit;transition:transform .18s,box-shadow .18s}
.card-link:hover{transform:translateY(-3px);box-shadow:var(--shadow-frame)}
.card-link .more{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-top:.7rem;display:inline-block}

.step-list{list-style:none;counter-reset:step;display:grid;gap:1rem;margin:1.4rem 0}
.step-list li{
  counter-increment:step;background:var(--surface);background-image:var(--linen);
  border:1px solid var(--line);border-radius:12px;padding:1.1rem 1.2rem 1.1rem 4rem;position:relative;color:var(--ink-soft);
}
.step-list li::before{
  content:counter(step,upper-roman);
  position:absolute;left:1.1rem;top:1rem;
  font-family:var(--font-display);font-style:italic;font-size:1.25rem;color:var(--accent);
}
.step-list li strong{display:block;font-family:var(--font-display);font-weight:500;font-size:1.06rem;margin-bottom:.15rem}

.check-list{list-style:none;display:grid;gap:.55rem;margin:1rem 0;color:var(--ink-soft)}
.check-list li{padding-left:1.5rem;position:relative}
.check-list li::before{content:"✦";position:absolute;left:0;color:var(--accent2)}

/* photo strips */
.photo-duo{display:grid;gap:1.2rem;grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));margin:1.6rem 0}
.photo-duo figure{background:var(--surface);border:1px solid var(--line);padding:10px 10px 30px;position:relative;box-shadow:var(--shadow-frame)}
.photo-duo img{width:100%;aspect-ratio:4/3;object-fit:cover;border:1px solid var(--accent2)}
.photo-duo figcaption{position:absolute;left:0;right:0;bottom:6px;text-align:center;font-family:var(--font-display);font-style:italic;font-size:.85rem;color:var(--accent)}

/* gallery */
.gallery-grid{display:grid;gap:1.3rem;grid-template-columns:repeat(auto-fill,minmax(min(100%,270px),1fr));align-items:start}
.gallery-grid figure{background:var(--surface);border:1px solid var(--line);padding:10px 10px 34px;position:relative;box-shadow:var(--shadow-frame)}
.gallery-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;border:1px solid var(--accent2)}
.gallery-grid .tall img{aspect-ratio:3/4}
.gallery-grid figcaption{position:absolute;left:0;right:0;bottom:8px;text-align:center;font-family:var(--font-display);font-style:italic;font-size:.85rem;color:var(--accent);padding:0 .5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* pricing */
.price-hero{
  text-align:center;background:var(--surface);background-image:var(--linen);
  border:1px solid var(--accent2);border-radius:14px;padding:2rem 1.4rem;margin:1.8rem 0;
}
.price-hero .amount{font-family:var(--font-display);font-size:clamp(2.4rem,7vw,3.6rem);color:var(--accent-deep);line-height:1.05}
.price-hero .amount small{font-size:.4em;letter-spacing:.1em}
.price-table{width:100%;border-collapse:collapse;margin:1.4rem 0;background:var(--surface)}
.price-table th,.price-table td{border:1px solid var(--line);padding:.8rem .9rem;text-align:left;font-size:.95rem;color:var(--ink-soft)}
.price-table th{font-family:var(--font-display);font-weight:500;color:var(--ink);background:var(--bg)}
.table-wrap{overflow-x:auto}

/* prose pages (answers/blog) */
.prose{max-width:720px;margin:0 auto}
.prose h2{margin:2.1rem 0 .7rem}
.prose h3{margin:1.5rem 0 .5rem}
.prose p{margin:.85rem 0}
.prose ul,.prose ol{margin:.85rem 0 .85rem 1.3rem;color:var(--ink-soft)}
.prose li{margin:.35rem 0}
.prose .keyfact{
  border-left:3px solid var(--accent);background:var(--surface);background-image:var(--linen);
  padding:1rem 1.2rem;margin:1.4rem 0;border-radius:0 10px 10px 0;font-size:1.02rem;
}
.byline{font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:1.1rem}
.breadcrumbs{font-size:.8rem;letter-spacing:.06em;color:var(--ink-soft);padding:1rem clamp(1rem,4vw,2.6rem) 0;max-width:1080px;margin:0 auto}
.breadcrumbs a{color:var(--accent);text-decoration:none}
.breadcrumbs a:hover{text-decoration:underline}

/* ---------- lead form ---------- */
.quote-section{scroll-margin-top:90px}
.lead-form{
  background:var(--surface);background-image:var(--linen);
  border:1px solid var(--accent2);border-radius:16px;
  padding:clamp(1.4rem,3.4vw,2.4rem);max-width:760px;margin:1.6rem auto 0;
  display:grid;gap:1rem;grid-template-columns:1fr 1fr;
}
.lead-form .full{grid-column:1/-1}
.lead-form label{display:block;font-size:.78rem;letter-spacing:.13em;text-transform:uppercase;color:var(--accent);margin-bottom:.35rem}
.lead-form input,.lead-form textarea,.lead-form select{
  width:100%;padding:.85rem .9rem;font:400 1rem var(--font-body);color:var(--ink);
  background:var(--bg);border:1px solid var(--line);border-radius:9px;
}
.lead-form input:focus,.lead-form textarea:focus{outline:2px solid var(--accent2);border-color:var(--accent2)}
.hp-wrap{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.form-submit{
  grid-column:1/-1;background:var(--accent);color:var(--surface);border:none;cursor:pointer;
  font:600 .95rem/1 var(--font-body);letter-spacing:.12em;text-transform:uppercase;
  padding:1.1rem;border-radius:999px;transition:background .2s;
}
.form-submit:hover{background:var(--accent-deep)}
.form-submit:disabled{opacity:.65;cursor:wait}
.form-note{grid-column:1/-1;text-align:center;font-size:.85rem;color:var(--ink-soft);margin:0}
.lead-form.is-success{border-color:var(--accent)}
@media(max-width:640px){.lead-form{grid-template-columns:1fr}}

/* ---------- footer ---------- */
.site-footer{
  background:var(--ink);color:#cfc6bb;margin-top:2rem;
  padding:clamp(2.4rem,6vw,4rem) clamp(1rem,4vw,2.6rem) 5.5rem;
}
.footer-inner{max-width:1080px;margin:0 auto;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr))}
.site-footer h3{color:var(--accent2);font-size:1rem;letter-spacing:.14em;text-transform:uppercase;font-family:var(--font-body);font-weight:600;margin-bottom:.8rem}
.site-footer a{color:#f0e9df;text-decoration:none}
.site-footer a:hover{color:var(--accent2)}
.site-footer ul{list-style:none;display:grid;gap:.45rem}
.site-footer p{color:#b5aa9c;font-size:.92rem}
.footer-brand{font-family:var(--font-display);font-style:italic;font-size:1.4rem;color:var(--surface);margin-bottom:.5rem;display:block}
.footer-legal{max-width:1080px;margin:2.2rem auto 0;padding-top:1.2rem;border-top:1px solid rgba(255,255,255,.12);font-size:.8rem;color:#8f8578;text-align:center}

@media(max-width:480px){
  body{font-size:16px}
  .frame{padding:10px 10px 34px}
  .frame-b{transform:rotate(1.3deg)}
}
