/* Ramadan Fund — Tactile Warmth v3 (01.05.2026)
   Тактильность + анимации + paper-cards + dotted-разделители
*/

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg:#F8F4ED;
  --bg-alt:#F0EBE0;
  --bg-warm:#FDFBF7;
  --surface:#FDFBF7;
  --ink:#1A1614;
  --ink-2:rgba(26,22,20,0.72);
  --ink-3:rgba(26,22,20,0.45);
  --ink-4:rgba(26,22,20,0.12);
  --ink-5:rgba(26,22,20,0.06);
  --line:rgba(26,22,20,0.08);
  --copper:#B8744A;
  --copper-soft:#E2B894;
  --copper-deep:#8B5532;
  --copper-glow:rgba(184,116,74,0.4);
  --green-soft:#5C7A6B;
  --red-alert:#B33A3A;
  --font:'Inter',-apple-system,system-ui,sans-serif;
  --font-display:'Inter',-apple-system,system-ui,sans-serif;
  --max:1200px;
  --max-narrow:880px;
  --ease:cubic-bezier(0.16,1,0.3,1);
}

html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{font-family:var(--font);background:var(--bg);color:var(--ink);line-height:1.6;font-size:17px;font-weight:400;position:relative;overflow-x:hidden}
a{color:var(--copper-deep);text-decoration:none;transition:color 0.25s}
a:hover{color:var(--copper)}
img,svg{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--copper);color:#fff}

/* ─────────── ТАКТИЛЬНАЯ ТЕКСТУРА (грейн) ─────────── */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.1, 0 0 0 0 0.1, 0 0 0 0 0.1, 0 0 0 0.55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:0.045;mix-blend-mode:multiply;
}
body > *{position:relative;z-index:2}

/* Тёплое медное свечение в углу страницы */
.glow-tr,.glow-bl,.glow-tl,.glow-br{position:absolute;width:600px;height:600px;border-radius:50%;pointer-events:none;z-index:0;filter:blur(80px)}
.glow-tr{top:-200px;right:-200px;background:radial-gradient(circle,rgba(184,116,74,0.12),transparent 70%)}
.glow-bl{bottom:-200px;left:-200px;background:radial-gradient(circle,rgba(184,116,74,0.10),transparent 70%)}
.glow-tl{top:-200px;left:-200px;background:radial-gradient(circle,rgba(184,116,74,0.10),transparent 70%)}
.glow-br{bottom:-200px;right:-200px;background:radial-gradient(circle,rgba(184,116,74,0.10),transparent 70%)}

/* ─────────── REVEAL ANIMATIONS ─────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 720ms var(--ease),transform 720ms var(--ease)}
.reveal.in-view{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:80ms}
.reveal-delay-2{transition-delay:160ms}
.reveal-delay-3{transition-delay:240ms}
.reveal-delay-4{transition-delay:320ms}

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

/* ─────────── SCROLL PROGRESS BAR ─────────── */
.scroll-progress{position:fixed;top:0;left:0;width:0;height:2px;background:var(--copper);z-index:200;transition:width 100ms linear}

/* ─────────── DOTTED DIVIDER ─────────── */
.divider-dotted{height:1px;background-image:radial-gradient(circle,rgba(184,116,74,0.4) 1px,transparent 1px);background-size:8px 1px;background-repeat:repeat-x;border:none;margin:60px auto;max-width:80%}

/* ─────────── Nav ─────────── */
nav{position:sticky;top:0;background:rgba(248,244,237,0.85);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-bottom:1px solid var(--line);z-index:100}
.nav-inner{max-width:var(--max);margin:0 auto;padding:18px 28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.nav-brand{font-weight:700;font-size:18px;letter-spacing:-0.01em;color:var(--ink);display:flex;align-items:center;gap:10px;transition:transform 0.3s var(--ease)}
.nav-brand:hover{transform:translateX(2px)}
.nav-brand .dot{width:8px;height:8px;border-radius:50%;background:var(--copper);display:inline-block;box-shadow:0 0 12px rgba(184,116,74,0.6);animation:pulse-dot 3s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 12px rgba(184,116,74,0.6);transform:scale(1)}50%{box-shadow:0 0 20px rgba(184,116,74,0.9);transform:scale(1.15)}}
.nav-links{display:flex;gap:30px;flex-wrap:wrap;font-size:15px}
.nav-links a{color:var(--ink-2);font-weight:500;position:relative;padding:4px 0}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--copper);transform:scaleX(0);transform-origin:left;transition:transform 0.3s var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-links a.active{color:var(--ink)}

