* { box-sizing: border-box; }
body {
  font-family: -apple-system, system-ui, 'Segoe UI', sans-serif;
  margin: 0; padding: 0; background: #faf8f3; color: #222;
  -webkit-font-smoothing: antialiased; line-height: 1.55;
}
.hero {
  background: linear-gradient(135deg, #2d5016 0%, #4a7c2e 100%);
  color: #fff; padding: 48px 20px 36px; text-align: center;
}
.hero .label {
  display: inline-block; margin-bottom: 14px; padding: 4px 12px;
  font-size: 11px; font-weight: 600; letter-spacing: 0.6px;
  text-transform: uppercase;
  background: rgba(255,255,255,0.14); border: 1px solid rgba(255,255,255,0.3);
  border-radius: 999px;
}
.hero h1 { margin: 0 0 10px; font-size: 28px; line-height: 1.25; max-width: 640px; margin-left: auto; margin-right: auto; }
.hero .sub { font-size: 15px; opacity: 0.9; max-width: 540px; margin: 0 auto; }
main { max-width: 740px; margin: 0 auto; padding: 24px 20px 60px; }
section { margin-bottom: 32px; }
h2 { color: #2d5016; font-size: 19px; margin: 28px 0 10px; }
h3 { color: #2d5016; font-size: 15px; margin: 20px 0 6px; }
.principle {
  background: #fff; border-radius: 10px; padding: 16px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06); margin-bottom: 12px;
}
.principle strong { color: #2d5016; }
.callout {
  background: #f3f7ee; border-left: 4px solid #4a7c2e;
  padding: 12px 14px; margin: 16px 0; border-radius: 0 8px 8px 0; font-size: 14px;
}
.callout.warn { background: #fff8e1; border-left-color: #e65100; }
.compare-table {
  width: 100%; border-collapse: collapse; margin: 16px 0;
  background: #fff; border-radius: 8px; overflow: hidden;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
.compare-table th, .compare-table td { padding: 10px 12px; text-align: left; font-size: 13px; border-bottom: 1px solid #eee; vertical-align: top; }
.compare-table th { background: #f3f7ee; color: #2d5016; font-weight: 700; }
.compare-table tr:last-child td { border-bottom: none; }
.form-card {
  background: #fff; border-radius: 12px; padding: 22px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.08); margin-top: 20px;
}
.form-card h2 { margin-top: 0; }
.field { margin-bottom: 14px; }
.field label { display: block; font-size: 13px; font-weight: 600; color: #444; margin-bottom: 4px; }
.field input, .field select {
  width: 100%; padding: 11px 13px; border: 1px solid #ccc; border-radius: 8px;
  font-size: 15px; background: #fff;
}
.field input:focus, .field select:focus {
  outline: none; border-color: #2d5016; box-shadow: 0 0 0 2px rgba(45,80,22,0.15);
}
.consent-row { display: flex; gap: 10px; align-items: flex-start; font-size: 13px; color: #555; margin: 8px 0 14px; }
.consent-row input { margin-top: 3px; flex-shrink: 0; }
.btn {
  width: 100%; padding: 13px; border: none; border-radius: 8px;
  background: #2d5016; color: #fff; font-size: 15px; font-weight: 600; cursor: pointer;
}
.btn:hover { background: #234012; }
.btn:disabled { background: #aaa; cursor: not-allowed; }
.note { font-size: 12px; color: #777; margin-top: 14px; }
.success-msg, .error-msg { margin-top: 14px; padding: 12px 14px; border-radius: 8px; font-size: 14px; display: none; }
.success-msg { background: #e8f5e9; color: #1b5e20; }
.error-msg { background: #ffebee; color: #b71c1c; }
.footer-nav {
  text-align: center; font-size: 12px; color: #777;
  border-top: 1px solid #e7e9d8; padding: 20px 16px; background: #f3f7ee;
}
.footer-nav a { color: #2d5016; text-decoration: none; margin: 0 8px; }

  /* Extracted utility classes (previously inline styles). */
  ._si1 { font-size:13px;color:#555; }
  ._si2 { font-size: 14px; color: #555; }
