/* Latent — latent.photography
   The entire design system: black, paper, one red. */

/* Newsreader, self-hosted (OFL). Served from our own origin: the privacy
   page promises "no tracking", and a Google Fonts <link> ships every
   visitor's IP to Google (LG München I, 3 O 17493/20). Variable font,
   weights 400–500, optical sizing on. */
@font-face {
  font-family: "Newsreader";
  src: url("/assets/fonts/newsreader-latin.woff2") format("woff2");
  font-weight: 400 500;
  font-style: normal;
  font-display: swap;
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Newsreader";
  src: url("/assets/fonts/newsreader-latin-ext.woff2") format("woff2");
  font-weight: 400 500;
  font-style: normal;
  font-display: swap;
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

:root {
  --black: #000000;
  --paper: #F5F2EC;
  --ink-on-black: #EBEBEB;
  --dim: #6E6A63;
  --safelight: #E2483D;
  --serif: "Newsreader", Georgia, serif;
  --sans: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { font-size: 17px; }

body {
  background: var(--paper);
  color: var(--black);
  font-family: var(--sans);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

.wrap {
  max-width: 660px;
  margin: 0 auto;
  padding: 0 28px;
}

/* Typography */
h1, h2, .display {
  font-family: var(--serif);
  font-optical-sizing: auto;
  font-weight: 500;
  line-height: 1.12;
  letter-spacing: -0.01em;
}
h1 { font-size: clamp(2.4rem, 7vw, 3.6rem); }
h2 { font-size: clamp(1.5rem, 4vw, 2rem); margin-bottom: 1rem; }
h3 { font-family: var(--serif); font-weight: 500; font-size: 1.15rem; margin-bottom: .35rem; }

.label {
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--dim);
}

p { margin-bottom: 1rem; max-width: 56ch; }
.dim { color: var(--dim); }

a { color: inherit; text-underline-offset: 3px; }
a:hover { opacity: .7; }

/* Header / footer */
header.site {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 28px 0 0;
}
header.site .wordmark {
  font-family: var(--serif); font-size: 1.25rem; text-decoration: none;
}

footer.site {
  background: var(--black);
  color: var(--ink-on-black);
  margin-top: 96px;
  padding: 56px 0 64px;
}
footer.site .label { color: #8F8F8F; }
.cta-note { margin-top: 12px; }
footer.site nav { display: flex; flex-wrap: wrap; gap: 18px; margin-top: 14px; }
footer.site a { color: var(--ink-on-black); font-size: .9rem; }
footer.site .fine { color: #8F8F8F; font-size: .8rem; margin-top: 28px; max-width: none; }

/* Hero */
.hero { padding: 64px 0 24px; }
.hero .visual { max-width: 340px; margin: 0 auto; display: block; }
.hero h1 { margin: 40px 0 14px; }
.hero .sub { font-size: 1.05rem; color: var(--dim); max-width: 44ch; }

.cta {
  display: inline-block;
  background: var(--safelight);
  color: var(--paper);
  font-family: var(--sans);
  font-weight: 600;
  text-decoration: none;
  padding: 15px 34px;
  border-radius: 999px;
  margin-top: 28px;
}
.cta:hover { opacity: .9; }

/* Ritual */
.ritual { padding: 72px 0 8px; }
.ritual ol { list-style: none; display: grid; gap: 44px; margin-top: 40px; }
.ritual li { display: grid; grid-template-columns: 56px 1fr; gap: 22px; align-items: start; }
.ritual img { width: 44px; height: 44px; }
.ritual p { margin: 0; color: var(--dim); }

/* Pricing */
.pricing { padding: 72px 0 8px; }
.pricing .cards { display: grid; gap: 16px; grid-template-columns: 1fr; margin-top: 36px; }
@media (min-width: 560px) { .pricing .cards { grid-template-columns: 1fr 1fr; } }
.card {
  border: 1px solid var(--black);
  padding: 26px 24px 22px;
}
.card .frames { font-family: var(--serif); font-size: 2.2rem; line-height: 1; }
.card .frames small { font-family: var(--sans); font-size: .85rem; color: var(--dim); margin-left: 6px; }
.card .price { font-weight: 600; font-size: 1.15rem; margin-top: 10px; }
.pricing .note { margin-top: 18px; color: var(--dim); font-size: .9rem; }

/* FAQ */
.faq { padding: 72px 0 8px; }
.faq dl { margin-top: 32px; display: grid; gap: 28px; }
.faq dd { color: var(--dim); margin-top: 6px; max-width: 58ch; }

/* Legal / text pages */
main.page { padding: 56px 0 8px; }
main.page h1 { font-size: clamp(1.9rem, 5vw, 2.6rem); margin-bottom: .4rem; }
main.page .meta { margin-bottom: 2.4rem; }
main.page h2 { font-size: 1.25rem; margin: 2.2rem 0 .6rem; }
main.page ul, main.page ol { margin: 0 0 1rem 1.2rem; }
main.page li { margin-bottom: .4rem; max-width: 56ch; }
address { font-style: normal; margin-bottom: 1rem; }

hr.rule { border: 0; border-top: 1px solid var(--black); opacity: .2; margin: 2.6rem 0; }
