/* ===== GERTS FOUNDATION — tokens ===== */
:root{
  --bg:#0b0b0c;
  --bg-2:#111113;
  --bg-3:#17171a;
  --line:rgba(255,255,255,0.08);
  --line-2:rgba(255,255,255,0.14);
  --ink:#f2f1ee;
  --ink-dim:rgba(242,241,238,0.62);
  --ink-mute:rgba(242,241,238,0.42);
  --red:oklch(0.62 0.22 25);
  --red-hot:oklch(0.68 0.25 25);
  --orange:oklch(0.76 0.18 55);
  --accent:var(--red);
  --mono:"JetBrains Mono", ui-monospace, monospace;
  --display:"Unbounded", "Wix Madefor Display", system-ui, sans-serif;
  --text:"Wix Madefor Text", system-ui, sans-serif;
  --maxw:1440px;
  --pad-x:clamp(20px, 4vw, 56px);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--text);font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden;max-width:100vw}
body{cursor:none}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:none;padding:0}

/* custom crosshair cursor */
.crosshair{position:fixed;left:0;top:0;width:22px;height:22px;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:difference}
.crosshair::before,.crosshair::after{content:"";position:absolute;background:#fff}
.crosshair::before{left:50%;top:0;bottom:0;width:1px;transform:translateX(-0.5px)}
.crosshair::after{top:50%;left:0;right:0;height:1px;transform:translateY(-0.5px)}
.crosshair .ring{position:absolute;inset:0;border:1px solid #fff;border-radius:50%;transform:scale(.35);transition:transform .2s}
.crosshair.hot .ring{transform:scale(1);border-color:var(--red-hot)}
@media (hover:none){body{cursor:auto} .crosshair{display:none}}

/* typography */
h1,h2,h3,h4{margin:0;font-family:var(--display);font-weight:600;letter-spacing:-0.02em;line-height:0.95}
p{margin:0;line-height:1.55}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-mute)}
.serif-q{font-family:"Lora", Georgia, serif;font-style:italic}
.hl-red{color:var(--red-hot)}
.hl-orange{color:var(--orange)}

/* layout */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x)}
section{position:relative;padding:clamp(80px,10vw,140px) 0}
.section-head{display:grid;grid-template-columns:200px 1fr;gap:clamp(24px,4vw,64px);align-items:start;margin-bottom:clamp(36px,5vw,72px)}
.section-head .label{display:flex;flex-direction:column;gap:10px}
.section-head .label .num{font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:0.2em}
.section-head .label .tag{font-family:var(--mono);font-size:11px;color:var(--red-hot);letter-spacing:0.2em;text-transform:uppercase}
.section-head h2{font-size:clamp(40px,6vw,84px)}

