/* ============================================================
   Енергія Перемоги України — благодійний фонд
   Faithful recreation of energyfoundation.com.ua
   · Layout: editorial / sectioned — білий фон, повітря
   · Шрифти: Montserrat (700/800 заголовки) + Mulish (тіло)
   · Колір: white default · ORANGE #E84C1D акцент-блоки/кнопки
            · NAVY #070838 footer/текст · RASPBERRY #CC3366 другий акцент
   · Радіус: soft (12–22px) · Рух: fade+підйом (additive)
   · Фішка: фото-карусель hero + оранжевий блок «цифри» + колаж «Про нас»
   · Ease-out: cubic-bezier(0.23,1,0.32,1)
   ============================================================ */

:root{
  --orange:#E84C1D;
  --orange-d:#cf3f15;
  --navy:#070838;
  --navy-2:#0c0e4a;
  --berry:#CC3366;
  --berry-d:#b32a59;
  --white:#ffffff;
  --ink:#070838;
  --muted:#5a5c70;
  --line:#e7e7ef;
  --bg-alt:#f6f6fb;
  --radius:18px;
  --radius-lg:26px;
  --radius-sm:12px;
  --wrap:1200px;
  --shadow:0 10px 30px rgba(7,8,56,.08);
  --shadow-lg:0 18px 50px rgba(7,8,56,.14);
  --ease:cubic-bezier(0.23,1,0.32,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:"Mulish",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.6;
  font-size:17px;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--berry);text-decoration:none;transition:color .2s var(--ease)}
