:root{
  --bg:#FFF0F6;
  --accent:#FF6B9D;
  --text:#4A1942;
  --card-a:#FFDDEB;
  --card-b:#FFEAF3;
  --card-c:#FBD7E7;
  --white:#ffffff;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:"Nunito",sans-serif;
  font-weight:400;
  line-height:1.6;
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block;border-radius:20px}
.container{width:min(1240px,calc(100% - 2rem));margin:0 auto}
.section{padding:90px 0}
h1,h2,h3{margin:0 0 1rem;line-height:1.12;font-weight:800}
h1{font-size:clamp(40px,6vw,64px)}
h2{font-size:clamp(30px,4vw,44px)}
h3{font-size:22px}
p{margin:0}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:13px 24px;border-radius:999px;border:2px solid var(--text);
  font-weight:700;transition:.2s ease;cursor:pointer
}
.btn:hover{transform:translateY(-2px)}
.btn-main{background:var(--accent);color:var(--white)}

.site-header{
  position:sticky;top:0;z-index:50;
  background:color-mix(in srgb,var(--bg) 88%,#fff);
  border-bottom:1px solid #4a194229;
}
.nav{min-height:74px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.logo{display:inline-flex;align-items:center;gap:10px;font-weight:800}
.logo-dot{width:14px;height:14px;border-radius:50%;background:var(--accent)}
.nav-menu{display:none;list-style:none;gap:20px;padding:0;margin:0}
.nav-menu a{font-weight:700;opacity:.8}
.nav-menu a:hover{opacity:1}
.phone{display:none;font-weight:700}
.menu-toggle{width:40px;height:40px;border:none;background:none;display:flex;flex-direction:column;justify-content:center;gap:5px;cursor:pointer}
.menu-toggle span{display:block;height:2px;background:var(--text)}
.mobile-menu{display:none;flex-direction:column;gap:10px;padding:0 1rem 1rem}
.mobile-menu.open{display:flex}

.hero{
  position:relative;
  text-align:center;
  padding:86px 0 66px;
}
.hero-kicker{text-transform:uppercase;letter-spacing:.08em;font-weight:700;opacity:.8;margin-bottom:16px}
.hero h1{max-width:980px;margin:0 auto 18px}
.hero-subtitle{max-width:980px;margin:0 auto 26px;font-size:20px}
.blob{
  position:absolute;border-radius:60% 40% 55% 45% / 45% 55% 45% 55%;
  background:color-mix(in srgb,var(--accent) 40%,#fff);
  opacity:.35;z-index:-1;animation:floatBlob 8s ease-in-out infinite;
}
.blob-a{width:280px;height:220px;left:-70px;top:20px}
.blob-b{width:220px;height:180px;right:5%;top:40px;animation-delay:1.2s}
.blob-c{width:260px;height:200px;left:40%;bottom:-60px;animation-delay:2.2s}

.trust-grid,.services-grid,.numbers-grid,.cases-grid,.team-grid,.pricing-grid,.contacts-grid,.footer-grid{
  display:grid;gap:16px;
}
.trust-card,.service-card,.number-card,.case-card,.team-card,.pricing-card,.contact-info{
  border-radius:32px;padding:24px;border:1px solid #4a194224;transition:.25s ease;
}
.trust-card:hover,.service-card:hover,.number-card:hover,.pricing-card:hover{transform:translateY(-4px)}
.trust-card:nth-child(1),.service-card:nth-child(1),.number-card:nth-child(1){background:var(--card-a)}
.trust-card:nth-child(2),.service-card:nth-child(2),.number-card:nth-child(2){background:var(--card-b)}
.trust-card:nth-child(3),.service-card:nth-child(3),.number-card:nth-child(3){background:var(--card-c)}
.trust-card:nth-child(4),.service-card:nth-child(4),.number-card:nth-child(4){background:#ffe4f0}
.service-card:nth-child(5){background:#ffeaf7}
.service-card:nth-child(6){background:#ffd9ea}

.trust-card strong,.number-card strong{display:block;font-size:40px;font-weight:800}
.timeline{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.timeline li{
  display:grid;grid-template-columns:58px 1fr;gap:14px;align-items:start;
  border-radius:24px;padding:14px 16px;background:#fff;border:1px solid #4a194224
}
.timeline li span{
  width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  background:var(--accent);color:#fff;font-weight:800
}

.case-card{background:#fff}
.case-card p{margin-top:12px;font-weight:700}
.team-card{background:#fff}

.faq-list{display:grid;gap:12px}
.faq-item{
  background:#fff;border:1px solid #4a194224;border-radius:20px;padding:14px 18px
}
.faq-item summary{cursor:pointer;font-weight:800}
.faq-item p{margin-top:10px}

.pricing-card{background:#fff}
.pricing-card.popular{border:2px solid var(--accent);box-shadow:0 12px 35px #ff6b9d33}
.pricing-card.custom{background:#ffe6f1}
.pricing-card h3{font-size:24px}
.pricing-card p{margin-bottom:16px}

.lead-wrap{
  position:relative;
  background:#fff4f9;
  border:1px solid #4a194224;
  border-radius:40px;
  padding:28px;
  display:grid;
  gap:20px;
  overflow:hidden;
}
.form-blob{
  position:absolute;right:-90px;bottom:-80px;width:320px;height:220px;
  fill:#ff6b9d30;animation:floatBlob 9s ease-in-out infinite
}
.lead-text{position:relative;z-index:1}
.lead-form{position:relative;z-index:1;display:grid;gap:12px}
.lead-form label{display:grid;gap:6px;font-weight:700}
.lead-form input{
  border:1px solid #4a194236;background:#fffafd;border-radius:16px;
  padding:12px 14px;font:400 16px "Nunito",sans-serif;color:var(--text)
}
.lead-form input:focus{outline:none;border-color:var(--accent)}
.form-thanks{font-weight:700;color:var(--accent)}

.contacts-grid{align-items:stretch}
.contact-info,.map{
  border-radius:28px;border:1px solid #4a194224;background:#fff;padding:22px
}
.contact-info p{margin-bottom:8px}
.map{width:100%;min-height:320px;border:0}

.floating-call{
  position:fixed;right:16px;bottom:16px;width:58px;height:58px;border-radius:50%;
  display:grid;place-items:center;background:var(--accent);color:#fff;font-size:24px;
  box-shadow:0 12px 24px #ff6b9d55;z-index:60;
  opacity:0;pointer-events:none;transform:translateY(12px);
  transition:opacity .3s ease,transform .3s ease;
}
.floating-call.is-visible{opacity:1;pointer-events:auto;transform:none}

.site-footer{padding:36px 0;border-top:1px solid #4a194229;background:#ffe8f3}
.footer-grid{
  gap:20px;
  grid-template-columns:minmax(0,1fr);
}
.footer-grid>div{
  display:grid;
  gap:8px;
  min-width:0;
}
.site-footer .logo{font-size:20px}
.site-footer p,.site-footer a{
  font-size:15px;
  line-height:1.45;
  overflow-wrap:anywhere;
}
.footer-grid a:hover{color:var(--accent)}

.legal-page{
  width:min(900px,calc(100% - 2rem));
  margin:40px auto;
  background:#fff;
  border:1px solid #4a194224;
  border-radius:32px;
  padding:28px;
}
.legal-back{
  display:inline-flex;
  margin-bottom:14px;
  color:var(--accent);
  font-weight:700;
}
.legal-underline{
  width:86px;height:4px;border-radius:999px;background:var(--accent);
  margin:0 0 20px;
}
.legal-page h2{font-size:24px;margin-top:18px}
.legal-page ul{padding-left:20px}

.reveal{opacity:0;transform:translateY(16px);transition:.6s ease}
.reveal.visible{opacity:1;transform:none}

.service-card h3::after{
  content:" ✦";
  color:var(--accent);
  display:inline-block;
  transition:transform .2s ease;
}
.service-card:hover h3::after{animation:wiggle .45s ease}

@media (min-width:768px){
  .menu-toggle{display:none}
  .mobile-menu{display:none!important}
  .nav-menu,.phone{display:flex}
  .trust-grid,.numbers-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .services-grid,.cases-grid,.pricing-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .team-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .contacts-grid{grid-template-columns:1fr 1fr}
  .lead-wrap{grid-template-columns:1.1fr 1fr}
  .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width:768px){
  .hero{ overflow: hidden; margin: 0; padding: 50px 15px; width: 100%; }
  h1 { font-size: 34px; }
}

@media (min-width:1280px){
  .trust-grid,.numbers-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .services-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .cases-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .pricing-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .team-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .footer-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
}

@media (min-width:1920px){
  .container{width:min(1520px,calc(100% - 6rem))}
  .pricing-grid{grid-template-columns:repeat(5,minmax(0,1fr))}
}

@keyframes floatBlob{
  0%,100%{transform:translateY(0) rotate(0)}
  50%{transform:translateY(-12px) rotate(4deg)}
}

@keyframes wiggle{
  0%{transform:rotate(0)}
  25%{transform:rotate(-14deg)}
  50%{transform:rotate(9deg)}
  75%{transform:rotate(-6deg)}
  100%{transform:rotate(0)}
}