/* header */
header.top{position:fixed;top:0;left:0;right:0;z-index:100;backdrop-filter:blur(14px);background:rgba(11,11,12,0.65);border-bottom:1px solid var(--line)}
header.top .inner{display:flex;align-items:center;justify-content:space-between;padding:16px var(--pad-x);max-width:var(--maxw);margin:0 auto}
.logo-mark{display:flex;align-items:center;gap:10px}
.logo-mark .g{width:34px;height:34px;display:grid;place-items:center}
.logo-mark .g img{width:100%;height:100%;object-fit:contain;display:block}
.logo-mark .wm{font-family:var(--display);letter-spacing:0.02em;font-size:15px}
.logo-mark .wm small{display:block;font-family:var(--mono);font-size:9px;color:var(--ink-mute);letter-spacing:0.22em;margin-top:2px}
nav.primary{display:flex;gap:28px;font-family:var(--mono);font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-dim)}
nav.primary a{position:relative;padding:6px 0}
nav.primary a:hover{color:var(--ink)}
.header-right{display:flex;gap:10px;align-items:center}
.btn{display:inline-flex;align-items:center;gap:10px;padding:12px 18px;border-radius:999px;font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;border:1px solid var(--line-2);transition:all .2s}
.btn:hover{border-color:var(--ink);color:var(--ink)}
.btn.primary{background:var(--red);color:#fff;border-color:var(--red)}
.btn.primary:hover{background:var(--red-hot);border-color:var(--red-hot)}
.btn .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.btn.primary .dot{background:#fff;animation:pulseDot 1.6s ease-in-out infinite}
@keyframes pulseDot{0%,100%{opacity:1}50%{opacity:0.35}}

/* HERO */
.hero{position:relative;min-height:100vh;padding-top:120px;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between}
.hero .rails{position:absolute;inset:0;pointer-events:none}
.hero .rails .v{position:absolute;top:0;bottom:0;width:1px;background:var(--line)}
.hero .rails .v.l{left:calc(var(--pad-x) + 0px)}
.hero .rails .v.r{right:calc(var(--pad-x) + 0px)}
.hero .rails .v.c{left:50%}
.hero .rails .h{position:absolute;left:0;right:0;height:1px;background:var(--line)}
.hero-meta{display:flex;justify-content:space-between;padding:14px var(--pad-x);font-family:var(--mono);font-size:10px;letter-spacing:0.2em;color:var(--ink-mute);text-transform:uppercase;border-bottom:1px solid var(--line)}
.hero-meta span b{color:var(--red-hot);font-weight:500}
.hero-body{flex:1;display:grid;align-content:center;padding:clamp(24px,6vw,80px) var(--pad-x);max-width:var(--maxw);margin:0 auto;width:100%}
.hero-slogan{font-family:var(--mono);font-size:12px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:28px;display:flex;gap:14px;align-items:center}
.hero-slogan .bar{height:1px;flex:1;background:var(--line-2);max-width:60px}
.hero h1{font-size:clamp(44px,7.6vw,124px);line-height:0.9;letter-spacing:-0.03em}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line > span{display:inline-block;transform:translateY(100%);animation:riseIn 1s cubic-bezier(.2,.7,.2,1) forwards}
.hero h1 .line:nth-child(2) > span{animation-delay:.12s}
.hero h1 .line:nth-child(3) > span{animation-delay:.24s}
@keyframes riseIn{to{transform:translateY(0)}}
.hero-tagline{margin-top:32px;font-family:"Lora",Georgia,serif;font-style:italic;font-size:clamp(20px,2vw,26px);max-width:640px;color:var(--ink);line-height:1.35}
.hero-tagline .quote{color:var(--red-hot);font-family:var(--display);font-style:normal;font-size:1.4em;line-height:0;vertical-align:-0.1em;margin-right:6px}
.hero-ctas{margin-top:40px;display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.hero-bottom{display:grid;grid-template-columns:1fr auto 1fr;align-items:end;padding:24px var(--pad-x);border-top:1px solid var(--line);gap:24px}
.hero-bottom .about{max-width:380px;color:var(--ink-dim);font-size:14px;line-height:1.55}
.hero-bottom .scroll{justify-self:center;display:flex;flex-direction:column;align-items:center;gap:10px;font-family:var(--mono);font-size:10px;letter-spacing:0.24em;color:var(--ink-mute);text-transform:uppercase}
.hero-bottom .scroll .line{width:1px;height:40px;background:linear-gradient(to bottom, transparent, var(--line-2), transparent);animation:scrollLine 2s ease-in-out infinite}
@keyframes scrollLine{0%,100%{opacity:0.4}50%{opacity:1}}
.hero-bottom .stamp{justify-self:end;text-align:right;font-family:var(--mono);font-size:10px;color:var(--ink-mute);letter-spacing:0.18em;text-transform:uppercase;line-height:1.6}

/* HERO canvas layers */
.hero-art{position:absolute;inset:0;pointer-events:none;z-index:0}
.hero-art canvas{position:absolute;inset:0;width:100%;height:100%}
.hero-body, .hero-meta, .hero-bottom{position:relative;z-index:2}

/* Variant A: word rotator */
.word-rot{display:inline-grid;position:relative;color:var(--red-hot);vertical-align:baseline}
.word-rot .w{grid-area:1 / 1;opacity:0;white-space:nowrap;pointer-events:none}
.word-rot .w.on{opacity:1;animation:rotWord .5s ease;pointer-events:auto}
@keyframes rotWord{from{opacity:0;transform:translateY(0.15em)}to{opacity:1;transform:translateY(0)}}

/* partners */
.partners-row{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:2px;overflow:hidden}
.partner-cell{background:var(--bg);padding:28px 18px;display:flex;align-items:center;justify-content:center;color:var(--ink-dim);font-family:var(--display);font-weight:500;font-size:16px;letter-spacing:0.01em;position:relative;transition:background .2s,color .2s}
.partner-cell:hover{background:var(--bg-2);color:var(--ink)}
.partner-cell .sm{font-family:var(--mono);font-size:9px;color:var(--ink-mute);letter-spacing:0.2em;text-transform:uppercase;position:absolute;top:8px;left:10px}

/* about / mission */
.mission-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:clamp(32px,5vw,80px);align-items:start}
.mission-body h3{font-size:clamp(28px,3.3vw,44px);margin-bottom:20px;font-weight:500}
.mission-body p{color:var(--ink-dim);font-size:17px;line-height:1.65;margin-bottom:14px;max-width:62ch}
.mission-aside{border-left:1px solid var(--line);padding-left:clamp(20px,3vw,40px);position:sticky;top:120px}
.stat-stack{display:grid;gap:24px}
.stat{display:grid;gap:4px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.stat .num{font-family:var(--display);font-size:48px;font-weight:600;letter-spacing:-0.02em;color:var(--ink);display:flex;align-items:baseline;gap:6px;font-variant-numeric:tabular-nums}
.count{position:relative;display:inline-block;font-variant-numeric:tabular-nums;line-height:1}
.count .count-reserve{visibility:hidden;display:inline-block;white-space:nowrap}
.count .count-live{position:absolute;left:0;top:0;right:0;text-align:left;white-space:nowrap}
.stat .num .unit{font-size:18px;color:var(--red-hot);font-weight:500}
.stat .label{font-family:var(--mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-mute)}

/* about story + why grids */
.story-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(32px,5vw,72px);align-items:start;margin-bottom:clamp(60px,8vw,120px)}
.story-text h3{font-size:clamp(28px,3.3vw,44px);margin-bottom:20px;font-weight:500;letter-spacing:-0.01em}
.story-text p{color:var(--ink-dim);font-size:17px;line-height:1.65;margin-bottom:14px;max-width:62ch}
.story-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px;padding-top:24px;border-top:1px solid var(--line)}
.story-stats .stat{border:none;padding:0}
.story-stats .num{font-family:var(--display);font-size:clamp(22px,2.2vw,28px);font-weight:600;letter-spacing:-0.01em;display:flex;align-items:baseline;gap:4px}
.story-stats .unit{font-size:0.55em;opacity:0.75}
.story-image{position:relative;aspect-ratio:4/3;overflow:hidden;border:1px solid var(--line);filter:grayscale(1) contrast(1.05)}
.story-image img{width:100%;height:100%;object-fit:cover;display:block}
.story-image .cap,.why-image .cap{position:absolute;left:12px;bottom:10px;font-family:var(--mono);font-size:10px;color:rgba(255,255,255,0.75);letter-spacing:0.2em;text-transform:uppercase;background:rgba(0,0,0,0.5);padding:4px 8px;backdrop-filter:blur(4px)}

.why-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(32px,5vw,72px);align-items:center;padding-top:clamp(32px,5vw,60px);border-top:1px solid var(--line)}
.why-image{position:relative;aspect-ratio:3/4;overflow:hidden;border:1px solid var(--line);filter:grayscale(1) contrast(1.05);max-width:520px}
.why-image img{width:100%;height:100%;object-fit:cover;display:block}
.why-text h3{font-size:clamp(32px,4vw,54px);margin-bottom:20px;font-weight:500;letter-spacing:-0.02em;line-height:1.05}
.why-text p{color:var(--ink-dim);font-size:17px;line-height:1.65;margin-bottom:14px;max-width:58ch}

