/* ============================================================
   «Долонька щастя» — партнерський лонгрід hromadske × МакДональдз
   Design system
   ============================================================ */

:root{
  /* Brand */
  --gold:        #FFBC0D;
  --gold-deep:   #F2A900;
  --red:         #DB0007;
  --ink:         #1A1A1A;
  --charcoal:    #2D2D2D;
  --kraft:       #B69A81;
  /* Playful sky-blue (from cover / infographics) */
  --sky:         #A9D8EC;
  --sky-soft:    #D6ECF6;
  --sky-line:    #7FC4E3;
  /* Neutrals */
  --paper:       #FFFFFF;
  --paper-warm:  #FFFDF8;
  --gray-50:     #F7F7F7;
  --gray-100:    #F0F0F0;
  --gray-400:    #8A8A8A;
  --gray-600:    #5A5A5A;

  --maxtext: 720px;
  --maxwide: 1120px;

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

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:'Montserrat', system-ui, sans-serif;
  color:var(--charcoal);
  background:var(--paper);
  font-size:19px;
  line-height:1.72;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; }

/* ---------- Reading progress + header ---------- */
.progress{
  position:fixed; top:0; left:0; height:4px; width:0%;
  background:linear-gradient(90deg,var(--gold),var(--red));
  z-index:120; transition:width .1s linear;
}
.site-header{
  position:sticky; top:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px clamp(18px,4vw,46px);
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--gray-100);
}
.wordmark{
  font-weight:800; font-size:25px; letter-spacing:-.02em;
  color:var(--ink); text-decoration:none; display:flex; align-items:center; gap:2px;
}
.wordmark .dot{ color:var(--red); }
.partner-badge{
  font-size:12px; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; color:var(--gray-600);
  background:var(--gray-50); border:1px solid var(--gray-100);
  padding:7px 14px; border-radius:6px; white-space:nowrap;
}

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxtext); margin:0 auto; padding:0 22px; }
.wrap-wide{ width:100%; max-width:var(--maxwide); margin:0 auto; padding:0 22px; }
section{ position:relative; overflow: hidden;}
.band-gray{ background:var(--gray-50); }
.band-warm{ background:var(--paper-warm); }
.pad{ padding:clamp(34px,6vw,44px) 0; }
.pad-sm{ padding:clamp(38px,5vw,64px) 0; }

/* ---------- Typography ---------- */
h1,h2,h3{ font-family:'Montserrat',sans-serif; color:var(--ink); letter-spacing:-.02em; }
.kicker{
  font-family:'Caveat',cursive; font-size:30px; color:var(--gold-deep);
  font-weight:700; line-height:1; margin:0 0 6px;
}
.eyebrow{
  font-size:13px; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  color:var(--red); margin:0 0 18px;
}
h2.section-title{
  font-size:clamp(28px,4.2vw,46px); font-weight:800; line-height:1.1;
  margin:0 0 6px; text-wrap:balance;
}
.swoosh{ display:block; width:clamp(150px,28%,260px); height:18px; margin:10px 0 26px; overflow:visible; }
h3.sub{ font-size:clamp(21px,2.6vw,27px); font-weight:700; line-height:1.25; margin:38px 0 12px; }
p{ margin:0 0 22px; text-wrap:pretty; }
.lead{ font-size:clamp(20px,2.4vw,25px); line-height:1.6; font-weight:500; color:var(--ink); }
strong,b{ font-weight:700; color:var(--ink); }
.hl{ background:linear-gradient(transparent 58%, rgba(255,188,13,.55) 58%); padding:0 2px; }
.hl-red{ color:var(--red); font-weight:700; }

.el {
    position: absolute;
}

