html, body {
  height: 100%;
}

body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* Основний контент */
main {
  flex: 1 0 auto;
}

/* Футер */
footer {
  flex-shrink: 0;
}


/* великий “ореол” + загальний градієнт */
body::before{
  content:"";
  position:fixed;
  inset:-20%;
  z-index:-2;
  pointer-events:none;
  opacity:0.95;
  filter:blur(18px);
  background:
    radial-gradient(800px 800px at 12% 12%,
      rgba(121,24,238,.35),
      transparent 65%),
    radial-gradient(900px 900px at 88% 18%,
      rgba(184,102,255,.28),
      transparent 70%),
    radial-gradient(900px 900px at 10% 90%,
      rgba(34,211,238,.22),
      transparent 70%),
    radial-gradient(1100px 1100px at 90% 100%,
      rgba(12,10,40,.9),
      transparent 75%),
 radial-gradient(2200px 1400px at 50% 0%,
  rgba(5,5,12,1),
  #020205 70%);

}

/* Контейнер для пульсів */
#bgPulse {
  position: fixed;
  inset: 0;
  overflow: hidden;
  z-index: -1;
}

/* Окреме коло */
.pulse-circle {
  position: absolute;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: rgba(121, 24, 238, 0.35); /* фіолетовий бренд */
  opacity: 0;
  transform: scale(0.3);
  filter: blur(40px);
  pointer-events: none;
  animation: pulse 3.2s ease-out forwards;
}

@keyframes pulse {
  0% {
    opacity: 0;
    transform: scale(0.4);
  }
  20% {
    opacity: 0.8;
  }
  100% {
    opacity: 0;
    transform: scale(2.2);
  }
}

/* дрібніші напівпрозорі “плями” поверх основи */
body::after{
  content:"";
  position:fixed;
  inset:-10%;
  z-index:-1;
  pointer-events:none;
  opacity:0.5;
  filter:blur(10px);
  background-image:
    radial-gradient(180px 180px at 15% 40%,
      rgba(121,24,238,.28),
      transparent 60%),
    radial-gradient(220px 220px at 35% 80%,
      rgba(184,102,255,.22),
      transparent 65%),
    radial-gradient(200px 200px at 70% 25%,
      rgba(34,211,238,.18),
      transparent 60%),
    radial-gradient(240px 240px at 85% 65%,
      rgba(121,24,238,.24),
      transparent 65%);
  animation:dv-blobs 48s ease-in-out infinite alternate;
}

@keyframes dv-blobs{
  0%{
    transform:translate3d(0,0,0) scale(1);
  }
  50%{
    transform:translate3d(-20px,10px,0) scale(1.05);
  }
  100%{
    transform:translate3d(15px,-15px,0) scale(1.02);
  }
}


:root{
  --brand:#7918EE;
  --brand2:#B866FF;
  --accent:#22d3ee;
  
 
  --ink:#f9f5ff;
  --muted:#c7c0e5;
  --line:rgba(255,255,255,.14);
  --glass:rgba(10,9,30,.9);
  --radius-lg:22px;
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);scroll-behavior:smooth;}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 20px}
footer{
    padding:38px 0 52px;
    text-align:center;
    color:var(--muted);
    font-size:12px; 
    flex-shrink:0;
}

/* ========================= */
/*      NEW NAVIGATION       */
/* ========================= */

.nav{
 position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:100;
  backdrop-filter:blur(18px);
  background:rgba(7,7,20,.9);
  border-bottom:1px solid rgba(255,255,255,.08);
}
/* когда включен WordPress admin-bar на десктопе */
body.admin-bar .nav{
  top:32px; /* высота админ-барa на десктопе */
}

/* на мобильных у admin-bar другая высота (46px) */
@media (max-width:782px){
  body.admin-bar .nav{
    top:46px;
  }
}
.nav-inner{
  max-width:1200px;
  margin:0 auto;
  height:64px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 24px;
  gap:20px;
}

/* ЛОГО ЗЛІВА */
.nav-left{
  display:flex;
  align-items:center;
  gap:10px;
  flex:0 0 auto;
}

.nav-logo{
  display:flex;
  align-items:center;
  justify-content:center;
}

.nav-logo img{
  height:30px;
  width:auto;
  display:block;
  border-radius:0;
  box-shadow:none !important;
}

/* МЕНЮ ПО ЦЕНТРУ */
.nav-menu{
  flex:1 1 auto;
}

/* WP виводить <ul> всередині .nav-menu */
.nav-menu > ul{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:26px;
  margin:0;
  padding:0;
  list-style:none;
}

.nav-menu li{
  list-style:none;
  position:relative;
}

.nav-menu a{
  color:var(--muted);
  font-size:15px;
  padding:6px 0;
  position:relative;
  display:inline-block;
}

.nav-menu a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-3px;
  width:0;
  height:2px;
  background:linear-gradient(90deg,var(--accent),var(--brand2));
  border-radius:999px;
  transition:width .18s ease;
}

.nav-menu a:hover::after{
  width:100%;
}

/* ДРОПДАУН ДЛЯ ДОЧІРНІХ (Portfolio) */
.nav-menu .menu-item-has-children{
  position:relative;
}

.nav-menu .sub-menu{
  position:absolute;
  top:100%;
  left:0;
  min-width:220px;
  margin-top:4px;              /* менший відступ, без «дірки» */
  padding:8px 0;
  border-radius:16px;
  background:rgba(7,7,20,.98);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 14px 32px rgba(0,0,0,.7);
  opacity:0;
  transform:translateY(4px);
  pointer-events:none;
  transition:opacity .18s ease,transform .18s ease;
  z-index:90;
}

.nav-menu .sub-menu li a{
  display:block;
  padding:7px 14px;
  font-size:14px;
}