/* hero watermark owl */
.hero-art .hero-owl-watermark{
  position:absolute;
  right:0;
  top:50%;
  transform:translateY(-50%);
  width:50vw;
  max-width:none;
  height:auto;
  opacity:0.34;
  filter:grayscale(0.2) contrast(1.05);
  pointer-events:none;
  mix-blend-mode:lighten;
  animation:owlFloat 9s ease-in-out infinite;
}
@keyframes owlFloat{0%,100%{transform:translateY(calc(-50% - 4px))}50%{transform:translateY(calc(-50% + 4px))}}
.hero-founded{margin-top:28px;display:flex;align-items:center;gap:14px;font-family:var(--mono);font-size:11px;color:var(--ink-dim);letter-spacing:0.2em;text-transform:uppercase}
.hero-founded b{color:var(--red-hot);font-weight:500}
.hero-founded .founded-line{height:1px;width:48px;background:var(--red-hot)}

@media (max-width: 960px){
  .story-grid, .why-grid{grid-template-columns:1fr}
  .why-image{max-width:100%;aspect-ratio:4/3}
  .story-stats{grid-template-columns:1fr}
}
/* team */
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.team-card{border:1px solid var(--line);background:var(--bg-2);padding:28px;display:grid;grid-template-columns:140px 1fr;gap:28px;transition:border .3s}
.team-card:hover{border-color:var(--line-2)}
.team-photo{width:140px;height:180px;background:var(--bg-3);position:relative;overflow:hidden;filter:grayscale(1) contrast(1.05)}
.team-photo img{width:100%;height:100%;object-fit:cover;display:block}
.team-photo .ph{position:absolute;inset:0;background:
  repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 6px),
  linear-gradient(180deg, #2a2a2e 0%, #18181a 100%)}
.team-photo .ph::after{content:attr(data-ph);position:absolute;inset:0;display:grid;place-items:center;font-family:var(--mono);font-size:10px;color:var(--ink-mute);letter-spacing:0.2em;text-transform:uppercase}
.team-info .name{font-family:var(--display);font-weight:600;font-size:22px;letter-spacing:-0.01em;margin-bottom:6px}
.team-info .role{font-family:var(--mono);font-size:10px;color:var(--red-hot);letter-spacing:0.2em;text-transform:uppercase;margin-bottom:14px}
.team-info .bio{color:var(--ink-dim);font-size:14px;line-height:1.6}
.team-info .expand{margin-top:14px;font-family:var(--mono);font-size:10px;color:var(--ink-mute);letter-spacing:0.2em;text-transform:uppercase;border-bottom:1px solid var(--line-2);display:inline-block;padding-bottom:2px;cursor:none}
.team-info .expand:hover{color:var(--ink);border-color:var(--ink)}
.team-card.expanded .bio-more{display:block}
.bio-more{display:none;margin-top:14px;padding-top:14px;border-top:1px solid var(--line);color:var(--ink-dim);font-size:14px;line-height:1.6}
.bio-more .quote-block{margin-top:16px;padding:14px 18px;border-left:2px solid var(--red);font-style:italic;color:var(--ink);font-family:"Lora",serif;font-size:15px;line-height:1.5}

/* directions */
.directions{display:grid;grid-template-columns:1fr;gap:0;border-top:1px solid var(--line)}
.direction-row{display:grid;grid-template-columns:80px 1.2fr 2fr 120px;align-items:center;padding:clamp(24px,3vw,40px) 0;border-bottom:1px solid var(--line);gap:clamp(20px,3vw,40px);cursor:none;position:relative;transition:padding .3s}
.direction-row:hover{padding-left:12px}
.direction-row .num{font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:0.2em;align-self:start;padding-top:10px}
.direction-row .title{font-family:var(--display);font-weight:500;font-size:clamp(28px,3.6vw,48px);letter-spacing:-0.02em;line-height:1}
.direction-row .desc{color:var(--ink-dim);font-size:15px;line-height:1.55;max-width:54ch}
.direction-row .arrow{justify-self:end;width:44px;height:44px;border:1px solid var(--line-2);border-radius:50%;display:grid;place-items:center;transition:all .3s}
.direction-row:hover .arrow{background:var(--red);border-color:var(--red);transform:rotate(-45deg)}
.direction-row .arrow svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.5}
.direction-preview{position:absolute;right:160px;top:50%;transform:translateY(-50%);width:280px;height:160px;background:var(--bg-3);overflow:hidden;filter:grayscale(1);opacity:0;pointer-events:none;transition:opacity .3s;border:1px solid var(--line)}
.direction-row:hover .direction-preview{opacity:1}
.direction-preview .ph{position:absolute;inset:0;background:
  repeating-linear-gradient(45deg, rgba(255,255,255,0.05) 0 2px, transparent 2px 8px),
  linear-gradient(180deg, #2a2a2e, #17171a)}
.direction-preview .lbl{position:absolute;bottom:8px;left:10px;font-family:var(--mono);font-size:9px;color:var(--ink-mute);letter-spacing:0.2em;text-transform:uppercase}

/* memorial */
.memorial-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:160px;gap:8px}
.mem-tile{position:relative;background:var(--bg-3);overflow:hidden;filter:grayscale(1)}
.mem-tile .ph{position:absolute;inset:0;background:
  repeating-linear-gradient(135deg, rgba(255,255,255,0.05) 0 2px, transparent 2px 8px),
  linear-gradient(180deg, #23232a, #0f0f12)}
.mem-tile .cap{position:absolute;left:10px;bottom:8px;font-family:var(--mono);font-size:9px;color:var(--ink-mute);letter-spacing:0.2em;text-transform:uppercase}
.mem-tile.span-2{grid-column:span 2}
.mem-tile.span-2r{grid-row:span 2}
.mem-tile.span-3{grid-column:span 3}
.mem-intro{max-width:56ch;color:var(--ink-dim);font-size:17px;line-height:1.65;margin-bottom:36px}

/* reporting */
.report-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(32px,4vw,64px);align-items:start}
.big-counter{border:1px solid var(--line);padding:32px;background:linear-gradient(180deg, var(--bg-2), var(--bg))}
.big-counter .label{font-family:var(--mono);font-size:11px;letter-spacing:0.2em;color:var(--ink-mute);text-transform:uppercase;margin-bottom:12px}
.big-counter .val{font-family:var(--display);font-weight:600;font-size:clamp(56px,8vw,112px);letter-spacing:-0.03em;line-height:1;color:var(--ink);display:flex;align-items:baseline;gap:10px;font-variant-numeric:tabular-nums}
.big-counter .val .cur{font-size:0.28em;color:var(--red-hot);font-weight:500}
.big-counter .val .cur.orange{color:var(--orange)}
.big-counter .sub{margin-top:14px;color:var(--ink-dim);font-size:13px;max-width:42ch;line-height:1.55}
.report-breakdown{display:grid;gap:18px;margin-top:24px}
.bar-row{display:grid;gap:8px}
.bar-row .meta{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;color:var(--ink-dim);letter-spacing:0.12em;text-transform:uppercase}
.bar-row .meta span:last-child{display:inline-block;min-width:4ch;text-align:right;font-variant-numeric:tabular-nums}
.bar-row .track{height:4px;background:var(--bg-3);position:relative;overflow:hidden}
.bar-row .fill{position:absolute;left:0;top:0;bottom:0;background:var(--red);transition:width 1.2s cubic-bezier(.2,.7,.2,1)}
.bar-row .fill.orange{background:var(--orange)}
.bar-row .fill.white{background:var(--ink-dim)}
.report-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:36px}
.reports-side{display:grid;gap:12px}
.report-item{display:grid;grid-template-columns:60px 1fr 24px;align-items:center;gap:14px;padding:16px 18px;border:1px solid var(--line);transition:border .2s, background .2s;cursor:none}
.report-item:hover{border-color:var(--line-2);background:var(--bg-2)}
.report-item .q{font-family:var(--mono);font-size:10px;color:var(--red-hot);letter-spacing:0.18em}
.report-item .n{font-family:var(--display);font-weight:500;font-size:15px}
.report-item .s{font-family:var(--mono);font-size:10px;color:var(--ink-mute);letter-spacing:0.15em;text-transform:uppercase;margin-top:3px}
.report-item svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5;opacity:0.5}

