@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;600;800&family=Fredoka:wght@500;700&display=swap");

:root{
  --bg: #0b1220;
  --ink: #0f172a;
  --muted: #5b6475;
  --card: rgba(255,255,255,.92);
  --line: rgba(15,23,42,.10);
  --pink: #ff3ea5;
  --aqua: #37d6ff;
  --lime: #67ffb1;
  --sun: #ffd56a;
  --radius: 24px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Plus Jakarta Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color:var(--ink);
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(55,214,255,.25), transparent 60%),
    radial-gradient(900px 500px at 90% 10%, rgba(255,62,165,.22), transparent 55%),
    radial-gradient(800px 500px at 50% 80%, rgba(103,255,177,.20), transparent 60%),
    linear-gradient(180deg, #f7fbff, #ffffff);
  padding-bottom: 70px; /* for bottom CTA */
}

.wrap{max-width:1200px;margin:0 auto;padding:0 22px}

/* top ribbon */
.top-ribbon{
  background: linear-gradient(90deg, rgba(55,214,255,.22), rgba(255,62,165,.16), rgba(255,213,106,.20));
  border-bottom: 1px solid rgba(15,23,42,.08);
}
.ribbon-inner{
  display:flex; gap:18px; align-items:center; justify-content:space-between;
  padding:10px 0;
}
.ribbon-left,.ribbon-right{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
.pill{
  background: rgba(255,255,255,.70);
  border: 1px solid rgba(15,23,42,.10);
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
}
.ribbon-link{
  text-decoration:none;
  font-weight:800;
  font-size: 12px;
  color: var(--ink);
  opacity:.85;
}
.ribbon-link:hover{opacity:1}

/* header */
.main-header{
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(15,23,42,.08);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding: 16px 0;
  gap: 14px;
}
.brand{
  display:flex; gap:12px; align-items:center;
  text-decoration:none;
  color: var(--ink);
}
.brand-mark{
  width: 44px; height: 44px;
  display:grid; place-items:center;
  border-radius: 14px;
  background: radial-gradient(circle at 30% 20%, rgba(255,62,165,.25), transparent 60%),
              radial-gradient(circle at 80% 30%, rgba(55,214,255,.25), transparent 55%),
              linear-gradient(180deg, #ffffff, rgba(255,255,255,.65));
  border: 1px solid rgba(15,23,42,.10);
}
.brand-name{
  font-family:"Fredoka";
  font-size: 20px;
  font-weight: 700;
  line-height: 1.1;
}
.brand-tag{
  display:block;
  margin-top: 2px;
  font-size: 12px;
  font-weight: 800;
  color: rgba(15,23,42,.55);
}

.nav{
  display:flex; gap:10px; align-items:center; flex-wrap:wrap;
}
.nav a{
  text-decoration:none;
  color: rgba(15,23,42,.82);
  font-weight: 800;
  font-size: 13px;
  padding: 10px 12px;
  border-radius: 999px;
  transition: .2s;
}
.nav a:hover{
  background: rgba(55,214,255,.14);
  color: var(--ink);
}
.nav .cta{
  background: linear-gradient(135deg, var(--pink), #ff7ac7);
  color: white !important;
  box-shadow: 0 10px 24px rgba(255,62,165,.25);
  padding: 10px 16px;
}
.nav .cta:hover{transform: translateY(-1px)}

.nav-toggle{
  display:none;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.70);
  border-radius: 14px;
  padding: 10px 12px;
  font-size: 16px;
}

/* HERO — вообще другой подход: “portal” + big art */
.hero-portal{
  margin-top: 22px;
  border-radius: 40px;
  overflow: hidden;
  border: 1px solid rgba(15,23,42,.10);
  box-shadow: 0 30px 70px rgba(15,23,42,.10);
  background:
    radial-gradient(900px 400px at 10% 0%, rgba(55,214,255,.30), transparent 60%),
    radial-gradient(700px 380px at 90% 10%, rgba(255,62,165,.28), transparent 55%),
    radial-gradient(600px 360px at 50% 90%, rgba(255,213,106,.22), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.65));
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 24px;
  padding: 80px;
  align-items: center;
}
.kicker{
  display:inline-flex; gap:10px; align-items:center;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(15,23,42,.10);
  font-weight: 900;
  font-size: 12px;
}
.h1{
  font-family:"Fredoka";
  font-size: 56px;
  line-height: 1.02;
  margin: 14px 0 10px;
}
.lead{
  font-size: 16px;
  line-height: 1.7;
  color: rgba(15,23,42,.70);
  max-width: 560px;
}
.cta-row{display:flex; gap:12px; flex-wrap:wrap; margin-top: 18px}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  text-decoration:none;
  font-weight: 900;
  border-radius: 999px;
  padding: 13px 18px;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.78);
  color: var(--ink);
}
.btn.primary{
  border: none;
  color: white;
  background: linear-gradient(135deg, var(--pink), #ff7ac7);
  box-shadow: 0 12px 26px rgba(255,62,165,.24);
}
.btn.primary:hover{transform: translateY(-2px)}
.btn:hover{background: rgba(55,214,255,.12)}

.hero-art{
  position: relative;
  min-height: 360px;
}
.art-stack{
  position:absolute; inset:0;
  display:grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 1fr;
  gap: 14px;
}
.art-stack img{
  width:100%; height:100%;
  object-fit: cover;
  border-radius: 26px;
  border: 1px solid rgba(15,23,42,.10);
  box-shadow: 0 20px 40px rgba(15,23,42,.12);
  transform: rotate(-1deg);
}
.art-stack img:nth-child(2){transform: rotate(2deg) translateY(6px)}
.art-stack img:nth-child(3){transform: rotate(1deg) translateY(-8px)}
.art-stack img:nth-child(4){transform: rotate(-2deg) translateY(10px)}

.hero-facts{
  margin-top: 18px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.fact{
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 22px;
  padding: 12px 14px;
}
.fact b{display:block; font-size: 14px}
.fact span{display:block; font-size: 12px; color: rgba(15,23,42,.62); margin-top: 3px}

/* sections */
.section{padding: 56px 0}
.section-title{
  font-family:"Fredoka";
  font-size: 34px;
  margin: 0 0 18px;
}
.grid{
  display:grid;

  gap: 14px;
}
.card{
  background: var(--card);
  border: 1px solid rgba(15,23,42,.10);
  border-radius: var(--radius);
  box-shadow: 0 18px 40px rgba(15,23,42,.08);
  padding: 18px;
}
.span-4{grid-column: span 4}
.span-6{grid-column: span 6}
.span-8{grid-column: span 8}
.span-12{grid-column: span 12}

.icon-chip{
  display:inline-flex; align-items:center; gap:10px;
  font-weight: 900;
  padding: 10px 12px;
  border-radius: 18px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.70);
}
.muted{color: rgba(15,23,42,.68); line-height: 1.7; font-size: 14px}
.list{margin: 10px 0 0; padding-left: 18px; color: rgba(15,23,42,.75); line-height: 1.8}
.quote{
  font-size: 14px;
  line-height: 1.7;
  color: rgba(15,23,42,.75);
  padding: 12px 14px;
  border-radius: 18px;
  background: rgba(55,214,255,.10);
  border: 1px solid rgba(55,214,255,.18);
}

/* footer */
.footer{
  margin-top: 50px;
  background: linear-gradient(180deg, rgba(255,255,255,.70), #ffffff);
  border-top: 1px solid rgba(15,23,42,.10);
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.3fr .7fr .8fr;
  gap: 18px;
  padding: 34px 0;
}
.footer-brand{display:flex; gap:12px; align-items:center}
.footer-name{font-family:"Fredoka"; font-size: 18px}
.footer-sub{font-size: 12px; font-weight: 800; color: rgba(15,23,42,.58)}
.footer-p{margin: 10px 0 0; color: rgba(15,23,42,.70); line-height: 1.7; font-size: 13px}
.footer-title{font-weight: 900; margin-bottom: 10px}
.footer-links{display:flex; flex-direction:column; gap:8px}
.footer-links a{color: rgba(15,23,42,.72); text-decoration:none; font-weight: 800; font-size: 13px}
.footer-links a:hover{color: var(--pink)}
.footer-badges{display:flex; gap:8px; flex-wrap:wrap; margin-top: 12px}
.badge2{
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.72);
  font-size: 12px; font-weight: 900;
}
.mini-card{
  margin-top: 14px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(255,62,165,.20);
  background: radial-gradient(circle at 20% 0%, rgba(255,62,165,.12), transparent 60%),
              rgba(255,255,255,.72);
}
.mini-title{font-weight: 900}
.mini-text{font-size: 12px; color: rgba(15,23,42,.68); margin-top: 6px; line-height: 1.6}
.mini-btn{
  display:inline-flex; margin-top: 10px;
  padding: 10px 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--aqua), var(--lime));
  color: #06212a;
  font-weight: 900;
  text-decoration:none;
}
.footer-bottom{
  padding: 14px 0 22px;
  display:flex; justify-content:space-between; align-items:center;
  border-top: 1px solid rgba(15,23,42,.08);
  color: rgba(15,23,42,.60);
  font-weight: 800;
  font-size: 12px;
}
.footer-bottom-links{display:flex; gap:10px; align-items:center}
.footer-bottom-links a{color: rgba(15,23,42,.60); text-decoration:none}
.footer-bottom-links a:hover{color: var(--pink)}

