/* Basic helper classes for layout and duotone poster vibe */
:root{--accent-1:#0fbfba;--accent-2:#ff6b6b;--muted:#f5f5f7;--text:#111}
*{box-sizing:border-box}
body{font-family:Inter, system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial; color:var(--text); margin:0; background:linear-gradient(135deg,var(--accent-1)10%,var(--accent-2)90%);}
.container{max-width:1100px;margin:0 auto;padding:2rem}
.site-header__inner,.site-footer__inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:rgba(255,255,255,0.06)}
.logo img{height:36px}
.main{padding:2rem 0;background:linear-gradient(180deg,rgba(255,255,255,0.02),rgba(0,0,0,0.02))}
.hero{display:flex;gap:2rem;align-items:center;padding:3rem 2rem}
.hero__content{flex:1;color:#fff}
.hero__title{font-size:2rem;margin:0 0 .5rem}
.hero__subtitle{margin:0 0 1rem;opacity:.95}
.btn{display:inline-block;padding:.6rem 1rem;border-radius:8px;text-decoration:none}
.btn--primary{background:#fff;color:var(--accent-1);font-weight:600}
.btn--ghost{background:transparent;border:1px solid rgba(255,255,255,0.2);color:#fff}
.img{overflow:hidden;border-radius:8px}
.img img{width:100%;height:100%;object-fit:cover;display:block}
.img--portrait{width:220px;height:320px}
.img--square{width:280px;height:280px}
.cards{display:grid;gap:1rem}
.cards--3up{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));}
.cards--4up{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));}
.card{background:rgba(255,255,255,0.06);padding:1rem;border-radius:10px}
.features__gallery{display:flex;gap:1rem;margin-top:1rem}
.zebra-list__item{padding:1rem;background:rgba(255,255,255,0.02);margin-bottom:1rem;border-radius:8px}
.pricing__card{background:rgba(255,255,255,0.04);padding:1rem;border-radius:8px;margin:0.5rem}
.logo-wall{display:flex;gap:1rem;align-items:center}
.testimonial{background:rgba(255,255,255,0.03);padding:1rem;border-radius:8px;margin-bottom:1rem}
.contact__list{list-style:none;padding:0;margin:1rem 0}
.contact__item{display:flex;gap:.5rem;align-items:center;padding:.4rem 0}
.site-footer__copy{opacity:.9}
/* Accessibility helpers */
[role="tab"]{padding:.5rem 1rem;border-radius:6px;background:rgba(255,255,255,0.03);border:none}