/* events */
.events-timeline{position:relative;padding-left:0}
.events-timeline::before{content:"";position:absolute;left:120px;top:0;bottom:0;width:1px;background:var(--line)}
.event-row{display:grid;grid-template-columns:120px 1fr;align-items:start;padding:28px 0;position:relative;gap:40px}
.event-row .date{font-family:var(--mono);font-size:11px;color:var(--ink-dim);letter-spacing:0.16em;text-transform:uppercase;padding-top:4px}
.event-row .date b{display:block;font-family:var(--display);font-weight:600;color:var(--ink);font-size:28px;letter-spacing:-0.01em;margin-bottom:4px}
.event-row::before{content:"";position:absolute;left:116px;top:36px;width:9px;height:9px;border-radius:50%;background:var(--bg);border:1px solid var(--line-2)}
.event-row.upcoming::before{background:var(--red);border-color:var(--red);box-shadow:0 0 0 4px rgba(219,68,55,0.15)}
.event-row .card{padding-left:60px;display:grid;gap:10px}
.event-row .tag{font-family:var(--mono);font-size:10px;letter-spacing:0.22em;color:var(--orange);text-transform:uppercase}
.event-row.upcoming .tag{color:var(--red-hot)}
.event-row h4{font-family:var(--display);font-size:clamp(20px,2vw,28px);font-weight:500;letter-spacing:-0.01em}
.event-row .loc{color:var(--ink-dim);font-size:14px;display:flex;gap:14px;font-family:var(--mono);letter-spacing:0.1em;text-transform:uppercase;font-size:10px}
.event-row .ph-img{margin-top:6px;height:120px;background:var(--bg-3);position:relative;overflow:hidden;filter:grayscale(1);max-width:520px}
.event-row .ph-img .ph{position:absolute;inset:0;background:repeating-linear-gradient(135deg, rgba(255,255,255,0.05) 0 2px, transparent 2px 8px), linear-gradient(180deg, #2a2a2e, #17171a)}
.event-row .ph-img .cap{position:absolute;bottom:8px;left:10px;font-family:var(--mono);font-size:9px;color:var(--ink-mute);letter-spacing:0.2em;text-transform:uppercase}

/* big cta */
.big-cta{padding:clamp(100px,14vw,180px) 0;text-align:center;border-top:1px solid var(--line);position:relative;overflow:hidden;isolation:isolate}
.big-cta::before{content:"";position:absolute;inset:0;background:url("assets/owl-skeleton.jpg") center/contain no-repeat;opacity:0.18;filter:grayscale(0.2) contrast(1.05);z-index:-1;pointer-events:none}
.big-cta::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center, transparent 0%, var(--bg) 80%);z-index:-1;pointer-events:none}
.big-cta .eyebrow{margin-bottom:20px}
.big-cta h2{font-size:clamp(52px,9vw,140px);line-height:0.92;max-width:12ch;margin:0 auto 28px}
.big-cta h2 em{font-style:normal;color:var(--red-hot)}
.big-cta .sub{color:var(--ink-dim);max-width:52ch;margin:0 auto 36px;font-size:17px;line-height:1.55}
.big-cta .ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* contacts */
.contacts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.contact-block{padding:36px 40px;border-right:1px solid var(--line);display:grid;gap:12px}
.contact-block:last-child{border-right:none}
.contact-block .lbl{font-family:var(--mono);font-size:10px;letter-spacing:0.22em;color:var(--ink-mute);text-transform:uppercase}
.contact-block .val{font-family:var(--display);font-weight:500;font-size:22px;letter-spacing:-0.01em}
.contact-block .socials{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.contact-block .socials a{font-family:var(--mono);font-size:13px;color:var(--ink-dim);letter-spacing:0.06em;display:flex;align-items:center;gap:10px;padding:4px 0}
.contact-block .socials a:hover{color:var(--ink)}
.contact-block .socials a::before{content:"→";color:var(--red-hot);font-family:var(--display)}

/* footer */
footer{padding:40px var(--pad-x);display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:10px;letter-spacing:0.2em;color:var(--ink-mute);text-transform:uppercase;max-width:var(--maxw);margin:0 auto;flex-wrap:wrap;gap:16px}
footer .footer-motto{text-align:center}

/* live ticker */
.ticker{position:fixed;bottom:0;left:0;right:0;z-index:90;background:var(--bg-2);border-top:1px solid var(--line);overflow:hidden;height:32px;display:flex;align-items:center}
.ticker .label{flex-shrink:0;background:var(--red);color:#fff;padding:0 14px;height:100%;display:flex;align-items:center;font-family:var(--mono);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;gap:8px}
.ticker .label .live-dot{width:6px;height:6px;border-radius:50%;background:#fff;animation:pulseDot 1.2s ease-in-out infinite}
.ticker .track{flex:1;overflow:hidden;position:relative;white-space:nowrap}
.ticker .track .line{display:inline-block;padding-left:100%;animation:tickerMove 60s linear infinite;font-family:var(--mono);font-size:11px;letter-spacing:0.12em;color:var(--ink-dim);text-transform:uppercase}
.ticker .track .line b{color:var(--ink);font-weight:500}
.ticker .track .line .sep{margin:0 18px;color:var(--red-hot)}
@keyframes tickerMove{from{transform:translateX(0)}to{transform:translateX(-100%)}}
body{padding-bottom:32px}

/* tweaks panel */
.tweaks{position:fixed;right:20px;bottom:50px;z-index:120;background:var(--bg-2);border:1px solid var(--line-2);padding:16px;width:280px;display:none;font-family:var(--mono);font-size:11px;backdrop-filter:blur(10px);box-shadow:0 24px 60px rgba(0,0,0,0.5)}
.tweaks.on{display:block}
.tweaks h5{font-family:var(--mono);font-size:10px;letter-spacing:0.22em;color:var(--red-hot);text-transform:uppercase;margin:0 0 12px}
.tweaks .row{display:grid;gap:6px;margin-bottom:14px}
.tweaks .row .lbl{color:var(--ink-mute);letter-spacing:0.14em;text-transform:uppercase;font-size:10px}
.tweaks .opts{display:flex;gap:6px;flex-wrap:wrap}
.tweaks .opt{padding:6px 10px;border:1px solid var(--line-2);color:var(--ink-dim);cursor:none;font-size:10px;letter-spacing:0.1em;text-transform:uppercase;transition:all .15s}
.tweaks .opt:hover{color:var(--ink)}
.tweaks .opt.on{background:var(--red);border-color:var(--red);color:#fff}

/* SVG owl logo */
.owl-svg{display:block}
.owl-svg path,.owl-svg circle,.owl-svg line{vector-effect:non-scaling-stroke}

/* helpers */
.hide{display:none !important}
.u-flex{display:flex;gap:12px;align-items:center}
.u-mono-sm{font-family:var(--mono);font-size:10px;color:var(--ink-mute);letter-spacing:0.2em;text-transform:uppercase}

/* ===== HELP (куди звертатися) ===== */
.help-intro{max-width:64ch;color:var(--ink-dim);font-size:17px;line-height:1.65;margin-bottom:36px}
.help-list{border-top:1px solid var(--line)}
.help-row{border-bottom:1px solid var(--line);transition:background .2s}
.help-row.open{background:var(--bg-2)}
.help-head{display:grid;grid-template-columns:130px 1.1fr 2fr 40px;align-items:center;gap:clamp(18px,2.4vw,36px);width:100%;padding:clamp(22px,2.6vw,32px) 0;text-align:left;cursor:none;transition:padding .3s}
.help-row.open .help-head{padding-left:12px}
.help-head .tag{font-family:var(--mono);font-size:11px;color:var(--red-hot);letter-spacing:0.2em;text-transform:uppercase}
.help-head .title{font-family:var(--display);font-weight:500;font-size:clamp(22px,2.6vw,34px);letter-spacing:-0.01em;line-height:1.05}
.help-head .short{color:var(--ink-dim);font-size:14px;line-height:1.55;max-width:62ch}
.help-head .toggle{justify-self:end;width:40px;height:40px;border:1px solid var(--line-2);border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-size:20px;color:var(--ink-dim);transition:all .2s}
.help-row.open .help-head .toggle{background:var(--red);border-color:var(--red);color:#fff}
.help-body{display:none;padding:0 0 clamp(24px,3vw,40px) 130px;gap:clamp(24px,4vw,64px);grid-template-columns:1.4fr 1fr}
.help-row.open .help-body{display:grid}
.help-points ul{list-style:none;padding:0;margin:8px 0 0;display:grid;gap:8px}
.help-points li{position:relative;padding-left:22px;color:var(--ink-dim);font-size:15px;line-height:1.55;max-width:54ch}
.help-points li::before{content:"→";position:absolute;left:0;top:0;color:var(--red-hot);font-family:var(--display);font-size:14px}
.help-contact{border-left:1px solid var(--line);padding-left:clamp(18px,2vw,28px);display:grid;gap:4px;align-content:start}
.help-contact .val{font-family:var(--display);font-weight:500;font-size:clamp(18px,1.8vw,22px);color:var(--ink);letter-spacing:-0.01em;margin-top:4px}
.help-contact .extra{font-family:var(--mono);font-size:10px;color:var(--ink-mute);letter-spacing:0.16em;text-transform:uppercase;margin-top:6px}

/* ===== REPORTING · monthly scroll ===== */
.reports-scroll{display:grid;gap:8px;max-height:520px;overflow-y:auto;padding-right:4px;scrollbar-width:thin;scrollbar-color:var(--line-2) transparent}
.reports-scroll::-webkit-scrollbar{width:6px}
.reports-scroll::-webkit-scrollbar-track{background:transparent}
.reports-scroll::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:3px}

/* ===== REGISTER · реєстрація ґерця ===== */
.register-sec{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.register-sec::before{content:"";position:absolute;inset:0;background:
  repeating-linear-gradient(0deg, transparent 0 40px, rgba(255,255,255,0.015) 40px 41px),
  repeating-linear-gradient(90deg, transparent 0 40px, rgba(255,255,255,0.015) 40px 41px);
  pointer-events:none}
.reg-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(32px,5vw,72px);align-items:start;position:relative}
.reg-text h3{font-size:clamp(28px,3.3vw,44px);margin:28px 0 18px;font-weight:500;letter-spacing:-0.02em;line-height:1.05}
.reg-text p{color:var(--ink-dim);font-size:17px;line-height:1.65;margin-bottom:14px;max-width:60ch}
.reg-term{border:1px solid var(--line-2);background:#050507;font-family:var(--mono);font-size:12px;padding:14px 18px;color:var(--ink-dim);letter-spacing:0.04em;position:relative;overflow:hidden;animation:termFlicker 7s steps(60,end) infinite}
.reg-term::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg, transparent, var(--red-hot), transparent);animation:termSweep 3.2s linear infinite;z-index:3}
.reg-term::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,0.55) 100%);pointer-events:none;z-index:2;mix-blend-mode:multiply}
@keyframes termSweep{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
@keyframes termFlicker{
  0%,100%{filter:brightness(1) contrast(1)}
  8%{filter:brightness(1.05) contrast(1.1)}
  9%{filter:brightness(0.85) contrast(0.95)}
  10%{filter:brightness(1) contrast(1)}
  42%{filter:brightness(1) contrast(1)}
  43%{filter:brightness(1.15) contrast(1.2)}
  44%{filter:brightness(0.9) contrast(1)}
  45%{filter:brightness(1) contrast(1)}
  72%{filter:brightness(1) contrast(1)}
  73%{filter:brightness(0.7) contrast(0.9)}
  74%{filter:brightness(1.1) contrast(1.1)}
  75%{filter:brightness(1) contrast(1)}
}
.reg-term.glitching{animation:termShake 0.3s steps(6,end)}
@keyframes termShake{
  0%{transform:translate(0,0)}
  20%{transform:translate(-1px,1px)}
  40%{transform:translate(1px,-1px)}
  60%{transform:translate(-1px,-1px)}
  80%{transform:translate(1px,0)}
  100%{transform:translate(0,0)}
}

/* scanlines */
.reg-term .term-scanlines{position:absolute;inset:0;background:repeating-linear-gradient(0deg, rgba(0,0,0,0) 0, rgba(0,0,0,0) 2px, rgba(255,255,255,0.025) 2px, rgba(255,255,255,0.025) 3px);pointer-events:none;z-index:2;mix-blend-mode:screen}
.reg-term .term-scanlines::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, transparent 0%, rgba(219,68,55,0.06) 50%, transparent 100%);height:40px;animation:termScan 4s linear infinite;pointer-events:none}
@keyframes termScan{0%{transform:translateY(-100%)}100%{transform:translateY(900%)}}