/* показ сабменю на десктопі */
.nav-menu .menu-item-has-children:hover > .sub-menu,
.nav-menu .menu-item-has-children:focus-within > .sub-menu,
.nav-menu .menu-item-has-children > .sub-menu:hover{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}


/* ПРАВА ЧАСТИНА: МОВИ + CTA */
.nav-right{
  display:flex;
  align-items:center;
  gap:16px;
  flex:0 0 auto;
}

/* CTA */
.nav-cta{
  display:flex;
  align-items:center;
  gap:10px;
}

/* Кнопки */
.btn{
  border-radius:14px;
  padding:10px 16px;
  border:1px solid transparent;
  font-weight:600;
  font-size:13px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  cursor:pointer;
  transition:background .18s ease,transform .18s ease,
             box-shadow .18s ease,border-color .18s ease,color .18s ease;
  background:transparent;
  color:var(--ink);
}
.btn-primary{
  background: linear-gradient(359deg, var(--brand), var(--brand2));
  color:#0a0615;
  border-color:rgba(255,255,255,.12);
  box-shadow:0 10px 28px rgba(121,24,238,.6);
}
.btn-primary:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 36px rgba(121,24,238,.7);
}
.btn-ghost{
  border-color:rgba(255,255,255,.16);
  background:rgba(15,14,40,.4);
  color:var(--muted);
}
.btn-ghost:hover{
  background:rgba(255,255,255,.06);
  color:var(--ink);
}

/* ПЕРЕМИКАЧ МОВ — ПРАПОРЦІ */
.lang-switcher{
  display:flex;
  align-items:center;
  gap:8px;
}
.lang-switcher ul{
  display:flex;
  gap:8px;
  margin:0;
  padding:0;
}
.lang-switcher li{
  list-style:none;
}
.lang-switcher a{
  display:flex;
  padding:0;
  border:none;
  background:none;
}
.lang-switcher img{
  width:22px;
  height:16px;
  border-radius:3px;
  box-shadow:0 0 0 1px rgba(255,255,255,.2);
}
.lang-switcher .current-lang img{
  box-shadow:0 0 0 1px var(--brand),0 0 12px var(--brand2);
}

/* Десктоп/мобільна версія мов */
.lang-switcher--mobile{display:none;}
.lang-switcher--desktop{display:flex;}

/* КНОПКА МЕНЮ (бургер) */
.nav-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:8px 14px;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.16em;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  color:var(--muted);
  background:rgba(255,255,255,.04);
  cursor:pointer;
}

.nav-toggle-label{
  line-height:1;
}

.nav-toggle-bars{
  display:inline-flex;
  flex-direction:column;
  gap:3px;
}

.nav-toggle-bars span{
  width:16px;
  height:2px;
  border-radius:999px;
  background:var(--muted);
  transition:.18s ease;
}

/* анімація в хрестик */
.nav-toggle.is-open .nav-toggle-bars span:nth-child(1){
  transform:translateY(5px) rotate(45deg);
}
.nav-toggle.is-open .nav-toggle-bars span:nth-child(2){
  opacity:0;
}
.nav-toggle.is-open .nav-toggle-bars span:nth-child(3){
  transform:translateY(-5px) rotate(-45deg);
}

/* коли моб-меню відкрите — фіксим скрол */
body.nav-open{
  overflow:hidden;
}

/* ========================= */
/*        MOBILE MENU        */
/* ========================= */

@media (max-width:860px){
  .lang-switcher img{
    width:34px;
    height:24px;
    border-radius:4px;
  }
}

@media (max-width:860px){

  .nav-inner{
    height:60px;
    padding:0 16px;
  }

  /* меню стає дропдауном */
  .nav-menu{
    position:absolute;
    top:60px;
    left:16px;
    right:16px;
    display:none;
    padding:18px 18px 14px;
    background:rgba(8,8,20,.98);
    border-radius:18px;
    border:1px solid rgba(255,255,255,.12);
  }

  .nav-menu.nav-menu--open{
    display:block;
  }

  .nav-menu > ul{
    flex-direction:column;
    align-items:flex-start;
    gap:12px;
  }

  /* ==== ГОЛОВНЕ! Portfolio + підкатегорії ==== */
  .nav-menu .sub-menu{
    position:static;
    margin:6px 0 0;
    padding:0 0 0 18px;   /* трохи відступу для кращого вигляду */
    border:0;
    background:transparent;
    box-shadow:none;
    display:block !important;  /* завжди показуємо */
    opacity:1;
    transform:none;
    pointer-events:auto;
  }

  .nav-menu .sub-menu li a{
    padding:4px 0;
    font-size:14px;
    opacity:0.9;
  }

  /* клас is-open більше не потрібен, але не заважає */
  .nav-menu .menu-item-has-children.is-open > .sub-menu{
    display:block !important;
  }

  /* ховаємо CTA та десктопні мови зверху */
  .nav-right .nav-cta{
    display:none;
  }
  .lang-switcher--desktop{
    display:none;
  }

  /* показуємо мови всередині меню */
  .lang-switcher--mobile{
    display:flex;
    margin-top:16px;
    justify-content:center;
  }

  /* показуємо бургер */
  .nav-toggle{
    display:flex;
  }
}



/* HERO */
header.hero{
  position:relative;overflow:hidden;
  padding:120px 0 90px;margin-top:56px;
 
}