:root{
  --bg: linear-gradient(180deg,#0f172a 0%, #111827 100%);
  --surface: rgba(255,255,255,0.04);
  --text: #ecf1f8;
  --muted: #94a3b8;
  --primary: #22d3ee;
  --accent: #f472b6;
  --radius: 20px;
  --shadow: 0 20px 50px rgba(0,0,0,.45);
  --border: 1px solid rgba(255,255,255,.06);
  --font-ui: "Poppins", ui-sans-serif, system-ui;
  --space-1:0.250rem; --space-2:0.500rem; --space-3:0.750rem; --space-4:1.000rem;
  --space-5:1.500rem; --space-6:2.000rem; --space-7:3.000rem;
  --mxw:1040px;
}
:root{ color-scheme: dark; }
body{ background: var(--bg); color: var(--text); font-family: var(--font-ui); }



/* ---------- Layout ---------- */
.container{ max-width: var(--mxw); margin-inline:auto; padding-inline:16px; }
section{ padding-block: var(--space-6); }
@media (min-width: 992px){ section{ padding-block: calc(var(--space-7) + .5rem); } }

/* Header / Nav */
header.header, header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(180%) blur(8px);
  background: color-mix(in oklab, var(--surface), transparent 85%);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.logo{ display:inline-flex; align-items:center; gap:.5rem; text-decoration:none; }
.logo img{ height:24px; width:auto; display:block; }
nav.nav{ display:flex; gap:.75rem; flex-wrap:wrap; }
nav.nav a{ font-size:.95rem; opacity:.9; }
nav.nav a:hover{ opacity:1; text-decoration:underline; }

/* ---------- HERO: жорстка двоколонка ---------- */
.hero{ background: linear-gradient(180deg, color-mix(in oklab, var(--bg), #000 4%), color-mix(in oklab, var(--bg), #000 0%)); }
.hero .container{
  display:grid; align-items:center; gap:32px;
}
@media (min-width: 992px){
  .hero .container{
    grid-template-columns: 1.15fr .85fr;
  }
}
/* усе НЕ <figure> — у ліву колонку, усі <figure> — у праву */
.hero .container > :not(figure){ grid-column: 1; }
.hero .container > figure{ grid-column: 1; } /* на мобілці під текстом */
@media (min-width: 992px){
  .hero .container > figure{ grid-column: 2; }
  .hero .container > figure:first-of-type{ margin-top:0; }
}
/* акуратні превʼюшки */
.hero figure.img{ max-width: 560px; margin-inline:auto; }
.hero figure.img + figure.img{ margin-top:16px; }
@media (min-width: 992px){
  .hero figure.img{ margin-inline:0; }
}

/* ---------- Media ---------- */
.img{ display:block; width:100%; overflow:hidden; border-radius: var(--radius); aspect-ratio:16/9; background:#20232b; }
.img img{ width:100%; height:100%; object-fit:cover; display:block; }
.img--square{ aspect-ratio:1/1; }

/* ---------- Cards / Grids ---------- */
.cards, .features, .portfolio, .benefits, .pricing-plans, .instructors{
  display:grid; gap:20px; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
.card{
  background: var(--surface); border: var(--border);
  border-radius: var(--radius); box-shadow: var(--shadow);
  transition: transform .15s ease, box-shadow .15s ease;
  padding: 1rem;
}
.card:hover{ transform: translateY(-2px); }
.cards .card{ height:100%; }

/* ---------- Typography ---------- */
h1{ font-size: clamp(2rem, 1.4rem + 2.2vw, 3rem); line-height:1.15; margin:.3em 0 .4em; }
h2{ font-size: clamp(1.5rem, 1.2rem + 1.2vw, 2.1rem); line-height:1.2; margin:.2em 0 .4em; }
p{ margin:.6em 0; }

/* ---------- Buttons (варіанти) ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.5rem;
  background: transparent; color:var(--primary); text-decoration:none;
  border:1px solid var(--primary); border-radius: calc(var(--radius) - 2px);
  padding:.65rem 1rem; line-height:1.2; cursor:pointer;
}
.btn:hover{ filter: brightness(0.98); }
.btn + .btn{ margin-left:.5rem; }

/* ---------- Contact block ---------- */
.contact-address{ white-space:pre-line; line-height:1.5; }

/* ---------- Dividers / spacing ---------- */
hr{ border:none; height:1px; background: rgba(255,255,255,.08); margin: 28px 0; }
.stack > * + *{ margin-top: var(--space-4); }

/* ---------- Auto dark polish ---------- */
@media (prefers-color-scheme: dark){
  :root{ color-scheme: dark; }
  body{ background: #0c1018; color: #e8eef8; }
  .card{ background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.10); }
  .img{ background: #1b2230; }
}
  /* HERO фон — випадковий патерн */
.hero{ background: linear-gradient(180deg, color-mix(in oklab, var(--bg), #000 4%), color-mix(in oklab, var(--bg), #000 0%)); }

/* IMG контейнер і зображення: жорстко змушуємо покриття контейнера */
.img{ display:block; width:100%; overflow:hidden; border-radius: var(--radius); aspect-ratio:16/9; background:#20232b; }
.img img{ width:100%; height:100% !important; object-fit:cover; display:block; } /* !important — щоб перебити інлайнові height:auto */

/* Іконки всередині карток/списків */
.card i[data-lucide]{ width:24px; height:24px; color: var(--primary); margin-bottom:.5rem; }

/* Охайні списки з іконками */
ul.icon-list{ list-style:none; padding:0; margin:0; display:grid; gap:12px; }
.icon-list li{ display:flex; align-items:flex-start; gap:10px; }
.icon-list li i[data-lucide]{ flex:none; width:22px; height:22px; margin-top:2px; color: var(--primary); }

/* Темна тема полірування */
@media (prefers-color-scheme: dark){
  .card{ background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.10); }
  .img{ background: #1b2230; }
}
  /* === Universal 2-col layout helpers === */
.auto-two > .container{
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  align-items: center;
}
@media (min-width: 992px){
  .auto-two > .container{
    grid-template-columns: 1fr 1fr;
  }
}

/* HERO — строгі області, щоб текст ліворуч, зображення праворуч */
.hero > .container{
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  align-items: center;
}
@media (min-width: 992px){
  .hero > .container{
    grid-template-columns: 1.15fr .85fr;
    grid-template-areas:
      "hero-text hero-media";
  }
  .hero > .container > :not(figure){ grid-area: hero-text; }
  .hero > .container > figure{ grid-area: hero-media; }
}

/* Media blocks — без «порожньої смуги» знизу */
figure.img{ width:100%; overflow:hidden; border-radius: var(--radius); background:#20232b; }
figure.img img{ width:100%; height:100% !important; object-fit:cover; display:block; }
figure.img.img--portrait{ aspect-ratio: 3/4; }
figure.img.img--square{ aspect-ratio: 1/1; }
figure.img:not(.img--portrait):not(.img--square){ aspect-ratio: 16/9; }

/* Cards grid */
.cards, .features, .benefits, .pricing-plans, .portfolio{
  display:grid; gap:20px; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
.card{ height:100%; padding:1rem; border:var(--border); border-radius:var(--radius); box-shadow:var(--shadow); background:var(--surface); }

/* Icon list tidy */
ul.icon-list{ list-style:none; padding:0; margin:0; display:grid; gap:14px; }
.icon-list li{ display:flex; gap:10px; align-items:flex-start; }
.icon-list i[data-lucide]{ width:22px; height:22px; margin-top:2px; color:var(--primary); }


.hero{ background: radial-gradient(60% 60% at 80% 10%, rgba(34,211,238,.18), transparent 60%); } h1{ letter-spacing:.4px; }

