/* ═══════════════════════════════════════════════════════════════
   Your Help UA — shared design system (Inter-only)
   Used by: index, about, program, volunteer, testimonials,
            donate, partners, faq, contacts, oferta, privacy-policy
═══════════════════════════════════════════════════════════════ */

/* ─── TOKENS ─────────────────────────────────────────────────── */
:root{
  --primary:#5080E0; --primary-deep:#3E68BE; --primary-darker:#2E4F95;
  --primary-soft:#E8EEFC; --primary-softer:#F5F8FE; --primary-tint:#B8CAF0;
  --accent:#FFC91E; --accent-deep:#E0AB00; --accent-soft:#FFF4D1;
  --ink:#14171C; --ink-soft:#4B5161; --ink-softer:#7A8196;
  --line:#E9EBF0; --cream:#F7F8FB; --muted:#EEF0F5; --bg:#FFFFFF;
  --radius-sm:10px; --radius-md:14px; --radius-lg:22px; --radius-xl:28px;
  --ease:cubic-bezier(.2,.8,.2,1);
}

/* ─── RESET / BASE ───────────────────────────────────────────── */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
  color:var(--ink); background:var(--bg);
  font-size:17px; line-height:1.65; font-weight:400;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:clip;
  font-feature-settings:"cv11","ss01","ss03";
}
img{ max-width:100%; height:auto; display:block; }
figure{ margin:0; }
blockquote{ margin:0; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:0; background:none; color:inherit; }
:focus-visible{ outline:3px solid rgba(80,128,224,.5); outline-offset:3px; border-radius:6px; }

.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* ─── TYPOGRAPHY — INTER ONLY ────────────────────────────────── */
h1,h2,h3,h4{ font-family:'Inter',sans-serif; color:var(--ink); margin:0; }
h1{ font-size:clamp(2.4rem,5.8vw,4.4rem); line-height:1.02; letter-spacing:-.038em; font-weight:800; }
h2{ font-size:clamp(1.9rem,3.8vw,2.9rem); line-height:1.08; letter-spacing:-.028em; font-weight:700; }
h3{ font-size:clamp(1.3rem,2.1vw,1.65rem); line-height:1.22; letter-spacing:-.02em; font-weight:600; }
h4{ font-size:clamp(1.05rem,1.4vw,1.18rem); line-height:1.3; font-weight:600; letter-spacing:-.012em; }
p{ margin:0; }
em{ font-style:italic; }
.kicker{ font-style:italic; font-weight:600; color:var(--primary-deep); }