@keyframes spin{to{transform:rotate(1turn)}}
.hero-inner{max-width:960px;margin:0 auto;text-align:center;}
.eyebrow{
  text-transform:uppercase;font-size:11px;letter-spacing:.18em;color:var(--muted);
}
.badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 13px;border-radius:999px;
  background:linear-gradient(135deg,rgba(255,255,255,.14),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.2);
  font-size:11px;color:#efe7ff;
  backdrop-filter:blur(10px);
  margin-top:6px;
}
.badge span.dot{
  width:7px;height:7px;border-radius:999px;
  background:radial-gradient(circle at 30% 20%,#fff,transparent 50%),var(--accent);
  box-shadow:0 0 0 4px rgba(34,211,238,.3);
}
h1{
  font-size:clamp(34px,7vw,68px);
  line-height:1.04;
  margin:18px auto 10px;
  max-width:900px;
  font-weight:800;
  letter-spacing:-.02em;
  background:linear-gradient(90deg,#fff,#E9DAFF 30%,#B866FF 65%,#fff);
  -webkit-background-clip:text;
  color:transparent;
  animation:shine 6s ease-in-out infinite;
}
@keyframes shine{0%{background-position:0%}50%{background-position:100%}100%{background-position:0%}}
.sub{
  max-width:780px;margin:0 auto 26px;
  color:var(--muted);font-size:clamp(15px,2vw,18px);
}
.cta-row{
  display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:6px;
}
.hero-metrics{
  display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:10px;
}
.pill{
  padding:7px 12px;border-radius:999px;
  background:rgba(10,9,35,.9);
  border:1px solid rgba(255,255,255,.18);
  font-size:12px;color:#efe8ff;
}
.logos-row{
  display:flex;flex-wrap:wrap;justify-content:center;gap:22px;margin-top:24px;
}
.logos-row img{
  height:46px;opacity:.96;
  filter:drop-shadow(0 7px 18px rgba(7,2,28,.7));
  transition:transform .16s ease,opacity .16s ease;
}
.logos-row img:hover{transform:translateY(-2px);opacity:1;}

/* SECTIONS */
section{padding:74px 0}
h2{
  font-size:clamp(24px,4.2vw,36px);
  text-align:center;
  margin:0 0 10px;
  font-weight:800;
}
.note{
  max-width:760px;margin:0 auto 34px;
  color:var(--muted);text-align:center;
  font-size:14px;
}

/* SOLUTIONS */
.services-wrap{
  max-width:1120px;margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0,1.3fr) minmax(0,2fr);
  gap:22px;
  align-items:stretch;
}
@media(max-width:960px){
  .services-wrap{grid-template-columns:1fr}
}
.services-lead{
  border-radius:var(--radius-lg);
  padding:22px 22px 26px;
  background:radial-gradient(circle at 0 0,rgba(34,211,238,.3),transparent 55%),radial-gradient(circle at 100% 100%,rgba(184,102,255,.32),transparent 55%),var(--glass);
  border:1px solid rgba(255,255,255,.24);
  box-shadow:0 18px 45px rgba(5,0,30,.75);
}
.services-lead h3{margin:0 0 8px;font-size:18px;}
.services-lead p{margin:0 0 14px;color:#f1e9ff;font-size:14px;}
.services-tags{
  display:flex;flex-wrap:wrap;gap:8px;font-size:12px;margin-top:6px;
}
.services-tags span{
  padding:6px 10px;border-radius:999px;
  background:rgba(7,7,26,.9);border:1px solid rgba(255,255,255,.22);
}
.grid-services{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
@media(max-width:720px){
  .grid-services{grid-template-columns:1fr}
}
.s-card{
  position:relative;overflow:hidden;isolation:isolate;
  border-radius:20px;
  background:radial-gradient(circle at 0 0,rgba(34,211,238,.22),transparent 55%),radial-gradient(circle at 100% 100%,rgba(121,24,238,.32),transparent 60%),#111026;
  border:1px solid rgba(255,255,255,.16);
  padding:16px 16px 18px;
  display:grid;
  grid-template-columns:auto 1fr;
  gap:12px;
}
.s-icon{
  width:40px;height:40px;border-radius:16px;
  background:radial-gradient(circle at 30% 10%,#fff,transparent 45%),radial-gradient(circle at 80% 90%,var(--brand2),transparent 65%),radial-gradient(circle at 10% 90%,var(--accent),transparent 50%);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 24px rgba(0,0,0,.6);
  flex-shrink:0;
}
.s-icon span{font-size:20px;color:#070714;}
.s-body h3{margin:0 0 6px;font-size:15px;}
.s-body p{margin:0 0 8px;font-size:13px;color:var(--muted);}
.s-meta{
  display:flex;align-items:center;justify-content:space-between;
  font-size:11px;color:#EAFBF3;opacity:.92;
}
.s-meta span.label{opacity:.7}
.s-card::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(circle at var(--x,60%) var(--y,30%),rgba(255,255,255,.14),transparent 55%);
  mix-blend-mode:screen;opacity:0;pointer-events:none;transition:opacity .18s ease;
}
.s-card:hover::after{opacity:.9;}

/* IMPACT DASHBOARD */
#impact{padding-top:60px;padding-bottom:80px;}
.impact-wrap{
  max-width:1120px;margin:0 auto;
  display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1.6fr);
  gap:22px;
  align-items:stretch;
}
@media(max-width:960px){
  .impact-wrap{grid-template-columns:1fr;}
}
.impact-main{
  border-radius:var(--radius-lg);
  padding:22px 22px 24px;
  background:radial-gradient(circle at 0 0,rgba(121,24,238,.5),transparent 60%),radial-gradient(circle at 100% 100%,rgba(34,211,238,.45),transparent 60%),#090718;
  border:1px solid rgba(255,255,255,.26);
  box-shadow:0 18px 52px rgba(3,0,28,.9);
  position:relative;
  overflow:hidden;
}
.impact-main::before{
  content:"Impact";position:absolute;right:-18px;bottom:-10px;
  font-size:60px;font-weight:800;letter-spacing:.2em;
  color:rgba(5,0,24,.7);pointer-events:none;
}
.impact-main h3{margin:0 0 10px;font-size:18px;}
.impact-main p{margin:0 0 12px;color:#f1e9ff;font-size:14px;}
.impact-bullets{margin:10px 0 0;padding-left:18px;font-size:13px;color:#e7defe;}
.impact-meta{
  margin-top:14px;font-size:12px;color:#ddd0ff;opacity:.9;
}

.impact-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;
}
@media(max-width:640px){
  .impact-grid{grid-template-columns:1fr;}
}
.impact-card{
  border-radius:18px;
  background:linear-gradient(145deg,rgba(17,16,40,.98),rgba(10,8,28,.98));
  border:1px solid rgba(255,255,255,.18);
  padding:14px 14px 16px;
  display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:flex-start;
}
.impact-icon{
  width:32px;height:32px;border-radius:12px;
  background:radial-gradient(circle at 30% 10%,#fff,transparent 40%),radial-gradient(circle at 100% 100%,var(--brand2),transparent 60%);
  display:flex;align-items:center;justify-content:center;font-size:18px;color:#070714;
}
.impact-body b{
  display:block;font-size:20px;margin-bottom:2px;
  background:linear-gradient(120deg,#fff,#E6FEFF 40%,#C596FF);
  -webkit-background-clip:text;color:transparent;
}
.impact-body span{display:block;font-size:12px;color:#ded5ff;}
.impact-body small{display:block;margin-top:4px;font-size:11px;color:#9f97d1;}

/* TOOL STACK */
.tools-wrap{
  max-width:1120px;margin:0 auto;
  display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1.6fr);
  gap:22px;align-items:stretch;
}
@media(max-width:960px){
  .tools-wrap{grid-template-columns:1fr;}
}
.tools-summary{
  border-radius:var(--radius-lg);
  padding:22px 22px 24px;
  background:linear-gradient(150deg,rgba(18,21,55,.98),rgba(7,7,22,.98));
  border:1px solid rgba(255,255,255,.2);
}
.tools-summary h3{margin:0 0 8px;font-size:18px;}
.tools-summary p{margin:0 0 12px;font-size:14px;color:var(--muted);}
.tools-badges{
  display:flex;flex-wrap:wrap;gap:8px;font-size:12px;margin-top:6px;
}
.tools-badges span{
  padding:6px 10px;border-radius:999px;
  background:rgba(15,17,45,.96);
  border:1px solid rgba(255,255,255,.25);
}
.tool-columns{
  border-radius:var(--radius-lg);
  padding:18px 18px 20px;
  background:radial-gradient(circle at 0 0,rgba(34,211,238,.24),transparent 55%),radial-gradient(circle at 100% 100%,rgba(184,102,255,.3),transparent 60%),#0b0a1c;
  border:1px solid rgba(255,255,255,.2);
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;
}
@media(max-width:720px){
  .tool-columns{grid-template-columns:1fr;}
}
.tool-group{
  border-radius:18px;background:rgba(10,10,28,.96);border:1px solid rgba(255,255,255,.17);
  padding:12px 12px 14px;
}
.tool-group h3{
  margin:0 0 6px;font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:#efe8ff;
}
.tool-group small{display:block;margin-bottom:8px;font-size:11px;color:#a99cdf;}
.tool-chips{
  display:flex;flex-wrap:wrap;gap:7px;font-size:12px;
}
.tool-chips span{
  padding:4px 9px;border-radius:999px;
  background:rgba(17,17,45,.98);
  border:1px solid rgba(255,255,255,.18);
  color:#e7defe;
}

/* CASES */
.cases-wrap{
  max-width:1120px;margin:0 auto;
  display:flex;flex-direction:column;gap:16px;
}
.case{
  position:relative;
  border-radius:20px;background:#101024;border:1px solid rgba(255,255,255,.16);
  padding:16px 18px 16px;
  display:grid;grid-template-columns:minmax(0,2.2fr) minmax(0,1.4fr);gap:16px;
  overflow:hidden;
}
@media(max-width:880px){
  .case{grid-template-columns:1fr;}
}
.case::before{
  content:"";position:absolute;left:0;top:0;width:100%;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--brand2));
}
.case-main h3{margin:0 0 4px;font-size:15px;}
.case-main small{font-size:11px;color:var(--muted);}
.case-main ul{
  margin:8px 0 0;padding-left:18px;
  color:var(--muted);font-size:12px;
}
.case-meta{
  display:flex;flex-direction:column;gap:6px;font-size:12px;color:#d6d0ff;
  justify-content:center;
}
.case-tag{
  align-self:flex-start;
  padding:4px 9px;border-radius:999px;
  background:rgba(34,211,238,.18);border:1px solid rgba(34,211,238,.5);
  color:#c9f9ff;font-size:11px;
}
.case-metric{font-size:12px;color:#f2ecff;}
.case-metric span{display:block;font-size:20px;font-weight:700;}

/* ========================= */
/*         CONTACT           */
/* ========================= */

#contact{
  padding:96px 0;
  position:relative;
  z-index:2;
}

.contact-wrap{
  max-width:960px;
  margin:0 auto;
  border-radius:var(--radius-lg);
  background:
    radial-gradient(circle at 0 0,rgba(121,24,238,.55),transparent 55%),
    radial-gradient(circle at 100% 100%,rgba(34,211,238,.5),transparent 55%),
    #080719;
  border:1px solid rgba(255,255,255,.28);
  box-shadow:0 22px 60px rgba(2,0,24,.95);
  padding:26px 22px 26px;
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(0,1.4fr);
  gap:24px;
  align-items:start;
}

@media(max-width:880px){
  #contact{
    padding:72px 0;
  }
  .contact-wrap{
    grid-template-columns:1fr;
  }
}

.contact-copy h3{
  margin:0 0 10px;
  font-size:20px;
}

.contact-copy p{
  margin:0 0 10px;
  color:#f0e9ff;
  font-size:14px;
}

.contact-hints{
  margin-top:8px;
  font-size:12px;
  color:#e3dcff;
  opacity:.9;
  padding-left:18px;
}

.contact-hints li{
  margin-bottom:4px;
}

/* PHONE */
.contact-phone{
  font-size:13px;
  color:#f0e9ff;
}

.contact-phone a{
  color:#ffffff;
  font-weight:600;
  text-decoration:none;
}

.contact-phone a:hover{
  text-decoration:underline;
}

/* FORM */
.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  font-size:13px;
}

@media(max-width:540px){
  .form-grid{grid-template-columns:1fr;}
}

.inp,
.sel,
.ta{
  width:100%;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.35);
  background:rgba(6,6,20,.88);
  color:var(--ink);
  padding:9px 11px;
  font-family:inherit;
  font-size:13px;
}

.inp::placeholder,
.ta::placeholder{
  color:rgba(231,222,255,.65);
}

.ta{
  min-height:110px;
  resize:vertical;
  margin-top:10px;
}

.contact-foot{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-top:12px;
  flex-wrap:wrap;
}

.small-text{
  font-size:11px;
  color:#ede3ff;
  opacity:.9;
}

@media(max-width:600px){
  .contact-foot{
    flex-direction:column;
    align-items:flex-start;
  }
}

/* ========================= */
/*      MESSENGER ROW        */
/* ========================= */

.contact-messengers{
  margin:8px 0 12px;
  display:flex;
  align-items:center;

  gap:8px 10px;
}

.contact-messengers-label{
  font-size:12px;
  color:#e3dcff;
  opacity:.9;
  margin-right:4px;
}

/* Тут ми стилізуємо саме ці три іконки
   (базуючись на svg, які ти дав раніше) */

.messenger-btn{
  width:32px;
  height:32px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(6,6,20,.95);
  border:1px solid rgba(255,255,255,.35);
  box-shadow:0 0 18px rgba(0,0,0,.8);
  transition:
    transform .16s ease-out,
    box-shadow .16s ease-out,
    border-color .16s ease-out,
    background .16s ease-out,
    opacity .16s ease-out;
}

.messenger-btn img{
   width:32px;
  height:32px;
  display:block;
}

/* hover ефект */
.messenger-btn:hover{
  transform:translateY(-1px) scale(1.03);
  border-color:rgba(121,24,238,.9);
  box-shadow:0 0 24px rgba(121,24,238,.7);
  background:rgba(10,10,30,1);
}

/* На мобі — щоб не розвалювалося і виглядало акуратно */
@media(max-width:540px){
  .contact-messengers{
    gap:10px;
  }
}
/* Мобільна адаптація: іконки з нового рядка */
@media (max-width: 540px){

  .contact-messengers{
    flex-direction:row;
    flex-wrap:wrap;
  }

  .contact-messengers-label{
    width:100%;       /* заставляє текст іти окремим рядком */
    margin-bottom:6px;
  }

  .contact-messengers a{
    margin-top:2px;   /* трохи відступу зверху для іконок */
  }
}


footer{
    padding:38px 0 52px;
    text-align:center;
    color:var(--muted);
    font-size:12px; 
     flex-shrink:0;
    }

/* LEFT MESSENGERS */
.messenger-bar{
  position:fixed;left:16px;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;gap:10px;z-index:60;
}
.messenger-btn{
  width:46px;height:46px;border-radius:999px;
  background:rgba(9,9,28,.96);
  border:1px solid rgba(255,255,255,.22);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 24px rgba(0,0,0,.55);
  cursor:pointer;
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
}
.messenger-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 30px rgba(0,0,0,.65);
  background:#191832;
}
.messenger-btn svg{width:22px;height:22px}
@media(max-width:768px){
  .messenger-bar{display:none;}
}

/* CHAT FAB */
.chat-fab{
  position:fixed;right:20px;bottom:20px;
  width:52px;height:52px;border-radius:999px;border:0;
  background:linear-gradient(135deg,var(--brand),var(--brand2));
  box-shadow:0 12px 32px rgba(121,24,238,.65);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:65;
  transition:transform .15s ease,box-shadow .15s ease;
}
.chat-fab:hover{transform:translateY(-1px);box-shadow:0 16px 40px rgba(121,24,238,.75);}
.chat-fab svg{width:24px;height:24px;fill:#070714;}

/* PAGE / BLOG STYLES */
/* ... (далі весь твій блоговий блок я залишив без змін) */
.page-content h1,
.single-post-header h1{
  font-size:clamp(26px,4vw,34px);
  margin-bottom:12px;
}
.entry-content, .single-post-content{
  font-size:15px;
  color:var(--muted);
}
.entry-content p,
.single-post-content p{
  margin:0 0 1em;
}
.entry-content a,
.single-post-content a{
  color:var(--accent);
}

/* Blog archive */
.blog-hero h1{
  font-size:clamp(28px,4vw,40px);
  font-weight:800;
}
.blog-view-switch{
  margin-top:12px;
  display:flex;
  gap:8px;
  font-size:13px;
}
.blog-view-switch a{
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  color:var(--muted);
}
.blog-view-switch a.is-active{
  background:linear-gradient(120deg,var(--brand),var(--brand2));
  color:#070714;
}

.blog-list--grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:16px;
}
.blog-list--list{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.blog-card{
  border-radius:20px;
  background:#101024;
  border:1px solid rgba(255,255,255,.16);
}
.blog-card-inner{
  display:block;
  padding:14px 16px 16px;
}
.blog-card-title{
  font-size:17px;
  margin:4px 0 6px;
}
.blog-card-meta{
  display:flex;
  justify-content:space-between;
  font-size:11px;
  color:var(--muted);
}
.blog-card-excerpt{
  font-size:13px;
  color:var(--muted);
}
.blog-pagination{
  margin-top:24px;
  text-align:center;
}

/* Single post */
.single-meta{
  display:flex;
  gap:10px;
  font-size:12px;
  color:var(--muted);
  margin-bottom:6px;
}
.single-post-footer{
  margin-top:24px;
  font-size:12px;
  color:var(--muted);
}
.single-tags a{
  color:var(--accent);
}

/* Single post shell */
.blog-single{
  padding-top:120px;
  padding-bottom:80px;
}

.single-shell{
  max-width:800px;
  margin:0 auto 40px;
  padding:24px 24px 26px;
  border-radius:22px;
  background:radial-gradient(circle at 0 0,rgba(121,24,238,.18),transparent 55%),
             radial-gradient(circle at 100% 100%,rgba(34,211,238,.15),transparent 55%),
             #090818;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 18px 40px rgba(3,0,20,.85);
}

.single-header{
  margin-bottom:18px;
}

.single-label{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:var(--muted);
  opacity:.9;
  margin-bottom:4px;
}

.single-meta{
  display:flex;
  gap:10px;
  font-size:12px;
  color:var(--muted);
  margin-bottom:6px;
}

.single-cat{
  padding:3px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(10,10,30,.8);
}

.single-title{
  font-size:clamp(28px,4vw,36px);
  margin:4px 0 10px;
  font-weight:800;
}

.single-intro{
  font-size:14px;
  color:var(--muted);
}

.single-post-content{
  font-size:15px;
  color:var(--muted);
  line-height:1.7;
}
.single-post-content h2,
.single-post-content h3{
  color:var(--ink);
  margin-top:1.6em;
  margin-bottom:.5em;
}
.single-post-content a{
  color:var(--accent);
}

.single-footer{
  margin-top:20px;
  font-size:12px;
  color:var(--muted);
}
.single-tags{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.single-tags span:first-child{
  opacity:.8;
}
.single-tags a{
  padding:3px 8px;
  border-radius:999px;
  background:rgba(17,17,45,.96);
  border:1px solid rgba(255,255,255,.18);
}

/* COMMENTS */
.comments-area{
  max-width:800px;
  margin:0 auto 40px;
  padding:22px 24px 26px;
  border-radius:22px;
  background:#0b0a1c;
  border:1px solid rgba(255,255,255,.14);
}

.comments-title{
  font-size:18px;
  margin:0 0 16px;
}
.comments-title span{
  display:block;
  font-size:13px;
  color:var(--muted);
}

.comment-list{
  list-style:none;
  margin:0 0 20px;
  padding:0;
}
.comment-list .comment{
  margin-bottom:16px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.comment-list .comment:last-child{
  border-bottom:0;
}
.comment-body{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:10px;
}
.comment-author img{
  border-radius:999px;
}
.comment-meta{
  font-size:11px;
  color:var(--muted);
  margin-bottom:4px;
}
.comment-content{
  font-size:13px;
  color:var(--muted);
}
.comment-reply-link{
  font-size:11px;
  color:var(--accent);
}

/* comment form */
.comment-form-shell{
  margin-top:18px;
}
.comment-reply-title{
  font-size:16px;
  margin:0 0 10px;
}
.comment-form p{
  margin-bottom:10px;
  font-size:13px;
}
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form textarea{
  width:100%;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.3);
  background:rgba(6,6,20,.9);
  color:var(--ink);
  padding:8px 10px;
  font-family:inherit;
  font-size:13px;
}
.comment-form textarea{
  min-height:120px;
}
.comment-form input[type="submit"]{
  margin-top:6px;
  border:0;
  border-radius:14px;
  padding:9px 16px;
  background:linear-gradient(120deg,var(--brand),var(--brand2));
  color:#070714;
  font-weight:600;
  cursor:pointer;
}
.comment-form input[type="submit"]:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(121,24,238,.7);
}
.single-nav{
  margin-top:30px;
  display:flex;
  justify-content:space-between;
  gap:10px;
  font-size:13px;
}
/* базовый фон – десктоп как есть */
@media (max-width: 1024px) {

    /* 1. БЛОК: ОЧИЩЕННЯ ТІЛА (BODY) */
    body::before,
    body::after {
        content: none !important;
        display: none !important;
    }

    body {
        /* Тіло завжди чорне, без градієнтів */
        background-image: none !important; 
        background-color: #020205 !important; 
        background-attachment: scroll !important;
        min-height: 100vh;
    }

    /* 2. БЛОК: ГРАДІЄНТИ ДЛЯ HERO */
    header.hero {
        background-color: #020205 !important;
        background-repeat: no-repeat;
        background-attachment: scroll;
        box-shadow: none !important;

        background-image:
            /* Слот 1: Верхній лівий (Фіолетовий) */
            radial-gradient(35vw 35vw at 10% 15%, 
                rgba(121, 24, 238, 0.3), 
                transparent 70%), 
            /* Слот 2: Центр (Світліший) */
            radial-gradient(30vw 30vw at 50% 50%, 
                rgba(184, 102, 255, 0.15), 
                transparent 90%),
            /* Слот 3: Нижній правий (Блакитний) */
            radial-gradient(40vw 40vw at 80% 85%, 
                rgba(34, 211, 238, 0.2), 
                transparent 65%);
    }

    /* 3. БЛОК: ГРАДІЄНТИ ДЛЯ СЕКЦІЇ IMPACT (ЧЕРЕЗ ОДНУ) */
    #impact {
        /* Важливо: Hero є header.hero. Решта секцій - #id */
        background-color: #020205 !important;
        background-repeat: no-repeat;
        box-shadow: none !important;

        background-image:
            /* Слот 1: Нижній лівий кут Impact (Блакитний) */
            radial-gradient(30vw 30vw at 5% 90%, 
                rgba(34, 211, 238, 0.25), 
                transparent 60%), 
            /* Слот 2: Верхній правий кут Impact (Фіолетовий) */
            radial-gradient(40vw 40vw at 95% 10%, 
                rgba(121, 24, 238, 0.2), 
                transparent 75%);
    }

    /* 4. БЛОК: ГРАДІЄНТИ ДЛЯ СЕКЦІЇ CASES (ЧЕРЕЗ ОДНУ) */
    #cases {
        background-color: #020205 !important;
        background-repeat: no-repeat;
        box-shadow: none !important;

        background-image:
            /* Слот 1: Верхній лівий (Світліший) */
            radial-gradient(25vw 25vw at 15% 5%, 
                rgba(184, 102, 255, 0.3), 
                transparent 60%),
            /* Слот 2: Середина справа (Темний) */
            radial-gradient(35vw 35vw at 85% 60%, 
                rgba(20, 20, 80, 0.25), 
                transparent 70%);
    }
    
    /* 5. БЛОК: ГРАДІЄНТИ ДЛЯ СЕКЦІЇ CONTACT (ОСТАННЯ) */
#contact {
    background-color: #020205 !important;
    background-repeat: no-repeat;
    box-shadow: none !important;

    background-image:
        /* Слот 1: Піднятий до верхнього правого кута */
        radial-gradient(45vw 45vw at 95% 85%, 
            rgba(121, 24, 238, 0.35), 
            transparent 70%);
}

    /* 6. БЛОК: ЗАБЕЗПЕЧЕННЯ ПРОЗОРОСТІ ВНУТРІШНІХ КОНТЕЙНЕРІВ */
    header.hero .hero-inner,
    section .wrap,
    .wrap {
        /* Внутрішні обгортки також мають бути прозорими */
        background-color: transparent !important;
        box-shadow: none !important;
    }
}

