/* ============================================================
   ГО "Немезіс Свої" — design system
   Calm · humane · modern · trustworthy
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Onest:wght@300;400;500;600;700;800&display=swap');

:root{
  /* palette */
  --bg:        #FAFCFA;
  --surface:   #FFFFFF;
  --tint:      #E4F5EF;
  --sand:      #F7EDE7;
  --ink:       #1A2C24;
  --ink-2:     #536158;
  --ink-3:     #8A968C;
  --green:      #23A776;
  --green-deep: #1A8A62;
  --green-soft: #C6EEE2;
  --clay:     #D2603F;
  --clay-soft:#F6DCD0;
  --line:      #E4E9E6;
  --line-2:    #EBF0EC;
  --footer:    #0C0C0C;

  /* hero dark section */
  --hero-bg:      #0D1510;
  --hero-surface: #162018;

  /* type */
  --font: 'Onest', system-ui, -apple-system, 'Segoe UI', sans-serif;

  /* spacing rhythm */
  --r-sm: 12px;
  --r:    18px;
  --r-lg: 26px;
  --r-xl: 34px;

  --shadow-sm: 0 1px 2px rgba(40,55,70,.04), 0 2px 8px rgba(40,55,70,.04);
  --shadow:    0 2px 6px rgba(40,55,70,.05), 0 14px 40px rgba(40,55,70,.07);
  --shadow-lg: 0 8px 24px rgba(40,55,70,.08), 0 30px 70px rgba(40,55,70,.10);

  --maxw: 1180px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
.icon{ fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
html{ scroll-behavior:smooth; scroll-padding-top:92px; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font);
  background:var(--bg);
  color:var(--ink);
  font-size:18px;
  line-height:1.6;
  font-weight:400;
  letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *{ animation-duration:.001ms !important; transition-duration:.001ms !important; }
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ margin:0; font-weight:700; line-height:1.08; letter-spacing:-0.025em; color:var(--ink); text-wrap:balance; }
p{ margin:0; text-wrap:pretty; }

::selection{ background:var(--clay-soft); color:var(--ink); }

/* focus visibility (a11y) */
:focus-visible{ outline:3px solid var(--green); outline-offset:3px; border-radius:6px; }

.skip-link{
  position:absolute; left:16px; top:-60px; z-index:200;
  background:var(--ink); color:#fff; padding:12px 18px; border-radius:12px;
  font-weight:600; transition:top .2s var(--ease);
}
.skip-link:focus{ top:16px; }

/* ---------- layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.section{ padding:96px 0; position:relative; }
.section--tint{ background:var(--tint); }
.section--sand{ background:var(--sand); }
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-size:14px; font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  color:var(--green-deep);
}
.eyebrow::before{
  content:""; width:22px; height:2px; border-radius:2px;
  background:var(--clay);
}
.section-head{ max-width:680px; margin-bottom:54px; }
.section-head h2{ font-size:clamp(30px,3.6vw,46px); margin:16px 0 0; }
.section-head .lead{ margin-top:18px; font-size:19px; color:var(--ink-2); }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:15px 26px; border-radius:14px; font-weight:600; font-size:16.5px;
  border:1px solid transparent; transition:transform .2s var(--ease), background .2s var(--ease), box-shadow .2s var(--ease), border-color .2s var(--ease);
  white-space:nowrap; line-height:1;
}
.btn svg{ width:18px; height:18px; }
.btn--primary{ background:var(--green-deep); color:#fff; box-shadow:0 6px 18px rgba(26,138,98,.26); }
.btn--primary:hover{ background:#157250; transform:translateY(-2px); box-shadow:0 10px 26px rgba(26,138,98,.34); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn--ghost:hover{ border-color:var(--green); color:var(--green-deep); transform:translateY(-2px); background:#fff; }
.btn--block{ width:100%; }
.btn--lg{ padding:18px 30px; font-size:17.5px; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:100;
  background:#080C09;
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease);
}
.site-header.is-scrolled{ border-bottom-color:rgba(255,255,255,.1); }
.nav{ display:flex; align-items:center; gap:28px; height:74px; }
.brand{ display:flex; align-items:center; gap:12px; margin-right:auto; }
.brand .mark{ width:42px; height:42px; flex:0 0 auto; }
.brand .name{ display:flex; flex-direction:column; line-height:1.05; }
.brand .name b{ font-size:17px; font-weight:700; letter-spacing:-.02em; }
.brand .name small{ font-size:11.5px; color:var(--ink-3); font-weight:500; letter-spacing:.02em; }

.nav-links{ display:flex; align-items:center; gap:6px; }
.nav-links a{
  padding:9px 14px; border-radius:10px; font-size:15.5px; font-weight:500; color:rgba(210,225,218,.75);
  transition:color .18s var(--ease), background .18s var(--ease);
}
.nav-links a:hover{ color:#fff; background:rgba(255,255,255,.09); }
.nav-cta{ display:flex; align-items:center; gap:10px; }

.burger{
  display:none; width:46px; height:46px; border-radius:12px; border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08); align-items:center; justify-content:center; flex-direction:column; gap:5px;
}
.burger span{ width:20px; height:2px; background:#fff; border-radius:2px; transition:transform .3s var(--ease), opacity .2s; }
.burger.is-open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger.is-open span:nth-child(2){ opacity:0; }
.burger.is-open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile drawer */
.mobile-menu{
  position:fixed; inset:74px 0 auto 0; z-index:99;
  background:#080C09; border-bottom:1px solid rgba(255,255,255,.08);
  transform:translateY(-12px); opacity:0; pointer-events:none;
  transition:transform .28s var(--ease), opacity .28s var(--ease);
  box-shadow:0 8px 24px rgba(0,0,0,.4);
}
.mobile-menu.is-open{ transform:translateY(0); opacity:1; pointer-events:auto; }
.mobile-menu nav{ display:flex; flex-direction:column; padding:14px 28px 26px; gap:2px; height:auto; }
.mobile-menu a{ padding:15px 8px; font-size:18px; font-weight:500; color:rgba(210,225,218,.85); border-bottom:1px solid rgba(255,255,255,.08); }
.mobile-menu .btn{ margin-top:18px; }

