/* ===== DONI-GROUP — яркий «детский» конфетный лендинг ===== */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --pink:#ff3d8b; --pink2:#ff7eb3; --orange:#ff9f1c; --yellow:#ffd23f;
  --cyan:#22c8e6; --green:#2ed47a; --purple:#9b5de5; --blue:#5b8def;
  --wa:#25d366; --wa-d:#1ebe57;
  --ink:#2b1b3d; --mut:#6b5b7a;
  --card:#ffffff; --bg:#fff6fb;
  --ring:0 16px 40px rgba(43,27,61,.10);
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:'Nunito',system-ui,Segoe UI,sans-serif;color:var(--ink);background:var(--bg);
  overflow-x:hidden;width:100%;max-width:100%;line-height:1.6;font-weight:600}
h1,h2,h3,h4,.logo-txt{font-family:'Baloo 2','Fredoka','Nunito',sans-serif;line-height:1.08}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%}
.container{max-width:1180px;margin:0 auto;padding:0 22px}
section{position:relative;z-index:2}

/* фон: конфетное небо + 3D */
.sky{position:fixed;inset:0;z-index:0;background:
  radial-gradient(1200px 600px at 12% 0%,#ffe3f1 0%,transparent 55%),
  radial-gradient(1000px 600px at 100% 10%,#dff6ff 0%,transparent 55%),
  radial-gradient(900px 700px at 50% 100%,#fff3d6 0%,transparent 60%),
  linear-gradient(180deg,#fff6fb,#fdf0ff 60%,#eefcff)}
#bg3d{position:fixed;inset:0;z-index:1;width:100%;height:100%;display:block;pointer-events:none}

/* confetti слой */
.confetti{position:fixed;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.confetti i{position:absolute;top:-20px;width:9px;height:14px;border-radius:2px;opacity:.8;
  animation:fall linear infinite}
@keyframes fall{0%{transform:translateY(-20px) rotate(0)}100%{transform:translateY(108vh) rotate(540deg)}}

/* ===== WhatsApp кнопки (общий стиль) ===== */
.wa-ic{width:1.25em;height:1.25em;flex:none;vertical-align:-.25em}
.btn-wa{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--wa),var(--wa-d));
  color:#fff;padding:15px 30px;border-radius:50px;font-weight:800;font-size:17px;
  box-shadow:0 14px 30px rgba(37,211,102,.40);transition:transform .2s,box-shadow .2s}
.btn-wa:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 20px 40px rgba(37,211,102,.5)}
.btn-wa.big{font-size:20px;padding:18px 38px}

/* ===== NAV ===== */
.nav{position:fixed;top:14px;left:50%;transform:translateX(-50%);z-index:40;width:min(1180px,94vw);
  display:flex;align-items:center;gap:18px;padding:10px 16px;border-radius:50px;
  background:rgba(255,255,255,.80);backdrop-filter:blur(14px);box-shadow:0 10px 30px rgba(255,61,139,.18);transition:.25s}
.nav.scrolled{background:#fff;box-shadow:0 12px 34px rgba(255,61,139,.22)}
.logo{display:flex;align-items:center;gap:9px;font-weight:800;font-size:21px}
.logo-ic{font-size:24px;animation:spin 8s linear infinite}
.logo-txt{background:linear-gradient(90deg,var(--pink),var(--orange));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.nav-links{display:flex;gap:22px;margin-left:auto;font-weight:700}
.nav-links a{color:var(--mut);transition:.2s;position:relative}
.nav-links a:hover{color:var(--pink)}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-4px;height:3px;border-radius:3px;background:var(--pink);transition:right .25s}
.nav-links a:hover::after{right:0}
.nav-wa{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--wa),var(--wa-d));
  color:#fff;padding:10px 20px;border-radius:50px;font-weight:800;box-shadow:0 8px 18px rgba(37,211,102,.35);white-space:nowrap;transition:.2s}
.nav-wa:hover{transform:translateY(-2px)}

/* ===== HERO ===== */
.hero{min-height:100vh;display:grid;place-items:center;text-align:center;padding:150px 22px 80px;position:relative}
.hero-inner{max-width:860px;position:relative;z-index:3}
.hero-badge{display:inline-block;background:#fff;border:2px solid #ffd9ea;color:var(--pink);
  padding:8px 20px;border-radius:50px;font-weight:800;margin-bottom:22px;box-shadow:0 8px 22px rgba(255,61,139,.12)}
.hero h1{font-size:clamp(34px,8.5vw,92px);font-weight:800;letter-spacing:.5px;overflow-wrap:break-word;
  background:linear-gradient(120deg,var(--pink) 10%,var(--purple) 40%,var(--orange) 75%,var(--cyan));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 6px 0 rgba(255,255,255,.6));margin-bottom:18px}
.hero-sub{font-size:clamp(16px,2.3vw,21px);color:var(--mut);font-weight:700;margin-bottom:32px}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:30px}
.btn-outline{display:inline-flex;align-items:center;gap:8px;background:#fff;border:2.5px solid var(--pink);color:var(--pink);
  padding:13px 28px;border-radius:50px;font-weight:800;font-size:17px;transition:.2s}
.btn-outline:hover{background:var(--pink);color:#fff;transform:translateY(-3px)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.18);border:2px solid rgba(255,255,255,.7);
  color:#fff;padding:16px 30px;border-radius:50px;font-weight:800;font-size:18px;transition:.2s}
.btn-ghost:hover{background:#fff;color:var(--pink)}
.hero-chips{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.chip{padding:9px 18px;border-radius:50px;font-weight:800;color:#fff;box-shadow:0 8px 18px rgba(0,0,0,.08)}
.chip-pink{background:var(--pink)}.chip-orange{background:var(--orange)}.chip-cyan{background:var(--cyan)}.chip-green{background:var(--green)}

/* плавающие эмодзи */
.float-emoji{position:absolute;font-size:46px;z-index:2;opacity:.95;filter:drop-shadow(0 8px 14px rgba(0,0,0,.12));animation:bob 5s ease-in-out infinite}
.e1{top:18%;left:8%}.e2{top:24%;right:10%;animation-delay:.6s}.e3{top:62%;left:11%;animation-delay:1.2s}
.e4{top:70%;right:13%;animation-delay:.3s}.e5{top:14%;right:26%;animation-delay:1.6s;font-size:38px}.e6{top:55%;right:32%;animation-delay:.9s;font-size:30px}
@media(max-width:760px){.float-emoji{font-size:32px}.e5,.e6{display:none}}

.scroll-hint{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);color:var(--pink);font-size:22px;animation:bob 1.6s infinite;z-index:3}

/* ===== Бегущая строка ===== */
.marquee{overflow:hidden;background:linear-gradient(90deg,var(--pink),var(--orange),var(--yellow),var(--cyan),var(--purple),var(--pink));
  background-size:300% 100%;animation:hue 14s linear infinite;padding:13px 0;position:relative;z-index:3;
  box-shadow:0 8px 24px rgba(255,61,139,.2)}
.marquee-track{display:flex;gap:38px;width:max-content;animation:scrollx 26s linear infinite}
.marquee-track span{color:#fff;font-weight:800;font-size:19px;white-space:nowrap;text-shadow:0 2px 4px rgba(0,0,0,.12)}
@keyframes scrollx{to{transform:translateX(-50%)}}
@keyframes hue{to{background-position:300% 0}}

/* волны-разделители */
.wave{display:block;width:100%;height:60px;position:relative;z-index:2;margin-bottom:-1px}
.wave-top{margin-top:0}

/* ===== SECTIONS ===== */
.section{padding:80px 0}
.products{background:#fff}
.head{text-align:center;max-width:740px;margin:0 auto 44px}
.eyebrow{display:inline-block;background:#fff;border:2px solid #ffe0ee;color:var(--pink);font-weight:800;
  padding:6px 16px;border-radius:50px;margin-bottom:14px}
h2{font-size:clamp(28px,5vw,46px);font-weight:800;margin-bottom:10px}
.lead{color:var(--mut);font-weight:700;font-size:18px}

/* карточки продукции */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px}
.card{background:var(--card);border-radius:26px;padding:32px 24px 26px;position:relative;overflow:hidden;
  box-shadow:var(--ring);transition:transform .28s,box-shadow .28s,border-color .28s;border:3px solid transparent}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:8px}
.card:hover{transform:translateY(-10px) rotate(-1deg);box-shadow:0 28px 60px rgba(255,61,139,.25)}
.card-emoji{font-size:62px;margin-bottom:12px;display:inline-block;transition:transform .3s}
.card:hover .card-emoji{transform:scale(1.15) rotate(8deg)}
.card h3{font-size:23px;margin-bottom:8px}.card p{color:var(--mut);font-weight:600;font-size:15px;margin-bottom:14px}
.tag{display:inline-block;font-weight:800;font-size:13px;padding:6px 14px;border-radius:50px;background:#fff3f9;color:var(--pink)}
.c-pink::before{background:var(--pink)}.c-pink:hover{border-color:var(--pink)}
.c-yellow::before{background:var(--yellow)}.c-yellow:hover{border-color:var(--yellow)}.c-yellow .tag{background:#fff8e1;color:#e09600}
.c-orange::before{background:var(--orange)}.c-orange:hover{border-color:var(--orange)}.c-orange .tag{background:#fff1df;color:var(--orange)}
.c-cyan::before{background:var(--cyan)}.c-cyan:hover{border-color:var(--cyan)}.c-cyan .tag{background:#e2faff;color:#0aa6c2}

/* полоса цифр */
.stats-band{background:linear-gradient(135deg,var(--pink),var(--purple) 55%,var(--orange));overflow:hidden}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center;color:#fff;position:relative;z-index:2}
.stat b{display:block;font-family:'Baloo 2';font-size:clamp(34px,6vw,56px);font-weight:800;text-shadow:0 4px 0 rgba(0,0,0,.08)}
.stat span{font-weight:700;opacity:.95}
.stats-emoji{position:absolute;font-size:120px;opacity:.14;z-index:1;animation:bob 6s ease-in-out infinite}
.se1{top:-20px;left:4%}.se2{bottom:-30px;left:46%;animation-delay:1s}.se3{top:-10px;right:5%;animation-delay:.5s}
@media(max-width:620px){.stats{grid-template-columns:repeat(2,1fr);gap:26px}}

/* плашки преимуществ */
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}
.tile{background:#fff;border-radius:22px;padding:26px;box-shadow:0 14px 34px rgba(43,27,61,.08);transition:transform .25s;border:2px solid #fff}
.tile:hover{transform:translateY(-8px);border-color:#ffe0ee}
.tile-ic{display:inline-grid;place-items:center;width:62px;height:62px;border-radius:18px;font-size:30px;margin-bottom:14px;transition:transform .25s}
.tile:hover .tile-ic{transform:scale(1.1) rotate(-6deg)}
.tile h4{font-size:20px;margin-bottom:6px}.tile p{color:var(--mut);font-weight:600;font-size:15px}
.ic-pink{background:#ffe1ee}.ic-orange{background:#ffeed6}.ic-cyan{background:#d9f7ff}
.ic-green{background:#d7f7e6}.ic-purple{background:#efe2ff}.ic-yellow{background:#fff3cf}

/* где купить */
.where{background:#fff}
.where-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}
.wcard{background:linear-gradient(160deg,#fff,#fff7fb);border-radius:20px;padding:26px 14px;text-align:center;font-size:46px;
  box-shadow:0 12px 30px rgba(43,27,61,.08);transition:transform .25s;cursor:default;border:2px solid #fff}
.wcard span{display:block;font-size:16px;font-weight:800;color:var(--ink);margin-top:8px}
.wcard:hover{transform:translateY(-6px) scale(1.04) rotate(-1deg);border-color:#ffe0ee}
.badges{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:34px}
.badge{background:#fff;border:2px solid #f0e3fb;color:var(--ink);font-weight:800;padding:10px 18px;border-radius:50px;
  box-shadow:0 8px 20px rgba(43,27,61,.06)}

/* CTA WhatsApp */
.cta-inner{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--cyan),var(--purple) 55%,var(--pink));
  border-radius:34px;padding:56px 28px;text-align:center;color:#fff;box-shadow:0 24px 60px rgba(155,93,229,.3)}
.cta-inner h2{color:#fff}.cta-inner p{font-weight:700;opacity:.96;margin-bottom:24px;font-size:18px;max-width:560px;margin-left:auto;margin-right:auto}
.cta-emoji{font-size:60px;display:block;margin-bottom:8px;animation:bob 3s ease-in-out infinite}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-inner .btn-wa{background:#fff;color:var(--wa-d)}
.cta-inner .btn-wa:hover{background:#f3fff8}

/* контакты */
.contacts{background:#fff}
.contacts-grid{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:center}
.contact-list{list-style:none;margin:24px 0}
.contact-list li{display:flex;gap:14px;align-items:center;padding:12px 0}
.contact-list small{color:var(--mut);font-weight:700}
.ci{display:inline-grid;place-items:center;width:50px;height:50px;border-radius:15px;font-size:24px;flex:none}
.contact-list a{color:var(--green);font-weight:800;font-size:19px}
.contact-btns{display:flex;gap:12px;flex-wrap:wrap}
.map-wrap{border-radius:26px;overflow:hidden;box-shadow:0 20px 50px rgba(43,27,61,.18);border:4px solid #fff}
#map{height:430px;width:100%;background:#eef}
.leaflet-popup-content-wrapper{border-radius:14px}

/* footer */
.foot{background:var(--ink);color:#fff;padding:30px 0;position:relative;z-index:2}
.foot-inner{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between}
.foot a{color:var(--yellow)}.foot-brand{font-weight:800;font-size:18px}.foot-addr{opacity:.85}
.foot-wa{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--wa),var(--wa-d));
  color:#fff!important;padding:10px 20px;border-radius:50px;font-weight:800;transition:.2s}
.foot-wa:hover{transform:translateY(-2px)}

/* ===== Плавающая кнопка WhatsApp ===== */
.wa-float{position:fixed;right:20px;bottom:20px;z-index:50;display:inline-flex;align-items:center;gap:0;
  background:linear-gradient(135deg,var(--wa),var(--wa-d));color:#fff;height:62px;border-radius:50px;
  padding:0 18px;box-shadow:0 12px 30px rgba(37,211,102,.5);overflow:hidden;max-width:62px;
  transition:max-width .35s ease,box-shadow .25s,transform .2s}
.wa-float .wa-ic{width:30px;height:30px;flex:none}
.wa-float-txt{font-weight:800;font-size:16px;white-space:nowrap;opacity:0;margin-left:10px;transition:opacity .3s .05s}
.wa-float:hover{max-width:320px;transform:translateY(-2px)}
.wa-float:hover .wa-float-txt{opacity:1}
.wa-pulse{position:absolute;inset:0;border-radius:50px;box-shadow:0 0 0 0 rgba(37,211,102,.55);animation:pulse 2.2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 18px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
@media(max-width:560px){.wa-float{height:58px;max-width:58px;padding:0 14px}.wa-float .wa-ic{width:28px;height:28px}}

/* ===== анимации ===== */
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes spin{to{transform:rotate(360deg)}}
.reveal{opacity:0;transform:translateY(34px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===== responsive ===== */
@media(max-width:820px){
  .nav-links{display:none}
  .nav-wa{margin-left:auto}
  .contacts-grid{grid-template-columns:1fr}
  .section{padding:60px 0}
  .hero{padding:120px 18px 70px}
  .cta-inner{padding:44px 20px}
  .marquee-track span{font-size:17px}
  .stats-emoji{font-size:90px}
}
@media(max-width:480px){
  .container{padding:0 16px}
  .nav{gap:8px;padding:8px 12px;width:min(1180px,96vw)}
  .logo{font-size:18px}.logo-ic{font-size:20px}
  .nav-wa{padding:9px 13px;font-size:14px}
  .hero{padding:106px 14px 56px}
  .hero h1{font-size:clamp(28px,9vw,40px)}
  .hero-sub{font-size:15px}
  .hero-badge{font-size:13px;padding:7px 14px}
  .btn-wa,.btn-outline{font-size:15px;padding:13px 22px}
  .btn-wa.big{font-size:17px;padding:15px 26px}
  .chip{font-size:13px;padding:8px 14px}
  .stat b{font-size:clamp(28px,9vw,40px)}
  .card{padding:26px 20px 22px}.card-emoji{font-size:54px}
  .wcard{font-size:40px;padding:22px 10px}
  .tile{padding:22px}
  #map{height:320px}.map-wrap{border-width:3px}
  .float-emoji{font-size:26px}
  .e1{left:3%}.e2{right:4%}.e3{left:4%}.e4{right:5%}
  .foot-inner{justify-content:center;text-align:center}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
