/* ============================================================
   WebProMax — аренда сайтов для цветочного бизнеса
   Static landing styles. No build step required.
   ============================================================ */

:root {
  /* Palette — warm botanical */
  --bg:        #fbf7f3;
  --bg-soft:   #f4ece4;
  --ink:       #1d2620;
  --ink-soft:  #4a574e;
  --line:      #e7ddd2;

  --green:        #2f6b4f;
  --green-deep:   #173d2c;
  --green-darker: #0f2a1e;

  /* WebProMax brand */
  --brand:        #ff6d00;
  --brand-deep:   #e25f00;
  --brand-2:      #6059ad;

  --rose:   #d9696b;
  --rose-soft: #f4ddd9;
  --blush:  #f6e3df;
  --gold:   #c79a4a;

  --white:  #ffffff;

  --radius: 22px;
  --radius-sm: 14px;
  --shadow-sm: 0 2px 10px rgba(23, 61, 44, .06);
  --shadow:    0 18px 50px rgba(23, 61, 44, .12);
  --shadow-lg: 0 30px 80px rgba(15, 42, 30, .28);

  --maxw: 1160px;
  --ff-serif: "Playfair Display", Georgia, serif;
  --ff-sans:  "Manrope", system-ui, -apple-system, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--ff-sans);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

h1, h2, h3 { font-family: var(--ff-serif); font-weight: 600; line-height: 1.12; letter-spacing: -0.01em; margin: 0; }
p { margin: 0; }
a { color: inherit; text-decoration: none; }

.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }

