/* ATELIER GOUD — warm crème · messing-goud · editorial serif · gestikte lijnen */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --bg:#faf6ee; --bg2:#f3ecdd; --ink:#2a241d; --muted:#6f6557;
  --gold:#a8842c; --gold-soft:#c9a24b; --aubergine:#4a2b3a;
  --card:#fffdf8; --line:rgba(42,36,29,.12);
  --serif:"Fraunces",Georgia,serif; --sans:"Inter",system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font:400 17px/1.65 var(--sans)}
img{max-width:100%;display:block;height:auto}
a{color:var(--gold);}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.15}
main{width:min(1140px,92vw);margin:0 auto}
section{padding:72px 0}
h2{font-size:clamp(28px,3.6vw,40px);margin-bottom:10px}
.intro{color:var(--muted);max-width:60ch;margin-bottom:36px}

/* stitched divider motif */
.services h2::after,.reviews h2::after,.local h2::after,.steps-wrap h2::after,.faq h2::after{
  content:"";display:block;width:74px;margin-top:14px;border-top:2px dashed var(--gold-soft)}

/* header */
header.site{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:28px;
  padding:14px 4vw;background:rgba(250,246,238,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.brand{text-decoration:none;color:var(--ink);display:flex;flex-direction:column;line-height:1.1}
.brand-name{font:500 24px var(--serif)}
.brand-name em{font-style:italic;color:var(--gold)}
.brand-sub{font:600 10px/1 var(--sans);letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-top:4px}
nav.main{display:flex;gap:22px;margin-left:auto;flex-wrap:wrap}
nav.main a{font:500 14px var(--sans);color:var(--ink);text-decoration:none;padding:6px 0;border-bottom:2px solid transparent}
nav.main a:hover{color:var(--gold)}
nav.main a[aria-current]{border-bottom-color:var(--gold)}
header .cta{font:600 14px var(--sans);text-decoration:none;color:#fff;background:var(--gold);
  padding:11px 20px;border-radius:3px;white-space:nowrap;box-shadow:0 2px 10px rgba(168,132,44,.35);transition:background .15s}
header .cta:hover{background:#8d6e22}

/* buttons */
.btn{display:inline-block;text-decoration:none;font:600 15px var(--sans);padding:14px 26px;border-radius:3px;transition:all .15s}
.btn.primary{background:var(--gold);color:#fff;box-shadow:0 3px 14px rgba(168,132,44,.35)}
.btn.primary:hover{background:#8d6e22;transform:translateY(-1px)}
.btn.ghost{color:var(--ink);border:1.5px solid var(--ink)}
.btn.ghost:hover{border-color:var(--gold);color:var(--gold)}
.actions{display:flex;gap:14px;flex-wrap:wrap}

/* hero */
.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center;padding:84px 0 64px}
.kicker{font:700 12px/1 var(--sans);letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.hero h1{font-size:clamp(34px,4.6vw,56px);margin-bottom:20px}
.lede{font-size:19px;color:var(--muted);max-width:54ch;margin-bottom:30px}
.hero-img{position:relative}
.hero-img img{border-radius:4px;box-shadow:0 24px 60px rgba(42,36,29,.22);width:100%;aspect-ratio:3/2.4;object-fit:cover}
.hero-img::before{content:"";position:absolute;inset:-16px 16px 16px -16px;border:1.5px solid var(--gold-soft);border-radius:4px;z-index:-1}
.trustline{margin-top:22px;font-size:14px;color:var(--muted)}
.trustline strong{color:var(--ink)}

/* trust strip */
.trust{display:flex;justify-content:center;gap:8px 44px;flex-wrap:wrap;padding:20px 0;
  border-top:2px dashed var(--gold-soft);border-bottom:2px dashed var(--gold-soft);font-size:14px;color:var(--muted)}
.trust strong{color:var(--ink)}

/* services */
.cards{display:grid;grid-template-columns:repeat(12,1fr);gap:22px}
.card{background:var(--card);border:1px solid var(--line);border-radius:5px;overflow:hidden;
  transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(42,36,29,.13)}
.card.featured{grid-column:span 6}
.card:not(.featured){grid-column:span 3}
.card img{height:300px;object-fit:cover;object-position:center 40%;width:100%}
.card-body{padding:24px 26px 26px;display:flex;flex-direction:column;flex:1}
.card h3{font-size:22px;margin-bottom:8px}
.card p{color:var(--muted);font-size:15px;flex:1}
.more{font:600 14px var(--sans);text-decoration:none;margin-top:16px}
.more:hover{text-decoration:underline}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;background:var(--aubergine);
  border-radius:6px;padding:48px 44px;color:#f3ead9}
.pillar h3{color:var(--gold-soft);font-size:21px;margin-bottom:8px}
.pillar p{font-size:15px;color:#d8cbbd}

/* reviews */
.disclaimer{font-size:13px;font-style:italic}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.review{background:var(--card);border:1px solid var(--line);border-radius:5px;padding:28px}
.stars{color:var(--gold);letter-spacing:3px;margin-bottom:14px}
.review blockquote{font-family:var(--serif);font-size:19px;line-height:1.45;margin-bottom:16px}
.review figcaption{font:600 13px var(--sans);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}

/* local */
.local-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:26px}
.local-card{background:var(--card);border:1px solid var(--line);border-radius:5px;padding:32px}
.local-card h3{font-size:19px;margin:18px 0 8px}
.local-card h3:first-child{margin-top:0}
.local-card address{font-style:normal;color:var(--muted)}
.tel{display:inline-block;font:600 18px var(--sans);margin-top:6px}
.hours{border-collapse:collapse;width:100%;font-size:15px}
.hours th{text-align:left;font-weight:500;color:var(--muted);padding:6px 0;width:50%}
.hours td{padding:6px 0}
.hours tr+tr{border-top:1px dashed var(--line)}
.map iframe{width:100%;height:100%;min-height:360px;border:0;border-radius:5px;filter:sepia(.22) saturate(.9)}

/* cta band */
.ctaband{text-align:center;background:var(--bg2);border-radius:6px;padding:64px 24px;margin-bottom:72px}
.ctaband p{font-family:var(--serif);font-size:clamp(22px,3vw,30px);line-height:1.35;margin-bottom:26px}
.ctaband .actions{justify-content:center}

/* footer */
.site-foot{background:var(--ink);color:#cfc4b4;padding:54px 4vw 28px}
.foot-grid{width:min(1140px,100%);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:30px;font-size:14px}
.site-foot .brand-name{font-size:22px;color:#fff;margin-bottom:8px}
.site-foot address{font-style:normal}
.site-foot a{color:var(--gold-soft);text-decoration:none}
.colophon{width:min(1140px,100%);margin:34px auto 0;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);font-size:12px;color:#8d8273}

/* bridal page */
.bridal .hero{grid-template-columns:1fr .85fr}
.bridal .hero-img img{max-height:560px;object-fit:cover;object-position:center top;width:100%}
.steps{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:s;margin-top:34px}
.steps li{background:var(--card);border:1px solid var(--line);border-radius:5px;padding:30px;position:relative}
.step-nr{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;
  border:1.5px dashed var(--gold);color:var(--gold);font:600 18px var(--serif);margin-bottom:16px}
.steps h3{font-size:21px;margin-bottom:8px}
.steps p{color:var(--muted);font-size:15px}
.duo{display:grid;grid-template-columns:1fr 1fr;gap:22px;padding-top:0}
.panel{background:var(--card);border:1px solid var(--line);border-radius:5px;padding:34px}
.panel.accent{background:var(--aubergine);color:#f3ead9;border:none}
.panel h3{font-size:22px;margin-bottom:10px}
.panel.accent h3{color:var(--gold-soft)}
.panel p{color:var(--muted)}
.panel.accent p{color:#d8cbbd}
.faq details{background:var(--card);border:1px solid var(--line);border-radius:5px;margin-bottom:12px;padding:0 26px}
.faq summary{cursor:pointer;font:500 19px/1.3 var(--serif);padding:20px 0;list-style:none;position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:0;top:16px;font:400 26px var(--serif);color:var(--gold)}
.faq details[open] summary::after{content:"–"}
.faq details p{padding:0 0 22px;color:var(--muted);max-width:65ch}

/* responsive */
@media(max-width:980px){
  .hero,.bridal .hero{grid-template-columns:1fr;gap:36px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .card.featured,.card:not(.featured){grid-column:span 1}
  .pillars,.review-grid,.steps{grid-template-columns:1fr}
  .local-grid,.duo,.foot-grid{grid-template-columns:1fr}
  nav.main{display:none}
}

/* shopfront photo in local card */
.shopfront{border-radius:4px;margin-bottom:22px;border:1px solid var(--line)}
