/* Connect Frame — soft neutral workspace */
:root {
  --cfr-bg: #f3f1ec;
  --cfr-ink: #222;
  --cfr-soft: #6f6b64;
  --cfr-line: #dcd7cd;
  --cfr-accent: #3d5a4a;
  --cfr-sans: system-ui, "Segoe UI", Roboto, sans-serif;
  --cfr-serif: "Georgia", "Times New Roman", serif;
}
* { box-sizing: border-box; }
body { margin: 0; background: var(--cfr-bg); color: var(--cfr-ink); font-family: var(--cfr-sans); font-size: 1.02rem; line-height: 1.65; }
.cfr-wrap { max-width: 1180px; margin: 0 auto; padding: 0 clamp(1rem, 3vw, 2rem); }
.cfr-head { padding: 2rem 0 1.5rem; border-bottom: 1px solid var(--cfr-line); text-align: center; }
.cfr-logo { margin: 0 0 1rem; font-family: var(--cfr-serif); font-size: 1.35rem; letter-spacing: .02em; }
.cfr-logo a { color: inherit; text-decoration: none; }
.cfr-pills { display: flex; flex-wrap: wrap; justify-content: center; gap: .5rem; }
.cfr-pills a {
  font-size: .85rem;
  padding: .4rem .85rem;
  border-radius: 999px;
  border: 1px solid var(--cfr-line);
  background: #fff;
  color: var(--cfr-soft);
  text-decoration: none;
}
.cfr-pills a:hover { border-color: var(--cfr-accent); color: var(--cfr-ink); }
.cfr-main { padding: 2.5rem 0 4rem; }
.cfr-intro { display: grid; grid-template-columns: 1fr 1.1fr; gap: 2rem; align-items: center; margin-bottom: 3.5rem; }
@media (max-width: 880px) { .cfr-intro { grid-template-columns: 1fr; } }
.cfr-intro h1 { font-family: var(--cfr-serif); font-weight: 400; font-size: clamp(2rem, 4vw, 2.8rem); margin: 0 0 1rem; }
.cfr-intro p { color: var(--cfr-soft); margin: 0; max-width: 44ch; }
.cfr-intro-photo { width: 100%; height: auto; border-radius: 18px; border: 1px solid var(--cfr-line); display: block; }
.cfr-zigzag { display: grid; grid-template-columns: 1fr 0.85fr; gap: 2rem; align-items: start; padding: 3rem 0; border-top: 1px solid var(--cfr-line); }
@media (max-width: 860px) { .cfr-zigzag { grid-template-columns: 1fr; } }
.cfr-zigzag h2 { font-family: var(--cfr-serif); font-weight: 400; font-size: 1.7rem; margin: 0 0 1rem; }
.cfr-zigzag p { margin: 0 0 1rem; color: var(--cfr-soft); }
.cfr-zigzag-img { width: 100%; height: auto; border-radius: 14px; border: 1px solid var(--cfr-line); }
.cfr-panel { padding: 3rem 0; border-top: 1px solid var(--cfr-line); }
.cfr-panel h2 { font-family: var(--cfr-serif); font-weight: 400; font-size: 1.7rem; margin: 0 0 1.25rem; }
.cfr-panel-grid { columns: 2; column-gap: 2.5rem; }
@media (max-width: 760px) { .cfr-panel-grid { columns: 1; } }
.cfr-panel-grid p { margin: 0 0 1rem; color: var(--cfr-soft); break-inside: avoid; }
.cfr-river { background: #ebe7df; margin: 0 -2rem; padding: 3rem 2rem; border-radius: 20px; border: 1px solid var(--cfr-line); }
.cfr-river-inner { max-width: 720px; margin: 0 auto; }
.cfr-river h2 { font-family: var(--cfr-serif); font-weight: 400; font-size: 1.65rem; margin: 0 0 1rem; }
.cfr-river p { color: var(--cfr-soft); margin: 0 0 1rem; }
.cfr-river img { width: 100%; height: auto; border-radius: 12px; margin: 1.5rem 0; border: 1px solid var(--cfr-line); display: block; }
.cfr-closing { padding: 3.5rem 0 0; max-width: 640px; }
.cfr-closing h2 { font-family: var(--cfr-serif); font-weight: 400; font-size: 1.65rem; }
.cfr-closing p { color: var(--cfr-soft); }
.cfr-page { max-width: 680px; margin: 0 auto; padding: 2.5rem 0 3.5rem; }
.cfr-page h1 { font-family: var(--cfr-serif); font-weight: 400; font-size: 2rem; margin: 0 0 .5rem; }
.cfr-page .lead { color: var(--cfr-soft); margin: 0 0 1.5rem; }
.cfr-page p { color: var(--cfr-soft); margin: 0 0 1rem; }
.cfr-page figure { margin: 2rem 0; }
.cfr-page img { width: 100%; height: auto; border-radius: 12px; border: 1px solid var(--cfr-line); }
.cfr-split { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; max-width: 920px; margin: 0 auto; padding: 2.5rem 0 3.5rem; }
@media (max-width: 800px) { .cfr-split { grid-template-columns: 1fr; } }
.cfr-form label { display: block; font-size: .85rem; margin-bottom: .35rem; color: var(--cfr-soft); }
.cfr-form input, .cfr-form textarea { width: 100%; padding: .65rem .75rem; border: 1px solid var(--cfr-line); border-radius: 8px; font: inherit; background: #fff; }
.cfr-form textarea { min-height: 140px; resize: vertical; }
.cfr-form button { margin-top: .75rem; padding: .65rem 1.2rem; border: none; border-radius: 999px; background: var(--cfr-accent); color: #fff; font: inherit; cursor: pointer; }
.cfr-foot { border-top: 1px solid var(--cfr-line); padding: 2.5rem 0; margin-top: 2rem; }
.cfr-foot-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; font-size: .95rem; }
@media (max-width: 900px) { .cfr-foot-row { grid-template-columns: 1fr; } }
.cfr-foot p { margin: .35rem 0 0; color: var(--cfr-soft); }
.cfr-disclaimer { font-size: .88rem; color: var(--cfr-soft); margin-top: 1.5rem; max-width: 720px; }
.cfr-mini { font-size: .85rem; margin: 1rem 0 0; text-align: center; }
.cfr-copy { text-align: center; font-size: .8rem; color: var(--cfr-soft); margin: .75rem 0 0; }
.cfr-cookie-btn { border: none; background: none; font: inherit; color: var(--cfr-accent); cursor: pointer; text-decoration: underline; }
.cfr-banner { position: fixed; left: 50%; bottom: 1rem; transform: translateX(-50%); width: min(420px, 92vw); z-index: 50; }
.cfr-banner-box { background: #fff; border: 1px solid var(--cfr-line); border-radius: 14px; padding: 1rem 1.2rem; box-shadow: 0 10px 30px rgba(0,0,0,.08); font-size: .92rem; }
.cfr-banner-go { display: flex; gap: .5rem; margin-top: .75rem; }
.cfr-banner-go button { flex: 1; padding: .45rem .75rem; border-radius: 999px; border: 1px solid var(--cfr-line); background: #fff; cursor: pointer; font: inherit; }
#cfr-yes { background: var(--cfr-accent); color: #fff; border-color: var(--cfr-accent); }
.cfr-blog { max-width: 760px; margin: 0 auto; padding: 2.5rem 0 3rem; }
.cfr-blog-card { display: grid; grid-template-columns: 200px 1fr; gap: 1.25rem; padding: 1.5rem 0; border-bottom: 1px solid var(--cfr-line); }
@media (max-width: 640px) { .cfr-blog-card { grid-template-columns: 1fr; } }
.cfr-blog-card img { width: 100%; height: auto; border-radius: 10px; border: 1px solid var(--cfr-line); }
.cfr-blog-card h2 { font-family: var(--cfr-serif); font-size: 1.35rem; font-weight: 400; margin: 0 0 .35rem; }
.cfr-blog-card a { color: inherit; text-decoration: none; }
.cfr-blog-card a:hover { text-decoration: underline; }
.cfr-blog-card p { margin: 0; color: var(--cfr-soft); }