/* CTA buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 24px;border-radius:980px;font-weight:600;font-size:15px;letter-spacing:-0.005em;border:none;cursor:pointer;transition:transform 0.3s var(--ease),box-shadow 0.35s ease,background 0.25s ease;line-height:1;white-space:nowrap;position:relative;overflow:hidden}
.btn-primary{background:var(--ink);color:var(--bg)}
.btn-primary:hover{background:var(--copper-deep);color:#fff;transform:translateY(-2px);box-shadow:0 16px 32px -10px rgba(139,85,50,0.45)}
.btn-secondary{background:transparent;color:var(--ink);border:1px solid var(--ink-4)}
.btn-secondary:hover{border-color:var(--ink);background:var(--surface);transform:translateY(-1px)}
.btn-copper{background:var(--copper);color:#fff}
.btn-copper:hover{background:var(--copper-deep);transform:translateY(-2px);box-shadow:0 16px 32px -10px rgba(139,85,50,0.45);color:#fff}
.btn-arrow::after{content:'→';font-size:17px;transition:transform 0.3s var(--ease)}
.btn-arrow:hover::after{transform:translateX(6px)}

/* Sticky mobile CTA */
.mobile-cta{display:none}
@media(max-width:880px){
  .mobile-cta{display:flex;position:fixed;bottom:16px;left:16px;right:16px;z-index:90;justify-content:center}
  .mobile-cta a{flex:1;text-align:center;justify-content:center;box-shadow:0 12px 32px -8px rgba(26,22,20,0.25)}
  body{padding-bottom:80px}
}

/* ─────────── Hero ─────────── */
.hero{max-width:var(--max);margin:0 auto;padding:100px 28px 80px;position:relative}
.hero-grid{display:grid;grid-template-columns:1fr;gap:60px;position:relative;z-index:2}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:13px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-2);margin-bottom:28px}
.eyebrow .marker{width:24px;height:1px;background:var(--copper);display:inline-block}
h1{font-family:var(--font-display);font-size:clamp(44px,7vw,96px);font-weight:600;line-height:1.02;letter-spacing:-0.035em;color:var(--ink);margin-bottom:28px}
h1 em{font-style:normal;color:var(--copper);font-weight:600;position:relative}
h1 em::after{content:'';position:absolute;bottom:0.05em;left:0;right:0;height:0.06em;background:var(--copper);opacity:0.25}
.lead{font-size:clamp(17px,1.7vw,21px);color:var(--ink-2);max-width:640px;line-height:1.55;margin-bottom:40px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}

/* Hero мини-bullets под heading */
.hero-bullets{display:flex;gap:24px;flex-wrap:wrap;margin-top:32px;font-size:14px;color:var(--ink-3)}
.hero-bullet{display:inline-flex;align-items:center;gap:8px}
.hero-bullet svg{width:16px;height:16px;color:var(--copper);flex-shrink:0}

/* Decorative crescent in hero */
.hero-crescent{position:absolute;top:80px;right:5%;width:160px;height:160px;opacity:0.08;color:var(--copper);pointer-events:none;animation:slow-rotate 60s linear infinite}
@keyframes slow-rotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* Counter (большие цифры) */
.counter{margin-top:90px;padding:60px 0;border-top:1px dashed var(--ink-4);border-bottom:1px dashed var(--ink-4);display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:50px;align-items:end;position:relative}
.counter-cell{position:relative}
.counter-cell::after{content:'';position:absolute;left:0;bottom:-2px;width:24px;height:1px;background:var(--copper)}
.counter-num{font-family:var(--font-display);font-weight:600;font-size:clamp(48px,6vw,84px);line-height:1;letter-spacing:-0.04em;color:var(--ink);margin-bottom:14px;font-variant-numeric:tabular-nums}
.counter-num .unit{font-size:0.5em;color:var(--copper);font-weight:500;margin-left:0.1em}
.counter-lbl{font-size:14px;color:var(--ink-3);font-weight:500;letter-spacing:0.01em;line-height:1.5;max-width:220px}