.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: var(--green);
}
.eyebrow::before { content: ""; width: 26px; height: 1px; background: var(--gold); }
.eyebrow.light { color: #cdbfa0; }
.eyebrow.light::before { background: var(--gold); }

.section { padding: clamp(64px, 9vw, 130px) 0; }
.section-head { max-width: 720px; margin-bottom: 52px; }
.section-head h2 { font-size: clamp(30px, 4.4vw, 50px); margin: 16px 0 14px; }
.section-head p { color: var(--ink-soft); font-size: 18px; }
.center { text-align: center; margin-left: auto; margin-right: auto; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: var(--ff-sans); font-weight: 700; font-size: 16px;
  padding: 16px 30px; border-radius: 100px; border: 0; cursor: pointer;
  transition: transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background .25s, color .25s;
  white-space: nowrap;
}
.btn svg { width: 18px; height: 18px; }
.btn-primary { background: var(--brand); color: #fff; box-shadow: 0 10px 26px rgba(255,109,0,.38); }
.btn-primary:hover { background: var(--brand-deep); transform: translateY(-3px); box-shadow: 0 16px 34px rgba(255,109,0,.48); }
.btn-ghost { background: transparent; color: var(--ink); border: 1.5px solid var(--line); }
.btn-ghost:hover { border-color: var(--green); color: var(--green); transform: translateY(-2px); }
.btn-light { background: #fff; color: var(--green-deep); }
.btn-light:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.btn-lg { padding: 19px 38px; font-size: 17px; }

/* ---------- Header ---------- */
.header {
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: saturate(140%) blur(14px);
  background: rgba(251,247,243,.78);
  border-bottom: 1px solid transparent;
  transition: border-color .3s, background .3s;
}
.header.scrolled { border-color: var(--line); background: rgba(251,247,243,.92); }
.header .wrap { display: flex; align-items: center; justify-content: space-between; height: 76px; }
.brand { display: flex; align-items: center; }
.logo-img { height: 34px; width: auto; display: block; }
.footer .logo-img { height: 38px; }
.nav { display: flex; align-items: center; gap: 26px; }
.nav a { font-weight: 600; font-size: 15px; color: var(--ink-soft); transition: color .2s; }
.nav a:hover { color: var(--green); }
.nav .btn { padding: 12px 22px; font-size: 15px; }
.nav-links { display: flex; gap: 28px; }
/* Телефон в шапке */
.head-phone { display: inline-flex; align-items: center; gap: 8px; font-weight: 800; font-size: 16px; color: var(--green-deep) !important; white-space: nowrap; }
.head-phone svg { width: 17px; height: 17px; color: var(--brand); }
.head-phone:hover { color: var(--brand) !important; }
@media (max-width: 980px) { .nav-links { display: none; } }
@media (max-width: 560px) { .head-phone span { display: none; } }

/* ---------- Hero ---------- */
.hero { position: relative; padding: clamp(40px, 6vw, 70px) 0 clamp(60px, 7vw, 96px); }
.hero-card {
  position: relative; overflow: hidden;
  border-radius: 30px;
  background:
    radial-gradient(120% 120% at 80% -10%, rgba(217,105,107,.22), transparent 55%),
    linear-gradient(155deg, var(--green-deep), var(--green-darker));
  color: #f3efe9;
  padding: clamp(36px, 5vw, 70px);
  box-shadow: var(--shadow-lg);
}
.hero-grid { position: relative; z-index: 3; display: grid; grid-template-columns: 1.15fr .85fr; gap: 30px; align-items: center; }
@media (max-width: 900px) { .hero-grid { grid-template-columns: 1fr; } }

.hero h1 { font-size: clamp(36px, 5.6vw, 66px); color: #fff; margin: 18px 0 22px; }
.hero h1 em { font-style: normal; color: #f3b6b0; }
.hero .lead { font-size: clamp(17px, 1.6vw, 20px); color: #d4ddd4; max-width: 560px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }

.hero-badges { display: flex; flex-wrap: wrap; gap: 10px 12px; margin-top: 34px; }
.hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.16);
  padding: 9px 15px; border-radius: 100px; font-size: 14px; font-weight: 600; color: #e7ede7;
}
.hero-badge b { color: #fff; }
.hero-badge .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gold); }

/* Spotlight (CSS recreation of the aceternity/spline effect) */
.spotlight {
  position: absolute; pointer-events: none; z-index: 1;
  top: -30%; left: -10%; width: 70%; height: 160%;
  background: radial-gradient(closest-side, rgba(255,255,255,.20), transparent 70%);
  transform: rotate(-18deg);
  filter: blur(28px);
  opacity: 0; animation: spotlightIn 1.6s ease forwards .15s;
}
@keyframes spotlightIn { to { opacity: 1; } }

/* Floral visual panel */
.hero-visual { position: relative; height: 100%; min-height: 280px; display: grid; place-items: center; }
.bloom {
  position: relative; width: clamp(220px, 26vw, 320px); aspect-ratio: 1; border-radius: 50%;
  background: radial-gradient(circle at 50% 50%, rgba(243,182,176,.28), rgba(243,182,176,0) 62%);
  display: grid; place-items: center;
}
.bloom svg { width: 78%; height: 78%; filter: drop-shadow(0 18px 30px rgba(0,0,0,.35)); animation: floaty 7s ease-in-out infinite; }
@keyframes floaty { 0%,100% { transform: translateY(-6px) rotate(-1deg); } 50% { transform: translateY(8px) rotate(1deg); } }

/* Falling petals */
.petals { position: absolute; inset: 0; overflow: hidden; z-index: 2; pointer-events: none; }
.petal { position: absolute; top: -8%; width: 14px; height: 14px; background: var(--rose); opacity: .55;
  border-radius: 12px 1px 12px 1px; animation: fall linear infinite; }
@keyframes fall {
  0%   { transform: translateY(-10%) translateX(0) rotate(0deg); opacity: 0; }
  10%  { opacity: .6; }
  100% { transform: translateY(120vh) translateX(60px) rotate(320deg); opacity: 0; }
}

/* ---------- Comparison: без сайта / с сайтом ---------- */
.compare { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; }
@media (max-width: 820px) { .compare { grid-template-columns: 1fr; } }
.col {
  border-radius: var(--radius); padding: 38px 34px; border: 1px solid var(--line); background: #fff;
}
.col.bad { background: linear-gradient(180deg, #fff, #fdf3f2); border-color: #f1d8d6; }
.col.good { background: linear-gradient(180deg, var(--green-deep), var(--green-darker)); border-color: transparent; color: #eef3ee; box-shadow: var(--shadow); }
.col h3 { font-size: 26px; margin-bottom: 6px; }
.col.good h3 { color: #fff; }
.col .tag { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; font-size: 13px; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 18px; }
.col.bad .tag { color: var(--rose); }
.col.good .tag { color: #f3b6b0; }
.col ul { list-style: none; margin: 22px 0 0; padding: 0; display: grid; gap: 15px; }
.col li { display: flex; gap: 13px; align-items: flex-start; font-size: 16.5px; }
.col li .ic { flex: 0 0 26px; width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; margin-top: 1px; font-size: 14px; font-weight: 800; }
.col.bad li .ic { background: var(--rose-soft); color: var(--rose); }
.col.good li .ic { background: rgba(255,255,255,.14); color: #b8f0cf; }
.col.bad li span:last-child { color: var(--ink-soft); }
.col.good li span:last-child { color: #d8e2d8; }

/* ---------- Benefits grid ---------- */
.cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 900px) { .cards { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .cards { grid-template-columns: 1fr; } }
.card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  padding: 32px 28px; box-shadow: var(--shadow-sm);
  transition: transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s, border-color .3s;
}
.card:hover { transform: translateY(-6px); box-shadow: var(--shadow); border-color: #e3d4c2; }
.card .ic-box {
  width: 54px; height: 54px; border-radius: 16px; display: grid; place-items: center; margin-bottom: 20px;
  background: linear-gradient(150deg, var(--blush), #fff); color: var(--green); border: 1px solid var(--line);
}
.card .ic-box svg { width: 26px; height: 26px; }
.card h3 { font-size: 21px; margin-bottom: 10px; }
.card p { color: var(--ink-soft); font-size: 15.5px; }

/* ---------- How it works ---------- */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; counter-reset: step; }
@media (max-width: 900px) { .steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .steps { grid-template-columns: 1fr; } }
.step {
  position: relative; background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  padding: 34px 26px 28px; box-shadow: var(--shadow-sm);
}
.step .num {
  font-family: var(--ff-serif); font-size: 44px; font-weight: 700; color: var(--brand);
  line-height: 1; margin-bottom: 14px; display: block;
}
.step h3 { font-size: 19px; margin-bottom: 9px; }
.step p { color: var(--ink-soft); font-size: 15px; }

/* ---------- Pricing / offer ---------- */
.offer {
  position: relative; overflow: hidden;
  border-radius: 30px; padding: clamp(40px, 5vw, 64px);
  background: radial-gradient(120% 130% at 85% -20%, rgba(199,154,74,.25), transparent 55%), linear-gradient(155deg, var(--green-deep), var(--green-darker));
  color: #eef3ee; box-shadow: var(--shadow-lg);
}
.offer-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 40px; align-items: center; position: relative; z-index: 2; }
@media (max-width: 860px) { .offer-grid { grid-template-columns: 1fr; } }
.offer h2 { color: #fff; font-size: clamp(28px, 4vw, 44px); margin-bottom: 16px; }
.offer p { color: #d4ddd4; font-size: 17px; }
.price-list { display: grid; gap: 14px; }
.price-row {
  display: flex; justify-content: space-between; align-items: baseline; gap: 16px;
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--radius-sm); padding: 18px 22px;
}
.price-row .k { font-weight: 600; color: #e7ede7; }
.price-row .v { font-family: var(--ff-serif); font-size: 24px; color: #fff; white-space: nowrap; }
.price-row .v small { font-family: var(--ff-sans); font-size: 13px; color: #b9c6ba; font-weight: 600; }
.price-row.free .v { color: #b8f0cf; }
.offer .fine { margin-top: 18px; font-size: 14px; color: #aebbae; }

/* ---------- FAQ ---------- */
.faq { max-width: 800px; margin: 0 auto; }
.q { border-bottom: 1px solid var(--line); }
.q summary {
  list-style: none; cursor: pointer; padding: 24px 4px; font-size: 19px; font-weight: 700;
  display: flex; justify-content: space-between; gap: 20px; align-items: center; color: var(--green-deep);
}
.q summary::-webkit-details-marker { display: none; }
.q summary .plus { flex: 0 0 auto; width: 26px; height: 26px; position: relative; transition: transform .3s; }
.q summary .plus::before, .q summary .plus::after { content: ""; position: absolute; background: var(--brand); border-radius: 2px; }
.q summary .plus::before { top: 12px; left: 4px; right: 4px; height: 2px; }
.q summary .plus::after { left: 12px; top: 4px; bottom: 4px; width: 2px; transition: opacity .3s; }
.q[open] summary .plus::after { opacity: 0; }
.q[open] summary .plus { transform: rotate(180deg); }
.q .a { padding: 0 4px 26px; color: var(--ink-soft); font-size: 16px; max-width: 90%; }

/* ---------- CTA band ---------- */
.cta-band { text-align: center; }
.cta-band .inner {
  background: linear-gradient(150deg, var(--brand), var(--brand-deep)); color: #fff;
  border-radius: 30px; padding: clamp(44px, 6vw, 72px); box-shadow: 0 30px 70px rgba(255,109,0,.32);
}
.cta-band h2 { color: #fff; font-size: clamp(28px, 4.4vw, 48px); margin-bottom: 16px; }
.cta-band p { color: #fff2e6; font-size: 18px; max-width: 540px; margin: 0 auto 30px; }

/* Быстрые контакты под CTA */
.cta-contacts { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin-top: 26px; }
.cta-contacts a {
  display: inline-flex; align-items: center; gap: 9px; font-weight: 700; font-size: 15px; color: #fff;
  background: rgba(255,255,255,.16); border: 1px solid rgba(255,255,255,.28);
  padding: 11px 18px; border-radius: 100px; transition: background .2s, transform .2s;
}
.cta-contacts a:hover { background: rgba(255,255,255,.26); transform: translateY(-2px); }
.cta-contacts svg { width: 17px; height: 17px; }

/* ---------- Footer ---------- */
.footer { padding: 64px 0 36px; border-top: 1px solid var(--line); margin-top: 20px; background: var(--bg-soft); }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 36px; }
@media (max-width: 820px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: 30px; } }
@media (max-width: 520px) { .footer-grid { grid-template-columns: 1fr; } }
.footer-col h4 { font-family: var(--ff-sans); font-size: 13px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--green); margin: 0 0 16px; }
.footer-about .logo-img { margin-bottom: 16px; }
.footer-about p { color: var(--ink-soft); font-size: 14.5px; max-width: 320px; }
.footer-contacts { list-style: none; margin: 0; padding: 0; display: grid; gap: 13px; }
.footer-contacts li { display: flex; gap: 11px; align-items: flex-start; font-size: 15px; color: var(--ink); }
.footer-contacts li svg { width: 18px; height: 18px; color: var(--brand); flex: 0 0 auto; margin-top: 2px; }
.footer-contacts a { color: var(--ink); transition: color .2s; }
.footer-contacts a:hover { color: var(--brand); }
.messengers { display: flex; flex-wrap: wrap; gap: 10px; }
.msg-btn {
  display: inline-flex; align-items: center; gap: 9px; font-weight: 700; font-size: 14.5px; color: var(--ink);
  background: #fff; border: 1px solid var(--line); padding: 11px 16px; border-radius: 100px;
  transition: border-color .2s, transform .2s, color .2s;
}
.msg-btn:hover { border-color: var(--brand); color: var(--brand); transform: translateY(-2px); }
.msg-btn svg { width: 18px; height: 18px; }
.footer-bottom { margin-top: 44px; padding-top: 24px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.footer-bottom p { color: var(--ink-soft); font-size: 13.5px; }
.footer-bottom a { color: var(--ink-soft); }
.footer-bottom a:hover { color: var(--brand); }

/* ---------- Reveal on scroll ---------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .bloom svg, .petal, .spotlight { animation: none !important; }
}

/* ============================================================
   Анкета (page 2)
   ============================================================ */
.form-hero { padding: 50px 0 10px; }
.back-link { display: inline-flex; align-items: center; gap: 8px; color: var(--ink-soft); font-weight: 600; font-size: 15px; margin-bottom: 26px; }
.back-link:hover { color: var(--green); }

.form-shell { display: grid; grid-template-columns: .82fr 1.18fr; gap: 36px; align-items: start; }
@media (max-width: 900px) { .form-shell { grid-template-columns: 1fr; } }

.form-aside {
  position: sticky; top: 100px;
  border-radius: var(--radius); padding: 38px 32px;
  background: linear-gradient(155deg, var(--green-deep), var(--green-darker)); color: #eef3ee;
  box-shadow: var(--shadow);
}
@media (max-width: 900px) { .form-aside { position: static; } }
.form-aside h1 { font-family: var(--ff-serif); font-size: clamp(28px, 3.4vw, 40px); color: #fff; margin: 14px 0 16px; }
.form-aside p { color: #d4ddd4; }
.form-aside ul { list-style: none; padding: 0; margin: 26px 0 0; display: grid; gap: 14px; }
.form-aside li { display: flex; gap: 12px; font-size: 15px; color: #dbe4db; }
.form-aside li .ic { color: #b8f0cf; flex: 0 0 auto; }

.form-card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  padding: clamp(28px, 4vw, 44px); box-shadow: var(--shadow-sm);
}
.fieldset { border: 0; padding: 0; margin: 0 0 26px; }
.fieldset legend { font-family: var(--ff-serif); font-size: 20px; color: var(--green-deep); margin-bottom: 16px; padding: 0; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 560px) { .grid-2 { grid-template-columns: 1fr; } }
.field { margin-bottom: 18px; }
.field label { display: block; font-weight: 600; font-size: 14.5px; margin-bottom: 8px; color: var(--ink); }
.field label .req { color: var(--rose); }
.field input, .field select, .field textarea {
  width: 100%; font-family: var(--ff-sans); font-size: 16px; color: var(--ink);
  background: var(--bg); border: 1.5px solid var(--line); border-radius: var(--radius-sm);
  padding: 14px 16px; transition: border-color .2s, box-shadow .2s, background .2s;
}
.field textarea { min-height: 110px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: 0; border-color: var(--green); background: #fff; box-shadow: 0 0 0 4px rgba(47,107,79,.12);
}
.field input::placeholder, .field textarea::placeholder { color: #a89e92; }

.chips { display: flex; flex-wrap: wrap; gap: 10px; }
.chip { position: relative; }
.chip input { position: absolute; opacity: 0; pointer-events: none; }
.chip span {
  display: inline-flex; padding: 11px 18px; border-radius: 100px; border: 1.5px solid var(--line);
  font-weight: 600; font-size: 15px; cursor: pointer; transition: all .2s; background: #fff; color: var(--ink-soft);
}
.chip input:checked + span { border-color: var(--green); background: var(--green); color: #fff; }
.chip span:hover { border-color: var(--green); }

.form-foot { margin-top: 8px; }
.form-foot .btn { width: 100%; }
.consent { display: flex; gap: 10px; align-items: flex-start; font-size: 13px; color: var(--ink-soft); margin: 16px 0 22px; }
.consent input { margin-top: 3px; flex: 0 0 auto; }

.form-status { margin-top: 16px; font-size: 14.5px; border-radius: var(--radius-sm); padding: 0; max-height: 0; overflow: hidden; transition: max-height .3s, padding .3s; }
.form-status.show { padding: 14px 16px; max-height: 200px; }
.form-status.ok { background: #e9f6ee; color: #1f6b43; border: 1px solid #bfe6cd; }
.form-status.err { background: #fdecea; color: #b02a26; border: 1px solid #f3c9c5; }

/* Success screen */
.success { text-align: center; padding: 40px 20px; }
.success .check { width: 84px; height: 84px; border-radius: 50%; background: var(--green); display: grid; place-items: center; margin: 0 auto 22px; color: #fff; }
.success h2 { font-size: 32px; color: var(--green-deep); margin-bottom: 12px; }
.success p { color: var(--ink-soft); max-width: 420px; margin: 0 auto 26px; }
.hidden { display: none !important; }
