/* ==========================
   GLOBAL / BASE STYLES
   ========================== */

/* Верхняя узкая полоса */
.top-bar {
    background:#000000;
    color:#ffffff;
    font-size: 13px;
    padding: 3px 12px;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 2000;
    height: 30px;
    line-height: 24px;
}

.top-bar .container {
    display: flex;
    justify-content: flex-end;
    gap: 15px;
    height: 100%;
    align-items: center;
}

.top-bar span {
    display: flex;
    align-items: center;
    gap: 5px;
}

/* Основи */
body {
    margin: 0;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    background-color: #1e1e1e;
    color: #ffffff;
    line-height: 1.6;
    padding-top: 110px; /* под узкую полосу и хедер */
}

.container {
    width: 90%;
    max-width: 1200px;
    margin: auto;
    padding: 0;
}

/* Хедер */
.main-header {
    position: fixed;
    top: 30px; /* под top-bar */
    left: 0;
    width: 100%;
    background-image: url('9.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    color: white;
    z-index: 1500;
    padding: 0; /* убраны внутренние отступы */
    height: 80px; /* фиксированная высота */
    margin-top: 0; /* убрана щель между top-bar и header */
}

.main-header::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: -1;
}

.header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 100%;
    position: relative;
    z-index: 2;
    padding: 0 40px;
}

.logo {
    display: flex;
    align-items: center;
    height: 100%;
}

.logo img.logo-img {
    height: 100%;
    width: auto;
    display: block;
}

.nav-menu {
    margin-left: auto;
    display: flex;
    align-items: center;
    height: 100%;
}

.nav-menu a {
    color: #fff;
    text-decoration: none;
    margin-left: 20px;
    padding: 5px 10px;
    transition: color 0.3s, border-bottom 0.3s;
    border-bottom: 2px solid transparent;
    font-size: 18px;
    font-weight: 500;
}

.nav-menu a:hover,
.nav-menu a.active {
    color: #00bfff;
    border-bottom: 2px solid #00bfff;
}

/* Герой-секція */
.hero-section {
    background: linear-gradient(rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.6)),
                url('6.jpg') center/cover no-repeat;
    background-attachment: fixed;
    padding: 50px 0;
    color: #fff;
    text-align: center;
    position: relative;
}

.hero-text p {
    font-size: 20px;
    color: #ddd;
    text-shadow: 0 1px 8px #000;
    line-height: 1.9;
}

.hero-text {
    position: relative;
    z-index: 2;
}

.hero-text h1 {
    font-size: 48px;
    color: #00bfff;
    text-shadow: 0 2px 12px #000;
    margin-bottom: 20px;
}

.hero-text p {
    font-size: 30px;
    color: #ddd;
    text-shadow: 0 1px 8px #000;
}

@media (max-width: 600px) {
    .hero-text h1 { font-size: 32px; }
    .hero-text p { font-size: 16px; }
}

/* більше відступу під кнопкою */
.hero-section .btn-wrapper{ margin-top: clamp(16px,3.2vw,36px); }

/* керуй усіма проміжками одним параметром */
.hero-text{ gap: clamp(14px, 3vw, 26px); }

/* на мобілці трохи менші заголовки */
@media (max-width:600px){
  .hero-text h1{ font-size: clamp(28px, 9vw, 44px); line-height: 1.12; }
}

/* Кнопки */
.btn-primary {
    background-color: #00bfff;
    color: #000;
    font-weight: bold;
    border-radius: 6px;
    padding: 12px 30px;
    text-transform: uppercase;
    box-shadow: 0 4px 10px rgba(0, 191, 255, 0.3);
    transition: background 0.3s, color 0.3s;
    border: none;
    cursor: pointer;
    text-decoration: none;
}

.btn-primary:hover { background-color: #0099cc; color: #fff; }

.btn-outline {
    background-color: transparent;
    color: #00bfff;
    border: 2px solid #00bfff;
    font-weight: bold;
    border-radius: 6px;
    padding: 12px 30px;
    text-transform: uppercase;
    box-shadow: 0 4px 10px rgba(0, 191, 255, 0.2);
    transition: background 0.3s, color 0.3s;
    cursor: pointer;
    text-decoration: none;
}

.btn-outline:hover { background-color: #00bfff; color: #000; }

/* Блок переваг */
.features h2,
.target-groups h2,
.cta-contact h2 {
    color: #00bfff;
    text-align: center;
    font-size: 28px;
    margin-bottom: 30px;
}

.cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
}

/* Карточки */
.card, .target-card {
    position: relative;
    cursor: pointer;
    background-color: #2a2a2a;
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0 0 10px rgba(0,0,0,0.4);
    transition: transform 0.3s;
    z-index: 1;
}

.card h3, .target-card h3 {
    color: #00bfff;
    font-size: 20px;
    margin-bottom: 10px;
    position: relative;
    cursor: pointer;
}

.card:hover, .target-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 0 20px 5px rgba(0, 191, 255, 0.4);
    transition: box-shadow 0.3s ease, transform 0.3s ease;
}

/* Блок цільової аудиторії */
.target-groups {
    background: linear-gradient(rgba(0,0,0,0.6), rgba(0,0,0,0.6)),
                url('4.jpg') center/cover no-repeat;
    padding: 40px 0;
    color: #fff;
}