/* ========================= */
/*         FOOTER            */
/* ========================= */

.dv-footer{
  margin-top:40px;
  background:#000000;
  color:var(--muted);
  font-size:13px;
  border-top:1px solid rgba(255,255,255,.08);
  padding:28px 0 22px;
}

/* TOP ROW */
.dv-footer-top{
  display:flex;
  flex-wrap:wrap;
  gap:32px;
  justify-content:space-between;
  align-items:flex-start;
  margin-bottom:18px;
}

.dv-footer-col{
  min-width:0;
}

.dv-footer-title{
  margin:0 0 8px;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:#e5e7eb;
}

/* CLIENTS LOGOS */
.dv-footer-clients-logos{
	margin-top: 10%;
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  align-items:center;
}

.dv-footer-client img{
  height:30px!important;
  width:auto;
  display:block;
}


/* FOOTER MENUS */
.dv-footer-menu-list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:4px;
}

.dv-footer-menu-list a{
  color:var(--muted);
  font-size:13px;
  text-decoration:none;
  opacity:.85;
}

.dv-footer-menu-list a:hover{
  opacity:1;
  color:#ffffff;
}

/* BOTTOM BAR */
.dv-footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:12px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:space-between;
  align-items:center;
  font-size:12px;
  color:var(--muted);
}