/* Page hero (subpages) */
.page-hero{max-width:var(--max);margin:0 auto;padding:80px 28px 50px;position:relative}
.page-hero h1{font-size:clamp(36px,5.5vw,72px);margin-bottom:20px}
.page-hero p.lead{font-size:19px;max-width:680px}

/* ─────────── Sections ─────────── */
.section{max-width:var(--max);margin:0 auto;padding:90px 28px;position:relative}
.section-head{margin-bottom:56px;max-width:760px}
.section-num{font-size:13px;color:var(--copper);letter-spacing:0.1em;text-transform:uppercase;font-weight:600;margin-bottom:16px;display:inline-flex;align-items:center;gap:10px}
.section-num::before{content:'';width:14px;height:1px;background:var(--copper);display:inline-block}
.section-title{font-family:var(--font-display);font-size:clamp(32px,4.2vw,52px);font-weight:600;line-height:1.05;letter-spacing:-0.025em;margin-bottom:18px;color:var(--ink)}
.section-sub{font-size:18px;color:var(--ink-2);max-width:620px;line-height:1.55}

/* ─────────── Campaign cards ─────────── */
.campaigns-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:22px}
.campaign-card{background:var(--bg-warm);border:1px solid var(--line);border-radius:24px;overflow:hidden;display:flex;flex-direction:column;transition:transform 0.4s var(--ease),box-shadow 0.4s ease,border-color 0.4s ease;box-shadow:0 1px 0 rgba(26,22,20,0.04),0 4px 16px -8px rgba(26,22,20,0.06)}
.campaign-card:hover{transform:translateY(-6px) rotate(-0.2deg);box-shadow:0 30px 60px -16px rgba(26,22,20,0.18);border-color:var(--copper-glow)}
.cc-cover{height:200px;position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:24px;transition:background-position 0.6s ease}
.cc-cover.cover-medicines{background:linear-gradient(135deg,#D8C5B6 0%,#B89876 100%)}
.cc-cover.cover-food{background:linear-gradient(135deg,#E5D4BA 0%,#C9A876 100%)}
.cc-cover.cover-utility{background:linear-gradient(135deg,#D4C5B8 0%,#A88B70 100%)}
.cc-cover.cover-education{background:linear-gradient(135deg,#E3D8C8 0%,#B89A78 100%)}
.cc-cover.cover-closed{background:linear-gradient(135deg,#C8C0B5 0%,#8E8579 100%);opacity:0.85}
.cc-cover::before{content:'';position:absolute;top:-50%;right:-30%;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,0.18);filter:blur(50px);transition:transform 0.8s ease}
.campaign-card:hover .cc-cover::before{transform:scale(1.2) translate(-10%,10%)}
.cc-cover::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 70%,rgba(0,0,0,0.06),transparent 50%);pointer-events:none}
.cc-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:rgba(255,255,255,0.92);backdrop-filter:blur(8px);border-radius:980px;font-size:12px;font-weight:600;letter-spacing:0.02em;color:var(--ink);position:relative;z-index:1}
.cc-tag.urgent{background:var(--red-alert);color:#fff;animation:pulse-urgent 2s ease-in-out infinite}
@keyframes pulse-urgent{0%,100%{box-shadow:0 0 0 0 rgba(179,58,58,0.5)}50%{box-shadow:0 0 0 8px rgba(179,58,58,0)}}
.cc-tag.closed-tag{background:rgba(255,255,255,0.9);color:var(--green-soft)}
.cc-body{padding:28px;display:flex;flex-direction:column;flex:1;gap:16px}
.cc-title{font-family:var(--font-display);font-size:22px;font-weight:600;line-height:1.25;letter-spacing:-0.015em;color:var(--ink)}
.cc-desc{font-size:15px;color:var(--ink-2);line-height:1.6;flex:1}
.cc-progress{margin-top:10px}
.cc-progress-bar{height:6px;background:var(--ink-4);border-radius:980px;overflow:hidden;margin-bottom:12px;position:relative}
.cc-progress-fill{height:100%;background-image:repeating-linear-gradient(45deg,var(--copper),var(--copper) 4px,var(--copper-deep) 4px,var(--copper-deep) 8px);background-size:200% 100%;border-radius:980px;transition:width 0.8s var(--ease);animation:progress-shift 4s linear infinite}
@keyframes progress-shift{0%{background-position:0% 0}100%{background-position:200% 0}}
.cc-progress-text{display:flex;justify-content:space-between;font-size:13px;color:var(--ink-3);font-weight:500}
.cc-progress-text strong{color:var(--ink);font-weight:600}
.cc-action{margin-top:8px;padding:14px 20px;background:var(--ink);color:var(--bg);border-radius:14px;text-align:center;font-weight:600;font-size:14px;letter-spacing:-0.005em;transition:all 0.3s var(--ease);display:flex;align-items:center;justify-content:center;gap:8px}
.cc-action:hover{background:var(--copper-deep);color:#fff;letter-spacing:0.01em}
.cc-action::after{content:'→';transition:transform 0.3s var(--ease)}
.cc-action:hover::after{transform:translateX(6px)}

/* ─────────── Process steps (Что мы делаем) ─────────── */
.steps{max-width:var(--max);margin:0 auto;padding:0 28px;position:relative}
.steps::before{content:'';position:absolute;left:60px;top:60px;bottom:60px;width:1px;background-image:radial-gradient(circle,var(--copper-glow) 1px,transparent 1px);background-size:1px 8px}
.step{display:grid;grid-template-columns:160px 1fr;gap:48px;padding:56px 0;border-bottom:1px dashed var(--ink-4);align-items:start;position:relative}
.step:last-child{border-bottom:0}
.step-num{font-family:var(--font-display);font-size:120px;font-weight:200;line-height:0.9;color:transparent;-webkit-text-stroke:1.5px var(--copper);letter-spacing:-0.04em;margin-top:-12px;font-variant-numeric:tabular-nums}
.step-title{font-family:var(--font-display);font-size:32px;font-weight:600;letter-spacing:-0.02em;margin-bottom:14px;line-height:1.15}
.step-desc{font-size:17px;color:var(--ink-2);line-height:1.65;max-width:640px}
.step-meta{margin-top:20px;display:flex;gap:24px;flex-wrap:wrap;font-size:14px;color:var(--ink-3)}
.step-meta span{display:inline-flex;align-items:center;gap:8px}
.step-meta .dot{width:5px;height:5px;border-radius:50%;background:var(--copper);display:inline-block}

/* ─────────── Stories timeline ─────────── */
.timeline{max-width:var(--max-narrow);margin:0 auto;padding:0 28px;position:relative}
.timeline::before{content:'';position:absolute;left:104px;top:0;bottom:0;width:1px;background-image:radial-gradient(circle,var(--copper-glow) 2px,transparent 2px);background-size:1px 12px}
.timeline-item{display:grid;grid-template-columns:160px 1fr;gap:40px;padding:48px 0;align-items:start;position:relative}
.timeline-item::after{content:'';position:absolute;left:96px;top:54px;width:18px;height:18px;border-radius:50%;background:var(--bg);border:2px solid var(--copper);z-index:2;box-shadow:0 0 0 6px var(--bg)}
.timeline-year{font-family:var(--font-display);font-size:64px;font-weight:200;letter-spacing:-0.03em;color:var(--copper);position:relative;font-variant-numeric:tabular-nums;line-height:0.9}
.timeline-card{background:var(--bg-warm);border:1px solid var(--line);border-radius:24px;padding:36px;position:relative;transition:transform 0.4s var(--ease),box-shadow 0.4s ease;box-shadow:0 1px 0 rgba(26,22,20,0.04),0 4px 16px -8px rgba(26,22,20,0.06);overflow:hidden}
.timeline-card::before{content:attr(data-watermark);position:absolute;top:-30px;right:-10px;font-family:var(--font-display);font-size:200px;font-weight:200;color:var(--ink);opacity:0.04;letter-spacing:-0.04em;line-height:1;pointer-events:none}
.timeline-card:hover{transform:translateY(-3px);box-shadow:0 20px 40px -16px rgba(26,22,20,0.12)}
.timeline-card h3{font-family:var(--font-display);font-size:24px;font-weight:600;letter-spacing:-0.015em;margin-bottom:14px;line-height:1.25;position:relative;z-index:1}
.timeline-card p{font-size:16px;color:var(--ink-2);line-height:1.65;position:relative;z-index:1}
.timeline-card .meta{margin-top:22px;display:flex;gap:20px;flex-wrap:wrap;font-size:13px;color:var(--ink-3);padding-top:20px;border-top:1px dashed var(--line);position:relative;z-index:1}
.timeline-card .meta strong{color:var(--ink);font-weight:600}

/* ─────────── Give cards ─────────── */
.give-grid{max-width:var(--max);margin:0 auto;padding:0 28px;display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.give-card{background:var(--bg-warm);border:1px solid var(--line);border-radius:28px;padding:48px 40px;cursor:pointer;transition:all 0.5s var(--ease);position:relative;overflow:hidden;min-height:300px;display:flex;flex-direction:column;box-shadow:0 1px 0 rgba(26,22,20,0.04),0 4px 16px -8px rgba(26,22,20,0.06)}
.give-card:hover{transform:translateY(-4px);box-shadow:0 30px 60px -16px rgba(26,22,20,0.15);border-color:var(--copper-glow)}
.give-card.expanded{grid-column:1/-1;background:var(--ink);color:var(--bg);border-color:var(--ink);box-shadow:0 40px 80px -20px rgba(26,22,20,0.4)}
.give-card.expanded .gc-icon,.give-card.expanded .gc-title,.give-card.expanded .gc-sub{color:var(--bg)}

/* Индивидуальные акценты */
.give-card[data-card="onetime"]{}
.give-card[data-card="recurring"]::after{content:'';position:absolute;top:24px;left:24px;width:8px;height:8px;border-radius:50%;background:var(--copper);animation:pulse-dot 2s ease-in-out infinite;z-index:5}
.give-card[data-card="zakat"]{border-top:3px solid var(--copper)}
.give-card[data-card="major"]{background-image:radial-gradient(circle,rgba(184,116,74,0.05) 1px,transparent 1px);background-size:12px 12px;background-position:0 0;background-color:var(--bg-warm)}

.give-card .gc-icon{width:64px;height:64px;border-radius:18px;background:rgba(184,116,74,0.12);color:var(--copper);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:600;font-size:26px;margin-bottom:28px;letter-spacing:-0.02em;transition:all 0.5s var(--ease)}
.give-card:hover .gc-icon{transform:rotate(-6deg) scale(1.05);filter:drop-shadow(0 0 16px rgba(184,116,74,0.4))}
.give-card.expanded .gc-icon{background:rgba(248,244,237,0.1);color:var(--copper-soft);transform:rotate(6deg) scale(1.08)}
.give-card .gc-title{font-family:var(--font-display);font-size:30px;font-weight:600;letter-spacing:-0.02em;line-height:1.15;margin-bottom:14px;color:var(--ink);position:relative;z-index:1}
.give-card .gc-sub{font-size:16px;color:var(--ink-2);line-height:1.55;flex:1;position:relative;z-index:1}
.give-card.expanded .gc-sub{color:rgba(248,244,237,0.7)}
.gc-arrow{position:absolute;top:32px;right:32px;width:42px;height:42px;border-radius:50%;border:1px solid var(--ink-4);display:flex;align-items:center;justify-content:center;color:var(--ink-2);transition:all 0.4s var(--ease);font-size:14px}
.give-card:hover .gc-arrow{border-color:var(--copper);color:var(--copper);transform:rotate(-45deg) scale(1.05)}
.give-card.expanded .gc-arrow{transform:rotate(45deg);border-color:var(--copper-soft);color:var(--copper-soft)}

.gc-options{margin-top:36px;padding-top:36px;border-top:1px solid rgba(248,244,237,0.15);display:none;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.give-card.expanded .gc-options{display:grid;animation:fadeUp 0.6s var(--ease) 0.2s both}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.gc-option{background:rgba(248,244,237,0.05);border:1px solid rgba(248,244,237,0.1);border-radius:18px;padding:24px;transition:all 0.3s var(--ease);cursor:pointer;color:var(--bg)}
.gc-option:hover{background:rgba(184,116,74,0.18);border-color:var(--copper);transform:translateY(-2px)}
.gc-option-amount{font-family:var(--font-display);font-size:24px;font-weight:600;letter-spacing:-0.015em;margin-bottom:6px;font-variant-numeric:tabular-nums}
.gc-option-desc{font-size:14px;color:rgba(248,244,237,0.65);line-height:1.5}

/* ─────────── Trust strip ─────────── */
.trust-strip{max-width:var(--max);margin:0 auto;padding:80px 28px;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:40px;position:relative}
.trust-cell{padding:0 0 0 24px;border-left:2px solid var(--copper);transition:transform 0.3s var(--ease),padding-left 0.3s var(--ease)}
.trust-cell:hover{transform:translateY(-2px);padding-left:30px}
.trust-cell h4{font-family:var(--font-display);font-size:22px;font-weight:600;letter-spacing:-0.015em;margin-bottom:10px;color:var(--ink)}
.trust-cell p{font-size:15px;color:var(--ink-2);line-height:1.6}

/* ─────────── Form ─────────── */
.form-card{background:var(--bg-warm);border:1px solid var(--line);border-radius:28px;padding:56px 48px;max-width:var(--max-narrow);margin:0 auto;position:relative;box-shadow:0 1px 0 rgba(26,22,20,0.04),0 24px 48px -16px rgba(26,22,20,0.08)}
.form-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--copper),var(--copper-deep));border-radius:28px 28px 0 0}
.form-meta-top{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-3);margin-bottom:32px;text-transform:uppercase;letter-spacing:0.05em;font-weight:600}
.form-meta-top::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--copper);box-shadow:0 0 8px rgba(184,116,74,0.5)}
.form-progress{height:2px;background:var(--ink-4);border-radius:980px;overflow:hidden;margin:0 0 36px 0}
.form-progress-fill{height:100%;background:var(--copper);border-radius:980px;width:0%;transition:width 0.4s var(--ease)}
.form-progress-meta{display:flex;justify-content:space-between;font-size:13px;color:var(--ink-3);margin-bottom:32px;font-variant-numeric:tabular-nums}
.form-row{margin-bottom:36px}
.form-row label{display:flex;align-items:baseline;gap:10px;font-size:15px;font-weight:600;color:var(--ink);margin-bottom:6px;letter-spacing:-0.005em}
.form-row label .num{color:var(--copper);font-weight:700;font-variant-numeric:tabular-nums;font-size:13px}
.form-row .hint{font-size:14px;color:var(--ink-3);margin-bottom:14px;line-height:1.5}
.form-row input,.form-row textarea,.form-row select{width:100%;background:transparent;border:none;border-bottom:1.5px solid var(--ink-4);border-radius:0;padding:12px 0;color:var(--ink);font-family:inherit;font-size:17px;transition:border-color 0.3s ease}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{outline:none;border-bottom-color:var(--copper)}
.form-row textarea{min-height:100px;resize:vertical;border:1.5px solid var(--ink-4);border-radius:14px;padding:14px 18px;background:var(--bg)}
.form-row textarea:focus{border-color:var(--copper)}
.chip-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.chip{padding:9px 18px;background:var(--bg);border:1px solid var(--ink-4);border-radius:980px;color:var(--ink-2);font-size:14px;font-weight:500;cursor:pointer;transition:all 0.25s var(--ease)}
.chip:hover{border-color:var(--copper);color:var(--copper);transform:translateY(-1px)}
.chip.active{background:var(--ink);color:var(--bg);border-color:var(--ink);position:relative;padding-left:30px}
.chip.active::before{content:'';position:absolute;left:14px;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background:var(--copper)}
.form-submit{width:100%;padding:18px 24px;background:var(--ink);color:var(--bg);border:none;border-radius:16px;font-weight:600;font-size:16px;letter-spacing:-0.005em;cursor:pointer;transition:all 0.35s var(--ease);margin-top:14px;display:inline-flex;align-items:center;justify-content:center;gap:10px}
.form-submit::after{content:'→';transition:transform 0.3s var(--ease)}
.form-submit:hover{background:var(--copper-deep);transform:translateY(-2px);box-shadow:0 16px 32px -8px rgba(139,85,50,0.45)}
.form-submit:hover::after{transform:translateX(6px)}

/* ─────────── Reports ─────────── */
.reports-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:24px;max-width:var(--max);margin:0 auto;padding:0 28px}
.report-card{background:var(--bg-warm);border:1px solid var(--line);border-top:4px solid var(--copper);border-radius:20px;padding:40px 36px;display:flex;flex-direction:column;gap:18px;transition:transform 0.4s var(--ease),box-shadow 0.4s ease;position:relative;box-shadow:0 1px 0 rgba(26,22,20,0.04),0 8px 24px -12px rgba(26,22,20,0.06)}
.report-card:hover{transform:translateY(-4px);box-shadow:0 30px 60px -16px rgba(26,22,20,0.12)}
.report-card::after{content:'';position:absolute;top:24px;right:24px;width:48px;height:48px;border:1.5px solid var(--copper);border-radius:50%;opacity:0.25;background-image:radial-gradient(circle,var(--copper) 1px,transparent 1px);background-size:6px 6px}
.report-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:rgba(92,122,107,0.1);color:var(--green-soft);border-radius:980px;font-size:12px;font-weight:600;letter-spacing:0.05em;align-self:flex-start;text-transform:uppercase}
.report-card h3{font-family:var(--font-display);font-size:26px;font-weight:600;line-height:1.2;letter-spacing:-0.02em;color:var(--ink)}
.report-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:24px 0;border-top:1px dashed var(--ink-4);border-bottom:1px dashed var(--ink-4);margin:6px 0}
.report-stat{display:flex;flex-direction:column;gap:4px}
.report-stat-num{font-family:var(--font-display);font-size:26px;font-weight:600;letter-spacing:-0.02em;color:var(--ink);font-variant-numeric:tabular-nums}
.report-stat-lbl{font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:0.06em}
.report-card p{font-size:15px;color:var(--ink-2);line-height:1.6}

/* Структура расходов */
.expenses-block{background:var(--bg-warm);border:1px solid var(--line);border-radius:24px;padding:48px;max-width:var(--max-narrow);margin:60px auto;box-shadow:0 1px 0 rgba(26,22,20,0.04),0 8px 24px -12px rgba(26,22,20,0.06)}
.expense-row{display:grid;grid-template-columns:200px 1fr 80px;gap:24px;padding:20px 0;border-bottom:1px dashed var(--ink-4);align-items:center}
.expense-row:last-child{border-bottom:0}
.expense-pct{font-family:var(--font-display);font-size:32px;font-weight:600;color:var(--copper);letter-spacing:-0.02em;font-variant-numeric:tabular-nums}
.expense-bar{height:4px;background:var(--ink-4);border-radius:980px;overflow:hidden}
.expense-bar-fill{height:100%;background:var(--copper);border-radius:980px}
.expense-lbl{font-weight:600;font-size:16px;color:var(--ink)}
.expense-desc{font-size:13px;color:var(--ink-3);margin-top:4px}

/* ─────────── About story blocks ─────────── */
.story-block{background:var(--bg-warm);border:1px solid var(--line);border-radius:28px;padding:48px 44px;margin-bottom:24px;max-width:var(--max-narrow);margin-left:auto;margin-right:auto;position:relative;box-shadow:0 1px 0 rgba(26,22,20,0.04),0 8px 24px -12px rgba(26,22,20,0.06)}
.story-block h3{font-family:var(--font-display);font-size:30px;font-weight:600;letter-spacing:-0.02em;margin-bottom:20px;line-height:1.2;display:flex;align-items:center;gap:18px}
.story-block h3::before{content:'';flex-shrink:0;width:48px;height:1px;background:var(--copper)}
.story-block p{font-size:17px;color:var(--ink-2);line-height:1.7;margin-bottom:14px}
.story-block p:last-child{margin-bottom:0}
.story-block strong{color:var(--ink);font-weight:600}

.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px;max-width:var(--max);margin:0 auto;padding:0 28px}
.value-card{background:var(--bg-warm);border:1px solid var(--line);border-radius:20px;padding:36px 32px;transition:all 0.4s var(--ease);position:relative;overflow:hidden;box-shadow:0 1px 0 rgba(26,22,20,0.04),0 4px 16px -8px rgba(26,22,20,0.04)}
.value-card::before{content:'';position:absolute;top:24px;right:24px;width:24px;height:24px;background-image:radial-gradient(circle,var(--copper) 1px,transparent 1px);background-size:6px 6px;opacity:0.3}
.value-card:hover{transform:translateY(-4px);border-color:var(--copper-glow);box-shadow:0 20px 40px -16px rgba(26,22,20,0.1)}
.value-card .v-icon{width:48px;height:48px;border-radius:14px;background:rgba(184,116,74,0.1);color:var(--copper);display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:all 0.4s var(--ease)}
.value-card:hover .v-icon{transform:rotate(-4deg) scale(1.1);background:var(--copper);color:var(--bg)}
.value-card .v-icon svg{width:24px;height:24px}
.value-card h4{font-family:var(--font-display);font-size:21px;font-weight:600;letter-spacing:-0.015em;color:var(--ink);margin-bottom:12px}
.value-card p{font-size:15px;color:var(--ink-2);line-height:1.6}

