/* shared.css — Goudmeijer design system (all pages) */

:root{
  --bg:#F2EAD3;
  --paper:#FAF6E9;
  --ink:#1B2A24;
  --ink-2:#3a4a43;
  --muted:#6B7C68;
  --rule:rgba(27,42,36,.18);
  --rule-soft:rgba(27,42,36,.10);
  --gold:#A07A36;
  --gold-deep:#82601E;
  --serif:"Instrument Serif", "Times New Roman", serif;
  --sans:"Geist", ui-sans-serif, -apple-system, "Helvetica Neue", sans-serif;
  --mono:"Geist Mono", ui-monospace, "SF Mono", monospace;
}
html{scroll-behavior:smooth}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  font-size:16px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:var(--paper)}

.wrap{max-width:1320px;margin:0 auto;padding:0 40px}
@media (max-width:720px){.wrap{padding:0 22px}}

/* Topstrip */
.topstrip{background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:11px;letter-spacing:.04em;padding:8px 0}
.topstrip-inner{display:flex;justify-content:space-between;align-items:center;gap:24px}
.topstrip .tick{display:inline-flex;align-items:center;gap:10px}
.topstrip .dot{width:6px;height:6px;border-radius:50%;background:#9BE3B5;box-shadow:0 0 0 0 rgba(155,227,181,.7);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(155,227,181,.6)}70%{box-shadow:0 0 0 8px rgba(155,227,181,0)}100%{box-shadow:0 0 0 0 rgba(155,227,181,0)}}
.topstrip .sep{opacity:.4}
@media (max-width:720px){.topstrip-inner > :nth-child(2){display:none}}

/* Nav */
nav.main{display:flex;align-items:center;justify-content:space-between;padding:22px 0;border-bottom:.5px solid var(--rule-soft)}
.brand{display:flex;align-items:baseline;gap:10px;font-family:var(--serif);font-size:30px;line-height:1;letter-spacing:-.01em}
.brand .mark{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:34px;line-height:1;transform:translateY(2px)}
.brand small{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);align-self:center;border-left:.5px solid var(--rule);padding-left:10px}
nav.main ul{display:flex;gap:32px;list-style:none;margin:0;padding:0;font-size:14px}
nav.main a:hover{color:var(--gold-deep)}
nav.main ul a{position:relative;padding:6px 0}
nav.main ul a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold);transition:width .25s ease}
nav.main a:hover::after{width:100%}
.nav-cta{display:inline-flex;align-items:center;gap:8px;font-size:13px;padding:10px 16px;border:.5px solid var(--ink);border-radius:999px;transition:background .2s, color .2s}
.nav-cta:hover{background:var(--ink);color:var(--paper)}
.nav-cta .arr{font-family:var(--serif);font-style:italic;font-size:16px;line-height:1;transform:translateY(-1px)}
@media (max-width:900px){nav.main ul{display:none}}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;border-radius:999px;font-size:14px;letter-spacing:.01em;transition:all .2s ease;border:.5px solid transparent;cursor:default}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--gold-deep)}
.btn-ghost{border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn .arrow{display:inline-block;font-family:var(--serif);font-style:italic;font-size:18px;line-height:1;transition:transform .2s}
.btn:hover .arrow{transform:translateX(3px)}

/* Section primitives */
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";display:inline-block;width:16px;height:1px;background:currentColor;opacity:.6}
h1,h2,h3{font-family:var(--serif);font-weight:400;letter-spacing:-.01em;margin:0}
h1{font-size:clamp(56px,8vw,124px);line-height:.94}
h2{font-size:clamp(40px,5vw,72px);line-height:1.02}
h3{font-size:28px;line-height:1.15}
.italic{font-style:italic;color:var(--gold-deep)}
p{margin:0}
.rule{height:1px;background:var(--rule);margin:0}

/* Trust strip */
.trust-strip{border-top:.5px solid var(--rule-soft);border-bottom:.5px solid var(--rule-soft);padding:28px 0}
.trust-strip-inner{display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:14px}
.trust-item .glyph{width:36px;height:36px;border-radius:50%;border:.5px solid var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-style:italic;font-size:18px}
.trust-item .t1{font-size:14px;display:block}
.trust-item .t2{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:block;margin-top:2px}

/* Footer */
footer{padding:80px 0 32px;background:var(--ink);color:rgba(250,246,233,.72)}
footer .top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;border-bottom:.5px solid rgba(250,246,233,.16);padding-bottom:48px}
footer .brand-block .brand{color:var(--paper)}
footer .brand-block p{margin-top:18px;font-family:var(--serif);font-size:17px;max-width:32ch;line-height:1.45;color:rgba(250,246,233,.6)}
footer h4{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:rgba(250,246,233,.5);margin:0 0 18px;font-weight:400}
footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:14px}
footer a:hover{color:var(--gold)}
footer .bot{display:flex;justify-content:space-between;padding-top:32px;font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:rgba(250,246,233,.45)}
@media (max-width:900px){footer .top{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:560px){footer .top{grid-template-columns:1fr}footer .bot{flex-direction:column;gap:8px}}

/* ─────────── Animations ─────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.is-in{opacity:1;transform:translateY(0)}
.reveal-d2{transition-delay:.08s}
.reveal-d3{transition-delay:.16s}
.reveal-d4{transition-delay:.24s}
.reveal-d5{transition-delay:.32s}
.reveal-d6{transition-delay:.4s}
.lift{transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s cubic-bezier(.2,.7,.2,1)}
.lift:hover{transform:translateY(-3px)}
.hero-in{opacity:0;animation:fadeUp 1s cubic-bezier(.2,.7,.2,1) .15s forwards}
.hero-in-d2{opacity:0;animation:fadeUp 1s cubic-bezier(.2,.7,.2,1) .3s forwards}
.hero-in-d3{opacity:0;animation:fadeUp 1s cubic-bezier(.2,.7,.2,1) .5s forwards}
.hero-in-d4{opacity:0;animation:fadeUp 1s cubic-bezier(.2,.7,.2,1) .7s forwards}
.hero-in-d5{opacity:0;animation:fadeIn 1.2s ease .9s forwards}
@media (prefers-reduced-motion: reduce){
  .reveal,.hero-in,.hero-in-d2,.hero-in-d3,.hero-in-d4,.hero-in-d5{
    opacity:1!important;transform:none!important;animation:none!important;
  }
}