/* ---------- Hero ---------- */
.hero{ position:relative; overflow:hidden; }
.hero-inner{ max-width:980px; margin:0 auto; padding:0 22px; text-align:center; position:relative; z-index:2; }
.hero h1{
  font-size:clamp(33px,6vw,68px); font-weight:800; line-height:1.06;
  margin:18px auto 0; max-width:15ch; text-wrap:balance;
}
.hero h1 .accent{ color:var(--red); }
.hero .stand{
  font-size:clamp(18px,2.3vw,23px); font-weight:500; color:var(--gray-600);
  max-width:60ch; margin:22px auto 0; line-height:1.6;
}
.hero-art{ position:relative; margin:clamp(8px,3vw,30px) auto -2px; max-width:1920px; }
.hero-art img{ width:100%; }
.hero-meta{
  display:flex; flex-wrap:wrap; gap:10px 26px; justify-content:center; align-items:center;
  font-size:14px; color:var(--gray-400); font-weight:600; margin-top:10px;
}
.hero-meta .dotsep{ width:5px; height:5px; border-radius:50%; background:var(--gold); }
/* partners */
.partners {
    display: flex;
    justify-content: center;
    gap: 20px;
    align-items: center;
    flex-wrap: wrap;
}
.partners-logo {
    max-width: 90%!important;
	width: 850px;
    margin: 0 auto;
}
@media (max-width:768px) {
	.partners-logo {
		width: 400px;
	}
}
/* floating clouds */
.cloud{ position:absolute; opacity:.9; z-index:1; pointer-events:none; }

/* ---------- Decorative blue blob ---------- */
.blob{
  position:absolute; z-index:0; pointer-events:none;
  background:var(--sky); filter:blur(.3px); opacity:.55;
}

/* ---------- Pull quote ---------- */
.quote{ position:relative; margin:46px auto; max-width:760px; padding:8px 0 8px 34px; }
.quote::before{
  content:""; position:absolute; left:0; top:6px; bottom:6px; width:6px;
  border-radius:6px; background:linear-gradient(var(--gold),var(--gold-deep));
}
.quote p{
  font-size:clamp(21px,2.7vw,28px); line-height:1.45; font-weight:600;
  color:var(--ink); margin:0 0 16px; text-wrap:pretty;
}
.quote span {
    font-weight: 500;
    font-size: .8em;
}
.quote .who{ display:flex; align-items:center; gap:14px; }
.quote .who .nm{ font-size:15px; font-weight:700; color:var(--ink); line-height:1.3; }
.quote .who .rl{ font-size:14px; font-weight:500; color:var(--gray-600); line-height:1.3; }
.quote .who .av{
  width:46px; height:46px; flex:none; border-radius:50%;
  background:var(--gold); display:grid; place-items:center; color:#fff; font-weight:800; font-size:19px;
}

/* ---------- Big stat figures ---------- */
.statrow{ display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:24px; margin:14px 0; }
.stat{ text-align:center; padding:14px 8px; }
.stat .fig{ font-size:clamp(22px,5vw,42px); font-weight:800; line-height:1; color:var(--red); letter-spacing:-.03em; }
.stat .fig.gold{ color:var(--gold-deep); }
.stat .lbl{ font-size:15px; font-weight:600; color:var(--gray-600); margin-top:10px; line-height:1.4; }

.bignum{ text-align:center; padding:18px 0; }
.bignum .fig{ font-size:clamp(20px,11vw,30px); font-weight:800; line-height:.9; color:var(--gold-deep); letter-spacing:-.04em; }
.bignum .cap{ font-size:clamp(18px,2.4vw,24px); font-weight:600; color:var(--ink); margin-top:8px; }

/* ---------- Figures / photos ---------- */
figure{ margin:34px 0; }
figure img{ width:100%; border-radius:16px; box-shadow:0 18px 50px -18px rgba(0,0,0,.32); }
figcaption{ font-size:14px; color:var(--gray-400); font-weight:500; margin-top:12px; line-height:1.4; }
.photo-grid{ display:grid; gap:18px; }
.photo-grid.two{ grid-template-columns:1fr 1fr; align-items:center; }
.media-split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(26px,4vw,56px); align-items:center; }
.media-split .txt p:last-child{ margin-bottom:0; }
.portrait{ aspect-ratio:3/4; object-fit:cover; }

/* ---------- Sketchy card (infographic) ---------- */
.sketch{
  position:relative; background:var(--paper);
  border:2.5px solid var(--ink); border-radius:6px;
}
.sketch::after{
  content:""; position:absolute; inset:5px; border:1.5px solid var(--ink);
  border-radius:4px; opacity:.5; pointer-events:none;
}

/* ============================================================
   INFOGRAPHIC 1 — flow of help
   ============================================================ */