/* ─────────── CTA banner ─────────── */
.cta-banner{background:var(--ink);color:var(--bg);border-radius:32px;padding:80px 56px;text-align:center;margin:80px auto;max-width:calc(var(--max) - 56px);position:relative;overflow:hidden}
.cta-banner::before{content:'';position:absolute;top:-50%;right:-20%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(184,116,74,0.15),transparent 70%);filter:blur(60px);pointer-events:none}
.cta-banner > *{position:relative;z-index:1}
.cta-banner h2{font-family:var(--font-display);font-size:clamp(32px,4.5vw,56px);font-weight:600;letter-spacing:-0.025em;line-height:1.05;margin-bottom:20px;color:var(--bg)}
.cta-banner h2 em{color:var(--copper-soft);font-style:normal}
.cta-banner p{font-size:18px;color:rgba(248,244,237,0.65);max-width:560px;margin:0 auto 36px;line-height:1.55}
.cta-banner .btn-copper{padding:16px 32px;font-size:16px}

/* ─────────── Footer ─────────── */
footer{margin-top:120px;padding:60px 28px 40px;border-top:1px solid var(--line);background:var(--bg-alt);position:relative}
footer::before{content:'';position:absolute;top:-1px;left:50%;transform:translateX(-50%);width:160px;height:1px;background-image:radial-gradient(circle,var(--copper) 1.5px,transparent 1.5px);background-size:8px 1px;background-repeat:repeat-x}
.footer-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand-block{display:flex;flex-direction:column;gap:18px}
.footer-brand{font-family:var(--font-display);font-weight:700;font-size:24px;letter-spacing:-0.015em;color:var(--ink);display:flex;align-items:center;gap:10px}
.footer-brand .dot{width:10px;height:10px;border-radius:50%;background:var(--copper)}
.footer-tag{font-size:14px;color:var(--ink-3);max-width:300px;line-height:1.65}
.footer-region{margin-top:8px;display:flex;align-items:center;gap:10px;font-size:12px;color:var(--ink-3);letter-spacing:0.04em;text-transform:uppercase}
.footer-region svg{width:16px;height:16px;color:var(--copper)}
.footer-col h5{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:14px;letter-spacing:0.04em;text-transform:uppercase}
.footer-col a{display:block;font-size:14px;color:var(--ink-2);padding:5px 0;font-weight:500;transition:padding-left 0.2s ease,color 0.2s ease}
.footer-col a:hover{color:var(--copper);padding-left:6px}
.footer-bottom{max-width:var(--max);margin:0 auto;padding-top:32px;border-top:1px solid var(--line);font-size:13px;color:var(--ink-3);display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;align-items:center}