/* matrix falling columns behind content */
.reg-term .term-matrix{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:1;opacity:0.38}
.reg-term .term-matrix .mcol{position:absolute;top:-60%;display:flex;flex-direction:column;font-family:var(--mono);font-size:11px;color:var(--red-hot);line-height:1.2;animation:matrixFall linear infinite;white-space:nowrap}
.reg-term .term-matrix .mcol i{font-style:normal;opacity:0;animation:matrixChar 1.2s linear infinite}
.reg-term .term-matrix .mcol i:nth-child(1){animation-delay:0s}
.reg-term .term-matrix .mcol i:nth-child(2){animation-delay:0.08s}
.reg-term .term-matrix .mcol i:nth-child(3){animation-delay:0.16s}
.reg-term .term-matrix .mcol i:nth-child(4){animation-delay:0.24s}
.reg-term .term-matrix .mcol i:nth-child(5){animation-delay:0.32s}
.reg-term .term-matrix .mcol i:nth-child(6){animation-delay:0.40s}
.reg-term .term-matrix .mcol i:nth-child(7){animation-delay:0.48s}
.reg-term .term-matrix .mcol i:nth-child(8){animation-delay:0.56s}
.reg-term .term-matrix .mcol i:nth-child(9){animation-delay:0.64s}
.reg-term .term-matrix .mcol i:nth-child(10){animation-delay:0.72s;color:#fff;text-shadow:0 0 6px var(--red-hot)}
.reg-term .term-matrix .mcol i:nth-child(11){animation-delay:0.80s;opacity:0.6;color:var(--orange)}
.reg-term .term-matrix .mcol i:nth-child(n+12){animation-delay:0.88s;opacity:0.4}
@keyframes matrixFall{0%{transform:translateY(0)}100%{transform:translateY(280%)}}
@keyframes matrixChar{0%,60%{opacity:0.9}100%{opacity:0}}

.reg-term .term-head,.reg-term .term-lines{position:relative;z-index:4}
.reg-term .term-head{display:flex;align-items:center;gap:10px;padding-bottom:10px;border-bottom:1px solid var(--line);margin-bottom:10px;font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-mute)}
.reg-term .term-head .dot{width:7px;height:7px;border-radius:50%;background:var(--red-hot);animation:pulseDot 1.6s ease-in-out infinite;box-shadow:0 0 8px var(--red-hot)}
.reg-term .term-head .ok{margin-left:auto;color:var(--red-hot);font-weight:500;display:inline-flex;align-items:center;gap:6px}
.reg-term .term-head .blink{color:var(--red-hot);animation:blinkHard 1s steps(2,end) infinite}
@keyframes blinkHard{0%,49%{opacity:1}50%,100%{opacity:0}}
.reg-term .term-lines{display:grid;gap:4px;line-height:1.6}
.reg-term .term-lines b{color:var(--red-hot);font-weight:500;display:inline-block;min-width:5ch;text-shadow:0 0 8px rgba(219,68,55,0.45);position:relative}
.reg-term.glitching .term-lines b{color:#fff;text-shadow:-2px 0 var(--red-hot), 2px 0 oklch(0.7 0.2 230), 0 0 8px rgba(219,68,55,0.6);animation:rgbShift 0.3s steps(6,end)}
@keyframes rgbShift{
  0%{text-shadow:-2px 0 var(--red-hot), 2px 0 oklch(0.7 0.2 230)}
  33%{text-shadow:2px 0 var(--red-hot), -2px 0 oklch(0.7 0.2 230)}
  66%{text-shadow:-1px 0 var(--red-hot), 1px 0 oklch(0.7 0.2 230)}
  100%{text-shadow:0 0 8px rgba(219,68,55,0.45)}
}
.reg-term .mono-c{color:var(--orange)}
.reg-term .tok{color:var(--ink)}
.reg-term .dim{color:var(--ink-mute);margin-top:6px;font-size:11px}
.reg-term .cursor-blink{color:var(--red-hot);animation:blinkHard 0.8s steps(2,end) infinite;margin-left:2px;font-weight:500}
.reg-bullets{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:8px}
.reg-bullets li{position:relative;padding-left:34px;color:var(--ink-dim);font-size:14px;line-height:1.55;font-family:var(--mono);letter-spacing:0.04em}
.reg-bullets li::before{content:"[·]";position:absolute;left:0;color:var(--red-hot);font-family:var(--mono)}
.reg-cta{border:1px solid var(--line-2);padding:clamp(24px,3vw,36px);background:linear-gradient(180deg, var(--bg-3), var(--bg-2));display:grid;gap:14px;position:sticky;top:120px}
.reg-number{display:grid;gap:4px;padding-bottom:16px;border-bottom:1px solid var(--line);margin-bottom:6px}
.reg-number .sm{font-family:var(--mono);font-size:10px;color:var(--ink-mute);letter-spacing:0.2em;text-transform:uppercase}
.reg-number .val{font-family:var(--display);font-weight:600;font-size:clamp(44px,5vw,64px);letter-spacing:-0.02em;color:var(--ink);font-variant-numeric:tabular-nums;line-height:1}
.reg-note{color:var(--ink-mute);font-size:13px;line-height:1.55;margin-top:6px}

/* ===== DONATE box (BigCTA enhanced) ===== */
.big-cta .donate-box{max-width:920px;margin:40px auto 0;border:1px solid var(--line-2);padding:clamp(22px,2.6vw,32px);background:rgba(17,17,19,0.72);backdrop-filter:blur(8px);text-align:left;display:grid;gap:22px}
.donate-tabs{display:flex;gap:6px;justify-content:center;border-bottom:1px solid var(--line);padding-bottom:14px}
.d-tab{font-family:var(--mono);font-size:12px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-mute);padding:8px 14px;cursor:none;border:1px solid transparent;transition:all .15s}
.d-tab:hover{color:var(--ink)}
.d-tab.on{color:#fff;background:var(--red);border-color:var(--red)}
.donate-amounts{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.d-amt{font-family:var(--mono);font-size:13px;letter-spacing:0.14em;padding:12px 18px;border:1px solid var(--line-2);color:var(--ink-dim);cursor:none;transition:all .15s;min-width:110px;font-variant-numeric:tabular-nums}
.d-amt:hover{color:var(--ink);border-color:var(--ink-dim)}
.d-amt.on{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.d-custom{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line-2);padding:0 14px;min-width:140px;transition:border .15s}
.d-custom.on{border-color:var(--ink)}
.d-custom input{background:transparent;border:none;outline:none;color:var(--ink);font-family:var(--mono);font-size:13px;letter-spacing:0.1em;padding:12px 0;width:100%;min-width:0}
.d-custom input::placeholder{color:var(--ink-mute);text-transform:uppercase;letter-spacing:0.18em;font-size:11px}
.d-custom span{color:var(--ink-dim);font-family:var(--mono);font-size:13px}
.donate-cta-row{display:flex;gap:14px;align-items:center;justify-content:center;flex-wrap:wrap;padding-top:8px;border-top:1px dashed var(--line)}
.donate-cta-row .btn.primary{padding:16px 26px;font-size:12px}
.donate-cta-row .btn.primary .mono-tag{font-family:var(--mono);opacity:0.7;margin-left:4px;letter-spacing:0.12em}
.donate-note{font-family:var(--mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-mute);max-width:38ch}
.donate-details{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;padding-top:20px;border-top:1px solid var(--line);text-align:left}
.donate-details .d-col{display:grid;gap:4px;align-content:start}
.donate-details .d-val{font-family:var(--display);font-weight:500;font-size:16px;color:var(--ink);letter-spacing:-0.01em;margin-top:2px}
.donate-details .d-val.mono{font-family:var(--mono);font-size:13px;letter-spacing:0.06em;color:var(--ink);word-break:break-all}
.donate-details .d-val.mono.small{font-size:11px;letter-spacing:0.04em;color:var(--ink-dim)}
.donate-details .d-val-dim{color:var(--ink-dim);font-size:13px;line-height:1.55;margin-top:4px}

/* responsive */
@media (max-width: 960px){
  .mission-grid{grid-template-columns:1fr}
  .mission-aside{border-left:none;padding-left:0;border-top:1px solid var(--line);padding-top:24px}
  .team-grid{grid-template-columns:1fr}
  .direction-row{grid-template-columns:40px 1fr 44px;row-gap:10px}
  .direction-row .desc{grid-column:2 / span 2;max-width:100%}
  .direction-preview{display:none}
  .memorial-grid{grid-template-columns:repeat(3,1fr)}
  .report-grid{grid-template-columns:1fr}
  .contacts-grid{grid-template-columns:1fr}
  .contact-block{border-right:none;border-bottom:1px solid var(--line)}
  .section-head{grid-template-columns:1fr}
  .hero-bottom{grid-template-columns:1fr;gap:14px}
  .hero-bottom .scroll, .hero-bottom .stamp{justify-self:start;text-align:left}
  nav.primary{display:none}
  .events-timeline::before{left:0}
  .event-row{grid-template-columns:1fr;gap:10px}
  .event-row::before{left:-4px;top:10px}
  .event-row .card{padding-left:20px}
  .partners-row{grid-template-columns:repeat(3,1fr)}
  .hero-art .hero-owl-watermark{width:80vw;right:0;opacity:0.22}
  .help-head{grid-template-columns:1fr 36px;row-gap:4px;column-gap:12px}
  .help-head .tag{grid-column:1;grid-row:1}
  .help-head .toggle{grid-column:2;grid-row:1;align-self:start;justify-self:end}
  .help-head .title{grid-column:1 / span 2;grid-row:2}
  .help-head .short{grid-column:1 / span 2;grid-row:3;max-width:100%}
  .help-body{grid-template-columns:1fr;padding-left:0}
  .help-contact{border-left:none;border-top:1px solid var(--line);padding-left:0;padding-top:16px;margin-top:8px}
  .reg-grid{grid-template-columns:1fr}
  .reg-cta{position:static}
  .donate-details{grid-template-columns:1fr;gap:18px}
  .report-stats{grid-template-columns:repeat(2,1fr);gap:14px}
}

@media (max-width: 720px){
  body{cursor:auto}
  header.top .inner{padding:12px var(--pad-x);gap:10px}
  .logo-mark .wm{font-size:14px}
  .logo-mark .wm small{display:none}
  .header-right .btn{padding:10px 14px;font-size:10px}
  .header-right .btn.primary{padding:10px 14px}
  .hero{padding-top:90px}
  .hero-meta{flex-direction:column;gap:6px;align-items:flex-start;font-size:9px}
  .hero h1{font-size:clamp(38px,11vw,68px)}
  .hero-tagline{font-size:16px;line-height:1.45}
  .hero-ctas{flex-direction:column;align-items:stretch;gap:10px;margin-top:28px}
  .hero-ctas .btn{justify-content:center}
  .hero-ctas > span{display:none !important}
  .hero-bottom .about{font-size:13px}
  .hero-bottom .scroll{display:none}
  .hero-art .hero-owl-watermark{width:100vw;right:0;opacity:0.16;mix-blend-mode:screen}
  .report-stats{grid-template-columns:1fr;gap:10px}
  .report-stats .stat{padding-bottom:12px}
  .partners-row{grid-template-columns:repeat(2,1fr)}
  .partner-cell{padding:22px 12px;font-size:14px;text-align:center}
  .story-stats{grid-template-columns:1fr}
  .story-text h3, .why-text h3, .mission-body h3{font-size:clamp(24px,6vw,32px)}
  .team-card{grid-template-columns:1fr;padding:20px;gap:18px}
  .team-photo{width:100%;height:auto;aspect-ratio:4/3}
  .direction-row{padding:18px 0;gap:12px}
  .direction-row .num{font-size:10px;padding-top:6px}
  .direction-row .title{font-size:clamp(20px,5.5vw,28px)}
  .direction-row .desc{font-size:13px}
  .direction-row .arrow{width:36px;height:36px}
  .memorial-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:120px;gap:6px}
  .memorial-grid .span-2, .memorial-grid .span-2r{grid-column:auto;grid-row:auto}
  .big-counter{padding:22px 18px}
  .big-counter .val{font-size:clamp(40px,12vw,64px)}
  .big-counter .label{font-size:10px}
  .reports-side .report-item{grid-template-columns:48px 1fr 18px;padding:12px 14px;gap:10px}
  .reports-side .report-item .n{font-size:13px}
  .event-row .ph-img{display:none}
  .event-row .card{padding:16px 18px}
  .event-row .date b{font-size:18px}
  .events-timeline{padding-left:18px}
  .big-cta h2{font-size:clamp(40px,11vw,72px)}
  .big-cta .sub{font-size:14px}
  .big-cta .ctas{flex-direction:column;align-items:stretch}
  .big-cta .ctas .btn{justify-content:center}
  .big-cta::before{background-size:cover;opacity:0.12}
  .big-cta .donate-box{padding:18px 14px;gap:18px}
  .d-amt{flex:1;min-width:calc(50% - 6px);padding:12px 10px;font-size:12px}
  .d-custom{flex:1;min-width:100%}
  .donate-cta-row{flex-direction:column;align-items:stretch}
  .donate-cta-row .btn.primary{justify-content:center}
  .donate-note{text-align:center;max-width:none}
  .help-head{grid-template-columns:60px 1fr 32px;gap:12px}
  .help-head .tag{font-size:9px}
  .help-head .title{grid-column:1 / span 2;font-size:20px}
  .help-head .short{font-size:13px}
  .help-head .toggle{width:32px;height:32px;font-size:16px}
  .reg-text h3{font-size:24px}
  .reg-term{font-size:10px;padding:12px 14px}
  .reg-number .val{font-size:40px}
  .contact-block{padding:24px 22px}
  .contact-block .val{font-size:18px}
  footer{padding:28px var(--pad-x);font-size:9px;justify-content:flex-start;flex-direction:column;align-items:flex-start;gap:8px;padding-bottom:48px}
  .ticker .label{padding:0 10px;font-size:9px}
  .ticker .track .line{font-size:10px}
  section{padding:clamp(56px,12vw,90px) 0}
}

@media (max-width: 420px){
  :root{--pad-x:16px}
  .partners-row{grid-template-columns:1fr}
  .memorial-grid{grid-template-columns:1fr;grid-auto-rows:140px}
  .direction-row{grid-template-columns:32px 1fr 36px;gap:10px}
  .hero h1{font-size:clamp(34px,12vw,56px)}
}