@media (hover:hover){a:hover{color:var(--berry-d)}}
h1,h2,h3,h4{font-family:"Montserrat",sans-serif;color:var(--ink);line-height:1.14;margin:0 0 .5em;font-weight:800;letter-spacing:-.01em}
p{margin:0 0 1rem}
:focus-visible{outline:3px solid var(--berry);outline-offset:3px;border-radius:6px}
ul{margin:0;padding:0;list-style:none}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 22px;width:100%}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:"Montserrat",sans-serif;font-weight:700;font-size:1rem;
  padding:.8rem 1.5rem;border-radius:999px;border:2px solid transparent;
  cursor:pointer;transition:transform .16s var(--ease),background-color .2s var(--ease),box-shadow .2s var(--ease),color .2s var(--ease);
  white-space:nowrap;min-height:44px;text-align:center;justify-content:center;
}
.btn:active{transform:scale(.97)}
.btn--lg{padding:1rem 1.9rem;font-size:1.06rem}
.btn--primary{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn--ghost{background:transparent;color:var(--orange);border-color:var(--orange)}
@media (hover:hover){
  .btn--primary:hover{background:var(--orange-d);border-color:var(--orange-d);color:#fff;box-shadow:0 10px 24px rgba(232,76,29,.34)}
  .btn--ghost:hover{background:var(--orange);color:#fff}
}

/* ---------- HEADER ---------- */
.site-header{
  position:sticky;top:0;z-index:60;background:rgba(255,255,255,.94);
  backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid var(--line);
}
.header__inner{display:flex;align-items:center;gap:1.2rem;min-height:78px}
.brand{display:flex;align-items:center;gap:.7rem;color:var(--ink);font-weight:800;flex:none}
@media (hover:hover){.brand:hover{color:var(--ink)}}
.brand__mark{width:50px;height:50px;border-radius:50%;flex:none}
.brand__name{font-family:"Montserrat",sans-serif;font-weight:800;font-size:1.02rem;line-height:1.08;display:flex;flex-direction:column}
.brand__name small{font-weight:600;font-size:.66rem;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}
.nav{margin-left:auto;display:flex;align-items:center;gap:.2rem}
.nav>a,.nav__droptoggle{
  color:var(--ink);font-family:"Montserrat",sans-serif;font-weight:600;font-size:.97rem;
  padding:.5rem .85rem;border-radius:10px;display:inline-flex;align-items:center;gap:.3rem;
  background:transparent;border:0;cursor:pointer;
}
@media (hover:hover){.nav>a:hover,.nav__droptoggle:hover{color:var(--orange);background:var(--bg-alt)}}
.nav__drop{position:relative}
.nav__menu{
  position:absolute;top:calc(100% + 8px);left:0;min-width:210px;background:#fff;
  border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);
  padding:.4rem;display:none;flex-direction:column;z-index:70;
}
.nav__drop.is-open .nav__menu{display:flex}
.nav__menu a{color:var(--ink);font-family:"Montserrat",sans-serif;font-weight:600;font-size:.92rem;padding:.6rem .8rem;border-radius:9px}
@media (hover:hover){.nav__menu a:hover{background:var(--bg-alt);color:var(--orange)}}
.header__actions{display:flex;align-items:center;gap:.8rem}
.lang{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden}
.lang__btn{
  border:0;background:transparent;cursor:pointer;font-family:"Montserrat",sans-serif;
  font-weight:700;font-size:.78rem;padding:.4rem .65rem;color:var(--muted);min-height:34px;
}
.lang__btn.is-active{background:var(--navy);color:#fff}
.socials--head{margin:0}
.socials--head .social{width:34px;height:34px;background:var(--bg-alt);color:var(--navy)}
@media (hover:hover){.socials--head .social:hover{background:var(--orange);color:#fff}}
.socials--head .social svg{width:17px;height:17px}
.nav__toggle{display:none;background:transparent;border:0;color:var(--ink);cursor:pointer;padding:.4rem;min-width:44px;min-height:44px;align-items:center;justify-content:center}

/* ---------- HERO CAROUSEL ---------- */
.hero{position:relative;background:var(--navy);overflow:hidden;isolation:isolate}
.hero__track{position:relative;width:100%;aspect-ratio:1024/528;max-height:640px}
.hero__slide{position:absolute;inset:0;opacity:0;transition:opacity .42s var(--ease);pointer-events:none}
.hero__slide.is-active{opacity:1;pointer-events:auto}
.hero__slide img{width:100%;height:100%;object-fit:cover}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,8,56,.72),rgba(7,8,56,.32) 60%,rgba(7,8,56,.12))}
.hero__caption{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center}
.hero__caption h1{
  color:#fff;font-weight:800;letter-spacing:-.02em;max-width:760px;margin:0;
  font-size:clamp(1.8rem,5.2vw,4rem);text-shadow:0 4px 24px rgba(0,0,0,.35);
}
.hero__cta-wrap{position:absolute;left:0;right:0;bottom:clamp(4.5rem,12vw,7rem);z-index:5;display:flex}
.hero__arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:6;
  width:48px;height:48px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(255,255,255,.85);color:var(--navy);
  display:flex;align-items:center;justify-content:center;
  transition:transform .16s var(--ease),background-color .2s var(--ease);
}
.hero__arrow:active{transform:translateY(-50%) scale(.92)}
@media (hover:hover){.hero__arrow:hover{background:#fff}}
.hero__arrow--prev{left:clamp(.5rem,2vw,1.5rem)}
.hero__arrow--next{right:clamp(.5rem,2vw,1.5rem)}
.hero__dots{position:absolute;left:0;right:0;bottom:clamp(1.4rem,4vw,2.2rem);z-index:6;display:flex;justify-content:center;gap:.6rem}
.hero__dot{
  width:12px;height:12px;border-radius:50%;border:2px solid #fff;background:transparent;
  cursor:pointer;padding:0;transition:background-color .2s var(--ease),transform .16s var(--ease);
}
.hero__dot.is-active{background:var(--orange);border-color:var(--orange)}
.hero__dot:active{transform:scale(.85)}

/* ---------- SECTION ---------- */
.section{padding:clamp(3rem,7vw,5.5rem) 0}
.section--alt{background:var(--bg-alt)}
.sec-head{margin-bottom:2.4rem;max-width:760px}
.sec-head--center{margin-left:auto;margin-right:auto;text-align:center}
.eyebrow{font-family:"Montserrat",sans-serif;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;font-size:.78rem;color:var(--orange);margin-bottom:.6rem}
.sec-title{font-size:clamp(1.6rem,4vw,2.5rem)}

/* ---------- STATS (orange rounded block) ---------- */
.stats{
  background:var(--orange);color:#fff;border-radius:var(--radius-lg);
  padding:clamp(2rem,5vw,3.4rem);
  display:grid;grid-template-columns:minmax(220px,.8fr) 1.6fr;gap:clamp(1.6rem,4vw,3rem);align-items:center;
}
.stats__title{color:#fff;font-size:clamp(1.7rem,4vw,2.6rem);line-height:1.05;margin:0;text-transform:uppercase}
.stats__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,3vw,2rem)}
.stat b{display:block;font-family:"Montserrat",sans-serif;font-weight:800;font-size:clamp(1.9rem,4vw,2.7rem);line-height:1;margin-bottom:.5rem}
.stat span{display:block;font-size:.92rem;color:rgba(255,255,255,.92);line-height:1.4}

/* ---------- NEWS ---------- */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.news-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);transition:transform .25s var(--ease),box-shadow .25s var(--ease);display:flex;flex-direction:column}
@media (hover:hover){.news-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}}
.news-card__img{aspect-ratio:16/10;overflow:hidden;background:var(--bg-alt)}
.news-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
@media (hover:hover){.news-card:hover .news-card__img img{transform:scale(1.04)}}
.news-card__body{padding:1.5rem;display:flex;flex-direction:column;flex:1}
.news-card__date{font-family:"Montserrat",sans-serif;font-weight:700;font-size:.78rem;
  text-transform:uppercase;letter-spacing:.04em;color:var(--berry);margin-bottom:.6rem}