/* копірайт */
.dv-footer-copy{
  line-height:1.5;
}

/* "Powered by" — тускліше завжди */
.dv-footer-powered{
  opacity:0.35; /* майже не видно, але читається */
  font-size:11px;
}

.dv-footer-powered a{
  color:#ffffff;
  font-weight:600;
  text-decoration:none;
}

.dv-footer-powered a:hover{
  text-decoration:underline;
  opacity:0.7;
}

/* ========================= */
/*        RESPONSIVE         */
/* ========================= */

/* Планшети і вниз */
@media (max-width:1024px){
  .dv-footer-top{
    flex-direction:column;
    gap:24px;
    align-items:center;        /* всі три колонки по центру */
    text-align:center;
  }

  .dv-footer-col{
    width:100%;
    display:flex;
    flex-direction:column;
    align-items:center;        /* заголовки + меню по центру */
  }

  .dv-footer-clients-logos{
    justify-content:center;    /* лого клієнтів по центру */
  }

  .dv-footer-bottom{
    flex-direction:column;
    align-items:center;        /* копірайт + powered по центру */
    gap:6px;
    text-align:center;
  }

  .dv-footer-copy{
    text-align:center;
  }

  .dv-footer-powered{
    text-align:center;
  }
}

/* Мобілки — трохи компактніше */
@media (max-width:640px){
  .dv-footer{
    padding:22px 0 18px;
  }

  .dv-footer-top{
    gap:20px;
  }

  .dv-footer-client img{
    height:30px;
  }

  .dv-footer-menu-list a{
    font-size:12px;
  }

  .dv-footer-bottom{
    font-size:11px;
  }
}

