@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700;900&family=Inter:wght@400;500;700&display=swap');

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'Inter', system-ui, sans-serif;
  background: #F2EAD9;
  color: #1C2740;
  font-size: 17px; line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
.wrap { max-width: 720px; margin: 0 auto; padding: 90px 32px 120px; }
.kicker {
  font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
  color: #34407F; font-weight: 700; margin-bottom: 28px;
  display: flex; align-items: baseline; gap: 14px;
}
.kicker::before { content: ''; flex-shrink: 0; width: 36px; height: 1px; background: #34407F; }
.kicker::after { content: '№ 27'; margin-left: auto; opacity: 0.7; letter-spacing: 0.12em; }
h1 {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 900; font-size: clamp(40px, 5.6vw, 72px);
  line-height: 1.05; letter-spacing: -0.015em;
  margin: 0 0 22px;
  color: #1C2740;
}
.dropcap::first-letter {
  font-family: 'Playfair Display', Georgia, serif; font-weight: 900;
  font-size: 4.6em; line-height: 0.92; padding: 6px 12px 0 0;
  float: left; color: #34407F;
}
.lede { font-size: 22px; line-height: 1.45; color: #3A3527; max-width: 600px; margin: 0 0 36px; font-weight: 400; }
hr.rule { border: 0; border-top: 1px solid #E6DCC8; margin: 48px 0; }
.byline { display: flex; gap: 24px; align-items: center; font-size: 14px; color: #3A3527; margin: 32px 0 0; }
.byline a { color: #1C2740; text-decoration: underline; text-underline-offset: 4px; }
.cta {
  display: inline-flex; align-items: center; gap: 10px;
  background: #1C2740; color: #F2EAD9;
  padding: 16px 30px; font-family: 'Inter', sans-serif; font-weight: 700;
  text-decoration: none; font-size: 15px; letter-spacing: 0.04em;
}
.cta:hover { background: #34407F; }

.feature-list { display: grid; gap: 36px; margin: 56px 0 0; }
.feature { padding-left: 32px; border-left: 2px solid #34407F; }
.feature h3 { font-family: 'Playfair Display', Georgia, serif; font-weight: 700; font-size: 26px; margin: 0 0 8px; color: #1C2740; letter-spacing: -0.01em; }
.feature p { margin: 0; font-size: 16px; line-height: 1.6; color: #1C2740; }
.feature .num { font-family: 'Playfair Display', Georgia, serif; font-style: italic; color: #34407F; font-size: 18px; display: block; margin-bottom: 6px; }

footer { max-width: 720px; margin: 0 auto; padding: 48px 32px; border-top: 1px solid #E6DCC8; font-size: 13px; color: #3A3527; display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap; }
footer a { color: #3A3527; text-decoration: underline; text-underline-offset: 3px; }

/* Privacy / Support pages — long-read editorial */
.long-read { max-width: 720px; margin: 0 auto; padding: 80px 32px 100px; }
.long-read h1 { font-size: clamp(36px, 4.8vw, 56px); margin-bottom: 12px; }
.long-read .meta { color: #3A3527; font-size: 13px; margin-bottom: 56px; letter-spacing: 0.06em; text-transform: uppercase; }
.long-read article { margin-bottom: 40px; }
.long-read article h2 { font-family: 'Playfair Display', Georgia, serif; font-weight: 700; font-size: 22px; margin: 0 0 10px; color: #1C2740; }
.long-read article p { margin: 0; font-size: 16px; line-height: 1.65; color: #1C2740; }

.faq-group { margin: 36px 0; }
.faq-group > h2 { font-family: 'Playfair Display',Georgia,serif; font-size: 18px; color: #34407F; text-transform: uppercase; letter-spacing: 0.12em; font-weight: 700; padding-bottom: 8px; border-bottom: 1px solid #E6DCC8; }
.faq { margin: 22px 0; }
.faq dt { font-family: 'Playfair Display',Georgia,serif; font-weight: 700; font-size: 18px; margin-bottom: 4px; color: #1C2740; }
.faq dd { margin: 0; color: #1C2740; line-height: 1.6; }

/* Editorial contact form — large generous serif inputs */
.cf-edit { margin: 36px 0 48px; padding: 32px; border-top: 4px double #1C2740; border-bottom: 4px double #1C2740; }
.cf-edit .cf-head h2 { font-family: 'Playfair Display',Georgia,serif; font-weight: 700; font-size: 28px; margin: 0 0 4px; color: #1C2740; letter-spacing: -0.01em; }
.cf-edit .cf-intro { font-style: italic; color: #3A3527; margin: 0 0 22px; font-size: 17px; }
.cf-edit .cf-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.cf-edit .cf-label.cf-subject, .cf-edit .cf-label.cf-message { grid-column: span 2; }
.cf-edit .cf-label > span { display: block; font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: #34407F; font-weight: 700; margin-bottom: 6px; }
.cf-edit input, .cf-edit textarea { width: 100%; font-family: 'Inter',sans-serif; font-size: 16px; padding: 12px 14px; border: 1px solid #E6DCC8; border-radius: 0; background: #F2EAD9; color: #1C2740; }
.cf-edit input:focus, .cf-edit textarea:focus { outline: 2px solid #34407F; outline-offset: 1px; }
.cf-edit textarea { min-height: 140px; resize: vertical; }
.cf-edit .cf-hp { display: none; }
.cf-edit .cf-actions { margin-top: 14px; display: flex; gap: 22px; align-items: baseline; flex-wrap: wrap; }
.cf-edit .cf-submit { background: #1C2740; color: #F2EAD9; padding: 14px 28px; border: 0; font-family: 'Inter',sans-serif; font-weight: 700; font-size: 14px; letter-spacing: 0.08em; text-transform: uppercase; cursor: pointer; }
.cf-edit .cf-submit:hover { background: #34407F; }
.cf-edit .cf-direct { font-size: 13px; color: #3A3527; }
.cf-edit .cf-direct a { color: #34407F; text-decoration: underline; }
@media (max-width: 640px) { .cf-edit .cf-fields { grid-template-columns: 1fr; } .cf-edit .cf-label.cf-subject, .cf-edit .cf-label.cf-message { grid-column: span 1; } }
