:root {
  --bg: #f4f7f4;
  --panel: #ffffff;
  --panel-soft: #f8fbf8;
  --text: #14211a;
  --muted: #617067;
  --line: rgba(10, 65, 32, 0.09);
  --green-900: #0a5e2a;
  --green-700: #138842;
  --green-100: #e9f5ec;
  --gold-500: #f4a100;
  --gold-100: #fff4da;
  --danger: #8f1f1f;
  --danger-bg: #fdecec;
  --success: #115a2e;
  --success-bg: #e7f7ed;
  --shadow: 0 20px 45px rgba(12, 31, 18, 0.08);
  --radius: 24px;
  --container: 1180px;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: 'Inter', system-ui, sans-serif;
  color: var(--text);
  background: radial-gradient(circle at top left, rgba(244,161,0,.08), transparent 25%), radial-gradient(circle at top right, rgba(19,136,66,.08), transparent 30%), var(--bg);
  line-height: 1.55;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.container { width: min(calc(100% - 2rem), var(--container)); margin: 0 auto; }
.narrow { max-width: 920px; }
.center { text-align: center; }
.left { text-align: left; }
.lead, .hero-lead { color: var(--muted); font-size: clamp(1.08rem, 2vw, 1.28rem); }
.micro { color: var(--muted); font-size: .95rem; margin-top: .9rem; }
.strong, .highlight { font-weight: 800; }
.highlight { color: var(--green-900); }
h1, h2, h3 { line-height: 1.06; letter-spacing: -0.03em; margin: 0 0 1rem; }
h1 { font-size: clamp(2.45rem, 5vw, 4.9rem); }
h2 { font-size: clamp(1.9rem, 4vw, 3rem); }
h3 { font-size: clamp(1.35rem, 2.2vw, 1.85rem); }
h1 span, h2 span { color: var(--green-900); }
.hero-shell { padding: 3rem 0 4rem; }
.hero-grid, .signup-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 2rem; align-items: center; }
.brand-logo { width: min(100%, 370px); margin-bottom: 1rem; }
.brand-logo-download { margin: 0 auto 1rem; }
.eyebrow { display: inline-flex; padding: .48rem .85rem; border-radius: 999px; background: var(--gold-100); color: #8e5a00; font-weight: 800; font-size: .9rem; }
.eyebrow-green { background: var(--green-100); color: var(--green-900); }
.card, .community-card {
  background: rgba(255,255,255,.94);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.card, .community-card, .premium-panel, .table-card, .block-space { padding: 2rem; }
.premium-panel { background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,251,248,.98)); }
.trust-points { display: flex; flex-wrap: wrap; gap: .8rem; margin: 1.5rem 0 0; }
.trust-points span { padding: .8rem 1rem; background: rgba(255,255,255,.82); border: 1px solid var(--line); border-radius: 999px; font-weight: 700; }
.hero-actions { margin-top: 2rem; }
.disclaimer { max-width: 760px; margin-top: 1rem; color: var(--muted); font-size: .9rem; }
.panel-label { color: var(--green-900); font-size: .9rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.panel-foot { margin-top: 1.2rem; padding-top: 1rem; border-top: 1px solid var(--line); color: var(--muted); font-weight: 700; }
.btn {
  display: inline-flex; align-items: center; justify-content: center; min-height: 58px; padding: .95rem 1.5rem;
  border-radius: 14px; border: 0; cursor: pointer; font-weight: 800; letter-spacing: -0.02em;
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}
.btn:hover, .btn:focus-visible { transform: translateY(-2px); filter: brightness(1.03); }
.btn-primary { color: #fff; background: linear-gradient(180deg, var(--green-700), var(--green-900)); box-shadow: 0 14px 28px rgba(10,94,42,.2); }
.btn-large { min-height: 64px; padding-inline: 2rem; }
.section { padding: 5rem 0; }
.section-soft { background: linear-gradient(180deg, rgba(255,255,255,.45), rgba(233,245,236,.58)); border-top: 1px solid rgba(10,65,32,.04); border-bottom: 1px solid rgba(10,65,32,.04); }
.table-title { font-size: 1.15rem; font-weight: 800; margin-bottom: 1rem; text-align: center; }
.cost-table { border: 1px solid var(--line); border-radius: 18px; overflow: hidden; }
.cost-row { display: grid; grid-template-columns: 1fr 1fr; }
.cost-row > div { padding: 1rem 1.1rem; background: #fff; border-bottom: 1px solid var(--line); }
.cost-row > div:last-child { color: #b52f21; font-weight: 800; }
.cost-head > div { background: var(--green-100); color: var(--text)!important; font-weight: 800; }
.cost-row:last-child > div { border-bottom: 0; }
.table-note { text-align: center; color: var(--muted); margin-top: 1rem; }
.cta-band { padding: 5rem 0 5.5rem; background: linear-gradient(180deg, rgba(9,82,37,.97), rgba(7,58,27,.99)); color: #fff; }
.cta-band .lead { color: rgba(255,255,255,.82); }
.check-list, .community-list { list-style: none; padding: 0; margin: 1.25rem 0 0; }
.check-list li, .community-list li { position: relative; padding-left: 1.8rem; margin-bottom: .9rem; font-weight: 600; }
.check-list li::before, .community-list li::before { content: '✓'; position: absolute; left: 0; top: 0; color: var(--green-700); font-weight: 900; }
.section-head { margin-bottom: 1rem; }
.club-form { display: grid; gap: 1rem; }
.field-group label { display: block; margin-bottom: .45rem; font-weight: 700; }
.field-group input { width: 100%; min-height: 54px; padding: .85rem 1rem; border-radius: 14px; border: 1px solid var(--line); background: #fff; font: inherit; }
.club-btn { width: 100%; }
.alert { border-radius: 14px; padding: 1rem 1.1rem; margin-bottom: 1rem; font-weight: 600; }
.alert-success { background: var(--success-bg); color: var(--success); border: 1px solid rgba(17,90,46,.18); }
.alert-error { background: var(--danger-bg); color: var(--danger); border: 1px solid rgba(143,31,31,.18); }
@media (max-width: 980px) {
  .hero-grid, .signup-grid { grid-template-columns: 1fr; }
  .brand-logo { width: min(100%, 330px); }
}
@media (max-width: 640px) {
  .section, .cta-band { padding: 3.75rem 0; }
  .hero-shell { padding: 2rem 0 3rem; }
  .cost-row { grid-template-columns: 1fr; }
  .trust-points { display: grid; }
  .btn, .btn-large { width: 100%; }
  .card, .community-card, .premium-panel, .table-card, .block-space { padding: 1.25rem; }
}


.logo-plate {
  display: inline-block;
  padding: 1rem 1.25rem;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(248,251,248,.96));
  border: 1px solid rgba(10,65,32,.08);
  box-shadow: 0 16px 34px rgba(12,31,18,.07);
}
.brand-logo {
  margin-bottom: 0;
}
.hero-copy .logo-plate,
.center .logo-plate {
  margin-bottom: 1rem;
}