.target-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
}

.target-card h3 { margin-bottom: 10px; }

/* CTA */
.cta-contact {
    background: linear-gradient(rgba(0,0,0,0.7), rgba(0,0,0,0.7)),
                url('8.jpg') center/cover no-repeat;
    background-attachment: fixed;
    padding: 60px 20px;
    text-align: center;
    color: #fff;
}

.cta-contact p {
    color: #ccc;
    font-size: 18px;
    margin-bottom: 30px;
}

.cta-buttons { display: flex; justify-content: center; gap: 15px; flex-wrap: wrap; }

/* Футер (старые базовые классы на случай использования) */
.footer { background-color: #111; padding: 20px 0; text-align: center; color: #777; font-size: 14px; }
.footer-btn { min-width: 180px; padding: 12px 30px; font-size: 1rem; text-align: center; }

/* Видалення фону для електронного документообігу */
.no-bg { background-image: none !important; background-color: #1c1c1c !important; }

/* Новий блок: Програмні рішення з логотипами */
.soft-logos { display: flex; flex-wrap: wrap; gap: 2rem; margin-top: 2rem; }

.soft-item {
    background-color: #2a2a2a;
    border-radius: 16px;
    padding: 1.5rem;
    flex: 1 1 45%;
    display: flex;
    align-items: flex-start;
    gap: 1.5rem;
    box-shadow: 0 0 10px rgba(0, 191, 255, 0.2);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.soft-item:hover { transform: translateY(-5px); box-shadow: 0 0 20px rgba(0, 191, 255, 0.4); }

.soft-item img { width: 80px; height: auto; object-fit: contain; border-radius: 12px; background-color: #1e1e1e; padding: 5px; }

.soft-item p { margin: 0; color: #ffffff; font-size: 1rem; line-height: 1.5; }

.soft-item p strong { color: #00bfff; font-weight: 600; display: block; margin-bottom: 0.3rem; font-size: 1.1rem; }

@media (max-width: 768px) {
    .soft-item { flex-direction: column; align-items: center; text-align: center; }
    .soft-item img { width: 60px; }
}

/* ===== Сторінка "Електронний документообіг" ===== */
.document-flow { background-color: #1e1e1e; padding: 60px 20px; color: #ffffff; text-align: center; }

.document-flow h1 { font-size: 40px; color: #00bfff; margin-bottom: 20px; text-shadow: 0 2px 8px #000; }

.document-flow p { font-size: 18px; color: #ccc; max-width: 800px; margin: 0 auto 30px auto; line-height: 1.7; }

.document-flow .features { margin-top: 40px; }

.document-flow .cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 20px; margin-top: 20px; }

.document-flow .card { background-color: #2a2a2a; padding: 20px; border-radius: 12px; box-shadow: 0 0 10px rgba(0,191,255,0.15); transition: transform 0.3s ease, box-shadow 0.3s ease; }

.document-flow .card:hover { transform: translateY(-5px); box-shadow: 0 0 20px rgba(0,191,255,0.4); }

.document-flow .card h3 { color: #00bfff; font-size: 20px; margin-bottom: 10px; }

.document-flow .card p { font-size: 16px; color: #ddd; }

.document-flow .btn-primary { margin-top: 40px; }

@media (max-width: 600px) {
    .document-flow h1 { font-size: 28px; }
    .document-flow p { font-size: 16px; }
    .document-flow .card h3 { font-size: 18px; }
    .document-flow .card p { font-size: 14px; }
}

/* Оформлення для сторінки Електронний документообіг */
.document-section { padding-inline: 20px; }

.document-section h1,
.document-section h2,
.document-section h3 { color: #00bfff; margin-top: 1.5rem; margin-bottom: 0.8rem; }

.document-section p,
.document-section li { color: #ddd; font-size: 1rem; line-height: 1.6; margin-bottom: 1rem; max-width: 900px; }

/* Контакти з фоном (вьюпортная подложка) */
.contacts-container {
    width: 100vw;
    min-height: 100vh;
    margin: 0;
    padding: 120px 2rem 2rem;
    background-image: url('3.jpg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    position: relative;
    z-index: 1;
    color: #ffffff;
    font-size: 1.3rem;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
}

/* Сучасне оформлення контактів (контентный контейнер) */
.contacts-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 120px 2rem 2rem;
    text-align: center;
    background-image: url('3.jpg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    position: relative;
    z-index: 1;
    color: #ffffff;
    font-size: 1.3rem;
}

.contacts-container::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(18, 18, 18, 0.85);
    z-index: -1;
    border-radius: 12px;
}

.contact-card { background-color: #2a2a2a; padding: 3rem; border-radius: 16px; max-width: 1000px; width: 100%; box-shadow: 0 4px 20px rgba(0, 191, 255, 0.2); }

.contact-name { font-size: 1.8rem; font-weight: 600; color: #00bfff; margin-bottom: 0.5rem; }
.contact-title { font-size: 1.2rem; color: #ccc; margin-bottom: 1.5rem; }
.contact-info p { font-size: 1.1rem; color: #ddd; line-height: 1.8; margin-bottom: 1rem; }
.contact-info a { color: #00bfff; text-decoration: none; }
.contact-info a:hover { text-decoration: underline; }

@media (max-width: 600px) {
  .contacts-container { font-size: 1rem; padding: 80px 1rem 2rem; }
  .contact-card { padding: 1.5rem; width: 100%; max-width: 100%; border-radius: 12px; }
  .contact-name { font-size: 1.5rem; }
  .contact-title { font-size: 1rem; }
  .contact-info p { font-size: 1rem; }
  .contact-card .btn-outline { font-size: 1rem; width: 100%; max-width: 100%; padding: 1rem; margin-top: 1.5rem; }
}

.contacts-container h2 { text-align: center; font-size: 2rem; margin-bottom: 2rem; color: #00bfff; }

.law-link { color: #66e0ff; text-decoration: underline; font-weight: 500; }
.law-link:hover { color: #00cc66; }

/* Корректное масштабирование логотипа */
.logo img.logo-img { height: 100%; max-height: 26px; width: auto; }

/* Мобильная адаптация логотипа и хедера */
@media (max-width: 480px) {
    .nav-menu a { font-size: 14px; margin-left: 8px; padding: 3px 6px; }
}

.logo-img { height: 80px; width: auto; max-width: 100%; object-fit: contain; display: block; }
.logo img.logo-img { max-height: 80px !important; height: auto !important; }

/* Адаптивне зменшення логотипа на мобільних пристроях */
@media (max-width: 600px) { .logo img.logo-img { height: 50px; } }

/* === Універсальна адаптація для мобільних пристроїв (перекриває інші) === */
@media (max-width: 600px) {
  body { font-size: 16px !important; padding-top: 90px !important; }
  .container { width: 95% !important; padding: 0 10px !important; }
  .nav-menu a { font-size: 14px !important; margin-left: 10px !important; padding: 4px 6px !important; }
  .logo img.logo-img { max-height: 50px !important; height: auto !important; }
  .btn-primary, .btn-outline { width: 100% !important; font-size: 1rem !important; padding: 1rem !important; display: block !important; margin: 1.5rem auto 0 !important; text-align: center !important; }
  .card, .target-card, .contact-card { padding: 1rem !important; max-width: 100% !important; width: 100% !important; border-radius: 12px !important; }
  .hero-text h1 { font-size: 28px !important; }
  .hero-text p { font-size: 16px !important; }
  .contacts-container { font-size: 1rem !important; padding: 80px 1rem 2rem !important; }
  .contact-name { font-size: 1.5rem !important; }
  .contact-title { font-size: 1rem !important; }
  .contact-info p { font-size: 1rem !important; }
  .cta-contact p { font-size: 16px !important; }
  .soft-item { flex-direction: column !important; align-items: center !important; text-align: center !important; }
  .soft-item img { width: 60px !important; }
}

/* Кнопка звонка */
.call-button-wrapper { position: fixed; bottom: 30px; right: 30px; z-index: 1000; }
.call-button {
  background-color: #00aaff; color: #000; border: none; border-radius: 50%; width: 70px; height: 70px; font-size: 12px; font-weight: bold; cursor: pointer; box-shadow: 0 4px 6px rgba(0,0,0,0.2); transition: all 0.3s ease; text-align: center; line-height: 1.1; display: flex; align-items: center; justify-content: center; text-wrap: balance; text-transform: uppercase; animation: pulse 1.8s infinite ease-in-out;
}
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(0, 191, 255, 0.5); } 70% { box-shadow: 0 0 0 20px rgba(0, 191, 255, 0); } 100% { box-shadow: 0 0 0 0 rgba(0, 191, 255, 0); } }

/* === Форма звонка — финальная тёмная === */
.call-form { position: fixed; bottom: 100px; right: 20px; background-color: #00bfff; padding: 20px; border-radius: 12px; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3); z-index: 9998; transition: all 0.3s ease-in-out; width: 280px; }
.call-form.hidden { display: none; }
.call-form input, .call-form button { all: unset; box-sizing: border-box; width: 100%; padding: 10px; margin-bottom: 10px; border-radius: 6px; font-size: 16px; font-family: inherit; }
.call-form input { background: #fff; color: #000; }
.call-form input::placeholder { color: #666; }
.call-form button { background-color: #fff; color: #000; font-weight: bold; text-align: center; cursor: pointer; transition: background 0.3s ease; }
.call-form button:hover { background-color: #e6e6e6; }

/* ===== Dark theme + violet glow overrides ===== */
:root{
  --bg:#000000; --panel:#131313; --panel-2:#1a1a1a; --text:#ffffff; --muted:#e2e2e2;
  --accent:#bca6ff; --accent-strong:#9b6bff; --accent-rgb:188,166,255;
  --glow:0 0 24px rgba(var(--accent-rgb),0.36); --glow-strong:0 0 38px rgba(var(--accent-rgb),0.52);
  --border:#2f2f2f;
}
body{ background-color:var(--bg) !important; color:var(--text) !important; }
.top-bar{ background:#000 !important; color:#fff !important; box-shadow:0 1px 0 rgba(255,255,255,.05); }
.main-header{ color:#fff; }
.main-header::before{ background: linear-gradient(180deg, rgba(var(--accent-rgb),0.08) 0%, rgba(0,0,0,0.6) 100%) !important; }
.nav-menu a{ color:#fff !important; border-bottom:2px solid transparent !important; }
.nav-menu a:hover, .nav-menu a.active{ color:var(--accent) !important; border-bottom-color:var(--accent) !important; text-shadow:0 0 6px rgba(var(--accent-rgb),0.35); }
.hero-section{ color:#fff !important; background: linear-gradient(rgba(0,0,0,.45), rgba(0,0,0,.45)), url('4.jpg') center/cover no-repeat !important; }
.hero-text h1{ color:#fff !important; text-shadow:0 0 10px rgba(var(--accent-rgb),0.35), 0 2px 14px rgba(0,0,0,0.7); }
.hero-text p{ color:#ddd !important; text-shadow:0 0 6px rgba(var(--accent-rgb),0.18); }
.btn-primary{ background:var(--accent) !important; color:#fff !important; box-shadow: var(--glow); border:none; }
.btn-primary:hover{ background:var(--accent-strong) !important; box-shadow: var(--glow-strong); }
.btn-outline{ border:2px solid var(--accent) !important; color:var(--accent) !important; background:transparent !important; }
.btn-outline:hover{ background:var(--accent) !important; color:#0b0b0b !important; }
.features h2, .target-groups h2, .cta-contact h2, .document-flow h1, .document-section h1, .document-section h2, .document-section h3, .contacts-container h2{ color:#fff !important; text-shadow:0 0 10px rgba(var(--accent-rgb),0.25); }
.card, .target-card{ background-color:var(--panel) !important; color:#fff !important; box-shadow:0 0 10px rgba(0,0,0,0.5); border:1px solid var(--border); }
.card h3, .target-card h3{ color:#fff !important; text-shadow:0 0 8px rgba(var(--accent-rgb),0.25); }
.card:hover, .target-card:hover{ transform: translateY(-5px); box-shadow:0 0 22px rgba(var(--accent-rgb),0.35); }
.target-groups{ color:#fff !important; }
.cta-contact{ color:#fff !important; }
.cta-contact p{ color:#cfcfcf !important; }
.footer{ background:#0a0a0a !important; color:#9a9a9a !important; border-top:1px solid var(--border); }
.law-link{ color:var(--accent) !important; }
.law-link:hover{ color:var(--accent-strong) !important; text-shadow:0 0 8px rgba(var(--accent-rgb),0.35); }
.contacts-container{ color:#fff; background-image:url('3.jpg'); }
.contacts-container::before{ background: rgba(0,0,0,0.82); }
.contact-card{ background:var(--panel) !important; border:1px solid var(--border); box-shadow: var(--glow); }
.contact-name{ color:#fff !important; }
.contact-title{ color:#cfcfcf !important; }
.contact-info p{ color:#e5e5e5 !important; }
.contact-info a{ color:var(--accent) !important; }
.document-flow, .document-section{ background-color:var(--bg) !important; color:#fff !important; }
.document-flow .card{ background:var(--panel) !important; box-shadow: var(--glow); }
.document-flow .card h3{ color:#fff !important; }
.call-button{ background:var(--accent) !important; color:#0b0b0b !important; box-shadow: var(--glow); }
.call-button:hover{ background:var(--accent-strong) !important; box-shadow: var(--glow-strong); }
.call-form{ background:var(--panel-2) !important; color:var(--text) !important; border:1px solid rgba(var(--accent-rgb),0.35) !important; box-shadow:0 8px 30px rgba(0,0,0,0.5), var(--glow); }
.call-form input{ background:#0d0d0d !important; color:#fff !important; border:1px solid #222 !important; }
.call-form input::placeholder{ color:#9a9a9a !important; }
.call-form button{ background:var(--accent) !important; color:#0b0b0b !important; }
.call-form button:hover{ background:var(--accent-strong) !important; }
.logo img.logo-img{ max-height:80px !important; height:auto !important; filter: drop-shadow(0 0 10px rgba(var(--accent-rgb),0.25)); }

/* Доступність: фокус */
a:focus-visible, button:focus-visible, .btn-primary:focus-visible, .btn-outline:focus-visible{ outline:2px solid var(--accent-strong); outline-offset:2px; box-shadow: var(--glow-strong); }

/* HERO улучшения */
.hero-section{ position:relative; overflow:hidden; }
.hero-section::before{ content:""; position:absolute; inset:0; background: linear-gradient(90deg, rgba(0,0,0,.40) 0%, rgba(0,0,0,.28) 38%, rgba(0,0,0,.18) 100%); pointer-events:none; z-index:0; }
.hero-text{ max-width: 1100px; margin-inline:auto; }
.hero-text h1{ max-width: 22ch; line-height: 1.18; letter-spacing: -0.01em; margin-inline:auto; text-shadow: 0 2px 14px rgba(0,0,0,.7), 0 0 10px rgba(167,139,250,.35); }
.hero-text p{ max-width: 60ch; margin: .75rem auto 0; }

/* HEADER: полупрозрачность + blur */
.main-header{ background: rgba(0,0,0,.55); -webkit-backdrop-filter: saturate(140%) blur(8px); backdrop-filter: saturate(140%) blur(8px); border-bottom: 1px solid rgba(255,255,255,.06); }

/* Навигация — violet hover */
.nav-menu a:hover, .nav-menu a.active{ color:#a78bfa !important; border-bottom-color:#a78bfa !important; text-shadow:0 0 6px rgba(167,139,250,.35); }

/* CTA-кнопка — градиент */
.btn-primary{ background: linear-gradient(90deg,#8b5cf6,#a78bfa) !important; color:#fff !important; border:none; box-shadow: 0 0 0 1px rgba(255,255,255,.12), 0 0 18px rgba(167,139,250,.30); }
.btn-primary:hover{ filter: brightness(1.05); box-shadow: 0 0 26px rgba(167,139,250,.40); }

/* Карточки — общий стиль */
.card,.target-card{ background:#101010 !important; border:1px solid #262626; box-shadow: 0 1px 0 rgba(255,255,255,.03); }
.card h3,.target-card h3{ color:#fff !important; text-shadow:0 0 8px rgba(167,139,250,.22); }
.card:hover,.target-card:hover{ transform: translateY(-4px); box-shadow: 0 0 22px rgba(167,139,250,.35); }

/* Нормативные ссылки */
.law-link{ color:#a78bfa !important; text-decoration: underline; }
.law-link:hover{ color:#8b5cf6 !important; text-shadow:0 0 8px rgba(167,139,250,.35); }

/* Плавающая кнопка звонка */
.call-button-wrapper{ right: 24px; bottom: 28px; }
@media (max-width: 640px){ .call-button-wrapper{ right: 14px; bottom: 14px; } }

/* Контейнеры секций */
.container{ max-width: 1100px; }

/* Скролл-якоря */
:where(h1,h2,h3){ scroll-margin-top: 120px; }

/* Сеточная настройка */
.cards{ grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 24px; }
.card,.target-card{ border-radius:14px; transition: transform .2s ease, box-shadow .25s ease, border-color .25s ease; min-height: 140px; }
.card h3,.target-card h3{ margin:0 0 .5rem 0; }
.card p{ color:#d9d9d9; }
.features, .target-groups, .cta-contact{ padding: 64px 0; }
@media (max-width: 640px){ .features, .target-groups, .cta-contact{ padding: 44px 0; } }

/* Стеклянные карточки (ui-glass) */
.ui-glass .card, .ui-glass .target-card{
  position: relative; background: rgba(16,16,16,.55) !important; border: 1px solid rgba(167,139,250,.22);
  border-radius: 16px; padding: 20px; color: #fff;
  backdrop-filter: blur(10px) saturate(130%); -webkit-backdrop-filter: blur(10px) saturate(130%);
  box-shadow: 0 1px 0 rgba(255,255,255,.04), 0 10px 30px rgba(0,0,0,.35);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease, background .25s ease;
  overflow: hidden; min-height: 140px;
}
.ui-glass .card::before, .ui-glass .target-card::before{
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(60% 40% at 18% 0%, rgba(167,139,250,.14), transparent 60%), radial-gradient(80% 60% at 100% 0%, rgba(255,255,255,.06), transparent 70%);
  mix-blend-mode: screen; opacity: .9;
}
.ui-glass .card::after, .ui-glass .target-card::after{
  content:""; position:absolute; inset:0; border-radius: inherit; padding: 1px;
  background: linear-gradient(120deg, rgba(167,139,250,.55), rgba(255,255,255,.08), rgba(167,139,250,.55));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor;
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); mask-composite: exclude;
  opacity: .7; pointer-events: none; transition: opacity .25s ease;
}
.ui-glass .card:hover, .ui-glass .target-card:hover{
  transform: translateY(-6px); border-color: rgba(167,139,250,.45);
  box-shadow: 0 14px 44px rgba(167,139,250,.22), 0 2px 0 rgba(255,255,255,.05) inset;
}
.ui-glass .card:hover::after, .ui-glass .target-card:hover::after{ opacity: 1; }
.ui-glass .card h3, .ui-glass .target-card h3{ margin: 0 0 .5rem 0; color:#fff; letter-spacing:.2px; text-shadow: 0 0 8px rgba(167,139,250,.22); }
.ui-glass .card p{ color:#d8d8d8; }
.card__icon{ width:40px; height:40px; margin-bottom:.75rem; border-radius:10px;
  background: radial-gradient(100% 100% at 50% 0%, rgba(167,139,250,.35), rgba(167,139,250,.12));
  box-shadow: 0 6px 18px rgba(167,139,250,.25) inset, 0 0 18px rgba(167,139,250,.18);
}
@media (max-width:640px){ .ui-glass .card, .ui-glass .target-card{ border-radius:14px; } }

/* Сетка features: 3/2/1 */
.features .cards{ display: grid; gap: 24px; grid-template-columns: repeat(3, minmax(260px, 1fr)); }
@media (max-width:1024px){ .features .cards{ grid-template-columns: repeat(2, minmax(260px,1fr)); } }
@media (max-width:640px){ .features .cards{ grid-template-columns: 1fr; } }
.features .cards > .card:last-child{ grid-column: auto !important; }

/* Заголовки над слоями + отступы */
.features, .target-groups, .cta-contact { position: relative; isolation: isolate; }
.features::before, .features::after, .target-groups::before, .target-groups::after, .cta-contact::before, .cta-contact::after { z-index: 0; }
.features h2, .target-groups h2, .cta-contact h2 { position: relative; z-index: 1; display: block; color: #fff !important; text-align: center; font-size: clamp(24px, 2.4vw, 34px); margin: 0 0 24px; }
.features .cards, .target-groups .target-cards { margin-top: 12px; }

/* ============================================
   RESTORE — GLOW FOR CARDS & BACKGROUND IMAGES
   ============================================ */
.card, .target-card{
  background:#101010 !important;
  border:1px solid rgba(var(--accent-rgb),.22) !important;
  box-shadow: 0 1px 0 rgba(255,255,255,.03), var(--glow) !important;
}
.card:hover, .target-card:hover{
  transform: translateY(-6px);
  border-color: rgba(var(--accent-rgb),.45) !important;
  box-shadow: 0 2px 0 rgba(255,255,255,.05), var(--glow-strong) !important;
}

.hero-section, .features, .target-groups, .cta-contact{ position:relative; isolation:isolate; }

/* hero: подсветка на ::after */
.hero-section::after{
  content:"" !important;
  position:absolute; inset:-18px; border-radius:28px;
  pointer-events:none; z-index:0;
  box-shadow: 0 0 90px rgba(var(--accent-rgb),.35), 0 0 260px rgba(var(--accent-rgb),.22) inset;
  background:
    radial-gradient(55% 40% at 0% 0%, rgba(var(--accent-rgb),.22), transparent 60%),
    radial-gradient(55% 40% at 100% 0%, rgba(var(--accent-rgb),.18), transparent 60%),
    radial-gradient(60% 45% at 100% 100%, rgba(var(--accent-rgb),.18), transparent 65%),
    radial-gradient(60% 45% at 0% 100%, rgba(var(--accent-rgb),.18), transparent 65%);
  mix-blend-mode: screen;
}
@media (max-width:640px){
  .hero-section::after{ inset:-10px; border-radius:18px; box-shadow: 0 0 50px rgba(var(--accent-rgb),.30), 0 0 160px rgba(var(--accent-rgb),.18) inset; }
}

/* features/target/cta: фиолетовая вуаль */
.features::after, .target-groups::after, .cta-contact::after{
  content:"" !important;
  position:absolute; inset:-20px; border-radius:24px;
  pointer-events:none; z-index:0;
  background:
    radial-gradient(70% 40% at 15% 0%, rgba(var(--accent-rgb),.18), transparent 60%),
    radial-gradient(60% 35% at 85% 5%, rgba(255,255,255,.08), transparent 70%);
  mix-blend-mode: screen;
}
@media (max-width:640px){
  .hero-section::after, .features::after, .target-groups::after, .cta-contact::after{
    inset:-12px; border-radius:16px;
  }
}

/* =====================================================
   ONE BACKGROUND FOR THREE SECTIONS (features+target+cta)
   ===================================================== */
:root{ --three-bg: url('009.jpg'); }

.features::before,.features::after,
.target-groups::before,.target-groups::after,
.cta-contact::before,.cta-contact::after{ /* перекрытые ранее */ }

:is(.features,.target-groups,.cta-contact){
  background: linear-gradient(rgba(0,0,0,.50), rgba(0,0,0,.50)), var(--three-bg) center 20%/cover fixed no-repeat !important;
}
@media (max-width: 768px){
  :is(.features,.target-groups,.cta-contact){
    background-attachment: scroll !important;
    background-position: center 25% !important;
  }
}

.features, .target-groups, .cta-contact{
  background-image: linear-gradient(rgba(0,0,0,.50), rgba(0,0,0,.50)), var(--three-bg);
  background-position: center 20%;
  background-size: cover; background-repeat: no-repeat;
  background-attachment: fixed !important;
}
@media (max-width: 768px){
  .features, .target-groups, .cta-contact{
    background-attachment: scroll !important;
    background-position: center 25% !important;
  }
}

/* ==============================
   SECTION TITLES & CARD CLAMP
   ============================== */
.section-title{ font-size: clamp(26px,2.4vw,36px); margin:0 0 28px; text-align:center; }
.features h2,.target-groups h2,.cta-contact h2{ font-size: clamp(26px,2.4vw,36px); margin:0 0 28px; text-align:center; }

.card h3,.target-card h3{
  min-height: 2.6em;
  line-height:1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.card:hover,.target-card:hover{
  transform: translateY(-6px);
  border-color: rgba(var(--accent-rgb),.55);
  box-shadow: 0 8px 30px rgba(0,0,0,.45), 0 0 28px rgba(var(--accent-rgb),.45);
}

/* ==============================
   ABOUT & CONTACTS — SAME BACKGROUND
   ============================== */
:root{ --page-bg: var(--three-bg); }
body.page-about, body.page-contacts{
  background-image: linear-gradient(rgba(0,0,0,.50), rgba(0,0,0,.50)), var(--page-bg);
  background-position: center 20%; background-size: cover;
  background-repeat:no-repeat; background-attachment: fixed;
}
.contacts-container{
  background-image: linear-gradient(rgba(0,0,0,.50), rgba(0,0,0,.50)), var(--page-bg);
  background-position: center 20%; background-size: cover; background-repeat:no-repeat; background-attachment: fixed;
}
@media (max-width:768px){
  body.page-about, body.page-contacts, .contacts-container{ background-attachment: scroll; }
}

/* ==============================
   REDUCED MOTION
   ============================== */
@media (prefers-reduced-motion: reduce){
  *{ animation: none !important; transition: none !important; }
}

/* ==============================
   CTA — OWN BACKGROUND
   ============================== */
:root{ --cta-bg: url('f2.jpg'); }
.cta-contact{
  background: linear-gradient(rgba(0,0,0,.60), rgba(0,0,0,.60)), var(--cta-bg) center/cover no-repeat !important;
  background-attachment: fixed !important;
}
@media (max-width:768px){
  .cta-contact{ background-attachment: scroll !important; background-position: center 30% !important; }
}

/* =============================================
   POLISH TWEAKS — FEATURES / CARDS / TITLES
   ============================================= */
.card, .target-card{
  border: 1px solid rgba(167,139,250,.22) !important;
  box-shadow:
    0 1px 0 rgba(255,255,255,.04),
    0 10px 30px rgba(0,0,0,.45),
    0 0 18px rgba(var(--accent-rgb),.30) !important;
}
.card:hover, .target-card:hover{
  border-color: rgba(var(--accent-rgb),.55) !important;
  box-shadow: 0 8px 30px rgba(0,0,0,.45), 0 0 28px rgba(var(--accent-rgb),.45) !important;
}
.features h2{
  margin-bottom: 32px !important;
  letter-spacing:-0.01em;
  text-shadow: 0 2px 14px rgba(0,0,0,.6), 0 0 10px rgba(var(--accent-rgb),.35) !important;
}
.features{ position:relative; isolation:isolate; }
.features::after{
  content:"" !important;
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background: radial-gradient(120% 80% at 50% 110%, rgba(0,0,0,.25), transparent 60%);
}
@media (max-width:640px){
  .features::after{ background: radial-gradient(120% 90% at 50% 110%, rgba(0,0,0,.34), transparent 60%) !important; }
}

/* =============================
   FOOTER (новая сетка/стили)
   ============================= */
:root{
  --footer-alpha: .16;
  --footer-blur: 8px;
  --accent-rgb: 167,139,250;
}
.site-footer{
  position: relative;
  background: rgba(16,16,16,var(--footer-alpha));
  border-top: 1px solid rgba(var(--accent-rgb),.22);
  -webkit-backdrop-filter: blur(var(--footer-blur)) saturate(140%);
          backdrop-filter: blur(var(--footer-blur)) saturate(140%);
  color: #e6e6e6;
}
.site-footer::before{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(70% 40% at 18% 0%, rgba(var(--accent-rgb),.14), transparent 60%),
    radial-gradient(80% 60% at 100% 0%, rgba(255,255,255,.06), transparent 70%);
  mix-blend-mode: screen; opacity:.18;
}
.footer-grid{
  position: relative; z-index:1;
  display: grid; gap: 28px;
  grid-template-columns: 1.4fr 1fr 1.2fr .9fr;
  padding: 28px 0;
}
@media (max-width: 960px){
  .footer-grid{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px){
  .footer-grid{ grid-template-columns: 1fr; }
}
.footer-logo img{ display:block; filter: drop-shadow(0 0 10px rgba(var(--accent-rgb),.22)); }
.footer-tagline{ margin-top:.4rem; color:#cfcfcf; font-size:.95rem; }
.footer-title{
  font-size:.9rem; text-transform:uppercase; letter-spacing:.06em;
  color:#bdbdbd; margin: 0 0 .6rem;
}
.footer-nav ul, .footer-contacts ul, .footer-legal{ list-style:none; margin:0; padding:0; }
.footer-nav a, .footer-contacts a, .footer-legal a{ color:#eaeaea; text-decoration:none; }
.footer-nav a:hover, .footer-contacts a:hover, .footer-legal a:hover{
  color:#fff; text-shadow:0 0 8px rgba(var(--accent-rgb),.35);
}
.footer-social{ display:flex; gap:12px; margin-top:.6rem; }
.footer-social .social{
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius:10px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  color:#fff; transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
}
.footer-social .social:hover{
  background: rgba(255,255,255,.10);
  box-shadow: 0 0 18px rgba(var(--accent-rgb),.35);
  transform: translateY(-2px);
}
.footer-btn{ display:inline-block; margin-top:.6rem; }
.footer-bottom{
  position: relative;
  border-top: 1px solid rgba(255,255,255,.06);
  background: rgba(16,16,16,var(--footer-alpha));
}
.footer-bottom__inner{
  display:flex; align-items:center; gap:12px;
  justify-content:space-between; flex-wrap:wrap;
  padding: 12px 0;
  color:#bdbdbd; font-size:.9rem;
}
.footer-legal{ display:flex; gap:16px; }
.footer-legal li{ white-space:nowrap; }

/* =============================
   HERO BACKGROUND VIDEO
   ============================= */
.hero-section{ position: relative; overflow: hidden; }
.hero-bg-video{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: -1;
  filter: brightness(.72) contrast(1.05) saturate(1.05);
  will-change: transform;
}
.hero-sound-toggle{
  position: absolute; right: 14px; bottom: 14px; z-index: 3;
  padding: .45rem .6rem; border-radius: 10px;
  background: rgba(16,16,16,.45);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff; cursor: pointer;
  -webkit-backdrop-filter: blur(6px) saturate(140%);
          backdrop-filter: blur(6px) saturate(140%);
  transition: transform .12s ease, background .2s ease, box-shadow .2s ease;
}
.hero-sound-toggle:hover{
  transform: translateY(-1px);
  box-shadow: 0 0 16px rgba(167,139,250,.32);
}
@media (prefers-reduced-motion: reduce){
  .hero-bg-video{ display: none; }
}
@media (max-width: 600px){
  .hero-bg-video{ filter: brightness(.78); }
}
/* дата-сейвер */
@media (prefers-reduced-data: reduce){
  .hero-bg-video{ display: none; }
}

/* =============================
   HERO VIDEO WINDOW — FINAL
   ============================= */

/* Контейнер окна в правом верхнем углу на десктопе */
.hero-video{
  position:absolute;
  top:24px;
  right:24px;
  z-index:6;
  width: clamp(300px, 32vw, 520px); /* не гигантское на ПК, не мелкое на FHD */
  max-height: calc(100vh - 48px);   /* не «уползает» вниз на ноутбуках */
}

/* Коробка видео: аспект задаёт JS по метаданным файла */
.hero-video .video-embed{
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;  /* fallback до loadedmetadata */
  overflow: hidden;

  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(16,16,16,.40);
  -webkit-backdrop-filter: blur(2px) saturate(140%);
          backdrop-filter: blur(2px) saturate(140%);
  box-shadow: 0 10px 30px rgba(0,0,0,.5), 0 0 22px rgba(167,139,250,.35);
}

/* Сам плеер: кадр целиком (без обрезки/растяжения) */
.hero-video .video-embed > video{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit: contain;  /* ← показываем всё, без обрезки */
  background:#000;      /* поля */
  display:block;
  z-index:1;            /* ниже кнопок */
}

/* Кнопки поверх видео */
.hero-pp{ z-index:6; pointer-events:auto; }
.video-sound-toggle{ z-index:7; }

/* Планшеты/малые ноуты — перенос в поток и центрирование */
@media (max-width: 1024px){
  .hero-video{
    position:relative;
    top:auto; right:auto;
    margin:16px auto 0;
    width: min(92vw, 720px);
    max-height: none;
  }
}
@media (max-width: 640px){
  .hero-video{ width: 94vw; margin-top:14px; }
}

/* Фолбек, если aspect-ratio не поддерживается */
@supports not (aspect-ratio: 1 / 1){
  .hero-video .video-embed::before{
    content:""; display:block; padding-top:56.25%; /* 16:9 */
  }
  .hero-video .video-embed > video{ position:absolute; inset:0; }
}

/* Гарантируем кликабельность слоями */
.hero-video, .hero-video *{ pointer-events: auto; }

/* =============================
   МЕЛКИЕ ДОПЫ
   ============================= */

/* Улучшение читаемости на узких экранах для карточек */
@media (max-width:600px){
  :root{ --card-alpha:.26; --card-alpha-hover:.34; }
}
/* === FIX: окно hero-видео без обрезки/растяжения === */
.hero-video .video-embed {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: #000 !important;        /* поля по бокам/сверху-снизу */
  overflow: hidden !important;
  border-radius: 12px !important;
}

/* сам плеер */
.hero-video .video-embed > video,
#heroVidWindow {
  width: 100% !important;
  height: auto !important;            /* соблюдаем пропорции источника */
  max-height: 72vh !important;        /* не «уползает» вниз на ноутбуках */
  object-fit: contain !important;     /* Показать ВСЁ видео без обрезки */
  background: #000 !important;        /* на случай letterbox */
  display: block !important;
}

/* на очень узких экранах — вписать по высоте, чтобы поместилось */
@media (max-width: 640px) {
  .hero-video .video-embed > video,
  #heroVidWindow {
    width: 100% !important;
    height: auto !important;
    max-height: 60vh !important;
    object-fit: contain !important;
  }
}
/* Акуратне вікно відео */
.hero-video {
  width: 30vw !important;       /* трохи менше на ПК */
  max-width: 500px !important;  /* обмеження */
}

.hero-video .video-embed {
  aspect-ratio: 16/9 !important;
  background: #000 !important;
  border-radius: 10px !important;
  overflow: hidden !important;
}

.hero-video .video-embed > video,
#heroVidWindow {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;  /* не ріже відео */
}
@media (max-width:1366px) {
  .hero-section {
    display: block !important;
  }
  .hero-video {
    margin: 20px auto 0 auto !important;
    width: 70% !important;
    max-width: 420px !important;
  }
}
/* Ноутбуки 13–14" (1280–1366px) */
@media (max-width:1366px) and (min-width:1280px) {
  .hero-video {
    width: 30vw !important;      /* менше вікно */
    max-width: 360px !important; /* обмеження ширини */
    margin: 16px auto 0 auto !important; /* центр + відступ */
  }
}
/* Ноутбуки 13–14" (1280–1366px) */
@media (max-width:1366px) and (min-width:1280px) {
  .hero-video {
    width: 28vw !important;       /* ще менше вікно */
    max-width: 320px !important;  /* максимум 320px */
    margin: 20px auto !important; /* по центру */
    float: none !important;
    display: block !important;
  }
}
/* Ноутбуки 13–14" (1280–1366px) */
@media (max-width:1366px) and (min-width:1280px) {
  .hero-video {
    transform: scale(0.65) translateX(-15%); /* зменшили в 2 рази + посунули вліво */
    transform-origin: top center;           /* щоб масштаб був від центру */
  }
}

