:root {
  --cream: #f7f1e8;
  --paper: #fffdf8;
  --ink: #172126;
  --muted: #5e6a66;
  --teal: #0f4c4a;
  --teal-dark: #0a3836;
  --brick: #b23a3a;
  --brick-dark: #922c2c;
  --amber: #e6b85c;
  --sage: #dce5d6;
  --border: #e8ded0;
  --shadow: 0 24px 70px rgba(23, 33, 38, 0.16);
  --soft-shadow: 0 14px 36px rgba(23, 33, 38, 0.08);
  --radius-lg: 28px;
  --radius-md: 18px;
  --radius-sm: 12px;
  --max: 1080px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at 15% 5%, rgba(230, 184, 92, 0.22), transparent 26rem),
    radial-gradient(circle at 90% 18%, rgba(15, 76, 74, 0.10), transparent 28rem),
    linear-gradient(180deg, var(--cream), #f5efe6 55%, #f2ede6);
  line-height: 1.55;
}

a { color: inherit; }
img, svg { max-width: 100%; }

.skip-link {
  position: absolute;
  left: 1rem;
  top: 1rem;
  z-index: 100;
  transform: translateY(-150%);
  background: var(--ink);
  color: white;
  padding: .75rem 1rem;
  border-radius: var(--radius-sm);
}
.skip-link:focus { transform: translateY(0); }

.shell {
  width: min(var(--max), calc(100% - 32px));
  margin: 0 auto;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 10;
  backdrop-filter: blur(14px);
  background: rgba(247, 241, 232, 0.86);
  border-bottom: 1px solid rgba(232, 222, 208, 0.8);
}
.nav-shell {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .85rem 0;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  text-decoration: none;
  font-weight: 900;
  letter-spacing: -0.02em;
}
.brand-mark {
  display: inline-grid;
  place-items: center;
  width: 2.3rem;
  height: 2.3rem;
  border-radius: 999px;
  color: var(--paper);
  background: var(--teal);
  font-size: .82rem;
}
.brand-text { color: var(--teal-dark); }
.site-nav {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-weight: 800;
  font-size: .93rem;
}
.site-nav a {
  text-decoration: none;
  color: var(--teal-dark);
  padding: .55rem .75rem;
  border-radius: 999px;
}
.site-nav a:hover { background: rgba(15, 76, 74, .08); }
.site-nav .nav-cta {
  background: var(--brick);
  color: var(--paper);
}
.site-nav .nav-cta:hover { background: var(--brick-dark); }

.section { padding: 4.5rem 0; }
.hero-section { padding: 2rem 0 3.5rem; }
.hero-card {
  overflow: hidden;
  position: relative;
  text-align: center;
  background: var(--paper);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: clamp(2rem, 4.5vw, 4.5rem);
  box-shadow: var(--shadow);
}
.hero-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 8% 12%, rgba(230, 184, 92, .18), transparent 12rem),
    radial-gradient(circle at 100% 0%, rgba(178, 58, 58, .10), transparent 16rem);
  pointer-events: none;
}
.hero-card > * { position: relative; }
.top-notice {
  margin: 0 0 1.3rem;
  color: var(--teal);
  font-size: .85rem;
  font-weight: 900;
}
.eyebrow {
  margin: 0 0 .6rem;
  color: var(--brick);
  font-size: .78rem;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}
h1, h2, h3 { line-height: 1.08; letter-spacing: -0.045em; }
h1 {
  max-width: 850px;
  margin: 0 auto;
  color: var(--ink);
  font-size: clamp(2.15rem, 5vw, 4.8rem);
  font-weight: 950;
}
.hero-question {
  margin: 1.35rem auto 1.5rem;
  color: var(--brick);
  font-size: clamp(1.18rem, 2.2vw, 1.7rem);
  font-weight: 900;
}
.hero-copy {
  max-width: 760px;
  margin: 0 auto 1.6rem;
  text-align: left;
  font-size: 1.04rem;
}
.hero-copy p { margin: 0 0 1rem; }
.hero-actions {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: .8rem;
  flex-wrap: wrap;
  margin: 1rem 0 .9rem;
}
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: .82rem 1.25rem;
  border-radius: 999px;
  border: 2px solid transparent;
  font-weight: 950;
  text-decoration: none;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.button:hover { transform: translateY(-1px); }
