@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@600&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

* { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body {
  margin: 0;
  background: #f9f5dc;
  color: #1a1a1a;
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 17px;
  line-height: 1.62;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; }
main { overflow: hidden; }
.shell {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 80px;
  width: 100%;
}
.shell, .grid > *, .split > *, .card, .offer-card, .form-panel { min-width: 0; }
.hero { padding: clamp(64px, 10vw, 126px) 0 clamp(44px, 7vw, 84px); }
.eyebrow { margin: 0 0 22px; color: #2d6e40; font-size: 12px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; }
h1, h2, h3 { margin: 0; }
h1, h2 { font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 600; line-height: 1.02; letter-spacing: -0.035em; }
h1 { max-width: 11.5ch; font-size: clamp(58px, 9vw, 112px); }
h2 { max-width: 12ch; font-size: clamp(42px, 6vw, 72px); }
h3 { font-size: clamp(22px, 2.2vw, 30px); line-height: 1.16; letter-spacing: -0.02em; }
p { margin: 0; max-width: 66ch; }
.lead { margin-top: 28px; max-width: 60ch; font-size: clamp(19px, 2vw, 24px); font-weight: 500; line-height: 1.5; }
.actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 36px; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 13px 20px; border: 1px solid #2d6e40; color: #2d6e40; text-decoration: none; font-weight: 800; }
.button.primary { background: #2d6e40; color: #f9f5dc; }
.button:hover, .button:focus-visible { background: #1a1a1a; border-color: #1a1a1a; color: #f9f5dc; }
section { padding: clamp(66px, 9vw, 116px) 0; }
.dark { background: #1a1a1a; color: #f9f5dc; }
.dark .eyebrow { color: #00a651; }
.grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.card, .offer-card { border: 1px solid rgba(26, 26, 26, 0.13); background: rgba(255, 255, 255, 0.24); padding: clamp(24px, 3vw, 34px); min-height: 100%; }
.card p, .offer-card p { margin-top: 14px; color: rgba(26, 26, 26, 0.68); }
.meta { margin-top: 18px; color: #2d6e40; font-weight: 800; }
.offer-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; align-items: stretch; }
.offer-card { display: grid; grid-template-rows: auto auto 1fr; gap: 22px; background: #fffaf0; }
.offer-card-header { display: grid; gap: 14px; }
.offer-card ul { margin: 0; padding-left: 1.1em; color: rgba(26, 26, 26, 0.68); }
.offer-card li + li { margin-top: 8px; }
.clarity-layout { display: grid; grid-template-columns: minmax(0, 0.92fr) minmax(320px, 0.78fr); gap: clamp(32px, 6vw, 72px); align-items: start; }
.clarity-copy { min-width: 0; }
.clarity-copy p + p { margin-top: 18px; }
.clarity-list { margin: 28px 0 0; padding-left: 1.1em; color: rgba(26, 26, 26, 0.74); }
.clarity-list li + li { margin-top: 10px; }
.form-panel { border-top: 1px solid rgba(26, 26, 26, 0.14); padding-top: 24px; }
.clarity-form-panel { align-self: start; background: #fffaf0; border: 1px solid rgba(26, 26, 26, 0.13); padding: clamp(24px, 3vw, 34px); }
form { display: grid; gap: 16px; margin-top: 18px; }
label { display: grid; gap: 7px; font-size: 13px; font-weight: 800; letter-spacing: 0.02em; }
fieldset { margin: 0; padding: 0; border: 0; min-width: 0; }
.mode-switch { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.mode-switch legend { grid-column: 1 / -1; margin: 0 0 2px; font-size: 13px; font-weight: 800; letter-spacing: 0.02em; }
.mode-switch label { position: relative; display: grid; min-height: 116px; padding: 14px; border: 1px solid rgba(26, 26, 26, 0.16); background: #fffdf5; cursor: pointer; }
.mode-switch input { position: absolute; inset: 14px auto auto 14px; width: 18px; height: 18px; margin: 0; accent-color: #2d6e40; }
.mode-switch span { display: grid; gap: 6px; padding-left: 28px; align-content: start; }
.mode-switch strong { font-size: clamp(12px, 1.35vw, 14px); line-height: 1.18; }
.mode-switch small { color: rgba(26, 26, 26, 0.66); font-size: 12.5px; line-height: 1.35; }
.mode-switch label:has(input:checked) { border-color: #2d6e40; box-shadow: inset 0 0 0 1px #2d6e40; }
input, textarea, select, button { font: inherit; }
input, textarea, select { width: 100%; border: 1px solid rgba(26, 26, 26, 0.18); background: #fffdf5; color: #1a1a1a; padding: 13px 14px; }
textarea { min-height: 130px; resize: vertical; }
button { width: max-content; border: 1px solid #2d6e40; background: #2d6e40; color: #f9f5dc; padding: 13px 20px; font-weight: 800; cursor: pointer; }
button:hover, button:focus-visible { background: #1a1a1a; border-color: #1a1a1a; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.notice { display: none; margin-top: 18px; padding: 14px 16px; background: rgba(0, 166, 81, 0.12); border: 1px solid rgba(0, 166, 81, 0.28); font-weight: 700; }
.notice.is-visible { display: block; }
.small { font-size: 14px; color: rgba(26, 26, 26, 0.58); }

@media (max-width: 900px) {
  .shell { padding: 0 32px; }
  .grid, .grid.two, .split, .offer-grid, .clarity-layout { grid-template-columns: 1fr; }
}

@media (max-width: 520px) {
  body { font-size: 16px; }
  .shell { padding: 0 24px; }
  h1 { max-width: 100%; font-size: clamp(46px, 15vw, 68px); }
  h2 { max-width: 100%; }
  .lead { font-size: 18px; }
  .mode-switch { grid-template-columns: 1fr; }
  .mode-switch label { min-height: 0; }
  button { width: 100%; }
}

@media (max-width: 520px) {
  .lead,
  p {
    max-width: 100%;
  }
}

@media (max-width: 520px) {
  .shell,
  .offer-card,
  .form-panel {
    width: 100%;
    max-width: 100%;
  }
}