.news-card h3{font-size:1.2rem;margin-bottom:.6rem}
.news-card p{color:var(--muted);font-size:.97rem;flex:1}
.news-card__more{display:inline-flex;align-items:center;gap:.4rem;font-family:"Montserrat",sans-serif;
  font-weight:700;font-size:.95rem;color:var(--orange);margin-top:.4rem}
.news-card__more svg{transition:transform .2s var(--ease)}
@media (hover:hover){.news-card__more:hover{color:var(--orange-d)}.news-card__more:hover svg{transform:translateX(4px)}}

/* ---------- PARTNERS ---------- */
.logos{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.logo-plate{
  display:inline-flex;align-items:center;justify-content:center;
  padding:1rem 1.6rem;border:1px solid var(--line);border-radius:var(--radius-sm);
  background:#fff;color:#7a7c90;font-family:"Montserrat",sans-serif;font-weight:700;
  font-size:1rem;letter-spacing:.02em;transition:color .2s var(--ease),border-color .2s var(--ease);
}
@media (hover:hover){.logo-plate:hover{color:var(--navy);border-color:#c9c9da}}

/* ---------- AWARDS ---------- */
.awards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.award{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem 1.6rem;box-shadow:var(--shadow);text-align:center}
.award__ic{display:inline-flex;width:54px;height:54px;align-items:center;justify-content:center;
  border-radius:14px;background:rgba(232,76,29,.10);color:var(--orange);margin-bottom:1rem}
.award__ic svg{width:26px;height:26px}
.award h3{font-size:1.16rem;margin-bottom:.5rem}
.award p{color:var(--muted);font-size:.95rem;margin:0}

/* ---------- DONORS ---------- */
.donors{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}
.donor{
  background:#fff;border:1px solid var(--line);border-radius:999px;
  padding:.7rem 1.2rem;font-weight:700;font-size:.95rem;color:var(--navy);
  border-left:4px solid var(--orange);
}

/* ---------- ABOUT ---------- */
.about__inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,3rem);align-items:stretch}
.about__collage{position:relative}
.collage{
  position:relative;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;
  gap:12px;width:100%;aspect-ratio:1/1;border-radius:var(--radius);overflow:hidden;
}
.collage img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-sm)}
.collage__logo{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:clamp(86px,22%,128px);aspect-ratio:1/1;border-radius:50%;background:#fff;
  display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px rgba(7,8,56,.22);z-index:2;
}
.collage__logo img{width:74%;height:74%;border-radius:0}
.about__block{
  background:var(--orange);color:#fff;border-radius:var(--radius-lg);
  padding:clamp(1.8rem,4vw,2.6rem);display:flex;flex-direction:column;justify-content:center;
}
.about__mission{color:#fff;font-size:clamp(1.02rem,2vw,1.18rem);font-weight:600;margin-bottom:1.4rem}
.about__goal-title{color:#fff;font-size:1.2rem;margin-bottom:.8rem}
.about__goals{display:grid;gap:.7rem}
.about__goals li{position:relative;padding-left:1.7rem;color:rgba(255,255,255,.95);font-size:1rem;line-height:1.45}
.about__goals li::before{
  content:"";position:absolute;left:0;top:.5em;width:10px;height:10px;border-radius:50%;
  background:#fff;
}

/* ---------- VALUES (accordion) ---------- */
.values{margin-top:clamp(2rem,5vw,3.2rem)}
.values__title{font-size:clamp(1.4rem,3vw,2rem);margin-bottom:1.2rem;text-align:center}
.acc{max-width:780px;margin:0 auto;display:grid;gap:.8rem}
.acc__item{border:1px solid var(--line);border-radius:var(--radius);background:#fff;overflow:hidden;box-shadow:var(--shadow)}
.acc__head{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  background:transparent;border:0;cursor:pointer;text-align:left;
  font-family:"Montserrat",sans-serif;font-weight:700;font-size:1.08rem;color:var(--ink);
  padding:1.1rem 1.4rem;min-height:56px;
}
.acc__ico{color:var(--orange);flex:none;transition:transform .3s var(--ease)}
.acc__item.is-open .acc__ico{transform:rotate(45deg)}
.acc__panel{overflow:hidden;max-height:0;opacity:0;transition:max-height .35s var(--ease),opacity .3s var(--ease)}
.acc__item.is-open .acc__panel{opacity:1}
.acc__inner{padding:0 1.4rem 1.2rem}
.acc__inner p{color:var(--muted);margin:0;font-size:.98rem}

/* ---------- DIRECTIONS ---------- */
.dir__inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,3rem);align-items:center}
.dir__media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3}
.dir__media img{width:100%;height:100%;object-fit:cover}
.dir__list{display:grid;gap:.85rem;margin-bottom:1.8rem}
.dir__list li{position:relative;padding-left:1.8rem;font-size:1.02rem;line-height:1.45;color:var(--ink)}
.dir__list li::before{
  content:"";position:absolute;left:0;top:.45em;width:12px;height:12px;border-radius:50%;
  background:var(--orange);box-shadow:0 0 0 4px rgba(232,76,29,.14);
}