.button:focus-visible {
  outline: 3px solid var(--amber);
  outline-offset: 3px;
}
.button.primary {
  background: var(--brick);
  color: var(--paper);
  box-shadow: 0 10px 24px rgba(178, 58, 58, .20);
}
.button.primary:hover { background: var(--brick-dark); }
.button.secondary {
  background: transparent;
  color: var(--teal);
  border-color: rgba(15, 76, 74, .22);
}
.helper, .trust-row {
  margin: .6rem 0 0;
  color: var(--muted);
  font-size: .9rem;
}
.trust-row { font-size: .84rem; }
.trust-row span { color: rgba(94, 106, 102, .75); }

.language-note {
  max-width: 720px;
  margin: .85rem auto 0;
  color: var(--muted);
  font-size: .88rem;
  line-height: 1.45;
}
.language-note strong { color: var(--teal-dark); }

.section-heading {
  max-width: 770px;
  margin: 0 auto 2rem;
  text-align: center;
}
.section-heading.align-left { text-align: left; margin: 0; }
.section-heading h2,
.info-card h2,
.privacy-card h2,
.final-card h2 {
  margin: 0 0 .8rem;
  font-size: clamp(2rem, 4vw, 3.3rem);
  font-weight: 950;
}
.section-heading p { color: var(--muted); margin: 0; }

.data-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
.data-card {
  background: var(--paper);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 1.25rem;
  box-shadow: var(--soft-shadow);
}
.data-card-wide { grid-column: 1 / -1; }
.card-label {
  display: inline-flex;
  margin-bottom: .85rem;
  padding: .28rem .55rem;
  border-radius: 999px;
  color: var(--teal-dark);
  background: var(--sage);
  font-size: .72rem;
  font-weight: 950;
  letter-spacing: .09em;
  text-transform: uppercase;
}
.data-card h3 {
  margin: 0 0 1rem;
  font-size: 1.5rem;
  font-weight: 950;
}
.data-card dl { margin: 0; display: grid; gap: .65rem; }
.data-card dl div {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  border-top: 1px solid rgba(232, 222, 208, .8);
  padding-top: .65rem;
}
.data-card dt { color: var(--muted); font-weight: 700; }
.data-card dd { margin: 0; font-weight: 950; text-align: right; }
.data-card .no { color: var(--brick); }
.data-card p { margin: 0; color: var(--muted); }

.source-link-row {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: .65rem;
  margin: 1rem auto 0;
}
.source-link-row a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .62rem .85rem;
  border: 1px solid rgba(15, 76, 74, .18);
  border-radius: 999px;
  color: var(--teal-dark);
  background: rgba(255, 253, 248, .7);
  text-decoration: none;
  font-weight: 850;
  font-size: .88rem;
}
.source-link-row a:hover { border-color: var(--teal); background: var(--paper); }

.source-note {
  max-width: 820px;
  margin: 1.2rem auto 0;
  color: var(--muted);
  font-size: .88rem;
  text-align: center;
}
.inline-cta {
  max-width: 720px;
  margin: 2.25rem auto 0;
  padding: 1.5rem;
  text-align: center;
  background: var(--teal);
  color: var(--paper);
  border-radius: var(--radius-md);
}
.inline-cta h3 { margin: 0 0 .35rem; font-size: 1.65rem; }
.inline-cta p { margin: 0 0 1rem; color: rgba(255,253,248,.86); }
.inline-cta .button.primary { background: var(--paper); color: var(--brick); }

.two-column {
  display: grid;
  grid-template-columns: .85fr 1.15fr;
  gap: 2rem;
  align-items: start;
}
.check-card,
.info-card,
.contact-form {
  background: var(--paper);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 1.4rem;
  box-shadow: var(--soft-shadow);
}
.check-list,
.info-card ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: .75rem;
}
.check-list li,
.info-card li {
  position: relative;
  padding-left: 1.6rem;
}
.check-list li::before,
.info-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .45rem;
  width: .55rem;
  height: .55rem;
  border-radius: 50%;
  background: var(--teal);
}
.cards-two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
.warning-card { background: #fff8f4; }
.warning-card li::before { background: var(--brick); }

.privacy-section { padding-top: 2rem; }
.privacy-card {
  background: var(--sage);
  border: 1px solid rgba(15, 76, 74, .12);
  border-radius: var(--radius-lg);
  padding: clamp(1.4rem, 4vw, 2.4rem);
}
.privacy-card p:last-child { margin-bottom: 0; }

.resources-shell { max-width: 890px; }
.resource-links {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
}
.resource-links a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: .85rem 1rem;
  text-align: center;
  text-decoration: none;
  color: var(--teal-dark);
  background: var(--paper);
  border: 1px solid var(--border);
  border-radius: 999px;
  font-weight: 900;
}
.resource-links a:hover { border-color: var(--teal); }

