/* boot.css — font-var bindings + styles for elements that the original
   React template rendered with inline styles (FAB, mobile nav) or that are
   new to the standalone page set (.page-head, .prose, catalog rows). */

:root {
  --font-manrope: 'Manrope', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --font-playfair: 'Playfair Display', Georgia, serif;
  --font-cormorant: 'Cormorant', 'Playfair Display', Georgia, serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
img { max-width: 100%; }

/* ── burger + mobile nav ── */
.burger { display: none; flex-direction: column; gap: 5px; width: 40px; height: 40px;
  align-items: center; justify-content: center; background: transparent; border: 0; cursor: pointer; }
.burger span { display: block; width: 24px; height: 2px; background: #16181d; border-radius: 2px; transition: .25s; }
.burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity: 0; }
.burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.mobile-nav { display: none; flex-direction: column; gap: 4px; padding: 12px 18px 20px;
  background: rgba(255,255,255,.97); border-bottom: 1px solid #e7eef5; }
.mobile-nav.open { display: flex; }
.mobile-nav a { padding: 12px 6px; color: #16181d; text-decoration: none; border-bottom: 1px solid #eef3f8; font-size: 16px; }
.mobile-nav a.btn { border: 0; margin-top: 10px; text-align: center; }
@media (max-width: 980px) {
  .nebesa-site .hdr .nav, .nebesa-site .hdr .hours, .nebesa-site .hdr .contact { display: none; }
  .burger { display: flex; }
}

/* ── floating contact widget (FAB) ── */
.fab { position: fixed; right: 18px; bottom: 18px; width: 58px; height: 58px; z-index: 99990; }
.fab .fab-trigger { position: absolute; inset: 0; border-radius: 50%; border: 0; cursor: pointer;
  background: #2ba3e5; color: #fff; display: flex; align-items: center; justify-content: center;
  box-shadow: 0 10px 30px rgba(43,163,229,.45); transition: transform .3s cubic-bezier(.34,1.56,.64,1); z-index: 2; }
.fab.open .fab-trigger { transform: rotate(90deg); }
.fab .fab-item { position: absolute; left: 4px; bottom: 4px; width: 50px; height: 50px; border-radius: 50%;
  background: #2ba3e5; color: #fff; display: flex; align-items: center; justify-content: center;
  text-decoration: none; opacity: 0; pointer-events: none; transform: translateY(0);
  transition: transform .3s cubic-bezier(.34,1.56,.64,1), opacity .18s ease;
  box-shadow: 0 8px 20px rgba(43,163,229,.4); }
.fab.open .fab-item { opacity: 1; pointer-events: auto; }
.fab.open .fab-item[data-i="0"] { transform: translateY(-62px); }
.fab.open .fab-item[data-i="1"] { transform: translateY(-124px); }
.fab.open .fab-item[data-i="2"] { transform: translateY(-186px); }

/* ── feature icon (static svg fallback, was a lottie) ── */
.nebesa-site .feature .feature-ico { width: 72px; height: 72px; object-fit: contain; opacity: .85; margin-bottom: 8px; }

/* ── side clouds placeholder (decorative; original NebesaClouds) ── */
.neb-clouds { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 0; }

/* ── inner-page primitives (not in nebesa.css) ── */
.nebesa-site .page-head { padding: 120px 0 24px; text-align: center; }
.nebesa-site .page-head .lead, .nebesa-site .prose .lead { color: #5b6470; max-width: 760px; margin: 14px auto 0; line-height: 1.6; }
.nebesa-site .page-head .back, .nebesa-site .back { display: inline-block; color: #2ba3e5; text-decoration: none; font-size: 14px; margin-bottom: 10px; }
.nebesa-site .prose { padding: 28px 0 80px; }
.nebesa-site .prose p { max-width: 820px; margin: 0 auto 18px; color: #3a424d; line-height: 1.7; }
.nebesa-site .prose .h2 { text-align: center; margin-bottom: 18px; }

.nebesa-site .cats, .nebesa-site .prog-list, .nebesa-site .contacts { padding: 24px 0 60px; }
.nebesa-site .cats-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 22px; }
.nebesa-site .cats-grid .pcard { width: auto; }

.nebesa-site .prog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 16px; }
.nebesa-site .prow { display: block; padding: 18px 20px; border: 1px solid #e7eef5; border-radius: 14px;
  background: #fff; text-decoration: none; color: #16181d; transition: .2s; }
.nebesa-site .prow:hover { border-color: #2ba3e5; box-shadow: 0 12px 30px rgba(43,163,229,.12); transform: translateY(-2px); }
.nebesa-site .prow-nm { font-family: var(--font-playfair); font-size: 20px; margin-bottom: 6px; }
.nebesa-site .prow-meta { display: flex; gap: 14px; color: #5b6470; font-size: 14px; margin-bottom: 8px; }
.nebesa-site .prow-price { color: #2ba3e5; font-weight: 700; }
.nebesa-site .prow-desc { color: #5b6470; font-size: 14px; line-height: 1.5; }

.nebesa-site .prog-meta-big { display: flex; gap: 18px; justify-content: center; margin: 8px 0 14px; font-size: 18px; }
.nebesa-site .prog-cta { display: flex; gap: 12px; justify-content: center; margin-top: 22px; flex-wrap: wrap; }
.nebesa-site .disclaimer { color: #8a929c; font-size: 13px; max-width: 680px; margin: 22px auto 0; text-align: center; }

.nebesa-site .contacts-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 20px; }
.nebesa-site .ccard { padding: 24px; border: 1px solid #e7eef5; border-radius: 16px; background: #fff; }
.nebesa-site .ccard h3 { margin: 0 0 12px; font-family: var(--font-playfair); font-size: 20px; }
.nebesa-site .ccard .big { font-size: 22px; font-weight: 700; color: #16181d; text-decoration: none; display: block; margin-bottom: 6px; }
.nebesa-site .ccard a { color: #2ba3e5; text-decoration: none; }

.btn.btn-ghost { background: transparent; border: 1px solid #2ba3e5; color: #2ba3e5; }