.eyebrow{
  font-family:'Inter',sans-serif; font-weight:600; font-size:11.5px; line-height:1;
  letter-spacing:.14em; text-transform:uppercase; color:var(--primary-deep);
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{ content:""; width:28px; height:1px; background:var(--primary-deep); display:inline-block; }
.eyebrow.is-accent{ color:var(--accent-deep); }
.eyebrow.is-accent::before{ background:var(--accent-deep); }
.eyebrow.is-light{ color:var(--accent); }
.eyebrow.is-light::before{ background:var(--accent); }

.lead{ font-size:clamp(1.08rem,1.3vw,1.22rem); line-height:1.6; color:var(--ink-soft); font-weight:400; letter-spacing:-.005em; }
.divider-dot{ color:var(--accent); font-weight:700; margin:0 6px; }

.hl-accent{
  background-image:linear-gradient(transparent 68%, rgba(255,201,30,.5) 68%);
  padding:0 2px;
}

/* ─── LAYOUT ─────────────────────────────────────────────────── */
.wrap{ max-width:1320px; margin:0 auto; padding:0 clamp(20px,4vw,40px); }
.wrap-narrow{ max-width:980px; margin:0 auto; padding:0 clamp(20px,4vw,40px); }
section{ padding:clamp(72px,11vw,136px) 0; position:relative; }

/* ─── BUTTONS ────────────────────────────────────────────────── */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:16px 26px; min-height:52px;
  font-size:15px; font-weight:600; letter-spacing:-.005em;
  border-radius:12px; white-space:nowrap; line-height:1; cursor:pointer;
  transition:all .3s var(--ease); will-change:transform;
}
.btn svg{ width:18px; height:18px; stroke-width:2; }
.btn-primary{ background:var(--primary); color:#fff; box-shadow:0 6px 18px -4px rgba(80,128,224,.45); }
.btn-primary:hover{ background:var(--primary-deep); transform:translateY(-2px); box-shadow:0 14px 32px -8px rgba(80,128,224,.55); }
.btn-primary:active{ transform:translateY(1px) scale(.985); box-shadow:0 4px 10px -2px rgba(80,128,224,.35), inset 0 2px 3px rgba(0,0,0,.12); }
.btn-accent{ background:var(--accent); color:#3E2E00; box-shadow:0 6px 18px -4px rgba(255,201,30,.55); }
.btn-accent:hover{ background:var(--accent-deep); color:#1A1300; transform:translateY(-2px); box-shadow:0 14px 32px -8px rgba(255,201,30,.55); }
.btn-accent:active{ transform:translateY(1px) scale(.985); }
.btn-ghost{ background:transparent; color:var(--ink); box-shadow:inset 0 0 0 1.5px var(--line); }
.btn-ghost:hover{ box-shadow:inset 0 0 0 1.5px var(--primary); color:var(--primary-deep); transform:translateY(-2px); }
.btn-ghost:active{ transform:translateY(1px) scale(.985); }
.btn-ghost-light{ background:transparent; color:#fff; box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.3); }
.btn-ghost-light:hover{ background:rgba(255,255,255,.08); box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.7); transform:translateY(-2px); }
.btn-small{ padding:11px 18px; min-height:40px; font-size:13.5px; border-radius:10px; }
.btn-large{ padding:19px 34px; min-height:60px; font-size:16px; border-radius:14px; }
.btn-pill{ border-radius:999px; }

/* ─── HEADER ─────────────────────────────────────────────────── */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:50;
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  background:rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.1);
  transition:background .4s var(--ease), border-color .4s var(--ease);
}
.site-header.on-light{ background:rgba(255,255,255,.92); border-bottom-color:var(--line); }
.site-header.on-light .nav-links a{ color:var(--ink-soft); }
.site-header.on-light .nav-logo img{ filter:none; }
.site-header.on-light .btn-ghost{ color:var(--ink); box-shadow:inset 0 0 0 1.5px var(--line); }
.site-header.on-light .hamburger{ background:var(--primary-softer); color:var(--primary-deep); }
.site-header.is-scrolled{ background:rgba(255,255,255,.94); border-bottom-color:var(--line); }
.site-header.is-scrolled .nav-links a{ color:var(--ink-soft); }
.site-header.is-scrolled .nav-logo img{ filter:none; }
.site-header.is-scrolled .btn-ghost{ color:var(--ink); box-shadow:inset 0 0 0 1.5px var(--line); }
.site-header.is-scrolled .hamburger{ background:var(--primary-softer); color:var(--primary-deep); }

.nav{ display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:32px; }
.nav-logo{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
.nav-logo img{ height:38px; width:auto; filter:brightness(0) invert(1); transition:filter .4s var(--ease); }
.nav-links{ display:flex; align-items:center; gap:2px; }
.nav-links a{
  padding:10px 14px; border-radius:10px; font-size:14.5px; font-weight:500;
  color:rgba(255,255,255,.9); transition:all .2s var(--ease);
}
.nav-links a:hover, .nav-links a.is-active{ color:#fff; background:rgba(255,255,255,.12); }
.site-header.on-light .nav-links a:hover,
.site-header.on-light .nav-links a.is-active,
.site-header.is-scrolled .nav-links a:hover,
.site-header.is-scrolled .nav-links a.is-active{ color:var(--primary-deep); background:var(--primary-softer); }
.nav-cta{ display:flex; align-items:center; gap:10px; }
.nav-cta .btn-ghost{ color:#fff; box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.3); }
.hamburger{ display:none; width:42px; height:42px; border-radius:10px; background:rgba(255,255,255,.14); color:#fff; align-items:center; justify-content:center; }
@media (max-width:1050px){
  .nav-links{ display:none; }
  .hamburger{ display:flex; }
  .nav-cta .btn-ghost{ display:none; }
}

.mobile-menu{
  position:fixed; inset:66px 0 0 0; z-index:49;
  background:#fff; padding:28px 20px; display:none; flex-direction:column; gap:4px;
  border-top:1px solid var(--line);
  overflow-y:auto;
}
.mobile-menu.is-open{ display:flex; }
.mobile-menu a{ padding:14px 16px; font-size:17px; font-weight:500; border-radius:10px; color:var(--ink); }
.mobile-menu a:hover, .mobile-menu a.is-active{ background:var(--primary-softer); color:var(--primary-deep); }

/* ─── HERO (home) — EDITORIAL MOSAIC ─────────────────────────── */
.hero{
  padding:clamp(130px,16vw,180px) 0 clamp(80px,11vw,140px);
  position:relative; isolation:isolate; overflow:hidden;
  color:#fff;
  background:
    radial-gradient(ellipse 1000px 700px at 10% 10%, rgba(62,104,190,.55), transparent 60%),
    radial-gradient(ellipse 700px 600px at 90% 100%, rgba(255,201,30,.2), transparent 60%),
    linear-gradient(160deg, #1A2847 0%, #2E4F95 50%, #3E68BE 100%);
}
.hero::before{
  content:""; position:absolute; inset:0; z-index:-1; opacity:.08;
  background-image:
    linear-gradient(rgba(255,255,255,.5) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.5) 1px, transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 1000px 600px at 50% 50%, black 10%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 1000px 600px at 50% 50%, black 10%, transparent 80%);
  pointer-events:none;
}
.hero::after{
  content:""; position:absolute; left:-20%; bottom:-30%; z-index:-1;
  width:60%; height:70%;
  background:radial-gradient(circle, rgba(255,201,30,.14), transparent 65%);
  filter:blur(24px); pointer-events:none;
}

.hero-ghost{
  position:absolute; left:-30px; bottom:-80px; z-index:0;
  font-size:clamp(14rem,28vw,28rem); line-height:.72;
  font-weight:900; font-style:italic; color:#fff;
  opacity:.05; letter-spacing:-.08em; font-family:'Inter',sans-serif;
  pointer-events:none; user-select:none; white-space:nowrap;
}
.hero-ghost em{ color:var(--accent); font-style:italic; opacity:.8; }

.hero-grid{
  position:relative; z-index:1;
  display:grid; grid-template-columns:1.12fr 1fr;
  gap:clamp(32px,5vw,72px); align-items:center;
}
@media (max-width:960px){ .hero-grid{ grid-template-columns:1fr; gap:56px; } }

.hero-text{ max-width:780px; }
.hero-text .eyebrow{ color:var(--accent); }
.hero-text .eyebrow::before{ background:var(--accent); }
.hero-text h1{
  font-size:clamp(2.6rem,6.2vw,5rem);
  line-height:.98; letter-spacing:-.042em; font-weight:800;
  color:#fff; margin:26px 0 28px;
  text-wrap:balance; max-width:14ch;
  text-shadow:0 2px 24px rgba(0,0,0,.22);
}
.hero-text h1 .em{ font-style:italic; font-weight:700; color:var(--accent); }
.hero-text h1 .hl{
  position:relative; display:inline-block; padding:0 .08em; white-space:nowrap;
}
.hero-text h1 .hl::before{
  content:""; position:absolute; left:-2px; right:-2px; bottom:.12em; height:.36em;
  background:var(--accent); z-index:-1; border-radius:4px;
  transform:skew(-8deg);
}

.hero-sub{
  max-width:54ch; font-size:clamp(1.06rem,1.4vw,1.22rem);
  color:rgba(255,255,255,.86); line-height:1.6; margin-bottom:36px;
  text-shadow:0 1px 14px rgba(0,0,0,.3);
}
.hero-ctas{ display:flex; flex-wrap:wrap; gap:12px; margin-bottom:48px; }

.hero-proof{
  display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(16px,2.5vw,32px);
  padding-top:32px; border-top:1px solid rgba(255,255,255,.18);
}
@media (max-width:720px){ .hero-proof{ grid-template-columns:repeat(2,1fr); gap:24px; } }
.hero-proof-item{ display:flex; flex-direction:column; gap:6px; }
.hero-proof-num{
  font-weight:800; font-size:clamp(1.6rem,2.6vw,2.25rem);
  line-height:1; letter-spacing:-.035em; color:#fff;
  font-variant-numeric:tabular-nums;
}
.hero-proof-num .accent-dot{ color:var(--accent); }
.hero-proof-label{ font-size:12.5px; color:rgba(255,255,255,.72); letter-spacing:.005em; line-height:1.35; max-width:22ch; }

/* ─── MOSAIC ─── */
.hero-mosaic{
  position:relative;
  aspect-ratio:1/1.04;
  width:100%; max-width:560px;
  margin-left:auto;
}
@media (max-width:960px){ .hero-mosaic{ aspect-ratio:1/.92; max-width:100%; } }
@media (max-width:520px){ .hero-mosaic{ aspect-ratio:1/1; } }

.hm-item{
  position:absolute; border-radius:var(--radius-lg); overflow:hidden;
  background:#1A2847;
  box-shadow:0 28px 60px -18px rgba(0,0,0,.55), 0 4px 14px rgba(0,0,0,.2);
  border:1px solid rgba(255,255,255,.12);
  transition:transform .6s var(--ease);
}
.hm-item img{ width:100%; height:100%; object-fit:cover; }

.hm-main{ top:0; right:0; width:72%; height:68%; z-index:2; transform:rotate(2deg); }
.hm-sm1{ bottom:0; left:0; width:50%; height:46%; z-index:3; transform:rotate(-4deg); }
.hm-sm2{ bottom:10%; right:6%; width:42%; height:38%; z-index:4; transform:rotate(2.5deg); }

@media (max-width:520px){
  .hm-main{ width:82%; height:74%; }
  .hm-sm1{ width:56%; height:48%; }
  .hm-sm2{ display:none; }
}

.hero-mosaic:hover .hm-main{ transform:rotate(0deg) translateY(-4px); }
.hero-mosaic:hover .hm-sm1{ transform:rotate(-1deg) translateY(-4px); }
.hero-mosaic:hover .hm-sm2{ transform:rotate(0deg) translateY(-4px); }
@media (prefers-reduced-motion:reduce){
  .hero-mosaic:hover .hm-main,
  .hero-mosaic:hover .hm-sm1,
  .hero-mosaic:hover .hm-sm2{ transform:none; }
}

.hm-stat{
  position:absolute; top:-4%; left:-4%; z-index:5;
  background:#fff; color:var(--ink);
  padding:16px 20px; border-radius:16px;
  box-shadow:0 18px 40px -10px rgba(0,0,0,.35);
  display:flex; flex-direction:column; gap:2px;
  transform:rotate(-3deg);
  animation:stickerIn 1s var(--ease) both .5s;
}
.hm-stat-num{ font-size:1.85rem; font-weight:800; letter-spacing:-.04em; line-height:1; color:var(--primary-deep); font-variant-numeric:tabular-nums; }
.hm-stat-num .accent{ color:var(--accent-deep); }
.hm-stat-lbl{ font-size:12px; font-weight:500; color:var(--ink-soft); letter-spacing:-.005em; }

.hm-badge{
  position:absolute; top:10%; right:-6%; z-index:5;
  background:var(--accent); color:#2E1E00;
  padding:9px 16px; border-radius:999px;
  font-size:11.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  display:inline-flex; align-items:center; gap:8px;
  box-shadow:0 14px 34px -10px rgba(255,201,30,.55);
  transform:rotate(5deg);
  animation:stickerIn 1.1s var(--ease) both .7s;
}
.hm-badge svg{ width:14px; height:14px; stroke-width:2.5; }

.hm-sticker{
  position:absolute; bottom:-4%; right:-2%; z-index:6;
  background:#fff; padding:16px 20px; border-radius:16px;
  max-width:240px; color:var(--ink);
  box-shadow:0 20px 44px -12px rgba(0,0,0,.4);
  display:flex; align-items:center; gap:14px;
  transform:rotate(-2deg);
  animation:stickerIn 1.2s var(--ease) both .9s;
}
.hm-sticker-icon{
  width:40px; height:40px; border-radius:12px; flex-shrink:0;
  background:var(--accent-soft); color:var(--accent-deep);
  display:flex; align-items:center; justify-content:center;
}
.hm-sticker-body strong{ display:block; font-weight:700; font-size:14px; color:var(--ink); letter-spacing:-.012em; line-height:1.25; margin-bottom:2px; }
.hm-sticker-body span{ font-size:11.5px; color:var(--ink-soft); line-height:1.35; }

@media (max-width:520px){ .hm-stat{ padding:12px 16px; } .hm-stat-num{ font-size:1.5rem; } .hm-sticker{ display:none; } }

@keyframes stickerIn{
  0%{ opacity:0; transform:rotate(-12deg) translateY(20px); }
  100%{ opacity:1; }
}
@media (prefers-reduced-motion:reduce){
  .hm-stat, .hm-badge, .hm-sticker{ animation:none; }
}

/* ─── PAGE HERO (subpages) ───────────────────────────────────── */
.page-hero{
  padding:clamp(160px,20vw,220px) 0 clamp(72px,10vw,120px);
  background:
    radial-gradient(ellipse 900px 500px at 50% 0%, rgba(80,128,224,.16), transparent 70%),
    radial-gradient(ellipse 600px 400px at 85% 40%, rgba(255,201,30,.14), transparent 60%),
    linear-gradient(180deg, var(--primary-softer) 0%, var(--cream) 100%);
  position:relative; overflow:hidden;
}
.page-hero::before{
  content:""; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(80,128,224,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(80,128,224,.05) 1px, transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 900px 500px at 50% 50%, black 20%, transparent 80%);
  pointer-events:none;
}
.page-hero .wrap{ position:relative; z-index:1; }
.page-hero-crumbs{ font-size:13px; font-weight:500; color:var(--ink-soft); margin-bottom:20px; display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.page-hero-crumbs a{ transition:color .2s var(--ease); }
.page-hero-crumbs a:hover{ color:var(--primary-deep); }
.page-hero-crumbs .sep{ color:var(--accent); font-weight:700; }
.page-hero h1{ max-width:18ch; text-wrap:balance; }
.page-hero h1 .em{ font-style:italic; font-weight:800; color:var(--primary-deep); }
.page-hero-sub{ max-width:64ch; margin-top:24px; font-size:clamp(1.1rem,1.5vw,1.3rem); color:var(--ink-soft); line-height:1.55; }
.page-hero-ctas{ display:flex; flex-wrap:wrap; gap:12px; margin-top:36px; }

/* ─── SECTION HEADS ──────────────────────────────────────────── */
.sec-head{ max-width:720px; margin-bottom:56px; }
.sec-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.sec-head.center .eyebrow{ justify-content:center; }
.sec-head .eyebrow{ margin-bottom:18px; }
.sec-head h2{ margin-bottom:18px; }
.sec-head h2 .em{ font-style:italic; font-weight:700; color:var(--primary-deep); }

/* ─── MISSION — EDITORIAL RICH ───────────────────────────────── */
.mission{
  padding:clamp(96px,14vw,160px) 0; background:var(--cream);
  position:relative; overflow:hidden; isolation:isolate;
}
.mission::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background-image:
    linear-gradient(rgba(80,128,224,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(80,128,224,.05) 1px, transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 900px 520px at 50% 50%, black 10%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 900px 520px at 50% 50%, black 10%, transparent 75%);
  pointer-events:none;
}
.mission::after{
  content:""; position:absolute; right:-80px; top:20%; z-index:-1;
  width:320px; height:320px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,201,30,.18), transparent 70%);
  filter:blur(20px); pointer-events:none;
}
.m-mark{
  position:absolute; left:clamp(-20px,-2vw,0px); top:40px; z-index:-1;
  font-size:clamp(16rem,26vw,24rem); line-height:.72;
  font-weight:900; font-style:italic; color:var(--primary);
  opacity:.06; letter-spacing:-.08em; font-family:'Inter',sans-serif;
  pointer-events:none; user-select:none;
}

.m-grid{
  display:grid; grid-template-columns:1.35fr 1fr;
  gap:clamp(40px,6vw,84px); align-items:start;
  position:relative; z-index:1;
}
@media (max-width:960px){ .m-grid{ grid-template-columns:1fr; gap:48px; } }

.m-main .eyebrow{ margin-bottom:24px; }

.m-headline{
  font-size:clamp(2rem,4.2vw,3.5rem); line-height:1.05; letter-spacing:-.035em;
  font-weight:700; color:var(--ink);
  margin:0 0 32px;
  text-wrap:balance;
}
.m-headline em{ font-style:italic; font-weight:600; color:var(--primary-deep); }
.m-hl{
  position:relative; display:inline-block; white-space:nowrap;
  padding:0 .08em;
}
.m-hl::before{
  content:""; position:absolute; left:0; right:0; bottom:.1em; height:.4em;
  background:var(--accent); z-index:-1; border-radius:3px;
}

.m-body{
  max-width:56ch;
  font-size:clamp(1.05rem,1.3vw,1.22rem); line-height:1.65;
  color:var(--ink-soft); margin:0 0 44px;
}
.m-body strong{ color:var(--ink); font-weight:600; }

.m-pillars{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:44px; }
.m-pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 16px; border-radius:999px;
  background:#fff; border:1px solid var(--line);
  font-size:13.5px; font-weight:500; color:var(--ink); letter-spacing:-.005em;
  transition:all .3s var(--ease);
  cursor:default;
}
.m-pill:hover{ transform:translateY(-2px); border-color:var(--primary); color:var(--primary-deep); }
.m-pill svg{ width:14px; height:14px; flex-shrink:0; stroke-width:2; color:var(--primary); }
.m-pill.is-accent{ background:var(--accent-soft); border-color:#F5DD7A; }
.m-pill.is-accent svg{ color:var(--accent-deep); }
.m-pill.is-accent:hover{ background:var(--accent); color:#2E1E00; border-color:var(--accent-deep); }
.m-pill.is-accent:hover svg{ color:#2E1E00; }

.m-sig{
  display:flex; align-items:center; gap:16px; flex-wrap:wrap;
  padding-top:32px; border-top:1px solid rgba(80,128,224,.18);
  font-size:14.5px; color:var(--ink-soft); line-height:1.5;
}
.m-sig-pin{
  width:36px; height:36px; border-radius:50%; flex-shrink:0;
  background:var(--primary); color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 20px -6px rgba(80,128,224,.4);
}
.m-sig strong{ color:var(--ink); font-weight:600; }
.m-sig-dot{ color:var(--accent); font-weight:700; margin:0 4px; }

.m-side{ display:flex; flex-direction:column; gap:14px; }
.m-card{
  padding:24px 26px; border-radius:var(--radius-lg);
  background:#fff; border:1px solid var(--line);
  display:flex; gap:20px; align-items:flex-start;
  transition:all .35s var(--ease);
  position:relative; overflow:hidden;
}
.m-card:hover{ transform:translateY(-3px); border-color:var(--primary-tint); box-shadow:0 20px 40px -20px rgba(80,128,224,.22); }
.m-card.is-hero{
  background:linear-gradient(135deg, var(--primary-deep) 0%, var(--primary) 100%);
  color:#fff; border-color:transparent;
  box-shadow:0 18px 40px -12px rgba(80,128,224,.4);
}
.m-card.is-hero::after{
  content:""; position:absolute; right:-30px; bottom:-30px;
  width:140px; height:140px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,201,30,.3), transparent 70%);
  pointer-events:none;
}
.m-card-num{
  font-size:clamp(2rem,3vw,2.6rem); font-weight:800; line-height:.95;
  letter-spacing:-.04em; color:var(--primary-deep);
  font-variant-numeric:tabular-nums;
  flex-shrink:0; min-width:96px;
}
.m-card-num .accent{ color:var(--accent-deep); }
.m-card.is-hero .m-card-num{ color:#fff; }
.m-card.is-hero .m-card-num .accent{ color:var(--accent); }
.m-card-body{ flex:1; min-width:0; }
.m-card-label{ font-size:15px; font-weight:600; color:var(--ink); line-height:1.3; letter-spacing:-.012em; margin-bottom:4px; }
.m-card-sub{ font-size:13px; color:var(--ink-soft); line-height:1.5; }
.m-card.is-hero .m-card-label{ color:#fff; }
.m-card.is-hero .m-card-sub{ color:rgba(255,255,255,.78); }

/* Simple mission-quote (used on partners, volunteer) — legacy-compatible */
.mission-quote{
  position:relative; z-index:1;
  max-width:920px; margin:0 auto;
  padding-left:clamp(24px,4vw,60px);
  border-left:3px solid var(--primary);
}
.mission-quote .eyebrow{ margin-bottom:28px; }
.mission-quote p{
  font-weight:500; font-size:clamp(1.35rem,2.3vw,1.9rem);
  line-height:1.32; letter-spacing:-.02em; color:var(--ink);
  margin:0;
}
.mission-quote p em{ color:var(--primary-deep); font-style:italic; font-weight:600; }

/* ─── PROGRAM 7 DAYS — RICH ──────────────────────────────────── */
.program-rich{
  background:linear-gradient(180deg, #fff 0%, var(--cream) 60%, var(--primary-softer) 100%);
  position:relative; overflow:hidden;
}
.program-rich::before{
  content:""; position:absolute; right:-140px; top:15%; z-index:0;
  width:460px; height:460px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,201,30,.11), transparent 70%);
  filter:blur(30px); pointer-events:none;
}
.program-rich::after{
  content:""; position:absolute; left:-120px; bottom:10%; z-index:0;
  width:380px; height:380px; border-radius:50%;
  background:radial-gradient(circle, rgba(80,128,224,.1), transparent 70%);
  filter:blur(30px); pointer-events:none;
}
.program-rich .wrap{ position:relative; z-index:1; }

.program-head{
  display:grid; grid-template-columns:1.15fr .85fr;
  gap:clamp(32px,5vw,72px); align-items:center; margin-bottom:72px;
}
@media (max-width:960px){ .program-head{ grid-template-columns:1fr; gap:48px; } }
.program-head .lead{ max-width:54ch; }

.program-banner{
  position:relative; aspect-ratio:4/5; max-width:440px; width:100%; margin-left:auto;
  border-radius:var(--radius-lg); overflow:hidden;
  background:var(--primary-darker);
  box-shadow:0 32px 64px -20px rgba(26,40,71,.45);
}
@media (max-width:960px){ .program-banner{ margin:0 auto; max-width:360px; } }
.program-banner img{ width:100%; height:100%; object-fit:cover; }
.program-banner::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(26,40,71,.15) 0%, rgba(26,40,71,.35) 50%, rgba(26,40,71,.8) 100%);
  pointer-events:none;
}
.pb-stat{ position:absolute; left:clamp(20px,3vw,28px); bottom:clamp(20px,3vw,28px); z-index:2; color:#fff; }
.pb-stat-num{
  font-size:clamp(4rem,7vw,6rem); font-weight:800;
  font-style:italic; letter-spacing:-.05em; line-height:.9;
  color:var(--accent);
  text-shadow:0 6px 20px rgba(255,201,30,.3);
}
.pb-stat-label{
  font-size:12px; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  color:#fff; margin-top:8px;
}
.pb-badge{
  position:absolute; top:20px; right:20px; z-index:2;
  background:var(--accent); color:#2E1E00;
  padding:8px 14px; border-radius:999px;
  font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  box-shadow:0 10px 24px -6px rgba(255,201,30,.6);
  display:inline-flex; align-items:center; gap:6px;
}
.pb-badge svg{ width:12px; height:12px; stroke-width:2.5; }
.pb-quote{
  position:absolute; top:20px; left:20px; z-index:2;
  color:rgba(255,255,255,.9);
  font-style:italic; font-size:14px; line-height:1.35;
  max-width:64%; font-weight:500;
  text-shadow:0 2px 14px rgba(0,0,0,.5);
}

/* Days */
.days-wrap{ position:relative; }
.days-wrap::before{
  content:""; position:absolute; top:76px; left:5%; right:5%;
  height:2px; z-index:0;
  background:repeating-linear-gradient(to right, var(--primary-tint) 0, var(--primary-tint) 5px, transparent 5px, transparent 11px);
  pointer-events:none;
}
@media (max-width:1100px){ .days-wrap::before{ display:none; } }

.days{ display:grid; grid-template-columns:repeat(7,1fr); gap:18px; position:relative; z-index:1; }
@media (max-width:1100px){ .days{ grid-template-columns:repeat(4,1fr); gap:16px; } }
@media (max-width:640px){ .days{ grid-template-columns:repeat(2,1fr); gap:12px; } }

.day{
  padding:26px 22px; background:#fff; border:1px solid var(--line);
  border-radius:var(--radius-md);
  display:flex; flex-direction:column; gap:16px;
  min-height:248px; position:relative;
  transition:all .4s var(--ease);
  box-shadow:0 2px 8px rgba(26,40,71,.05);
}
.day:hover{ transform:translateY(-5px); border-color:var(--primary); box-shadow:0 20px 40px -14px rgba(80,128,224,.25); }
.day-icon{
  width:38px; height:38px; border-radius:10px;
  background:var(--primary-soft); color:var(--primary-deep);
  display:flex; align-items:center; justify-content:center;
  transition:all .35s var(--ease);
}
.day-icon svg{ width:18px; height:18px; stroke-width:2; }
.day:hover .day-icon{ background:var(--accent); color:#2E1E00; transform:rotate(-6deg) scale(1.06); }

.day-n{ font-weight:600; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--primary-deep); }
.day-n span{ display:block; font-size:2.1rem; font-weight:800; color:var(--ink); letter-spacing:-.04em; margin-top:-2px; font-variant-numeric:tabular-nums; }
.day-title{ font-weight:600; font-size:1rem; line-height:1.28; color:var(--ink); margin-top:auto; letter-spacing:-.012em; }
.day-body{ font-size:13px; color:var(--ink-soft); line-height:1.55; }

.day.is-accent{
  background:linear-gradient(140deg, var(--primary-deep) 0%, var(--primary) 100%);
  border-color:var(--primary-deep);
  box-shadow:0 22px 48px -14px rgba(80,128,224,.48);
  transform:translateY(-10px); z-index:2;
}
.day.is-accent:hover{ transform:translateY(-14px); box-shadow:0 30px 56px -14px rgba(80,128,224,.55); }
.day.is-accent .day-n, .day.is-accent .day-n span, .day.is-accent .day-title{ color:#fff; }
.day.is-accent .day-body{ color:rgba(255,255,255,.85); }
.day.is-accent .day-icon{ background:rgba(255,255,255,.16); color:#fff; }
.day.is-accent:hover .day-icon{ background:var(--accent); color:#2E1E00; }
.day.is-accent::before{
  content:"★ Серцевина тижня";
  position:absolute; top:-14px; left:50%; transform:translateX(-50%);
  background:var(--accent); color:#2E1E00;
  padding:5px 12px; border-radius:999px;
  font-size:10.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  white-space:nowrap;
  box-shadow:0 8px 18px -4px rgba(255,201,30,.6);
  z-index:1;
}

/* ─── DAYS — ZIGZAG VARIANT ──────────────────────────────────── */
.days-wrap:has(.days.is-zigzag)::before{ display:none; }

.days.is-zigzag{
  display:grid;
  grid-template-columns:1fr 60px 1fr;
  gap:14px 36px;
  max-width:1120px; margin:0 auto;
  padding:24px 0;
  position:relative;
}
.days.is-zigzag::before{
  content:""; position:absolute;
  top:36px; bottom:36px; left:50%;
  width:2px; transform:translateX(-50%);
  background:repeating-linear-gradient(to bottom, var(--primary-tint) 0, var(--primary-tint) 6px, transparent 6px, transparent 14px);
  z-index:0;
}

.days.is-zigzag .day{
  width:100%; margin:0;
  min-height:auto;
  padding:20px 22px;
  position:relative; z-index:1;
  transform:none;
  align-self:stretch;
  display:flex; flex-direction:column; gap:12px;
}
.days.is-zigzag .day:nth-of-type(odd){ grid-column:1; }
.days.is-zigzag .day:nth-of-type(even){ grid-column:3; }
.days.is-zigzag .day:nth-of-type(1){ grid-row:1; }
.days.is-zigzag .day:nth-of-type(2){ grid-row:2; }
.days.is-zigzag .day:nth-of-type(3){ grid-row:3; }
.days.is-zigzag .day:nth-of-type(4){ grid-row:4; }
.days.is-zigzag .day:nth-of-type(5){ grid-row:5; }
.days.is-zigzag .day:nth-of-type(6){ grid-row:6; }
.days.is-zigzag .day:nth-of-type(7){ grid-row:7; }
.days.is-zigzag .day:hover{ transform:translateY(-3px); }

/* Axis circle with day number */
.days.is-zigzag .day::after{
  content:attr(data-day);
  position:absolute; top:20px;
  width:48px; height:48px; border-radius:50%;
  background:#fff; color:var(--primary-deep);
  border:3px solid var(--primary);
  display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:1.1rem;
  font-variant-numeric:tabular-nums; letter-spacing:-.02em;
  box-shadow:0 10px 22px -6px rgba(80,128,224,.35);
  z-index:2;
}
/* Axis circle sits centered on the central dashed line (66px from card edge) */
.days.is-zigzag .day:nth-of-type(odd)::after{ right:-90px; }
.days.is-zigzag .day:nth-of-type(even)::after{ left:-90px; }

/* Connector line from card edge to axis circle */
.days.is-zigzag .day::before{
  content:""; position:absolute; top:42px;
  width:42px; height:2px;
  background:var(--primary-tint);
  z-index:1;
  transform:none; padding:0; background-image:none;
  color:transparent; font-size:0;
}
.days.is-zigzag .day:nth-of-type(odd)::before{ right:-42px; left:auto; }
.days.is-zigzag .day:nth-of-type(even)::before{ left:-42px; right:auto; }

/* Hide big day number inside card (axis circle shows it) */
.days.is-zigzag .day-n span{ display:none; }
.days.is-zigzag .day-n{ margin-bottom:-4px; }
.days.is-zigzag .day-title{ font-size:1.12rem; margin-top:0; }
.days.is-zigzag .day-body{ font-size:13.5px; }

/* Featured day 4 */
.days.is-zigzag .day.is-accent{
  background:linear-gradient(140deg, var(--primary-deep) 0%, var(--primary) 100%);
  border-color:var(--primary-deep);
  box-shadow:0 22px 48px -14px rgba(80,128,224,.48);
  transform:none;
}
.days.is-zigzag .day.is-accent:hover{ transform:translateY(-4px); box-shadow:0 28px 56px -14px rgba(80,128,224,.55); }
.days.is-zigzag .day.is-accent::after{
  background:var(--accent); color:#2E1E00;
  border-color:var(--accent-deep);
  box-shadow:0 12px 28px -6px rgba(255,201,30,.6);
}
.days.is-zigzag .day.is-accent .day-n{ color:var(--accent); }
.days.is-zigzag .day.is-accent .day-title{ color:#fff; }
.days.is-zigzag .day.is-accent .day-body{ color:rgba(255,255,255,.86); }
.days.is-zigzag .day.is-accent .day-icon{ background:rgba(255,255,255,.18); color:#fff; }

/* Zigzag side photos — decorative, fill opposite columns */
.zigzag-photo{
  border-radius:14px; overflow:hidden;
  aspect-ratio:4/3; max-width:280px;
  box-shadow:0 18px 38px -14px rgba(26,40,71,.35);
  align-self:center;
  transition:transform .5s var(--ease);
  z-index:1; position:relative;
}
.zigzag-photo img{ width:100%; height:100%; object-fit:cover; }
.zigzag-photo.is-left{ grid-column:1; justify-self:end; transform:rotate(2deg); }
.zigzag-photo.is-right{ grid-column:3; justify-self:start; transform:rotate(-3deg); }
.zigzag-photo:hover{ transform:rotate(0) scale(1.02); }

/* Mobile: left-axis stack */
@media (max-width:720px){
  .days.is-zigzag{
    display:flex; flex-direction:column; gap:14px;
    max-width:100%; padding:20px 0;
    grid-template-columns:none;
  }
  .days.is-zigzag::before{ left:26px; transform:none; top:32px; bottom:32px; }
  .days.is-zigzag .day,
  .days.is-zigzag .day:nth-of-type(odd),
  .days.is-zigzag .day:nth-of-type(even){
    width:calc(100% - 70px); grid-column:auto; grid-row:auto;
    margin-left:70px;
  }
  .days.is-zigzag .day::after,
  .days.is-zigzag .day:nth-of-type(odd)::after,
  .days.is-zigzag .day:nth-of-type(even)::after{
    left:-70px; right:auto;
    top:16px; width:44px; height:44px; font-size:.98rem;
  }
  .days.is-zigzag .day::before,
  .days.is-zigzag .day:nth-of-type(odd)::before,
  .days.is-zigzag .day:nth-of-type(even)::before{
    left:-26px; right:auto;
    width:26px; top:38px;
  }
  .zigzag-photo{ display:none; }
}

/* Program after-care card */
.program-after{
  margin-top:56px; padding:clamp(24px,3vw,32px);
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
  display:flex; gap:clamp(16px,2vw,24px); align-items:center;
  box-shadow:0 18px 40px -18px rgba(80,128,224,.18);
  transition:all .35s var(--ease);
}
.program-after:hover{ transform:translateY(-3px); border-color:var(--primary-tint); box-shadow:0 24px 50px -20px rgba(80,128,224,.25); }
.pa-icon{
  width:60px; height:60px; border-radius:16px; flex-shrink:0;
  background:var(--accent-soft); color:var(--accent-deep);
  display:flex; align-items:center; justify-content:center;
}
.pa-icon svg{ width:28px; height:28px; stroke-width:2; }
.pa-body{ flex:1; min-width:0; }
.pa-body strong{ display:block; font-weight:700; font-size:1.08rem; color:var(--ink); margin-bottom:6px; letter-spacing:-.015em; }
.pa-body p{ color:var(--ink-soft); font-size:15px; line-height:1.6; margin:0; }
@media (max-width:700px){
  .program-after{ flex-direction:column; text-align:center; }
  .program-after .btn{ width:100%; justify-content:center; }
}

/* ─── HEAL GRID — RICH ───────────────────────────────────────── */
.heal{
  background:linear-gradient(180deg, var(--cream) 0%, #fff 40%, var(--primary-softer) 100%);
  position:relative; overflow:hidden;
}
.heal::before{
  content:""; position:absolute; left:-120px; top:30%; z-index:0;
  width:380px; height:380px; border-radius:50%;
  background:radial-gradient(circle, rgba(80,128,224,.09), transparent 70%);
  filter:blur(30px); pointer-events:none;
}
.heal::after{
  content:""; position:absolute; right:-100px; bottom:0; z-index:0;
  width:340px; height:340px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,201,30,.1), transparent 70%);
  filter:blur(30px); pointer-events:none;
}
.heal .wrap{ position:relative; z-index:1; }

.heal-grid{
  display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:18px;
  grid-auto-rows:minmax(220px,auto);
}
@media (max-width:1000px){ .heal-grid{ grid-template-columns:1fr 1fr; } .heal-grid > .big{ grid-column:1/-1; } }
@media (max-width:640px){ .heal-grid{ grid-template-columns:1fr; } .heal-grid > .big{ grid-column:auto; } }

.heal-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:32px 28px; display:flex; flex-direction:column; gap:16px;
  transition:all .4s var(--ease); position:relative; overflow:hidden;
}
.heal-card:hover{ transform:translateY(-4px); border-color:var(--primary-tint); box-shadow:0 26px 52px -20px rgba(80,128,224,.22); }

.heal-card.big{
  grid-row:span 2; padding:40px;
  background:linear-gradient(140deg, var(--primary-deep) 0%, var(--primary) 100%);
  color:#fff; border-color:transparent;
  box-shadow:0 26px 54px -18px rgba(80,128,224,.42);
}
.heal-card.big::before{
  content:""; position:absolute; right:-40px; top:-40px;
  width:180px; height:180px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,201,30,.18), transparent 70%);
  pointer-events:none;
}
.heal-card.big h3{ color:#fff; }
.heal-card.big p{ color:rgba(255,255,255,.86); }

.heal-icon{
  width:52px; height:52px; border-radius:14px;
  background:var(--primary-soft); color:var(--primary-deep);
  display:flex; align-items:center; justify-content:center;
  transition:all .4s var(--ease);
  position:relative; z-index:1;
}
.heal-card:hover .heal-icon{ transform:rotate(-6deg) scale(1.08); background:var(--accent); color:#2E1E00; }
.heal-card.big .heal-icon{ background:rgba(255,255,255,.16); color:#fff; }
.heal-card.big:hover .heal-icon{ background:var(--accent); color:#2E1E00; }
.heal-card.is-accent{ background:var(--accent-soft); border-color:#F5DD7A; }
.heal-card.is-accent .heal-icon{ background:#fff; color:var(--accent-deep); }

.heal-card h3{ font-weight:700; font-size:1.3rem; letter-spacing:-.02em; }
.heal-card p{ color:var(--ink-soft); font-size:15px; line-height:1.6; }

.heal-meta{ display:flex; flex-wrap:wrap; gap:6px; margin-top:4px; }
.heal-meta span{
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 10px; border-radius:999px;
  background:var(--primary-softer); color:var(--primary-deep);
  font-size:11.5px; font-weight:600; letter-spacing:-.005em;
  white-space:nowrap;
}
.heal-meta span svg{ width:11px; height:11px; stroke-width:2.5; }
.heal-card.big .heal-meta span{ background:rgba(255,255,255,.14); color:#fff; }
.heal-card.is-accent .heal-meta span{ background:rgba(62,46,0,.1); color:#4A3A0A; }

.heal-quote{
  margin:auto 0 0; padding:18px 20px;
  background:rgba(255,255,255,.1); border-left:3px solid var(--accent);
  border-radius:10px;
  font-style:italic; font-size:1.05rem; line-height:1.42;
  color:#fff; font-weight:500;
  position:relative;
}
.heal-quote::before{
  content:"\201C"; position:absolute; top:-4px; right:14px;
  font-size:3rem; font-weight:800; font-style:italic;
  color:var(--accent); opacity:.35; line-height:.5;
}
.heal-quote cite{
  display:block; margin-top:10px; font-style:normal;
  font-size:12px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color:rgba(255,255,255,.7);
}

/* Before/after transformation strip */
.heal-result{
  margin-top:40px; padding:clamp(28px,3vw,44px) clamp(24px,3vw,48px);
  background:linear-gradient(135deg, var(--primary-darker) 0%, var(--primary-deep) 50%, var(--primary) 100%);
  border-radius:var(--radius-lg);
  display:grid; grid-template-columns:1fr auto 1fr auto;
  gap:clamp(20px,3vw,40px); align-items:center;
  color:#fff;
  position:relative; overflow:hidden;
  box-shadow:0 30px 60px -20px rgba(80,128,224,.45);
}
.heal-result::before{
  content:""; position:absolute; right:-60px; bottom:-60px;
  width:220px; height:220px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,201,30,.25), transparent 70%);
  pointer-events:none;
}
.heal-result::after{
  content:""; position:absolute; left:-80px; top:-80px;
  width:200px; height:200px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.08), transparent 70%);
  pointer-events:none;
}
@media (max-width:860px){
  .heal-result{ grid-template-columns:1fr; text-align:center; }
  .heal-result .hr-arrow{ justify-self:center; transform:rotate(90deg); }
  .heal-result .btn{ justify-self:center; }
}

.hr-side{ display:flex; flex-direction:column; gap:8px; position:relative; z-index:1; }
.hr-label{
  font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  font-weight:700; color:var(--accent);
  display:inline-flex; align-items:center; gap:8px;
}
.hr-label svg{ width:14px; height:14px; stroke-width:2.5; }
.hr-label.is-before{ color:rgba(255,255,255,.55); }
.hr-side strong{ font-weight:600; line-height:1.3; letter-spacing:-.015em; }
.hr-before strong{ font-size:clamp(1.05rem,1.6vw,1.3rem); color:rgba(255,255,255,.72); }
.hr-after strong{ font-size:clamp(1.2rem,1.9vw,1.5rem); color:#fff; font-weight:700; }

.hr-arrow{
  width:56px; height:56px; border-radius:50%;
  background:var(--accent); color:#2E1E00;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; position:relative; z-index:1;
  box-shadow:0 14px 32px -8px rgba(255,201,30,.55);
  transition:transform .4s var(--ease);
}
.heal-result:hover .hr-arrow{ transform:translateX(6px); }
.hr-arrow svg{ width:22px; height:22px; stroke-width:2.5; }

.heal-result .btn{ position:relative; z-index:1; }

/* ─── STATS BAR — RICH ───────────────────────────────────────── */
.stats{
  background:
    radial-gradient(ellipse 800px 500px at 85% 0%, rgba(255,201,30,.18), transparent 60%),
    radial-gradient(ellipse 700px 400px at 10% 100%, rgba(62,104,190,.5), transparent 60%),
    linear-gradient(135deg, var(--primary-darker) 0%, var(--primary-deep) 50%, var(--primary) 100%);
  color:#fff; padding:clamp(80px,10vw,120px) 0;
  position:relative; overflow:hidden;
}
.stats::before{
  content:""; position:absolute; inset:0; z-index:0; opacity:.06;
  background-image:
    linear-gradient(rgba(255,255,255,.5) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.5) 1px, transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse at 50% 50%, black 10%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 50%, black 10%, transparent 80%);
  pointer-events:none;
}
.stats .wrap{ position:relative; z-index:1; }

.stats-head{ max-width:780px; margin-bottom:56px; }
.stats-head .eyebrow{ color:var(--accent); margin-bottom:20px; }
.stats-head .eyebrow::before{ background:var(--accent); }
.stats-head h2{ color:#fff; }
.stats-head h2 .em{ font-style:italic; font-weight:700; color:var(--accent); }

.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(24px,3vw,40px); }
@media (max-width:900px){ .stats-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .stats-grid{ grid-template-columns:1fr; gap:16px; } }
.stat{
  display:flex; flex-direction:column; gap:14px;
  padding-top:28px; border-top:1px solid rgba(255,255,255,.2);
  position:relative;
  transition:border-color .4s var(--ease);
}
.stat:hover{ border-top-color:var(--accent); }
.stat::before{
  content:""; position:absolute; top:-2px; left:0;
  width:0; height:3px; background:var(--accent);
  transition:width .5s var(--ease);
}
.stat:hover::before{ width:44px; }

.stat-icon{
  width:42px; height:42px; border-radius:12px;
  background:rgba(255,201,30,.16); color:var(--accent);
  display:flex; align-items:center; justify-content:center;
  transition:all .35s var(--ease);
}
.stat:hover .stat-icon{ background:var(--accent); color:#2E1E00; transform:rotate(-4deg) scale(1.06); }
.stat-icon svg{ width:22px; height:22px; stroke-width:2; }

.stat-num{
  font-weight:800; font-size:clamp(2.4rem,5.4vw,4rem);
  line-height:.92; letter-spacing:-.04em; color:#fff;
  font-variant-numeric:tabular-nums; margin-top:4px;
}
.stat-num .accent-dot{ color:var(--accent); }
.stat-label{ font-size:14.5px; color:rgba(255,255,255,.78); max-width:24ch; line-height:1.5; }

.stats-note{
  margin-top:64px; padding-top:28px;
  border-top:1px solid rgba(255,255,255,.14);
  display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
  font-size:13.5px; color:rgba(255,255,255,.6);
}
.stats-note a{ color:var(--accent); text-decoration:underline; text-underline-offset:2px; }
.stats-note a:hover{ color:#fff; }

/* ─── EDITORIAL SPLIT ────────────────────────────────────────── */
.split{ background:var(--cream); }
.split-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,80px); align-items:center; }
@media (max-width:900px){ .split-grid{ grid-template-columns:1fr; } }
.split-frame{
  position:relative; isolation:isolate;
  aspect-ratio:4/5; border-radius:var(--radius-lg); overflow:hidden;
  background:var(--primary-darker);
  box-shadow:0 30px 60px -20px rgba(26,40,71,.35);
}
.split-frame img{ width:100%; height:100%; object-fit:cover; }
.split-frame::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 45%, rgba(26,40,71,.55) 100%);
  pointer-events:none;
}
.split-tag{
  position:absolute; left:24px; bottom:24px; z-index:2;
  background:rgba(255,255,255,.15); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  color:#fff; padding:10px 16px; border-radius:999px;
  font-size:12px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  border:1px solid rgba(255,255,255,.22);
}
.split-year{
  position:absolute; right:-16px; top:-16px; z-index:2;
  font-style:italic; font-weight:800;
  font-size:clamp(5rem,10vw,9rem); line-height:1; letter-spacing:-.06em;
  color:var(--accent); opacity:.95;
  mix-blend-mode:screen; pointer-events:none;
}

/* ─── SPLIT — RICH VARIANT (homepage «Хто ми») ───────────────── */
.split{ position:relative; overflow:hidden; }
.split::before{
  content:""; position:absolute; right:-160px; top:-120px; z-index:0;
  width:420px; height:420px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,201,30,.13), transparent 70%);
  filter:blur(30px); pointer-events:none;
}
.split .wrap{ position:relative; z-index:1; }

.split-grid-rich{ grid-template-columns:1fr 1.08fr; gap:clamp(40px,6vw,96px); align-items:center; }
@media (max-width:900px){ .split-grid-rich{ grid-template-columns:1fr; gap:72px; } }

.sv{ position:relative; aspect-ratio:4/5; max-width:520px; width:100%; }
@media (max-width:900px){ .sv{ max-width:440px; margin:0 auto; } }

.sv-main{
  position:absolute; top:0; left:0; width:82%; height:72%;
  border-radius:var(--radius-lg); overflow:hidden;
  background:var(--primary-darker);
  box-shadow:0 32px 64px -20px rgba(26,40,71,.45);
  transform:rotate(-2deg);
  transition:transform .6s var(--ease);
}
.sv-main img{ width:100%; height:100%; object-fit:cover; }
.sv-main::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 55%, rgba(26,40,71,.45) 100%);
  pointer-events:none;
}
.sv-inset{
  position:absolute; bottom:0; right:0; width:56%; height:46%;
  border-radius:var(--radius-lg); overflow:hidden;
  background:var(--primary-darker);
  box-shadow:0 24px 54px -16px rgba(26,40,71,.4);
  border:6px solid #fff;
  transform:rotate(3deg);
  transition:transform .6s var(--ease);
  z-index:2;
}
.sv-inset img{ width:100%; height:100%; object-fit:cover; }
.sv:hover .sv-main{ transform:rotate(0deg) translateY(-2px); }
.sv:hover .sv-inset{ transform:rotate(0deg) translateY(-2px); }
@media (prefers-reduced-motion:reduce){
  .sv:hover .sv-main, .sv:hover .sv-inset{ transform:none; }
}

.sv-year{
  position:absolute; right:8%; top:-6%; z-index:3;
  font-size:clamp(4.5rem,8vw,7.5rem); line-height:1;
  font-weight:800; font-style:italic; letter-spacing:-.06em;
  color:var(--accent); pointer-events:none;
  text-shadow:0 4px 16px rgba(255,201,30,.25);
}

.sv-pill{
  position:absolute; left:6%; bottom:52%; z-index:3;
  background:rgba(255,255,255,.96); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  color:var(--ink); padding:10px 14px; border-radius:999px;
  font-size:12.5px; font-weight:600; letter-spacing:-.005em;
  display:inline-flex; align-items:center; gap:8px;
  box-shadow:0 12px 28px -8px rgba(0,0,0,.25);
}
.sv-pill svg{ width:14px; height:14px; color:var(--primary); stroke-width:2; }

.sv-stamp{
  position:absolute; top:14%; left:-22px; z-index:3;
  background:var(--primary-deep); color:#fff;
  padding:14px 16px; border-radius:14px;
  font-size:12px; font-weight:600; line-height:1.3;
  display:flex; align-items:center; gap:12px; max-width:200px;
  transform:rotate(-6deg);
  box-shadow:0 14px 32px -8px rgba(80,128,224,.5);
}
.sv-stamp svg{ width:26px; height:26px; flex-shrink:0; color:var(--accent); stroke-width:2; }
.sv-stamp .sv-stamp-head{ display:block; color:var(--accent); font-weight:700; font-size:10px; text-transform:uppercase; letter-spacing:.1em; margin-bottom:2px; }

/* Rich content column */
.split-content h2{ margin-top:18px; }
.split-content h2 .em{ font-style:italic; font-weight:700; color:var(--primary-deep); }

.founder-quote{
  margin:32px 0; padding:26px 28px;
  background:#fff; border:1px solid var(--line);
  border-left:3px solid var(--primary); border-radius:var(--radius-md);
  position:relative;
}
.founder-quote::before{
  content:"\201C"; position:absolute; top:4px; right:18px;
  font-size:4rem; font-weight:800; font-style:italic;
  color:var(--primary); opacity:.14; line-height:.5;
}
.founder-quote p{
  font-size:1.06rem; line-height:1.5; font-weight:500; color:var(--ink);
  font-style:italic; margin:0 0 20px;
  letter-spacing:-.013em;
}
.founder-quote cite{
  display:flex; align-items:center; gap:12px; font-style:normal;
  padding-top:16px; border-top:1px solid var(--line);
}
.founder-quote cite .fq-avatar{
  width:38px; height:38px; border-radius:50%; flex-shrink:0;
  background:linear-gradient(135deg,var(--primary),var(--primary-deep));
  color:#fff; display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:13px; letter-spacing:-.01em;
}
.founder-quote cite strong{ display:block; font-weight:600; font-size:14.5px; color:var(--ink); letter-spacing:-.01em; }
.founder-quote cite em{ font-style:normal; font-size:12.5px; color:var(--ink-soft); }

.split-features{
  display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:32px;
}
@media (max-width:640px){ .split-features{ grid-template-columns:1fr; } }
.sf{
  padding:16px 18px; border:1px solid var(--line); border-radius:var(--radius-md);
  display:flex; gap:12px; align-items:flex-start;
  background:#fff; transition:all .3s var(--ease);
}
.sf:hover{ border-color:var(--primary-tint); transform:translateY(-2px); box-shadow:0 14px 28px -12px rgba(80,128,224,.18); }
.sf svg{ width:20px; height:20px; color:var(--primary); flex-shrink:0; stroke-width:2; margin-top:1px; }
.sf strong{ display:block; font-weight:700; font-size:14px; letter-spacing:-.012em; color:var(--ink); }
.sf span{ display:block; font-size:12px; color:var(--ink-soft); margin-top:2px; line-height:1.4; }

/* ─── MAP ────────────────────────────────────────────────────── */
.map-sec{ background:#fff; position:relative; overflow:hidden; }
.map-sec::before{
  content:""; position:absolute; left:-120px; top:20%; z-index:0;
  width:360px; height:360px; border-radius:50%;
  background:radial-gradient(circle, rgba(80,128,224,.08), transparent 70%);
  filter:blur(30px); pointer-events:none;
}
.map-sec .wrap{ position:relative; z-index:1; }
.map-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(32px,5vw,72px); align-items:start; }
@media (max-width:900px){ .map-grid{ grid-template-columns:1fr; } }

.map-intro-stat{
  display:inline-flex; align-items:center; gap:14px;
  margin-top:28px; padding:14px 18px;
  background:var(--accent-soft); border:1px solid #F5DD7A; border-radius:12px;
  font-size:13.5px; color:#3E2E00;
}
.map-intro-stat svg{ width:20px; height:20px; color:var(--accent-deep); stroke-width:2.5; flex-shrink:0; }
.map-intro-stat strong{ font-weight:700; color:#1A1300; }

.map-list{ list-style:none; padding:0; margin:32px 0 0; display:flex; flex-direction:column; gap:2px; }
.map-list li{
  padding:18px 0; border-bottom:1px solid var(--line);
  display:flex; align-items:center; gap:16px; font-size:17px;
  transition:padding-left .3s var(--ease);
}
.map-list li:hover{ padding-left:8px; }
.map-list li:last-child{ border-bottom:0; }
.map-pin{ width:28px; height:28px; border-radius:50%; flex-shrink:0; background:var(--accent); color:#3E2E00; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:12px; font-variant-numeric:tabular-nums; }
.map-place{ font-weight:600; font-size:17px; letter-spacing:-.01em; }
.map-meta{ margin-left:auto; font-size:13px; color:var(--ink-soft); }

.map-canvas{
  background:linear-gradient(135deg, var(--cream) 0%, var(--primary-softer) 100%);
  border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:28px; aspect-ratio:1.2/1; position:relative; overflow:hidden;
  box-shadow:inset 0 1px 2px rgba(255,255,255,.5);
}
.map-canvas svg{ width:100%; height:100%; }

.map-pulse{ transform-origin:center; transform-box:fill-box; animation:mapPulse 2.4s cubic-bezier(.4,0,.6,1) infinite; }
.map-pulse-2{ animation-delay:.6s; }
@keyframes mapPulse{
  0%{ r:13; opacity:.55; }
  70%{ r:30; opacity:0; }
  100%{ r:30; opacity:0; }
}
@media (prefers-reduced-motion:reduce){
  .map-pulse, .map-pulse-2{ animation:none; opacity:.25; }
}

.map-legend{
  position:absolute; left:24px; bottom:24px;
  display:flex; flex-wrap:wrap; gap:10px 16px;
  background:rgba(255,255,255,.92); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  padding:12px 16px; border-radius:12px;
  border:1px solid var(--line);
  font-size:12px; color:var(--ink-soft); font-weight:500;
}
.ml-item{ display:inline-flex; align-items:center; gap:6px; }
.ml-dot{ width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.ml-dot.primary{ background:var(--accent); box-shadow:0 0 0 3px rgba(255,201,30,.25); }
.ml-dot.accent{ background:var(--accent); }
.ml-dot.ghost{ background:var(--primary); }

.map-coord{
  position:absolute; right:20px; top:20px;
  font-size:10.5px; font-family:'Inter',sans-serif;
  font-variant-numeric:tabular-nums; letter-spacing:.04em;
  color:var(--ink-softer); font-weight:500;
  background:rgba(255,255,255,.8); padding:6px 10px; border-radius:8px;
  border:1px solid var(--line);
}

/* ─── LOCATIONS GRID ─────────────────────────────────────────── */
.loc-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px;
}
@media (max-width:900px){ .loc-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .loc-grid{ grid-template-columns:1fr; } }

.loc{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:28px 26px;
  display:flex; gap:18px; align-items:flex-start;
  transition:all .35s var(--ease); position:relative; overflow:hidden;
}
.loc:hover{ transform:translateY(-4px); border-color:var(--primary-tint); box-shadow:0 22px 44px -18px rgba(80,128,224,.22); }

.loc-pin{
  width:42px; height:42px; border-radius:50%; flex-shrink:0;
  background:var(--accent); color:#2E1E00;
  display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:16px; letter-spacing:-.01em;
  font-variant-numeric:tabular-nums;
  box-shadow:0 8px 20px -6px rgba(255,201,30,.4);
  transition:transform .35s var(--ease);
}
.loc:hover .loc-pin{ transform:scale(1.08) rotate(-4deg); }

.loc-body{ flex:1; min-width:0; }
.loc-tag{
  font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--primary-deep); margin-bottom:8px;
}
.loc h3{ font-weight:700; font-size:1.15rem; letter-spacing:-.02em; margin-bottom:8px; color:var(--ink); }
.loc p{ font-size:14px; color:var(--ink-soft); line-height:1.55; margin:0; }

.loc.is-main{
  background:linear-gradient(140deg, var(--primary-deep) 0%, var(--primary) 100%);
  border-color:transparent; color:#fff;
  box-shadow:0 22px 46px -16px rgba(80,128,224,.4);
}
.loc.is-main::before{
  content:""; position:absolute; right:-30px; top:-30px;
  width:140px; height:140px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,201,30,.2), transparent 70%);
  pointer-events:none;
}
.loc.is-main .loc-tag{ color:var(--accent); }
.loc.is-main h3{ color:#fff; }
.loc.is-main p{ color:rgba(255,255,255,.85); }

.loc.is-online .loc-pin{ background:var(--primary); color:#fff; box-shadow:0 8px 20px -6px rgba(80,128,224,.4); }
.loc.is-online .loc-tag{ color:var(--accent-deep); }

/* ─── DONATION TIERS ─────────────────────────────────────────── */
.tiers{ display:grid; grid-template-columns:repeat(5,1fr); gap:16px; align-items:stretch; }
@media (max-width:1100px){ .tiers{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:700px){ .tiers{ grid-template-columns:repeat(2,1fr); gap:12px; } }
@media (max-width:460px){ .tiers{ grid-template-columns:1fr; } }
.tier{
  background:var(--primary-softer); border:1.5px solid transparent;
  border-radius:var(--radius-md); padding:28px 22px 24px;
  display:flex; flex-direction:column; gap:14px; text-align:center;
  transition:all .35s var(--ease); position:relative;
}
.tier:hover{ transform:translateY(-4px); border-color:var(--primary); box-shadow:0 22px 44px -16px rgba(80,128,224,.25); }
.tier-price{ font-weight:800; font-size:clamp(2rem,3.5vw,2.6rem); line-height:1; letter-spacing:-.04em; color:var(--primary-deep); font-variant-numeric:tabular-nums; }
.tier-desc{ font-size:13.5px; color:var(--ink-soft); line-height:1.45; min-height:64px; }
.tier-btn{ margin-top:auto; }
.tier.is-featured{
  background:var(--primary); color:#fff;
  transform:translateY(-12px); padding-top:42px; border-color:var(--primary-deep);
  box-shadow:0 28px 56px -20px rgba(80,128,224,.45);
}
.tier.is-featured .tier-price{ color:#fff; font-size:clamp(2.5rem,4.5vw,3.4rem); }
.tier.is-featured .tier-desc{ color:rgba(255,255,255,.88); }
.tier.is-featured:hover{ transform:translateY(-14px); }
.tier-badge{
  position:absolute; top:-12px; left:50%; transform:translateX(-50%);
  background:var(--accent); color:#3E2E00;
  padding:6px 14px; border-radius:999px;
  font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; white-space:nowrap;
  box-shadow:0 8px 20px -6px rgba(255,201,30,.6);
}

/* ─── TESTIMONIALS — RICH ────────────────────────────────────── */
.testim{
  background:linear-gradient(180deg, #fff 0%, var(--primary-softer) 100%);
  position:relative; overflow:hidden;
}
.testim::before{
  content:""; position:absolute; right:-120px; top:15%; z-index:0;
  width:380px; height:380px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,201,30,.1), transparent 70%);
  filter:blur(30px); pointer-events:none;
}
.testim::after{
  content:""; position:absolute; left:-100px; bottom:10%; z-index:0;
  width:340px; height:340px; border-radius:50%;
  background:radial-gradient(circle, rgba(80,128,224,.12), transparent 70%);
  filter:blur(30px); pointer-events:none;
}
.testim .wrap{ position:relative; z-index:1; }

.testim-grid{ display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:18px; }
@media (max-width:980px){ .testim-grid{ grid-template-columns:1fr 1fr; } .testim-grid > :first-child{ grid-column:1/-1; } }
@media (max-width:640px){ .testim-grid{ grid-template-columns:1fr; } .testim-grid > :first-child{ grid-column:auto; } }

.testim-card{
  background:#fff; border:1px solid #E0E5EE;
  border-radius:var(--radius-lg); padding:clamp(28px,3vw,36px);
  display:flex; flex-direction:column; gap:18px;
  transition:all .4s var(--ease); position:relative; overflow:hidden;
  box-shadow:0 14px 32px -14px rgba(26,40,71,.15), 0 2px 6px rgba(26,40,71,.05);
}
.testim-card:hover{
  transform:translateY(-6px);
  border-color:var(--primary-tint);
  box-shadow:0 28px 56px -20px rgba(26,40,71,.25), 0 4px 10px rgba(26,40,71,.06);
}

.testim-card.is-feat{
  background:linear-gradient(140deg, var(--primary-deep) 0%, var(--primary) 100%);
  color:#fff; border-color:transparent;
  box-shadow:0 30px 60px -18px rgba(80,128,224,.45), 0 4px 12px rgba(0,0,0,.08);
}
.testim-card.is-feat::before{
  content:""; position:absolute; right:-60px; top:-60px;
  width:200px; height:200px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,201,30,.22), transparent 70%);
  pointer-events:none;
}
.testim-card.is-feat:hover{
  box-shadow:0 40px 72px -20px rgba(80,128,224,.55), 0 8px 16px rgba(0,0,0,.1);
}
.testim-card.is-feat .testim-name, .testim-card.is-feat .testim-text{ color:#fff; }
.testim-card.is-feat .testim-role{ color:rgba(255,255,255,.75); }
.testim-card.is-feat .testim-author{ border-color:rgba(255,255,255,.18); }
.testim-card.is-feat .testim-mark{ color:var(--accent); }

.testim-mark{
  font-weight:800; font-style:italic;
  font-size:4.5rem; line-height:.5; color:var(--primary);
  letter-spacing:-.06em; margin-bottom:-8px;
  font-family:'Inter',sans-serif;
}
.testim-text{
  font-weight:500; font-size:clamp(1.05rem,1.35vw,1.22rem);
  line-height:1.48; color:var(--ink); letter-spacing:-.01em;
}
.testim-card.is-feat .testim-text{
  font-size:clamp(1.25rem,1.85vw,1.6rem); line-height:1.38;
  font-weight:500;
}

.testim-author{
  display:flex; align-items:center; gap:14px;
  margin-top:auto; padding-top:22px;
  border-top:1px solid var(--line);
}
.testim-avatar{
  width:52px; height:52px; border-radius:50%; overflow:hidden; flex-shrink:0;
  background:var(--primary-soft);
  box-shadow:0 4px 12px -2px rgba(26,40,71,.15);
  border:2px solid #fff;
}
.testim-avatar img{ width:100%; height:100%; object-fit:cover; }
.testim-avatar.letter{
  background:linear-gradient(135deg,var(--primary),var(--primary-deep)); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:18px; letter-spacing:-.01em;
}
.testim-card.is-feat .testim-avatar.letter{
  background:linear-gradient(135deg,var(--accent),var(--accent-deep));
  color:#2E1E00;
}
.testim-card.is-feat .testim-avatar{ border-color:rgba(255,255,255,.25); }

.testim-name{ font-weight:700; font-size:15.5px; color:var(--ink); letter-spacing:-.012em; }
.testim-role{ font-size:13px; color:var(--ink-soft); margin-top:2px; }

/* ─── GALLERY ────────────────────────────────────────────────── */
.gallery-grid{
  display:grid; grid-template-columns:repeat(12,1fr);
  grid-auto-rows:98px; gap:12px;
}
@media (max-width:900px){ .gallery-grid{ grid-template-columns:repeat(6,1fr); grid-auto-rows:92px; } }
@media (max-width:560px){ .gallery-grid{ grid-template-columns:repeat(4,1fr); grid-auto-rows:82px; } }
.g-item{
  border-radius:var(--radius-md); overflow:hidden; position:relative;
  background:var(--primary-softer);
  transition:transform .5s var(--ease);
}
.g-item:hover{ transform:scale(1.012); }
.g-item img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease), filter .5s var(--ease); filter:saturate(.95); }
.g-item:hover img{ transform:scale(1.05); filter:saturate(1.05); }
.g-a{ grid-column:span 5; grid-row:span 3; }
.g-b{ grid-column:span 4; grid-row:span 2; }
.g-c{ grid-column:span 3; grid-row:span 2; }
.g-d{ grid-column:span 4; grid-row:span 2; }
.g-e{ grid-column:span 3; grid-row:span 3; }
.g-f{ grid-column:span 5; grid-row:span 2; }
@media (max-width:900px){ .g-a,.g-b,.g-c,.g-d,.g-e,.g-f{ grid-column:span 3; grid-row:span 2; } .g-a{ grid-column:span 6; grid-row:span 3; } }
@media (max-width:560px){ .g-a,.g-b,.g-c,.g-d,.g-e,.g-f{ grid-column:span 2; grid-row:span 2; } }

/* ─── PARTNERSHIPS ───────────────────────────────────────────── */
.partners{ background:var(--primary-darker); color:#fff; }
.partners h2{ color:#fff; }
.partners .lead{ color:rgba(255,255,255,.78); }
.partners .eyebrow{ color:var(--accent); }
.partners .eyebrow::before{ background:var(--accent); }
.part-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
@media (max-width:900px){ .part-grid{ grid-template-columns:1fr; } }
.part{
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius-lg); padding:36px 32px;
  display:flex; flex-direction:column; gap:22px;
  transition:all .35s var(--ease);
}
.part:hover{ background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.28); transform:translateY(-3px); }
.part-tier{ font-weight:700; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); }
.part h3{ color:#fff; font-weight:700; font-size:1.5rem; letter-spacing:-.022em; }
.part-desc{ font-size:15px; color:rgba(255,255,255,.75); line-height:1.6; }
.part-ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.part-ul li{ padding-left:24px; position:relative; font-size:14.5px; color:rgba(255,255,255,.85); line-height:1.5; }
.part-ul li::before{
  content:""; position:absolute; left:0; top:8px;
  width:14px; height:14px; border-radius:50%;
  background:var(--accent); box-shadow:inset 0 0 0 3px var(--primary-darker);
}
.part.featured{ background:var(--accent); color:#1A1300; border-color:var(--accent); }
.part.featured h3, .part.featured .part-tier{ color:#1A1300; }
.part.featured .part-desc, .part.featured .part-ul li{ color:#3E2E00; }
.part.featured .part-ul li::before{ background:var(--primary-darker); box-shadow:inset 0 0 0 3px var(--accent); }

/* ─── FAQ ────────────────────────────────────────────────────── */
.faq-list{ max-width:820px; margin:0 auto; display:flex; flex-direction:column; }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-item:first-child{ border-top:1px solid var(--line); }
.faq-q{
  width:100%; padding:22px 0; display:flex; align-items:center; justify-content:space-between; gap:24px;
  font-weight:600; font-size:clamp(1.05rem,1.45vw,1.22rem); letter-spacing:-.015em;
  color:var(--ink); text-align:left; transition:color .3s var(--ease);
}
.faq-q:hover{ color:var(--primary-deep); }
.faq-toggle{
  width:36px; height:36px; border-radius:50%; flex-shrink:0;
  background:var(--primary-softer); color:var(--primary-deep);
  display:flex; align-items:center; justify-content:center;
  transition:all .3s var(--ease);
}
.faq-q[aria-expanded="true"] .faq-toggle{ background:var(--primary); color:#fff; transform:rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .45s var(--ease); }
.faq-a-inner{ padding:0 0 24px; font-size:16px; color:var(--ink-soft); line-height:1.7; max-width:680px; }
.faq-a-inner a{ color:var(--primary-deep); text-decoration:underline; text-underline-offset:2px; }
.faq-q[aria-expanded="true"] + .faq-a{ max-height:520px; }
.faq-cat-head{ margin:48px 0 16px; }
.faq-cat-head:first-child{ margin-top:0; }
.faq-cat-head .eyebrow{ display:inline-flex; }

/* ─── CTA FINAL ──────────────────────────────────────────────── */
.cta-final{
  padding:clamp(80px,10vw,120px) 0;
  background:
    radial-gradient(ellipse 700px 400px at 80% 20%, rgba(255,201,30,.15), transparent 60%),
    linear-gradient(135deg, var(--primary-darker) 0%, var(--primary-deep) 60%, var(--primary) 100%);
  color:#fff; position:relative; overflow:hidden;
}
.cta-final::before{
  content:""; position:absolute; inset:auto -10% -40% -10%; height:600px;
  background:radial-gradient(ellipse 600px 300px at 50% 50%, rgba(255,201,30,.2), transparent 70%);
  pointer-events:none;
}
.cta-final h2{ color:#fff; max-width:18ch; margin-bottom:20px; }
.cta-final h2 .em{ color:var(--accent); font-style:italic; font-weight:800; }
.cta-final .lead{ color:rgba(255,255,255,.82); max-width:52ch; margin-bottom:40px; }
.cta-grid{ display:grid; grid-template-columns:1.3fr 1fr; gap:clamp(32px,5vw,72px); align-items:center; position:relative; z-index:1; }
@media (max-width:900px){ .cta-grid{ grid-template-columns:1fr; } }
.cta-actions{ display:flex; flex-wrap:wrap; gap:14px; }
.cta-card{
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.16);
  border-radius:var(--radius-lg); padding:32px 28px;
  backdrop-filter:blur(10px);
}
.cta-card h3{ color:#fff; font-weight:700; font-size:1.35rem; margin-bottom:8px; letter-spacing:-.02em; }
.cta-card-row{ display:flex; align-items:center; gap:14px; padding:14px 0; border-bottom:1px solid rgba(255,255,255,.12); }
.cta-card-row:last-child{ border-bottom:0; }
.cta-card-icon{ width:40px; height:40px; border-radius:10px; flex-shrink:0; background:rgba(255,201,30,.16); color:var(--accent); display:flex; align-items:center; justify-content:center; }
.cta-card-label{ font-size:12px; color:rgba(255,255,255,.6); letter-spacing:.03em; }
.cta-card-val{ font-size:15px; font-weight:500; color:#fff; margin-top:2px; }
.cta-card-val a{ color:var(--accent); text-decoration:underline; text-underline-offset:2px; }

/* ─── FORM ───────────────────────────────────────────────────── */
.form{ display:grid; gap:16px; max-width:560px; }
.form-field{ display:flex; flex-direction:column; gap:6px; }
.form-field label{ font-weight:600; font-size:13px; color:var(--ink); letter-spacing:-.005em; }
.form-field input,
.form-field textarea,
.form-field select{
  font:inherit; padding:14px 16px; border-radius:10px;
  border:1.5px solid var(--line); background:#fff;
  transition:border-color .3s var(--ease), box-shadow .3s var(--ease);
}
.form-field textarea{ resize:vertical; min-height:120px; }
.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus{ border-color:var(--primary); box-shadow:0 0 0 4px rgba(80,128,224,.15); outline:none; }
.form-hint{ font-size:12px; color:var(--ink-softer); }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:520px){ .form-row{ grid-template-columns:1fr; } }

/* ─── TEAM / PEOPLE CARDS ────────────────────────────────────── */
.people-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
@media (max-width:1000px){ .people-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .people-grid{ grid-template-columns:1fr; } }
.person{
  background:#fff; border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:22px;
  display:flex; flex-direction:column; gap:14px;
  transition:all .35s var(--ease);
}
.person:hover{ transform:translateY(-3px); border-color:var(--primary-tint); box-shadow:0 18px 40px -20px rgba(80,128,224,.2); }
.person-ava{
  aspect-ratio:1/1; width:100%;
  background:linear-gradient(135deg, var(--primary-soft), var(--primary-tint));
  color:var(--primary-darker);
  display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:2.5rem;
  border-radius:var(--radius-md); overflow:hidden;
  letter-spacing:-.03em;
}
.person-ava img{ width:100%; height:100%; object-fit:cover; }
.person-name{ font-weight:700; font-size:1.05rem; letter-spacing:-.015em; }
.person-role{ font-size:13px; color:var(--primary-deep); font-weight:500; }
.person-bio{ font-size:14px; color:var(--ink-soft); line-height:1.55; }

/* ─── TIMELINE ───────────────────────────────────────────────── */
.timeline{ display:flex; flex-direction:column; gap:0; position:relative; max-width:820px; margin:0 auto; }
.timeline::before{
  content:""; position:absolute; left:19px; top:8px; bottom:8px;
  width:2px; background:linear-gradient(180deg, var(--primary) 0%, var(--accent) 100%);
}
.tl-item{ display:grid; grid-template-columns:40px 1fr; gap:28px; padding:18px 0 28px; }
.tl-year{
  width:40px; height:40px; border-radius:50%; position:relative; z-index:1;
  background:#fff; color:var(--primary-deep);
  box-shadow:0 0 0 3px var(--primary);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:12px; letter-spacing:-.01em; font-variant-numeric:tabular-nums;
}
.tl-item.is-accent .tl-year{ background:var(--accent); color:#3E2E00; box-shadow:0 0 0 3px var(--accent-deep); }
.tl-body h4{ margin-bottom:6px; font-size:1.1rem; letter-spacing:-.015em; }
.tl-body p{ color:var(--ink-soft); font-size:15px; line-height:1.6; }

/* ─── PROSE (legal pages) ────────────────────────────────────── */
.prose{ max-width:820px; margin:0 auto; font-size:16.5px; line-height:1.75; color:var(--ink-soft); }
.prose h2{ margin-top:48px; margin-bottom:16px; color:var(--ink); font-size:1.55rem; font-weight:700; letter-spacing:-.022em; }
.prose h2:first-child{ margin-top:0; }
.prose h3{ margin-top:32px; margin-bottom:12px; color:var(--ink); font-size:1.2rem; font-weight:600; letter-spacing:-.015em; }
.prose p{ margin-bottom:16px; }
.prose ul, .prose ol{ padding-left:24px; margin-bottom:16px; display:flex; flex-direction:column; gap:8px; }
.prose li{ padding-left:4px; }
.prose strong{ font-weight:600; color:var(--ink); }
.prose a{ color:var(--primary-deep); text-decoration:underline; text-underline-offset:2px; }
.prose hr{ border:0; border-top:1px solid var(--line); margin:40px 0; }

/* ─── DEFINITION LIST (contacts) ─────────────────────────────── */
.kv-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
@media (max-width:700px){ .kv-grid{ grid-template-columns:1fr; } }
.kv{
  background:#fff; border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:28px;
  display:flex; gap:18px; align-items:flex-start;
  transition:all .35s var(--ease);
}
.kv:hover{ border-color:var(--primary-tint); box-shadow:0 16px 36px -18px rgba(80,128,224,.2); transform:translateY(-2px); }
.kv-icon{
  width:46px; height:46px; border-radius:12px; flex-shrink:0;
  background:var(--primary-soft); color:var(--primary-deep);
  display:flex; align-items:center; justify-content:center;
}
.kv-label{ font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-softer); font-weight:600; margin-bottom:4px; }
.kv-value{ font-weight:600; font-size:17px; letter-spacing:-.015em; color:var(--ink); line-height:1.3; }
.kv-value a{ color:var(--ink); transition:color .2s var(--ease); }
.kv-value a:hover{ color:var(--primary-deep); }
.kv-sub{ font-size:13px; color:var(--ink-soft); margin-top:4px; }

/* ─── FOOTER ─────────────────────────────────────────────────── */
footer{ background:#10131A; color:rgba(255,255,255,.72); padding:64px 0 32px; font-size:14.5px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; margin-bottom:48px; }
@media (max-width:900px){ .foot-grid{ grid-template-columns:1fr 1fr; gap:32px; } }
@media (max-width:480px){ .foot-grid{ grid-template-columns:1fr; } }
.foot-col h4{ color:#fff; font-weight:700; font-size:12px; letter-spacing:.12em; text-transform:uppercase; margin-bottom:18px; }
.foot-col ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.foot-col a{ color:rgba(255,255,255,.72); transition:color .2s var(--ease); }
.foot-col a:hover{ color:var(--accent); }
.foot-brand{ display:flex; flex-direction:column; gap:18px; align-items:flex-start; }
.foot-brand img{ height:44px; width:auto; max-width:180px; filter:brightness(0) invert(1); opacity:.95; }
.foot-brand p{ color:rgba(255,255,255,.6); line-height:1.6; max-width:36ch; }
.foot-social{ display:flex; gap:10px; margin-top:4px; }
.foot-social a{
  width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.06);
  display:flex; align-items:center; justify-content:center;
  transition:all .3s var(--ease);
}
.foot-social a:hover{ background:var(--accent); color:#2E1E00; transform:translateY(-2px); }
.foot-bottom{
  border-top:1px solid rgba(255,255,255,.08); padding-top:24px;
  display:flex; justify-content:space-between; align-items:center; gap:24px; flex-wrap:wrap;
  font-size:13px; color:rgba(255,255,255,.5);
}
.foot-bottom a{ color:rgba(255,255,255,.55); transition:color .2s var(--ease); }
.foot-bottom a:hover{ color:var(--accent); }
.foot-legal{ display:flex; gap:16px; flex-wrap:wrap; }

/* ─── REVEAL ANIMATION ───────────────────────────────────────── */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* ─── REPORTS — TRANSPARENCY SECTION ─────────────────────────── */
.reports{
  background:#F4F6FA;
  padding:clamp(80px,10vw,120px) 0;
  position:relative; overflow:hidden;
}
.reports::before{
  content:""; position:absolute; right:-100px; top:10%; z-index:0;
  width:380px; height:380px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,201,30,.1), transparent 70%);
  filter:blur(30px); pointer-events:none;
}
.reports .wrap{ position:relative; z-index:1; }

.reports-head{ max-width:860px; margin:0 auto 56px; text-align:center; }
.r-badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 18px; border-radius:999px;
  background:var(--accent); color:#2E1E00;
  font-size:11.5px; font-weight:800; letter-spacing:.14em; text-transform:uppercase;
  box-shadow:0 10px 24px -6px rgba(255,201,30,.5);
  margin-bottom:22px;
}
.r-badge svg{ width:14px; height:14px; stroke-width:2.5; }
.reports-head h2{ margin-bottom:20px; }
.reports-head > p{ color:var(--ink-soft); font-size:1.08rem; line-height:1.6; max-width:68ch; margin:0 auto 32px; }
.reports-head > p strong{ color:var(--ink); font-weight:700; }

.r-chips{ display:flex; flex-wrap:wrap; justify-content:center; gap:10px; }
.r-chip{
  display:inline-flex; align-items:center; gap:8px;
  padding:9px 16px; border-radius:999px;
  background:#fff; border:1px solid var(--line);
  font-size:13px; font-weight:600; color:var(--ink-soft); letter-spacing:-.005em;
  box-shadow:0 2px 6px rgba(26,40,71,.04);
}
.r-chip svg{ width:14px; height:14px; stroke-width:2.5; color:var(--primary); }
.r-chip.is-success svg{ color:#22C55E; }

.r-card{
  background:#fff; border:1px solid var(--line); border-radius:28px;
  padding:clamp(24px,3vw,40px);
  box-shadow:0 10px 30px -18px rgba(26,40,71,.15);
  margin-bottom:16px;
}
.r-card.is-clip{ padding:0; overflow:hidden; }

/* Expense breakdown */
.r-exp-head{
  display:flex; flex-wrap:wrap; gap:16px;
  justify-content:space-between; align-items:flex-start;
  margin-bottom:28px;
}
.r-exp-head h3{
  font-weight:800; font-size:1.2rem; letter-spacing:-.02em;
  display:flex; align-items:center; gap:10px; line-height:1.3;
}
.r-exp-head h3 svg{ width:22px; height:22px; color:var(--primary); stroke-width:2; }
.r-exp-head-sub{ font-size:13px; color:var(--ink-soft); margin-top:4px; max-width:52ch; }

.r-badge-success{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 16px; border-radius:12px;
  background:#F0FDF4; border:1px solid #BBF7D0; color:#16A34A;
  font-size:13.5px; font-weight:700; letter-spacing:-.005em; white-space:nowrap;
}
.r-badge-success svg{ width:14px; height:14px; stroke-width:2.5; }

.expense-bar{
  height:54px; border-radius:14px; overflow:hidden;
  display:flex; margin-bottom:24px;
  background:var(--muted);
  box-shadow:inset 0 1px 2px rgba(0,0,0,.06);
}
.exp-seg{
  height:100%; display:flex; align-items:center; justify-content:center;
  color:#fff; font-weight:800; font-size:14px; font-variant-numeric:tabular-nums;
  transition:opacity .3s var(--ease); overflow:hidden; white-space:nowrap;
}
.exp-seg:hover{ opacity:.88; }
.exp-seg.is-light{ color:#2E1E00; }

.exp-cards{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
@media (max-width:900px){ .exp-cards{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .exp-cards{ grid-template-columns:1fr; } }
.exp-card{
  background:#F7F8FB; border:1px solid var(--line); border-radius:14px;
  padding:18px 20px;
  transition:all .3s var(--ease);
}
.exp-card:hover{ border-color:var(--primary-tint); transform:translateY(-2px); }
.exp-card-top{ display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.exp-card-dot{ width:12px; height:12px; border-radius:50%; flex-shrink:0; }
.exp-card-name{ font-size:13.5px; font-weight:700; color:var(--ink); letter-spacing:-.01em; }
.exp-card-pct{
  margin-left:auto; font-size:1.3rem; font-weight:800;
  font-variant-numeric:tabular-nums; letter-spacing:-.025em;
}
.exp-card-sum{ font-size:12px; color:var(--ink-soft); font-weight:700; font-variant-numeric:tabular-nums; }

/* Tabs */
.r-tabs-head{
  background:var(--cream); padding:20px clamp(20px,3vw,28px);
  border-bottom:1px solid var(--line);
  display:flex; flex-wrap:wrap; gap:16px; align-items:center; justify-content:space-between;
}
.r-tabs-title h3{ font-size:1.08rem; font-weight:800; letter-spacing:-.02em; line-height:1.3; }
.r-tabs-title p{ font-size:12.5px; color:var(--ink-soft); margin-top:4px; }

.r-tabs{
  display:flex; gap:4px; padding:4px;
  background:var(--muted); border-radius:12px;
}
.r-tab{
  padding:8px 16px; border-radius:8px;
  font-size:13.5px; font-weight:700; letter-spacing:-.01em;
  color:var(--ink-soft); background:transparent; cursor:pointer;
  transition:all .25s var(--ease); white-space:nowrap;
}
.r-tab:hover{ color:var(--primary-deep); }
.r-tab.is-active{ background:#fff; color:var(--primary-deep); box-shadow:0 2px 8px rgba(26,40,71,.08); }

.r-panel{ display:none; padding:clamp(24px,3vw,32px); }
.r-panel.is-active{ display:block; }

.r-month-note{
  border-left:4px solid var(--primary);
  background:var(--primary-softer); border-radius:14px;
  padding:18px 22px; margin-bottom:28px;
  display:flex; flex-wrap:wrap; gap:16px; align-items:flex-start; justify-content:space-between;
}
.r-month-note-title{ font-weight:800; color:var(--primary-deep); font-size:14px; margin-bottom:4px; }
.r-month-note-desc{ font-size:13.5px; color:var(--primary-deep); line-height:1.5; font-weight:500; max-width:52ch; }
.r-tags{ display:flex; flex-wrap:wrap; gap:8px; }
.r-tag-primary{
  padding:7px 14px; border-radius:999px;
  background:var(--primary); color:#fff;
  font-size:12px; font-weight:800; letter-spacing:-.01em;
  font-variant-numeric:tabular-nums; white-space:nowrap;
}
.r-tag-accent{
  padding:7px 14px; border-radius:999px;
  background:var(--accent); color:#2E1E00;
  font-size:12px; font-weight:800; letter-spacing:-.01em; white-space:nowrap;
}

.r-month-h4{
  display:flex; align-items:center; gap:10px;
  font-size:1rem; font-weight:800; color:var(--ink); margin-bottom:16px; letter-spacing:-.015em;
}
.r-month-h4-icon{
  width:28px; height:28px; border-radius:8px;
  background:var(--primary-soft); color:var(--primary-deep);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.r-month-h4-icon svg{ width:14px; height:14px; stroke-width:2.5; }

/* Table */
.r-table-wrap{
  position:relative; isolation:isolate;
  border:1px solid var(--line); border-radius:16px; overflow:hidden;
  box-shadow:0 2px 8px rgba(26,40,71,.04);
}
.r-watermark{
  position:absolute; inset:0; z-index:0;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  opacity:.04; pointer-events:none; color:var(--primary-deep);
}
.r-watermark svg{ width:108px; height:108px; margin-bottom:14px; stroke-width:1.5; }
.r-watermark-text{ font-size:1.9rem; font-weight:900; letter-spacing:.2em; text-transform:uppercase; }

.r-table-scroll{ position:relative; z-index:1; overflow-x:auto; }
.r-table{
  width:100%; border-collapse:collapse;
  background:rgba(255,255,255,.92); font-size:14px; min-width:560px;
}
.r-table thead{ background:var(--cream); border-bottom:1px solid var(--line); }
.r-table th{
  padding:12px 20px; text-align:left;
  font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-soft);
}
.r-table th:last-child{ text-align:right; }
.r-table tbody tr{ border-bottom:1px solid var(--line); transition:background .2s var(--ease); }
.r-table tbody tr:hover{ background:rgba(232,238,252,.5); }
.r-table tbody tr:last-child{ border-bottom:0; }
.r-table td{ padding:14px 20px; vertical-align:top; }
.r-table-cat{ display:flex; align-items:center; gap:10px; font-weight:700; color:var(--ink); letter-spacing:-.01em; white-space:nowrap; }
.r-table-cat-dot{ width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.r-table-desc{ color:var(--ink-soft); font-size:13.5px; line-height:1.5; }
.r-table-sum{ text-align:right; font-weight:700; color:var(--ink); font-variant-numeric:tabular-nums; white-space:nowrap; }
.r-table tfoot{ background:var(--primary-softer); border-top:1px solid var(--primary-tint); }
.r-table tfoot td{ padding:16px 20px; font-weight:800; color:var(--ink); text-transform:uppercase; letter-spacing:.1em; font-size:13px; }
.r-table tfoot td:last-child{ color:var(--primary-deep); font-size:1.1rem; letter-spacing:-.02em; text-transform:none; font-variant-numeric:tabular-nums; }

/* PDF grid */
.r-docs-head{
  display:flex; align-items:center; gap:12px;
  font-size:1.25rem; font-weight:800; margin:48px 0 24px; letter-spacing:-.02em; color:var(--ink);
}
.r-docs-head svg{ width:22px; height:22px; color:var(--accent-deep); stroke-width:2; }

.pdf-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:14px; }
@media (max-width:1000px){ .pdf-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:640px){ .pdf-grid{ grid-template-columns:repeat(2,1fr); } }

.pdf-card{
  position:relative; display:block;
  background:#fff; border:1px solid var(--line); border-radius:18px;
  overflow:hidden; transition:all .3s var(--ease);
}
.pdf-card:hover{ border-color:var(--primary-tint); transform:translateY(-3px); box-shadow:0 18px 32px -14px rgba(26,40,71,.18); }
.pdf-card-label{
  position:absolute; top:8px; left:8px; z-index:2;
  background:rgba(255,255,255,.92); backdrop-filter:blur(6px);
  padding:4px 10px; border-radius:8px;
  font-size:10px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-soft); border:1px solid var(--line);
}
.pdf-card-body{
  height:160px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:18px; text-align:center;
  background:#F7F8FB; transition:background .3s var(--ease);
}
.pdf-card:hover .pdf-card-body{ background:var(--primary-softer); }
.pdf-card-body svg{ width:38px; height:38px; color:var(--primary); margin-bottom:12px; stroke-width:1.8; }
.pdf-card-name{ font-size:12.5px; font-weight:700; color:var(--ink); letter-spacing:-.01em; line-height:1.3; }

/* OCI card */
.r-oci{
  display:flex; flex-wrap:wrap; gap:20px; align-items:center;
  margin-bottom:16px;
}
.r-oci-main{
  display:flex; align-items:center; gap:16px; flex:1; min-width:260px;
}
.r-oci-icon{
  width:52px; height:52px; border-radius:14px; flex-shrink:0;
  background:var(--primary-softer); color:var(--primary-deep);
  display:flex; align-items:center; justify-content:center;
}
.r-oci-icon svg{ width:22px; height:22px; stroke-width:2; }
.r-oci-title{ font-weight:800; font-size:1.08rem; color:var(--ink); letter-spacing:-.015em; line-height:1.3; }
.r-oci-sub{ font-size:13px; color:var(--ink-soft); margin-top:4px; max-width:52ch; }

.r-info-strip{
  background:#F7F8FB; border-radius:10px;
  padding:12px 18px; margin-top:20px;
  font-size:12.5px; color:var(--ink-soft); font-weight:500;
  display:flex; align-items:flex-start; gap:10px; width:100%;
}
.r-info-strip svg{ width:16px; height:16px; color:var(--primary); flex-shrink:0; margin-top:2px; stroke-width:2; }

/* Request card */
.r-request{
  display:flex; flex-wrap:wrap; gap:20px; align-items:center; justify-content:space-between;
}
.r-request-title{ font-weight:800; font-size:1.08rem; color:var(--ink); letter-spacing:-.015em; }
.r-request-sub{ font-size:13px; color:var(--ink-soft); margin-top:4px; max-width:52ch; }

/* Photo report masonry */
.pr-head{ display:flex; align-items:center; gap:12px; margin-bottom:24px; flex-wrap:wrap; }
.pr-head svg{ width:22px; height:22px; color:var(--accent-deep); stroke-width:2; flex-shrink:0; }
.pr-head h4{ font-size:1.2rem; font-weight:800; letter-spacing:-.02em; color:var(--ink); margin:0; }
.pr-head-meta{ margin-left:auto; display:flex; gap:8px; flex-wrap:wrap; }
.pr-head-tag{
  padding:6px 14px; border-radius:999px;
  background:var(--primary); color:#fff;
  font-size:12px; font-weight:800; letter-spacing:-.005em; white-space:nowrap;
}
.pr-head-tag.is-accent{ background:var(--accent); color:#2E1E00; }
.pr-sub{ margin-bottom:24px; color:var(--ink-soft); font-size:14px; line-height:1.55; max-width:72ch; }

.pr-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(180px, 1fr));
  grid-auto-rows:160px; gap:10px; grid-auto-flow:dense;
}
@media (max-width:560px){ .pr-grid{ grid-auto-rows:120px; grid-template-columns:repeat(auto-fill, minmax(140px,1fr)); } }

.pr-item{
  position:relative; overflow:hidden; border-radius:12px;
  background:var(--primary-darker);
  transition:transform .4s var(--ease);
}
.pr-item.is-tall{ grid-row:span 2; }
.pr-item.is-wide{ grid-column:span 2; }
.pr-item.is-big{ grid-column:span 2; grid-row:span 2; }
.pr-item:hover{ transform:scale(1.015); }
.pr-item img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease), filter .4s var(--ease); filter:saturate(.96); }
.pr-item:hover img{ transform:scale(1.05); filter:saturate(1.05); }

@media (max-width:560px){
  .pr-item.is-wide, .pr-item.is-big{ grid-column:span 2; }
  .pr-item.is-big{ grid-row:span 2; }
}

/* ─── UTILITY ────────────────────────────────────────────────── */
.mt-20{ margin-top:20px; } .mt-32{ margin-top:32px; } .mt-48{ margin-top:48px; }
.mb-20{ margin-bottom:20px; } .mb-32{ margin-bottom:32px; } .mb-48{ margin-bottom:48px; }
.text-center{ text-align:center; }
.flex-cta{ display:flex; flex-wrap:wrap; gap:14px; }