/* ========================= */
/*        BENEFITS           */
/* ========================= */

#benefits {
  padding: 96px 0;
  position: relative;
  z-index: 1;
}

#benefits .note {
  max-width: 640px;
  margin-top: 12px;
}

.benefits-wrap {
  margin-top: 36px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

/* Картки переваг */
.benefit-card {
  position: relative;
  padding: 20px 22px;
  border-radius: 18px;
  background:
    radial-gradient(120% 160% at 0% 0%, rgba(121,24,238,0.16), transparent 55%),
    radial-gradient(120% 160% at 100% 100%, rgba(34,211,238,0.12), transparent 55%),
    rgba(8,8,20,0.94);
  border: 1px solid rgba(255,255,255,0.06);
  box-shadow: 0 18px 60px rgba(0,0,0,0.65);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  overflow: hidden;
  transition:
    transform 0.22s ease-out,
    box-shadow 0.22s ease-out,
    border-color 0.22s ease-out,
    background 0.22s ease-out;
}

/* Фіолетова смужка / маркер зліва */
.benefit-card::before {
  content: "";
  position: absolute;
  inset: 0;
  left: -40%;
  width: 55%;
  background: linear-gradient(
    135deg,
    rgba(121,24,238,0.55),
    rgba(34,211,238,0.0)
  );
  opacity: 0.18;
  pointer-events: none;
}

/* Дрібний акцент у верхньому куті */
.benefit-card::after {
  content: "";
  position: absolute;
  top: 16px;
  right: 18px;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: radial-gradient(circle, #fff 0, rgba(121,24,238,0.9) 45%, transparent 100%);
  box-shadow: 0 0 18px rgba(121,24,238,0.7);
}

/* Контент поверх псевдоелементів */
.benefit-card > * {
  position: relative;
  z-index: 1;
}

.benefit-card h3 {
  font-size: 1.02rem;
  line-height: 1.3;
  margin: 0 0 8px;
  font-weight: 600;
  letter-spacing: 0.01em;
}

.benefit-card p {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.55;
  color: rgba(236,239,244,0.86);
}

/* Hover-ефект */
.benefit-card:hover {
  transform: translateY(-3px);
  border-color: rgba(121,24,238,0.7);
  box-shadow:
    0 24px 80px rgba(0,0,0,0.75),
    0 0 0 1px rgba(121,24,238,0.24);
}

/* Адаптивність */
@media (max-width: 1024px) {
  .benefits-wrap {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  #benefits {
    padding: 72px 0;
  }

  .benefits-wrap {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .benefit-card {
    padding: 18px 16px;
  }
}
/* ========================= */
/*       WOW FOOTER          */
/* ========================= */

.dv-footer-wow{ position: relative; }

.dv-footer-wow-wrap{
  position:relative;
  border-radius:18px;
  padding:14px;
  background: rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.06);
  overflow:hidden;
}

/* aurora background */
.dv-footer-wow-aurora{
  position:absolute; inset:-40px;
  background:
    radial-gradient(60% 55% at 10% 20%, rgba(121,24,238,.28), transparent 60%),
    radial-gradient(55% 65% at 90% 30%, rgba(34,211,238,.18), transparent 62%),
    radial-gradient(55% 65% at 30% 95%, rgba(230,73,245,.12), transparent 55%);
  filter: blur(18px);
  opacity:.85;
  transform: translate3d(0,0,0);
  animation: dvAurora 10s ease-in-out infinite alternate;
  pointer-events:none;
}

@keyframes dvAurora{
  0%   { transform: translate(-10px,-6px) scale(1.02); }
  100% { transform: translate(12px,8px) scale(1.06); }
}

/* subtle noise */
.dv-footer-wow-noise{
  position:absolute; inset:0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.18'/%3E%3C/svg%3E");
  opacity:.10;
  mix-blend-mode: overlay;
  pointer-events:none;
}

/* head */
.dv-footer-wow-head{ position:relative; z-index:1; margin-bottom:12px; }

.dv-footer-wow-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,.86);
  padding:8px 10px;
  border-radius:999px;
  background: rgba(0,0,0,.35);
  border:1px solid rgba(121,24,238,.25);
}