.flow{ position:relative; }
.flow-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(28px,4vw,52px) clamp(30px,5vw,68px);
  position:relative; z-index:2;
}
.flow-blob{
  position:absolute; inset:-4% -3%; z-index:1;
  background:var(--sky); opacity:.5;
  border-radius:46% 54% 60% 40% / 55% 45% 58% 42%;
}
.step{
  position:relative; padding:24px 22px 22px; min-height:188px;
  display:flex; flex-direction:column; gap:14px;
  opacity:0; transform:translateY(26px) rotate(-.4deg);
  transition:opacity .6s var(--ease), transform .6s var(--ease);
}
.in .step{ opacity:1; transform:translateY(0) rotate(-.4deg); }
.step .ico{ height:62px; display:flex; align-items:center; }
.step .ico svg{ height:100%; width:auto; }
.step .n{
  position:absolute; top:-15px; left:-15px; width:38px; height:38px; border-radius:50%;
  background:var(--red); color:#fff; font-weight:800; font-size:18px;
  display:grid; place-items:center; box-shadow:0 4px 10px rgba(0,0,0,.18); z-index:3;
}
.step p{ margin:0; font-size:16.5px; font-weight:600; line-height:1.4; color:var(--ink); }
.step .arrow{
  position:absolute; z-index:4; color:var(--ink);
  opacity:0; transition:opacity .4s ease;
}
.in .step .arrow{ opacity:1; }
.step .arrow.right{ right:-13%; top:50%; transform:translateY(-50%); }
.step .arrow.down{ left:50%; bottom:-13%; transform:translateX(-50%); }
.flow-result{
  margin-top:clamp(26px,4vw,46px); position:relative; z-index:2;
  display:flex; align-items:flex-start; gap:16px;
  opacity:0; transform:translateY(20px); transition:.6s var(--ease);
}
.in .flow-result{ opacity:1; transform:none; }
.flow-result .tag{
  font-family:'Caveat',cursive; font-size:34px; font-weight:700; color:var(--red);
  flex:none; position:relative; line-height:1; padding:4px 6px 0;
}
.flow-result .tag .ring{ position:absolute; inset:-6px -4px; }
.flow-result .rtxt{ font-size:clamp(19px,2.4vw,24px); font-weight:700; color:var(--ink); line-height:1.35; }

/* ============================================================
   INFOGRAPHIC 2 — bar chart
   ============================================================ */
.chart{ position:relative; }
.chart-blob{
  position:absolute; left:-4%; right:-4%; top:14%; bottom:8%; z-index:1;
  background:var(--sky); opacity:.5;
  border-radius:48% 52% 44% 56% / 60% 50% 62% 40%;
}
.bars{
  position:relative; z-index:2;
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(14px,3vw,40px);
  align-items:end;
}
.bar-col{ display:flex; flex-direction:column; align-items:center; }
.bar-track{
  position:relative; width:clamp(54px,9vw,86px); height:300px;
  border:2.5px solid var(--ink); border-radius:3px;
  display:flex; align-items:flex-end; background:transparent;
}
.bar-fill{
  width:100%; background:var(--gold); height:0%;
  transition:height 1.3s var(--ease);
  border-top:2.5px solid var(--ink);
}
.bar-col:first-child .bar-fill{ border-top:none; }
.bar-pct{
  font-size:clamp(26px,4vw,44px); font-weight:800; color:var(--red);
  margin-top:14px; letter-spacing:-.02em;
}
.bar-lbl{ font-size:15px; font-weight:600; color:var(--ink); text-align:center; margin-top:8px; line-height:1.35; max-width:20ch; }
.chart-cap{
  position:relative; z-index:2; text-align:center; font-size:14px;
  color:var(--gray-600); font-weight:600; margin-top:30px;
}

/* ---------- Steps / numbered actions ---------- */
.actions{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin:30px 0 8px; }
.action{
  background:var(--paper); border-radius:16px; padding:26px 22px; position:relative;
  border:1px solid var(--gray-100); box-shadow:0 10px 30px -20px rgba(0,0,0,.25);
}
.action .num{
  font-family:'Caveat',cursive; font-size:54px; font-weight:700; color:var(--gold); line-height:.8;
}
.action p{ margin:12px 0 0; font-size:16.5px; font-weight:600; color:var(--ink); line-height:1.45; }