/* ---------- REPORTS ---------- */
.report-list{display:grid;gap:1rem;max-width:880px}
.report{display:flex;align-items:center;gap:1.1rem;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:1.1rem 1.3rem;box-shadow:var(--shadow)}
.report__ic{display:inline-flex;width:46px;height:46px;flex:none;align-items:center;justify-content:center;
  border-radius:12px;background:rgba(7,8,56,.06);color:var(--navy)}
.report__txt{display:flex;flex-direction:column;flex:1;min-width:0}
.report__txt b{font-family:"Montserrat",sans-serif;font-size:1.02rem}
.report__txt span{color:var(--muted);font-size:.88rem}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--navy);color:rgba(255,255,255,.8);padding:3.2rem 0 1.6rem;border-top:4px solid var(--orange)}
.footer__top{display:grid;grid-template-columns:1.5fr 1fr 1.4fr;gap:2.4rem;padding-bottom:2.2rem;border-bottom:1px solid rgba(255,255,255,.12)}
.footer__brand{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.footer__brand .brand__mark{width:52px;height:52px}
.footer__brand .brand__name{color:#fff;font-size:1.08rem}
.footer__about p{color:rgba(255,255,255,.7);font-size:.96rem;max-width:420px}
.socials{display:flex;gap:.6rem;margin-top:1rem;flex-wrap:wrap}
.social{display:inline-flex;width:42px;height:42px;align-items:center;justify-content:center;
  border-radius:50%;background:rgba(255,255,255,.08);color:#fff;transition:background-color .2s var(--ease),transform .16s var(--ease)}
.social svg{width:20px;height:20px}
.social:active{transform:scale(.92)}
@media (hover:hover){.social:hover{background:var(--orange);color:#fff;transform:translateY(-2px)}}
.footer__col h4{color:#fff;font-size:.92rem;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.9rem}
.footer__col>a{display:block;color:rgba(255,255,255,.72);font-size:.97rem;padding:.28rem 0}
@media (hover:hover){.footer__col>a:hover{color:var(--orange)}}
.footer__col--contact .socials{margin-top:.8rem}
.footer__map{margin-top:1.2rem}
.footer__map iframe{width:100%;height:180px;border:0;border-radius:var(--radius);filter:grayscale(.2)}
.footer__bar{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.6rem;
  padding-top:1.4rem;font-size:.86rem;color:rgba(255,255,255,.6)}
.footer__bar a{color:var(--orange)}
@media (hover:hover){.footer__bar a:hover{color:#ff9c7d}}

/* ---------- REVEAL (additive — visible by default) ---------- */
.reveal{opacity:1;transform:none;transition:opacity .6s var(--ease),transform .6s var(--ease)}
.js-reveal .reveal{opacity:0;transform:translateY(24px)}
.js-reveal .reveal.is-in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .stats{grid-template-columns:1fr}
  .stats__title{text-align:left}
  .stats__title br{display:none}
}
@media (max-width:900px){
  .nav{
    position:fixed;inset:78px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:#fff;border-bottom:1px solid var(--line);margin-left:0;
    padding:.6rem 22px 1rem;box-shadow:var(--shadow-lg);
    transform:translateY(-130%);transition:transform .3s var(--ease);
    max-height:calc(100dvh - 78px);overflow-y:auto;
  }
  .nav.is-open{transform:translateY(0)}
  .nav>a,.nav__droptoggle{padding:.85rem .4rem;border-radius:8px;font-size:1.05rem;width:100%}
  .nav__menu{position:static;display:flex;box-shadow:none;border:0;padding:0 0 .4rem 1rem;min-width:0}
  .nav__drop.is-open .nav__menu,.nav__menu{display:flex}
  .nav__toggle{display:inline-flex}
  .socials--head{display:none}
  .footer__top{grid-template-columns:1fr 1fr;gap:2rem}
  .footer__col--contact{grid-column:1 / -1}
}
@media (max-width:760px){
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .news-grid,.awards-grid{grid-template-columns:1fr 1fr}
  .about__inner,.dir__inner{grid-template-columns:1fr}
  .dir__media{aspect-ratio:16/10}
}
@media (max-width:640px){
  body{font-size:16px}
  .lang{display:none}
  .news-grid,.awards-grid{grid-template-columns:1fr}
  .report{flex-wrap:wrap}
  .report .btn{width:100%}
  .footer__top{grid-template-columns:1fr}
  .footer__bar{flex-direction:column}
  .brand__name small{display:none}
  .hero__caption{align-items:flex-start}
  .hero__cta-wrap{bottom:3.6rem}
}
@media (max-width:430px){
  .stats__grid{grid-template-columns:1fr}
  .hero__arrow{width:42px;height:42px}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .js-reveal .reveal{opacity:1!important;transform:none!important}
  .hero__slide{transition:none!important}
}