/* ─────────── Responsive ─────────── */
@media(max-width:880px){
  .nav-inner{padding:14px 20px}
  .nav-links{display:none}
  .hero{padding:60px 22px 50px}
  .hero-crescent{display:none}
  .counter{margin-top:60px;padding:40px 0;gap:36px}
  .section{padding:60px 22px}
  .page-hero{padding:50px 22px 30px}
  .step{grid-template-columns:1fr;gap:14px;padding:40px 0}
  .step-num{font-size:80px}
  .steps::before{display:none}
  .timeline::before{left:30px}
  .timeline-item{grid-template-columns:80px 1fr;gap:24px}
  .timeline-item::after{left:18px;top:36px}
  .timeline-year{font-size:32px}
  .timeline-card{padding:24px}
  .timeline-card::before{font-size:140px;right:-20px;top:-20px}
  .give-grid{grid-template-columns:1fr;padding:0 22px;gap:16px}
  .give-card{padding:36px 28px;min-height:auto}
  .form-card{padding:36px 24px;border-radius:20px}
  .cta-banner{padding:50px 32px;border-radius:24px;margin:50px 22px}
  .footer-inner{grid-template-columns:1fr 1fr;gap:32px}
  .reports-grid{padding:0 22px}
  .expense-row{grid-template-columns:80px 1fr;gap:14px}
  .expense-bar{display:none}
}
@media(max-width:520px){
  .footer-inner{grid-template-columns:1fr}
  .gc-arrow{top:24px;right:24px;width:36px;height:36px}
  h1{font-size:42px}
  .timeline-card::before{display:none}
}