/* ---------- Route line ---------- */
.route{ display:flex; flex-wrap:wrap; align-items:center; gap:12px 8px; justify-content:center; margin:18px 0; }
.route .node{
  background:var(--paper); border:2px solid var(--gold); border-radius:999px;
  padding:11px 20px; font-size:15.5px; font-weight:700; color:var(--ink);
}
.route .arr{ color:var(--gold-deep); font-weight:800; font-size:22px; }

/* ---------- Highlight card ---------- */
.callout{
  background:linear-gradient(135deg,#FFF6DC,#FFFBF0);
  border:1.5px solid rgba(242,169,0,.4); border-radius:20px;
  padding:clamp(26px,4vw,42px); margin:34px 0;
}
.callout .head{ display:flex; align-items:center; gap:14px; margin-bottom:6px; }
.callout h3{ font-size:clamp(21px,2.6vw,28px); font-weight:800; margin:0; color:var(--ink); }
.callout p:last-child{ margin-bottom:0; }

/* the build-stats panel */
.buildstats{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:18px;
  margin-top:26px;
}
.bcard{ background:var(--paper); border-radius:16px; padding:22px 18px; text-align:center; border:1px solid rgba(242,169,0,.25); }
.bcard .v{ font-size:clamp(32px,5vw,46px); font-weight:800; color:var(--gold-deep); line-height:1; letter-spacing:-.02em; }
.bcard .k{ font-size:14px; font-weight:600; color:var(--gray-600); margin-top:8px; line-height:1.35; }

/* ---------- CTA ---------- */
.cta{ position:relative; overflow:hidden; text-align:center; }
.cta h2{ font-size:clamp(30px,5vw,54px); font-weight:800; color:var(--ink); margin:0 auto; max-width:16ch; line-height:1.08; text-wrap:balance; }
.cta .stand{ font-size:clamp(18px,2.3vw,22px); color:var(--gray-600); max-width:52ch; margin:22px auto 0; font-weight:500; }
.btn{
  display:inline-flex; align-items:center; gap:12px; margin-top:34px;
  background:var(--gold); color:#fff; font-weight:800; font-size:18px;
  padding:18px 34px; border-radius:999px; text-decoration:none;
  box-shadow:0 14px 34px -10px rgba(242,169,0,.55); transition:transform .2s var(--ease), box-shadow .2s;
}
.btn:hover{ transform:translateY(-3px); box-shadow:0 20px 40px -10px rgba(242,169,0,.6); }
.btn .hand{ width:24px; height:24px; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--ink); color:#cfcfcf; padding:clamp(46px,6vw,72px) 0 40px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr; gap:40px; align-items:start; }
.site-footer .logos{ display:flex; flex-direction:column; gap:22px; }
.site-footer .logos img{ background:#fff; padding:16px 20px; border-radius:14px; width:fit-content; max-width:260px; }
.site-footer h4{ color:#fff; font-size:14px; letter-spacing:.14em; text-transform:uppercase; margin:0 0 14px; font-weight:700; }
.site-footer p{ font-size:15px; line-height:1.6; color:#b6b6b6; margin:0 0 14px; }
.site-footer .fnote{ font-size:13px; color:#7d7d7d; margin-top:30px; border-top:1px solid #333; padding-top:22px; }

.section-credits {
    font-size: .8em;
    text-align: center;
    padding: 20px 0;
    background: rgb(255 188 13);
}

/* ---------- Reveal base ---------- */
.reveal{ opacity:0; transform:translateY(30px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in-view{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; }
.reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; }
.reveal a {
    border-bottom: 1px solid #ffbc0d;
}

  /* ===== Обгортка блоку з фоновим el3.svg ===== */
  .steps-block {
    position: relative;
    max-width: 1200px;
    margin: 0 auto;
    padding: 70px 50px;
	background: url(../images/el3.svg) center no-repeat;
    background-size: contain;
  }



  .steps-grid img {
    display: block;
    max-width: 100%;
    height: auto;
	
  }

  /* Кроки (step1..step6) розтягуються на всю ширину своєї колонки */
  .steps-grid > img.is-step {
    width: 100%;
	transform: scale(1);
	transition:all .4s ease	;
  }
  .steps-grid > img.is-step:hover {
	transform: scale(1.1);	
  }

  .arr-r {
    width: 40px;
    justify-self: center;
	z-index: 2;
  }

  /* ===================================================== */
  /* ===============   ДЕСКТОП  (≥992px)   ================ */
  /* DOM-порядок елементів написаний "по мобільному" сценарію,
     тому на десктопі переставляємо через grid-area          */
  /* ===================================================== */
  .steps-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr) auto minmax(0, 1fr);
    column-gap: 0px;
    row-gap: 0;
    grid-template-areas:
      "s1 a1 s2 a2 s3"
      "ab ab ab ab ab"
      "s4 a3 s5 a4 s6";
	  align-items: center;
  }

  .step1 { grid-area: s1; }
  .arr1  { grid-area: a1; }
  .step2 { grid-area: s2; }
  .arr2  { grid-area: a2; }
  .step3 { grid-area: s3; }

  .arrback1 {
    grid-area: ab;
    width: 70%;
    margin: auto;
	z-index: 2;
}

  .step4 { grid-area: s4; }
  .arr3  { grid-area: a3; }
  .step5 { grid-area: s5; }
  .arr4  { grid-area: a4; }
  .step6 { grid-area: s6; }

  /* arr-back-s та друга копія стрілок (для мобільного between 4-5) на десктопі не потрібні взагалі */
  .steps-grid img.arrback-s1,
  .steps-grid img.arrback-s2 {
    display: none;
	z-index: 2;
  }

  /* ===================================================== */
  /* ===================  МОБІЛЬНА ВЕРСІЯ (≤991px) ========= */
  /* Ряд 1: step1 - arr-r - step2
     Ряд 2: arr-back-s
     Ряд 3: step3 - arr-r - step4
     Ряд 4: arr-back-s
     Ряд 5: step5 - arr-r - step6                              */
  /* ===================================================== */
  
  .clouds {
    z-index: -1;
    left: 2vw;
	}
	.clouds2 {
		z-index: -1;
		right: 2vw;
		top: 30%;
	}
  @media (max-width: 991px) {

    .steps-block {
      padding: 30px 16px;
    }

    .steps-grid {
      grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
      grid-template-areas:
        "s1  a1  s2"
        "abs1 abs1 abs1"
        "s3  a2  s4"
        "abs2 abs2 abs2"
        "s5  a3  s6";
    }

    .arr-r { width:6vw; }

    .step1 { grid-area: s1; }
    .arr1  { grid-area: a1; }
    .step2 { grid-area: s2; }

    .step3 { grid-area: s3; }
    .arr2  { grid-area: a2; }
    .step4 { grid-area: s4; }

    .step5 { grid-area: s5; }
    .arr3  { grid-area: a3; }
    .step6 { grid-area: s6; }

    /* Зайва на мобільному 4-та стрілка вправо не потрібна */
    .steps-grid img.arr4 { display: none; }

    /* Довга десктопна стрілка ховається */
    .steps-grid img.arrback1 { display: none; }

    /* Короткі мобільні зворотні стрілки показуються */
    .steps-grid img.arrback-s1,
    .steps-grid img.arrback-s2 {
      display: block;
	  width: 70%;
		margin: auto;
    }
    .arrback-s1 { grid-area: abs1; }
    .arrback-s2 { grid-area: abs2; }
  }

.video-link {
    display: inline-block;
    /* margin: auto; */
    max-width: 90%;
}
.video-link img {
    border-radius: 24px;
}
/* ---------- Responsive ---------- */
@media (max-width:860px){
  body{ font-size:18px; }
  .media-split{ grid-template-columns:1fr; }
  .media-split.rev .txt{ order:2; }
  .flow-grid{ grid-template-columns:1fr 1fr; }
  .actions{ grid-template-columns:1fr; }
  .step .arrow{ display:none; }
}
@media (max-width:600px){
  .site-header{ padding:12px 16px; }
  .partner-badge{ font-size:10px; padding:6px 10px; letter-spacing:.1em; }
  .wordmark{ font-size:21px; }
  .flow-grid{ grid-template-columns:1fr; }
  .photo-grid.two{ grid-template-columns:1fr; }
  .bars{ gap:8px; }
  .bar-track{ height:230px; }
  .footer-grid{ grid-template-columns:1fr; }
  .quote{ padding-left:22px; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; }
  .reveal,.step,.flow-result{ opacity:1 !important; transform:none !important; }
}


[data-theme="dark"] {
	.band-gray, .band-warm  {
		background: #656565;
	}

	.lead, h1, h2, h3, .quote p {
		color: var(--gold);
	}

}