/* styles.css (повністю нова система змінних та класи) */
:root {
  --ink: #0b1220;
  --muted: #647089;
  --paper: #f6f7fb;
  --card: #ffffff;
  --night: #0f1221;

  --fx-1: 24px;
  --fx-2: 18px;
  --fx-3: 12px;

  --r-lg: 22px;
  --r-md: 16px;
  --r-sm: 10px;

  --a1: 0.28s cubic-bezier(.2,.7,.2,1);

  /* градієнт інший, ніж у попередній версії */
  --glow: linear-gradient(135deg, #00bcd4 0%, #ffb300 100%);
  --accent: #0fa3b1;
  --accent-soft: rgba(15, 163, 177, .14);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.ui {
  margin: 0;
  font-family: 'Manrope', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: var(--ink);
  background: radial-gradient(1000px 500px at 90% -10%, rgba(15,163,177,.12), transparent 60%), var(--paper);
  line-height: 1.6;
}

/* утиліти */
.wrap { width: min(1120px, 92vw); margin-inline: auto; }
.section { padding: 88px 0; }
.section--tint { background: radial-gradient(800px 320px at -10% 0%, rgba(255,179,0,.16), transparent 50%); }
.grid-2 { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 40px; align-items: start; }
.head { display:flex; justify-content:space-between; align-items:flex-end; gap:20px; margin-bottom:28px; }
.head--center { flex-direction:column; align-items:center; text-align:center; }
.kicker { font-weight:700; letter-spacing:.08em; text-transform:uppercase; color: var(--accent); margin: 0 0 10px; }
.h1 { font-size: clamp(2.2rem, 2.2vw + 1rem, 3.2rem); line-height: 1.12; margin: 0 0 14px; }
.h2 { font-size: clamp(1.8rem, 1.6vw + 1rem, 2.4rem); line-height: 1.22; margin: 0 0 12px; }
.h5 { font-size: 1.125rem; margin: 0 0 8px; }
.lead { font-size: 1.1rem; color: var(--muted); margin-bottom: 18px; }
.muted { color: var(--muted); }

/* шапка */
.skip { position:absolute; left:-9999px; }
.skip:focus { left: 12px; top: 12px; background:#fff; padding:8px 12px; border-radius: 8px; z-index:9999; }

.bar {
  position: sticky; top:0; z-index:1000;
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(11,18,32,.08);
}
.bar .wrap { display:flex; align-items:center; justify-content:space-between; padding: 16px 0; }

.brand { display:flex; align-items:center; gap: 12px; font-weight:800; letter-spacing:.02em; }
.brand__img { height: 32px; display:block; }
.brand__name { font-size: 1.05rem; }

.burger {
  display:none; border:1px solid rgba(11,18,32,.14); background:var(--card);
  width: 44px; height:44px; border-radius: 12px; align-items:center; justify-content:center; gap:4px;
}
.burger__line { width:18px; height:2px; background: var(--ink); display:block; transition: var(--a1); }
.burger__label { position:absolute; left:-9999px; }

.menu { display:flex; gap:28px; font-weight:700; }
.menu a { position:relative; padding:8px 0; }
.menu a::after { content:''; position:absolute; left:0; bottom:-6px; height:2px; width:0; background:var(--accent); transition: var(--a1); }
.menu a:hover::after{ width:100%; }

/* інтро */
.intro__panel.card { display:grid; gap:16px; }
.intro__panel .tick { margin: 0 0 10px; padding-left: 18px; }
.intro__panel .tick li { margin: 6px 0; }
.intro__panel .stat { background: var(--night); color:#fff; border-radius: var(--r-md); padding: 20px; display:grid; gap:6px; }
.intro__panel .stat strong { font-size: 2.6rem; line-height: 1; }

.chips { display:flex; flex-wrap: wrap; gap:10px; margin: 14px 0 0; padding:0; list-style:none; }
.chips li { background: var(--accent-soft); color: var(--accent); font-weight:700; padding:8px 12px; border-radius: 999px; font-size:.95rem; }

.cta-row { display:flex; flex-wrap:wrap; gap:12px; margin-top: 14px; }
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding: 12px 22px; border-radius: 999px; font-weight:800; border:2px solid transparent; cursor:pointer;
  transition: var(--a1);
}
.btn--fill { background: var(--glow); color:#111; box-shadow: 0 16px 40px rgba(15,163,177,.22); }
.btn--fill:hover { transform: translateY(-2px); }
.btn--ghost { background: #fff; border-color: rgba(11,18,32,.2); }
.btn--ghost:hover { border-color: var(--accent); color: var(--accent); }

/* картки/сітки */
.card { background: var(--card); border-radius: var(--r-lg); padding: 24px; box-shadow: 0 20px 48px rgba(11,18,32,.08); }
.cards-4 { display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 18px; }
.tile { border:1px dashed rgba(15,163,177,.4); background: linear-gradient(145deg, rgba(15,163,177,.08), rgba(255,179,0,.08)); }
.tile .tag { display:inline-block; margin-top:10px; font-weight:800; color: var(--accent); }

/* вітрина */
.masonry { display:grid; grid-template-columns: repeat(12, 1fr); gap: 18px; margin-bottom: 22px; }
.shot { grid-column: span 4; overflow:hidden; }
.shot--wide { grid-column: span 8; }
.shot img { width:100%; display:block; border-radius: var(--r-md); }
.shot figcaption { display:grid; gap:6px; margin-top: 10px; }
.shot strong { font-size: 1.1rem; }

.gallery { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 18px; }
.gallery__item img { border-radius: var(--r-md); display:block; }

/* метод */
.steps { list-style:none; display:grid; gap: 14px; padding:0; }
.steps li { padding: 16px 18px; border:1px dashed rgba(255,179,0,.6); border-radius: var(--r-sm); background: rgba(255,179,0,.06); }

/* KPI */
.kpi { display:grid; gap: 14px; }
.kpi__item { background: var(--night); color:#fff; border-radius: var(--r-md); padding: 20px; }
.kpi__val { font-weight:800; font-size: 2rem; display:block; line-height:1; }
.kpi__label { opacity:.8; }

/* форма */
.form { display:grid; gap: 14px; grid-template-columns: 1fr 1fr; }
.field { display:grid; gap:6px; font-weight:700; }
.field input, .field textarea {
  width:100%; padding:12px 14px; border-radius: var(--r-sm); border:1px solid rgba(11,18,32,.14); font-size: 1rem;
}
.field--full { grid-column: 1 / -1; }
.hp { position:absolute; left:-99999px; }

/* футер */
.foot { margin-top: 70px; background: var(--night); color:#fff; padding: 48px 0 22px; }
.foot__grid { display:flex; align-items:flex-start; justify-content:space-between; gap: 28px; }
.foot__logo { height: 34px; margin-bottom: 8px; }
.foot__text { opacity:.8; max-width: 380px; }
.foot__actions { display:grid; gap: 12px; justify-items:end; }
.social { display:flex; gap: 12px; list-style:none; padding:0; margin:0; }
.social a { display:grid; place-items:center; width:40px; height:40px; border-radius: 12px; background: rgba(255,255,255,.14); text-decoration:none; color:#fff; font-weight:800; }
.social a:hover { background: rgba(255,255,255,.24); transform: translateY(-1px); transition: var(--a1); }
.foot__meta { text-align:center; opacity:.6; margin-top: 24px; }

/* анімація появи */
.reveal { opacity:0; transform: translateY(18px); transition: .6s ease; }
.reveal.in { opacity:1; transform: translateY(0); }

/* адаптив */
@media (max-width: 980px) {
  .grid-2 { grid-template-columns: 1fr; }
  .cards-4 { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .masonry { grid-template-columns: repeat(6, 1fr); }
  .shot { grid-column: span 3; }
  .shot--wide { grid-column: span 6; }
  .menu { position: fixed; right: 16px; top: 74px; width: min(340px, 88vw); background: var(--card); border-radius: var(--r-md);
          box-shadow: 0 24px 60px rgba(11,18,32,.18); display: grid; gap: 16px; padding: 22px; transform: translateY(-8px) scale(.96);
          pointer-events:none; opacity:0; transition: var(--a1); }
  .burger { display:inline-flex; }
  .menu.is-open { opacity:1; transform: translateY(0) scale(1); pointer-events:auto; }
}

@media (max-width: 680px) {
  .gallery { grid-template-columns: 1fr; }
  .cards-4 { grid-template-columns: 1fr; }
  .form { grid-template-columns: 1fr; }
}