.dv-dot{
  width:8px;height:8px;border-radius:999px;
  background: radial-gradient(circle, #fff 0, rgba(121,24,238,.95) 45%, transparent 100%);
  box-shadow: 0 0 18px rgba(121,24,238,.7);
  animation: dvPulse 1.9s ease-in-out infinite;
}
@keyframes dvPulse{
  0%,100%{ transform: scale(.85); opacity:.75; }
  50%{ transform: scale(1.15); opacity:1; }
}

.dv-footer-wow-sub{
  margin-top:8px;
  font-size:12px;
  line-height:1.45;
  color: rgba(236,239,244,.84);
  max-width: 520px;
}

/* grid */
.dv-footer-wow-grid{
  position:relative; z-index:1;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}

/* cards */
.dv-wow-card{
  position:relative;
  border-radius:18px;
  padding:14px 14px 12px;
  text-decoration:none;
  color:rgba(236,239,244,.9);
  background: rgba(8,8,20,.72);
  border:1px solid rgba(255,255,255,.08);
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  overflow:hidden;
  transform: translate3d(0,0,0);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

/* animated border shimmer */
.dv-wow-card::before{
  content:"";
  position:absolute; inset:-2px;
  border-radius:20px;
  background: conic-gradient(
    from 180deg,
    rgba(121,24,238,.0),
    rgba(121,24,238,.55),
    rgba(34,211,238,.40),
    rgba(230,73,245,.30),
    rgba(121,24,238,.0)
  );
  filter: blur(10px);
  opacity:.55;
  animation: dvSpin 3.8s linear infinite;
  pointer-events:none;
}
@keyframes dvSpin{ to { transform: rotate(360deg); } }

/* mask border so it looks like glow rim */
.dv-wow-card::after{
  content:"";
  position:absolute; inset:0;
  border-radius:18px;
  background: radial-gradient(120% 140% at 0% 0%, rgba(121,24,238,.18), transparent 55%),
              radial-gradient(120% 140% at 100% 100%, rgba(34,211,238,.10), transparent 55%);
  opacity:.8;
  pointer-events:none;
}

.dv-wow-card:hover{
  transform: translateY(-3px);
  border-color: rgba(121,24,238,.35);
  box-shadow: 0 26px 90px rgba(0,0,0,.75), 0 0 0 1px rgba(121,24,238,.20);
}

.dv-wow-card-top{
  position:relative; z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:8px;
}

.dv-wow-kicker{
  font-size:11px;
  letter-spacing:.12em;
  text-transform:upperc

.contact-captcha {
  margin: 14px 0 6px;
  padding: 14px;
  border-radius: 16px;

  background:
    radial-gradient(120% 160% at 0% 0%, rgba(121,24,238,0.22), transparent 55%),
    radial-gradient(120% 160% at 100% 100%, rgba(34,211,238,0.18), transparent 55%),
    rgba(8,8,20,0.88);

  border: 1px solid rgba(255,255,255,0.08);

  box-shadow:
    0 18px 60px rgba(0,0,0,0.65),
    0 0 0 1px rgba(121,24,238,0.25);

  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);

  display: flex;
  justify-content: flex-start;
}

/* iframe акуратніше */
.contact-captcha iframe {
  border-radius: 12px;
}

/* мобілка */
@media (max-width: 480px) {
  .contact-captcha {
    justify-content: center;
    padding: 10px;
  }
}