/* bottom CTA */
.bottom-cta{
  position: fixed;
  left: 18px;
  right: 18px;
  bottom: 14px;
  display:flex;
  justify-content:center;
  align-items:center;
  padding: 14px 18px;
  border-radius: 999px;
  text-decoration:none;
  font-weight: 1000;
  color: white;
  background: linear-gradient(135deg, var(--pink), #ff7ac7);
  box-shadow: 0 20px 44px rgba(255,62,165,.28);
  z-index: 2000;
}

/* mobile */
@media (max-width: 980px){
  .ribbon-inner{justify-content:center}
  .ribbon-right{display:none}
  .nav-toggle{display:inline-flex}
  .nav{
    position: fixed;
    inset: 0;
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(14px);
    padding: 90px 22px 22px;
    display: none;
    flex-direction: column;
    gap: 12px;
    z-index: 1500;
  }
  body.nav-open .nav{display:flex}
  .hero-grid{grid-template-columns: 1fr; padding: 26px}
  .hero-art{min-height: 320px}
  .hero-facts{grid-template-columns: 1fr}
  .h1{font-size: 44px}
  header{padding: 0}
  .footer-grid{grid-template-columns: 1fr}
  .span-4,.span-6,.span-8,.span-12{grid-column: span 12}
}


/* ---------- FORMS (fix) ---------- */
input, textarea, select {
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.14);
  background: rgba(255,255,255,.85);
  font: inherit;
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7);
}

textarea { resize: vertical; }

input:focus, textarea:focus, select:focus {
  border-color: rgba(255,62,165,.55);
  box-shadow: 0 0 0 4px rgba(255,62,165,.14);
}

button {
  font: inherit;
}

/* Make forms look premium inside cards */
.card form { margin-top: 12px; }
.card form > * { margin-top: 10px; }