.contact-grid { align-items: stretch; }
.contact-form {
  display: grid;
  gap: .75rem;
}
.contact-form label { font-weight: 850; }
.contact-form label span { color: var(--muted); font-weight: 600; }
.contact-form input,
.contact-form select,
.contact-form textarea {
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: .78rem .9rem;
  font: inherit;
  color: var(--ink);
  background: #fff;
}
.contact-form textarea { resize: vertical; }
.checkbox-label {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: .65rem;
  align-items: start;
  font-weight: 650 !important;
  color: var(--muted);
}
.checkbox-label input { width: auto; min-height: auto; margin-top: .35rem; }
.form-button { border: 0; margin-top: .4rem; }
.form-note { margin: 0; color: var(--muted); font-size: .82rem; }
.hidden-field { display: none; }

.final-cta { padding-top: 2rem; }
.final-card {
  text-align: center;
  background: var(--teal);
  color: var(--paper);
  border-radius: var(--radius-lg);
  padding: clamp(1.8rem, 5vw, 3rem);
}
.final-card p { color: rgba(255,253,248,.85); }
.final-card .button.primary { background: var(--paper); color: var(--brick); }
.site-footer {
  padding: 2rem 0;
  color: rgba(255,253,248,.78);
  background: var(--teal-dark);
  font-size: .92rem;
}
.site-footer p { max-width: 900px; margin: 0 auto .65rem; }
.footer-small { font-size: .82rem; }

.reveal { opacity: 0; transform: translateY(16px); transition: opacity .55s ease, transform .55s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

@media (max-width: 820px) {
  .site-nav { display: none; }
  .brand-text { font-size: .95rem; }
  .hero-section { padding-top: 1rem; }
  .hero-card { padding: 1.6rem; border-radius: 20px; box-shadow: 0 16px 42px rgba(23, 33, 38, .12); }
  h1 { font-size: 2.55rem; }
  .hero-question { font-size: 1.22rem; }
  .hero-copy { font-size: .98rem; }
  .button { width: 100%; max-width: 320px; }
  .trust-row span { display: none; }
  .trust-row { display: grid; gap: .15rem; }
  .language-note { font-size: .82rem; text-align: left; }
  .data-grid,
  .two-column,
  .cards-two,
  .resource-links {
    grid-template-columns: 1fr;
  }
  .section { padding: 3rem 0; }
  .section-heading,
  .section-heading.align-left { text-align: left; }
  .section-heading h2,
  .info-card h2,
  .privacy-card h2,
  .final-card h2 { font-size: 2.05rem; }
  .data-card dl div { align-items: start; }
}

@media (max-width: 480px) {
  .shell { width: min(100% - 22px, var(--max)); }
  .top-notice { font-size: .78rem; }
  h1 { font-size: 2.05rem; }
  .hero-question { font-size: 1.08rem; }
  .hero-card { padding: 1.25rem; }
  .data-card, .check-card, .info-card, .contact-form { padding: 1rem; }
  .data-card h3 { font-size: 1.25rem; }
  .data-card dl div { display: grid; gap: .2rem; }
  .data-card dd { text-align: left; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    scroll-behavior: auto !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .reveal { opacity: 1; transform: none; }
}

/* v2 content updates */
.data-card .card-context {
  margin: -.35rem 0 .95rem;
  color: var(--muted);
  font-size: .95rem;
}

.form-note-error {
  color: var(--brick) !important;
  font-weight: 800;
}

/* Added for clearer source links and data-use explanation */
.source-link-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .75rem;
  margin: 1rem auto 0;
}
.source-link-row a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: .65rem .9rem;
  border: 1px solid rgba(15, 76, 74, .22);
  border-radius: 999px;
  color: var(--teal-dark);
  background: rgba(255, 253, 248, .72);
  font-weight: 850;
  text-decoration: none;
}
.source-link-row a:hover { border-color: var(--teal); background: var(--paper); }
.cards-three {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}
.cards-three .info-card h3 {
  margin: 0 0 .7rem;
  font-size: 1.35rem;
  line-height: 1.12;
}
.cards-three .info-card p { margin: 0; color: var(--muted); }
@media (max-width: 900px) {
  .cards-three { grid-template-columns: 1fr; }
}