/* ============================================================
   HERO — dark section
   ============================================================ */
.hero{
  position:relative; overflow:hidden; padding:74px 0 92px;
  background:var(--hero-bg);
}
.hero-grid{
  display:grid; grid-template-columns:1.08fr .92fr; gap:64px; align-items:center;
}
.hero-copy{ position:relative; z-index:2; }
.hero h1{ font-size:clamp(30px,5.2vw,60px); letter-spacing:-.03em; color:#D4E5DA; }
.hero h1 .accent{ position:relative; white-space:nowrap; }
.hero h1 .accent::after{
  content:""; position:absolute; left:0; right:0; bottom:.08em; height:.16em;
  background:var(--clay); opacity:.5; border-radius:3px; z-index:-1;
}
.hero .eyebrow{ color:var(--green); }
.hero .sub{ margin-top:26px; font-size:20px; color:#769082; max-width:540px; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:36px; }
.hero-actions .btn--ghost{ color:#D4E5DA; border-color:rgba(255,255,255,.2); }
.hero-actions .btn--ghost:hover{ background:rgba(35,167,118,.12); border-color:var(--green); color:var(--green); }
.hero-note{
  display:flex; gap:12px; margin-top:30px; padding:16px 18px; max-width:540px;
  background:var(--hero-surface); border:1px solid rgba(255,255,255,.08); border-radius:16px;
  box-shadow:0 2px 12px rgba(0,0,0,.3);
}
.hero-note svg{ width:22px; height:22px; flex:0 0 auto; color:var(--green); margin-top:1px; }
.hero-note p{ font-size:14.5px; color:#769082; line-height:1.5; }

/* hero visual collage */
.hero-visual{ position:relative; z-index:1; min-height:480px; }
.hero-visual .slot-main{
  position:absolute; right:0; top:8px; width:84%; height:360px;
  border-radius:var(--r-xl); box-shadow:0 8px 40px rgba(0,0,0,.5); overflow:hidden;
}
.hero-visual .slot-sub{
  position:absolute; left:-6px; bottom:6px; width:46%; height:200px;
  border-radius:var(--r-lg); box-shadow:0 8px 30px rgba(0,0,0,.5); overflow:hidden;
  border:4px solid var(--hero-surface);
}
.hero-visual .slot-main img,
.hero-visual .slot-sub img{ width:100%; height:100%; object-fit:cover; display:block; }
.photo-placeholder{ background:linear-gradient(135deg,#e6efe8,#d9e7dd); display:flex; align-items:center; justify-content:center; }
.photo-placeholder__inner{ display:flex; flex-direction:column; align-items:center; gap:9px; color:#4a7a5a; opacity:.5; text-align:center; font-size:13px; font-weight:500; padding:20px; pointer-events:none; }
.photo-placeholder__inner svg{ stroke:#4a7a5a; }
.hero-badge{
  position:absolute; left:8%; top:-6px; z-index:3;
  display:flex; align-items:center; gap:11px;
  background:var(--hero-surface); border:1px solid rgba(255,255,255,.1); border-radius:16px; padding:12px 16px;
  box-shadow:0 4px 20px rgba(0,0,0,.4);
}
.hero-badge .dot{ width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:#2D1508; color:var(--clay); }
.hero-badge .dot svg{ width:20px;height:20px; }
.hero-badge b{ font-size:14.5px; display:block; color:#D4E5DA; }
.hero-badge span{ font-size:12.5px; color:#476150; }

/* soft background blobs */
.blob{ position:absolute; border-radius:50%; filter:blur(80px); z-index:0; pointer-events:none; }
.hero .blob-1{ width:560px;height:560px; background:#0E4030; right:-180px; top:-180px; opacity:.65; }
.hero .blob-2{ width:420px;height:420px; background:#3D1E10; left:-160px; bottom:-180px; opacity:.45; }

/* ============================================================
   CARDS — generic
   ============================================================ */
.grid{ display:grid; gap:20px; }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }

.card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:30px; transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
  position:relative; overflow:hidden;
}
.card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--green-soft); }
.card .ic{
  width:52px; height:52px; border-radius:14px; display:grid; place-items:center;
  background:var(--tint); color:var(--green-deep); margin-bottom:20px;
}
.card .ic svg{ width:26px; height:26px; }
.card h3{ font-size:20px; margin-bottom:10px; letter-spacing:-.02em; }
.card p{ font-size:15.5px; color:var(--ink-2); line-height:1.55; }
.card .idx{
  position:absolute; top:24px; right:26px; font-size:13px; font-weight:600;
  color:var(--ink-3); font-variant-numeric:tabular-nums;
}

/* audience cards keep warmer accent */
.card--audience .ic{ background:var(--sand); color:#B14E32; }

/* directions list (8) */
.dir-card{ padding:28px; }
.dir-card .ic{ width:46px;height:46px;border-radius:12px;margin-bottom:18px; }
.dir-card .ic svg{ width:23px;height:23px; }
.dir-card h3{ font-size:18.5px; }
.dir-card p{ font-size:14.5px; }

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{ display:grid; grid-template-columns:.94fr 1.06fr; gap:56px; align-items:center; }
.about-photo{ width:100%; height:100%; min-height:400px; border-radius:var(--r-xl); box-shadow:var(--shadow-lg); overflow:hidden; }
.about-copy h2{ font-size:clamp(30px,3.6vw,46px); }
.about-copy p{ margin-top:20px; font-size:18.5px; color:var(--ink-2); }
.goal-card{
  position:relative; padding:40px 44px; border-radius:var(--r-xl); overflow:hidden; margin-top:48px;
  display:grid; grid-template-columns:1fr 1.18fr; gap:40px; align-items:center;
  background:#fff; border:1.5px solid rgba(255,255,255,.12); color:var(--ink); box-shadow:var(--shadow-lg);
}
.goal-card .goal-main{ position:relative; z-index:1; }
.goal-card .eyebrow{ color:var(--clay); }
.goal-card .eyebrow::before{ background:var(--clay); }
.goal-card h3{font-size:24px; margin:14px 0 16px; }
.goal-card p{font-size:18px; line-height:1.6; }
.goal-card .ring{ position:absolute; border:1.5px solid rgba(255,255,255,.12); border-radius:50%; }
.goal-card .ring.r1{ width:260px;height:260px; right:-90px; bottom:-110px; }
.goal-card .ring.r2{ width:170px;height:170px; right:-30px; bottom:-50px; border-color:rgba(227,178,60,.35); }
.goal-card p{ position:relative; z-index:1; }

/* community photo band */
.community-band{ display:grid; grid-template-columns:1.12fr .88fr; gap:52px; align-items:center; }
.community-photo{ width:100%; height:440px; border-radius:var(--r-xl); box-shadow:var(--shadow-lg); overflow:hidden; }
.community-cap h2{ font-size:clamp(28px,3.3vw,42px); margin-top:16px; }
.community-cap .lead{ margin-top:18px; font-size:18px; color:var(--ink-2); }
.community-stats{ display:flex; gap:30px; margin-top:28px; flex-wrap:wrap; }
.community-stats .st b{ display:block; font-size:30px; font-weight:700; color:var(--green-deep); letter-spacing:-.02em; }
.community-stats .st span{ font-size:14px; color:var(--ink-2); }

/* ============================================================
   PRINCIPLES
   ============================================================ */
.principle{
  display:flex; gap:20px; padding:30px; background:#fff; border:1px solid var(--line);
  border-radius:var(--r-lg); transition:box-shadow .25s var(--ease), transform .25s var(--ease);
}
.principle:hover{ box-shadow:var(--shadow); transform:translateY(-3px); }
.principle .ic{
  width:50px;height:50px;flex:0 0 auto;border-radius:14px;display:grid;place-items:center;
  background:var(--green-soft); color:var(--green-deep);
}
.principle .ic svg{ width:25px;height:25px; }
.principle h3{ font-size:19px; margin-bottom:8px; }
.principle p{ font-size:15px; color:var(--ink-2); }

/* ============================================================
   DISCLAIMER
   ============================================================ */
.disclaimer{
  display:grid; grid-template-columns:auto 1fr; gap:28px; align-items:start;
  max-width:900px; margin:0 auto; padding:42px 44px;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-xl);
  box-shadow:var(--shadow-sm);
}
.disclaimer .badge{
  width:60px;height:60px;border-radius:16px;display:grid;place-items:center;
  background:var(--tint); color:var(--green-deep);
}
.disclaimer .badge svg{ width:30px;height:30px; }
.disclaimer h2{ font-size:26px; margin-bottom:14px; }
.disclaimer p{ color:var(--ink-2); font-size:17px; }
.disclaimer p + p{ margin-top:14px; }

/* ============================================================
   CONTACT / FORM
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:56px; align-items:start; }
.contact-aside h2{ font-size:clamp(28px,3.4vw,42px); }
.contact-aside .lead{ margin-top:18px; font-size:18px; color:var(--ink-2); }
.contact-mail{
  display:inline-flex; align-items:center; gap:13px; margin-top:30px; padding:16px 20px;
  background:#fff; border:1px solid var(--line); border-radius:16px; box-shadow:var(--shadow-sm);
  transition:border-color .2s var(--ease), transform .2s var(--ease);
}
.contact-mail:hover{ border-color:var(--green); transform:translateY(-2px); }
.contact-mail .ic{ width:44px;height:44px;border-radius:12px;background:var(--sand);color:var(--clay);display:grid;place-items:center; }
.contact-mail .ic svg{ width:22px;height:22px; }
.contact-mail small{ display:block; font-size:12.5px; color:var(--ink-3); }
.contact-mail b{ font-size:16.5px; }
.contact-trust{ margin-top:26px; display:flex; flex-direction:column; gap:12px; }
.contact-trust li{ display:flex; gap:12px; align-items:center; font-size:15px; color:var(--ink-2); list-style:none; }
.contact-trust svg{ width:20px;height:20px;color:var(--green);flex:0 0 auto; }
.contact-trust ul{ margin:0; padding:0; display:flex; flex-direction:column; gap:12px; }

.form-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-xl);
  padding:38px; box-shadow:var(--shadow);
}
.field{ margin-bottom:20px; }
.field label{ display:block; font-size:14.5px; font-weight:600; margin-bottom:8px; color:var(--ink); }
.field label .opt{ font-weight:400; color:var(--ink-3); }
.field .req{ color:var(--green); }
.field input, .field textarea, .field select{
  width:100%; padding:14px 16px; font-family:inherit; font-size:16px; color:var(--ink);
  background:var(--bg); border:1.5px solid var(--line); border-radius:12px;
  transition:border-color .18s var(--ease), background .18s var(--ease), box-shadow .18s var(--ease);
}
.field textarea{ min-height:130px; resize:vertical; }
.field input:focus, .field textarea:focus, .field select:focus{
  outline:none; border-color:var(--green); background:#fff; box-shadow:0 0 0 4px rgba(35,167,118,.18);
}
.field input::placeholder, .field textarea::placeholder{ color:var(--ink-3); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field.has-error input, .field.has-error textarea, .field.has-error select{ border-color:#c95b4a; background:#fdf4f2; }
.error-msg{ display:none; margin-top:7px; font-size:13.5px; color:#c0492f; font-weight:500; }
.field.has-error .error-msg{ display:block; }

.consent{ display:flex; gap:13px; align-items:flex-start; margin:6px 0 24px; }
.consent input{ width:21px; height:21px; margin-top:2px; flex:0 0 auto; accent-color:var(--green-deep); cursor:pointer; }
.consent label{ font-size:14px; color:var(--ink-2); line-height:1.5; }
.consent a{ color:var(--green-deep); font-weight:600; text-decoration:underline; text-underline-offset:2px; }
.consent.has-error label{ color:#c0492f; }

.form-status{ display:none; gap:13px; align-items:flex-start; padding:18px 20px; border-radius:14px; margin-top:8px; font-size:15px; }
.form-status svg{ width:22px;height:22px;flex:0 0 auto;margin-top:1px; }
.form-status.show{ display:flex; }
.form-status.ok{ background:#eaf5ee; color:#2c6e49; border:1px solid #bfe0cb; }
.form-status.err{ background:#fdeeea; color:#b03e29; border:1px solid #f1c9bf; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--footer); color:#c4d2c7; padding:70px 0 36px; }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:48px; padding-bottom:44px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer-brand .mark{ width:44px;height:44px;margin-bottom:18px; }
.footer-brand b{ color:#fff; font-size:18px; display:block; }
.footer-brand p{ margin-top:12px; font-size:15px; color:#6A8070; max-width:300px; }
.footer-col h4{ color:rgba(255,255,255,.45); font-size:12px; text-transform:uppercase; letter-spacing:.1em; margin-bottom:18px; font-weight:600; }
.footer-col a, .footer-col p{ display:block; font-size:15px; color:#7A9688; margin-bottom:12px; transition:color .18s var(--ease); }
.footer-col a:hover{ color:#fff; }
.footer-bottom{ display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; padding-top:26px; font-size:13.5px; color:#4A6257; }
.footer-bottom a{ color:#7A9688; }
.footer-bottom a:hover{ color:#fff; }

/* ============================================================
   PRIVACY PAGE
   ============================================================ */
.legal{ padding:64px 0 90px; }
.legal-head{ max-width:760px; margin-bottom:44px; }
.legal-head .back{ display:inline-flex; align-items:center; gap:8px; color:var(--green-deep); font-weight:600; font-size:15px; margin-bottom:24px; }
.legal-head .back svg{ width:17px;height:17px; }
.legal-head h1{ font-size:clamp(32px,4.4vw,52px); }
.legal-head .meta{ margin-top:16px; color:var(--ink-3); font-size:15px; }
.legal-body{ max-width:760px; }
.legal-note{
  display:flex; gap:14px; padding:22px 24px; background:var(--sand); border:1px solid var(--clay-soft);
  border-radius:16px; color:#8a4530; font-size:15.5px; margin-bottom:36px;
}
.legal-note svg{ width:22px;height:22px;flex:0 0 auto;color:#B14E32; }
.legal-body h2{ font-size:24px; margin:38px 0 14px; }
.legal-body p{ color:var(--ink-2); font-size:17px; margin-bottom:14px; }
.legal-body ul{ color:var(--ink-2); font-size:17px; padding-left:22px; margin:0 0 16px; }
.legal-body li{ color:var(--ink-2); margin-bottom:8px; }
.legal-body a{ color:var(--green-deep); text-decoration:underline; }

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.06s; }
.reveal.d2{ transition-delay:.12s; }
.reveal.d3{ transition-delay:.18s; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .hero-grid{ grid-template-columns:1fr; gap:48px; }
  .hero-visual{ min-height:380px; max-width:560px; }
  .grid-4{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:880px){
  .nav-links, .nav-cta .btn{ display:none; }
  .burger{ display:flex; }
  .grid-3{ grid-template-columns:repeat(2,1fr); }
  .about-grid{ grid-template-columns:1fr; gap:40px; }
  .about-photo{ min-height:300px; height:300px; order:-1; }
  .goal-card{ grid-template-columns:1fr; gap:18px; }
  .community-band{ grid-template-columns:1fr; gap:32px; }
  .community-photo{ height:320px; order:-1; }
  .contact-grid{ grid-template-columns:1fr; gap:40px; }
  .footer-top{ grid-template-columns:1fr 1fr; gap:36px; }
  .section{ padding:74px 0; }
}
@media (max-width:620px){
  body{ font-size:17px; }
  .wrap{ padding:0 20px; }
  .grid-3, .grid-2, .grid-4{ grid-template-columns:1fr; }
  .field-row{ grid-template-columns:1fr; gap:0; }
  .hero{ padding:48px 0 64px; }
  .hero-actions .btn{ width:100%; }
  .hero-visual{ min-height:340px; }
  .disclaimer{ grid-template-columns:1fr; gap:18px; padding:30px 24px; }
  .form-card{ padding:26px 22px; }
  .footer-top{ grid-template-columns:1fr; gap:30px; }
  .section-head{ margin-bottom:38px; }
  .goal-card{ padding:30px 26px; }
}
