:root{
  --bg:#0A0D12; --bg2:#0F141C; --txt:#EAF0F6; --txt2:#8A96A6;
  --cyan:#4DD8FF; --violet:#8B7CFF; --line:rgba(255,255,255,.08);
  --glass:rgba(255,255,255,.04);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--txt);line-height:1.65;overflow-x:hidden}
h1,h2,h3{font-family:'Space Grotesk',sans-serif}
.wrap{max-width:1240px;margin:0 auto;padding:0 40px}
a{color:inherit;text-decoration:none}
img{display:block}
.grad{background:linear-gradient(92deg,var(--cyan),var(--violet));-webkit-background-clip:text;background-clip:text;color:transparent}
.badge{position:fixed;bottom:20px;left:20px;z-index:99;background:rgba(255,255,255,.06);backdrop-filter:blur(10px);border:1px solid var(--line);color:var(--txt2);padding:8px 14px;border-radius:10px;font-size:10px;letter-spacing:.12em}

/* ===== HEADER ===== */
.lang{display:flex;align-items:center;background:var(--glass);border:1px solid var(--line);border-radius:10px;padding:3px;font-size:12.5px;font-weight:600}
.lang a{padding:6px 11px;border-radius:8px;color:var(--txt2);transition:.2s}
.lang a:hover{color:#fff}
.lang .on{background:linear-gradient(92deg,rgba(77,216,255,.18),rgba(139,124,255,.18));color:#fff}
header{position:sticky;top:0;z-index:50;background:rgba(10,13,18,.82);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.logo{margin-left:92px}
.logo img{height:44px;width:auto}
.menu{display:flex;gap:34px;font-size:14.5px;font-weight:500;color:var(--txt2)}
.menu a{position:relative;padding:6px 0;transition:.2s}
.menu a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:2px;background:linear-gradient(92deg,var(--cyan),var(--violet));transition:.25s;border-radius:2px}
.menu a:hover{color:#fff}
.menu a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:18px}
.nav-contact{display:flex;flex-direction:column;gap:7px}
.nav-phone{display:flex;align-items:center;gap:8px;font-weight:600;font-size:13.5px;line-height:1.2}
.nav-phone svg,.nav-mail svg{width:14px;height:14px;stroke:var(--cyan);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.nav-phone:hover{color:var(--cyan)}
.nav-mail{display:flex;align-items:center;gap:8px;font-weight:600;font-size:13.5px;color:var(--txt2);line-height:1.2}
.nav-mail:hover{color:var(--cyan)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(92deg,var(--cyan),var(--violet));color:#0A0D12;padding:13px 26px;border-radius:12px;font-weight:700;font-size:14px;transition:.25s;box-shadow:0 0 24px rgba(77,216,255,.22);border:none;cursor:pointer;font-family:'Inter',sans-serif}
.btn:hover{transform:translateY(-2px);box-shadow:0 0 40px rgba(77,216,255,.45)}
.btn-ghost{background:var(--glass);color:#fff;border:1px solid var(--line);box-shadow:none}
.btn-ghost:hover{border-color:var(--cyan);box-shadow:none}
/* burger */
.burger{display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:10px;background:var(--glass);cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.burger i{width:18px;height:2px;background:#fff;border-radius:2px;transition:.25s}
.mobile-menu{display:none;position:fixed;inset:0;z-index:60;background:rgba(10,13,18,.97);backdrop-filter:blur(20px);padding:32px;flex-direction:column}
.mobile-menu.open{display:flex}
.mm-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}
.mm-close{width:44px;height:44px;border:1px solid var(--line);border-radius:10px;background:var(--glass);color:#fff;font-size:20px;cursor:pointer}
.mobile-menu nav{display:flex;flex-direction:column;gap:8px}
.mobile-menu nav a{font-family:'Space Grotesk';font-size:26px;font-weight:600;padding:12px 0;border-bottom:1px solid var(--line)}
.mm-foot{margin-top:auto;display:flex;flex-direction:column;gap:14px;color:var(--txt2)}

/* ===== HERO ===== */
.hero{position:relative;min-height:calc(100vh - 76px);display:flex;align-items:center;padding:30px 0 120px}
.hero-bg{position:absolute;inset:0;z-index:-2;overflow:hidden}
.hero-bg img{position:absolute;top:0;left:-20%;width:170%;height:100%;object-fit:cover;opacity:.65;object-position:left 34%}
.hero-bg::after{content:'';position:absolute;inset:0;background:rgba(10,13,18,0)}
.orb{position:absolute;border-radius:50%;filter:blur(120px);z-index:-1;opacity:.5;pointer-events:none}
.orb1{width:480px;height:480px;background:rgba(77,216,255,.18);top:-120px;right:-80px}
.orb2{width:380px;height:380px;background:rgba(139,124,255,.16);bottom:-60px;left:-100px}
.kicker{display:inline-flex;align-items:center;gap:11px;background:var(--glass);border:1px solid var(--line);border-radius:100px;padding:7px 18px 7px 13px;font-size:13px;color:#C7D0DB;text-shadow:0 1px 3px rgba(0,0,0,.9),0 0 7px rgba(0,0,0,.6);margin-bottom:28px}
.bot{width:30px;height:30px;overflow:visible;animation:botbob 3.2s ease-in-out infinite;flex-shrink:0}
.bot .ant-dot{fill:var(--cyan);animation:antpulse 1.6s ease-in-out infinite;transform-box:fill-box;transform-origin:center}
.bot .eye{fill:var(--cyan);filter:drop-shadow(0 0 3px rgba(77,216,255,.9));animation:blink 4.2s ease-in-out infinite;transform-box:fill-box;transform-origin:center}
.bot .eye.r{animation-delay:.05s}
@keyframes botbob{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-2.5px) rotate(-4deg)}}
@keyframes antpulse{0%,100%{opacity:1;r:2.3}50%{opacity:.35;r:1.6}}
@keyframes blink{0%,40%,46%,100%{transform:scaleY(1)}43%{transform:scaleY(.12)}}
/* рот: видна только одна форма */
.bot .m{opacity:0;transition:opacity .12s}
.bot .m-idle{opacity:1}
.bot.wink .m-idle,.bot.surprise .m-idle,.bot.alert .m-idle,.bot.smile .m-idle,.bot.sing .m-idle,.bot.laugh .m-idle,.bot.love .m-idle,.bot.sleepy .m-idle,.bot.confused .m-idle{opacity:0}
.bot.smile .m-smile,.bot.laugh .m-smile,.bot.love .m-smile{opacity:1}
.bot.wink .m-smirk,.bot.confused .m-smirk{opacity:1}
.bot.surprise .m-o,.bot.sleepy .m-o{opacity:1}
.bot.sing .m-sing{opacity:1}
.bot.alert .m-flat{opacity:1}
/* смех: трясётся от хохота */
.bot.laugh{animation:laughBounce .32s ease-in-out infinite}
.bot.laugh .eye{animation:none;transform:scaleY(.5) translateY(-.4px)}
@keyframes laughBounce{0%,100%{transform:translateY(0) rotate(-2.5deg)}50%{transform:translateY(-2.5px) rotate(2.5deg)}}
/* влюблённость: глаза-сердечки */
.bot .h{opacity:0;fill:#FF6B9D;filter:drop-shadow(0 0 4px rgba(255,107,157,.9));transform-box:fill-box;transform-origin:center}
.bot.love .eye{opacity:0}
.bot.love .h{opacity:1;animation:heartBeat .75s ease-in-out infinite}
.bot.love .h2{animation-delay:.12s}
.bot.love .ant-dot{fill:#FF6B9D;filter:drop-shadow(0 0 5px rgba(255,107,157,.95))!important}
@keyframes heartBeat{0%,100%{transform:scale(1)}30%{transform:scale(1.3)}}
/* сонливость: зевает, клюёт носом, z-z-z */
.bot .zz{opacity:0;font-size:8px;fill:var(--txt2);font-family:'Space Grotesk',sans-serif;font-style:italic}
.bot .z2{font-size:6.5px}
.bot.sleepy{animation:sleepyTilt 4.8s ease-in-out}
.bot.sleepy .eye{animation:none;transform:scaleY(.22)}
.bot.sleepy .ant-dot{animation:antpulse 2.4s ease-in-out infinite;opacity:.4}
.bot.sleepy .z1{animation:noteUp 2s ease-out infinite}
.bot.sleepy .z2{animation:noteUp 2s ease-out 1s infinite}
@keyframes sleepyTilt{0%,100%{transform:rotate(0)}30%,85%{transform:rotate(9deg) translateY(1.5px)}}
/* озадаченность: смотрит вбок, знак вопроса */
.bot .q{opacity:0;font-size:10px;fill:var(--violet);font-family:'Space Grotesk',sans-serif;font-weight:700;filter:drop-shadow(0 0 4px rgba(139,124,255,.8))}
.bot.confused{animation:confTilt 3s ease}
.bot.confused .eye.l{animation:none;transform:translate(-1.2px,-1px)}
.bot.confused .eye.r{animation:none;transform:translate(1px,-.5px) scale(.75)}
.bot.confused .q{animation:qFloat 3s ease}
@keyframes confTilt{0%,100%{transform:rotate(0)}30%,75%{transform:rotate(10deg)}}
@keyframes qFloat{0%{opacity:0;transform:translateY(3px)}20%,80%{opacity:1;transform:translateY(-1px)}100%{opacity:0;transform:translateY(-6px)}}
/* подмигивание */
.bot.wink .eye.r{animation:winkA 1s ease-in-out}
@keyframes winkA{0%,100%{transform:scaleY(1)}25%,70%{transform:scaleY(.08)}}
/* удивление: подпрыгнул, глаза круглые */
.bot.surprise{animation:hop .55s ease}
.bot.surprise .eye{animation:surprEye 1.2s ease}
.bot.surprise .ant-dot{animation:antpulse .35s ease-in-out infinite}
@keyframes hop{0%{transform:translateY(0)}30%{transform:translateY(-5px) scale(1.07)}60%{transform:translateY(1.5px)}100%{transform:translateY(0)}}
@keyframes surprEye{0%{transform:scale(1)}25%,80%{transform:scale(1.45)}100%{transform:scale(1)}}
/* настороженность: прищур, глаза бегают, антенна янтарная */
.bot.alert{animation:alertTilt 1.6s ease}
.bot.alert .eye{animation:eyeDart 1.6s ease}
.bot.alert .ant-dot{fill:#FFC24D;animation:antpulse .45s ease-in-out infinite;filter:drop-shadow(0 0 5px rgba(255,194,77,.95))!important}
@keyframes alertTilt{0%,100%{transform:rotate(0)}20%{transform:rotate(-7deg)}55%{transform:rotate(5deg)}80%{transform:rotate(-2deg)}}
@keyframes eyeDart{0%,100%{transform:scaleY(.4) translateX(0)}25%{transform:scaleY(.4) translateX(-1.7px)}65%{transform:scaleY(.4) translateX(1.7px)}}
/* улыбка: тёплые глаза-полумесяцы */
.bot.smile .eye{animation:none;transform:scaleY(.55) translateY(-.4px)}
/* пение: раскачивается, ноты летят */
.bot.sing{animation:singSway .9s ease-in-out infinite}
.bot.sing .ant-dot{animation:antpulse .45s ease-in-out infinite}
@keyframes singSway{0%,100%{transform:rotate(-6deg)}50%{transform:rotate(6deg) translateY(-2px)}}
.bot .n{font-size:9px;fill:var(--cyan);opacity:0;font-family:'Space Grotesk',sans-serif}
.bot .n2{fill:var(--violet);font-size:8px}
.bot.sing .n1{animation:noteUp 1.2s ease-out infinite}
.bot.sing .n2{animation:noteUp 1.2s ease-out .55s infinite}
@keyframes noteUp{0%{opacity:0;transform:translate(0,3px)}25%{opacity:1}100%{opacity:0;transform:translate(7px,-13px) rotate(14deg)}}
h1{font-size:clamp(40px,5vw,72px);line-height:1.06;font-weight:700;letter-spacing:-.02em;max-width:900px}
/* напівпрозорий, але читабельний заголовок — фон проглядає крізь літери */
.hero h1{font-size:clamp(30px,3.8vw,54px);color:rgba(234,240,246,.85);text-shadow:0 2px 24px rgba(0,0,0,.6),0 1px 3px rgba(0,0,0,.55)}
.hero h1 .grad{opacity:.95}
@property --ring{syntax:"<angle>";inherits:false;initial-value:0deg}
.hero-sub{position:relative;margin:28px 0 36px;max-width:620px;padding:22px 28px;border-radius:18px;background:rgba(255,255,255,.022);font-family:'Comfortaa',sans-serif;font-weight:300;font-size:17.5px;line-height:1.7;letter-spacing:.012em;color:#BCC8D8}
/* бегущий по кругу импульс + тонкая постоянная рамка */
.hero-sub::before{content:"";position:absolute;inset:0;border-radius:18px;padding:1.6px;background:conic-gradient(from var(--ring),transparent 0 60%,rgba(77,216,255,.95) 76%,rgba(139,124,255,.95) 87%,transparent 96%),linear-gradient(rgba(255,255,255,.08),rgba(255,255,255,.08));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;animation:ringRun 4.8s linear infinite;pointer-events:none}
/* мягкий пульс свечения рамки */
.hero-sub::after{content:"";position:absolute;inset:0;border-radius:18px;animation:framePulse 4.8s ease-in-out infinite;pointer-events:none}
@keyframes ringRun{to{--ring:360deg}}
@keyframes framePulse{0%,100%{box-shadow:0 0 12px rgba(77,216,255,.05)}50%{box-shadow:0 0 26px rgba(139,124,255,.15)}}
@media(prefers-reduced-motion:reduce){.hero-sub::before{animation:none}.hero-sub::after{animation:none}}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-chips{display:flex;gap:14px;margin-top:44px;flex-wrap:wrap}
.chip{display:flex;align-items:center;gap:13px;background:var(--glass);border:1px solid var(--line);border-radius:16px;padding:13px 20px;backdrop-filter:blur(8px);position:relative;overflow:hidden;transition:transform .3s,border-color .3s}
.chip::after{content:'';position:absolute;inset:0;background:radial-gradient(320px 130px at 50% 0%,rgba(77,216,255,.12),transparent);opacity:0;transition:.3s;pointer-events:none}
.chip:hover{transform:translateY(-4px);border-color:rgba(77,216,255,.38)}
.chip:hover::after{opacity:1}
.chip:hover .chip-ic{border-color:rgba(77,216,255,.55);box-shadow:0 0 18px rgba(77,216,255,.3)}
.chip:hover .chip-ic svg{transform:scale(1.08)}
.chip-ic{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,rgba(77,216,255,.14),rgba(139,124,255,.14));border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.3s}
.chip-ic svg{width:20px;height:20px;stroke:var(--cyan);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:.3s}
.chip-tx b{display:block;font-family:'Space Grotesk';font-size:20px;line-height:1.12;background:linear-gradient(92deg,var(--cyan),var(--violet),var(--cyan));background-size:220% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 1px 3px rgba(0,0,0,.8));animation:chipFlow 6.5s linear infinite}
.chip-tx span{font-size:12.5px;color:#C7D0DB;text-shadow:0 1px 3px rgba(0,0,0,.9),0 0 6px rgba(0,0,0,.6)}
/* лёгкий пульс иконки */
@keyframes chipPulse{0%,100%{box-shadow:0 0 0 rgba(77,216,255,0)}50%{box-shadow:0 0 16px rgba(77,216,255,.26)}}
.chip-ic{animation:chipPulse 3.6s ease-in-out infinite}
/* бегущий перелив в значениях */
@keyframes chipFlow{0%{background-position:0 0}100%{background-position:-220% 0}}
/* редкий световой блик по карточке */
.chip::before{content:'';position:absolute;top:0;left:-70%;width:45%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.07),transparent);transform:skewX(-18deg);animation:chipSheen 8s ease-in-out infinite;pointer-events:none;z-index:1}
@keyframes chipSheen{0%{left:-70%}22%,100%{left:160%}}
/* рассинхрон между чипами */
.chip:nth-child(2) .chip-ic,.chip:nth-child(2)::before,.chip:nth-child(2) .chip-tx b{animation-delay:.7s}
.chip:nth-child(3) .chip-ic,.chip:nth-child(3)::before,.chip:nth-child(3) .chip-tx b{animation-delay:1.4s}
.chip:nth-child(4) .chip-ic,.chip:nth-child(4)::before,.chip:nth-child(4) .chip-tx b{animation-delay:2.1s}
.chip:nth-child(5) .chip-ic,.chip:nth-child(5)::before,.chip:nth-child(5) .chip-tx b{animation-delay:2.8s}
@media(prefers-reduced-motion:reduce){.chip-ic,.chip::before,.chip-tx b{animation:none}}
.scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;z-index:5}
.scroll-hint .sh-text{font-size:13px;font-weight:600;letter-spacing:.3em;text-transform:uppercase;background:linear-gradient(90deg,var(--txt2) 0%,var(--cyan) 35%,var(--violet) 55%,var(--txt2) 75%);background-size:250% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmer 3s linear infinite;white-space:nowrap}
@keyframes shimmer{to{background-position:-250% 0}}
.scroll-hint .chevs{display:flex;flex-direction:column;align-items:center;margin-top:-2px}
.scroll-hint .chevs svg{width:30px;height:15px;stroke:var(--cyan);fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;margin-top:-7px;filter:drop-shadow(0 0 7px rgba(77,216,255,.9));animation:chev 1.6s ease-in-out infinite}
.scroll-hint .chevs svg:nth-child(2){animation-delay:.22s;stroke:#6FAAFF}
.scroll-hint .chevs svg:nth-child(3){animation-delay:.44s;stroke:var(--violet);filter:drop-shadow(0 0 7px rgba(139,124,255,.9))}
@keyframes chev{0%{opacity:0;transform:translateY(-7px)}45%{opacity:1}100%{opacity:0;transform:translateY(8px)}}
.scroll-hint:hover .sh-text{animation-duration:1.2s}

/* ===== SECTIONS ===== */
section{padding:110px 0;position:relative}
.sec-kicker{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);margin-bottom:16px;font-weight:600}
h2{font-size:clamp(30px,3.6vw,50px);font-weight:700;letter-spacing:-.02em;margin-bottom:20px}
.sec-sub{color:var(--txt2);max-width:560px;font-size:17px}

/* about */
/* кикер + заголовок «Про компанію»/«Більше, ніж…» — вместе в одной рамке */
#about .wrap > .rv{display:block;width:calc(50% - 32px);box-sizing:border-box;padding:26px 38px 30px;border:1px solid var(--line);border-radius:22px;background:var(--glass);position:relative;overflow:hidden}
#about .wrap > .rv::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),transparent)}
#about .sec-kicker{display:inline-flex;align-items:center;gap:10px;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:24px;letter-spacing:-.02em;text-transform:none;color:var(--cyan);margin-bottom:14px;padding:0;border:0;background:none}
#about .sec-kicker::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--cyan);animation:aboutPulse 2.2s ease-in-out infinite}
@keyframes aboutPulse{0%,100%{box-shadow:0 0 0 0 rgba(77,216,255,.55);opacity:1}50%{box-shadow:0 0 0 7px rgba(77,216,255,0);opacity:.65}}
#about h2{font-family:'Space Grotesk',sans-serif;font-size:20.5px;margin-bottom:0}
#about .mission{font-size:16px}
/* синхронный циан-пульс ДВУХ текстовых рамок; имя анимации уникальное, чтобы НЕ задеть framePulse у hero */
#about .wrap > .rv,#about .about-card{animation:aboutFramePulse 2.6s ease-in-out infinite}
@keyframes aboutFramePulse{0%,100%{border-color:var(--line);box-shadow:0 0 0 0 rgba(77,216,255,0)}50%{border-color:rgba(77,216,255,.45);box-shadow:0 0 22px 1px rgba(77,216,255,.22)}}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-top:60px}
.about-card{background:var(--bg2);border:1px solid var(--line);border-radius:24px;padding:44px;position:relative;overflow:hidden}
.about-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),transparent)}
.about-card p{color:var(--txt2);margin-bottom:18px;font-size:15.5px}
.about-card p.lead{color:var(--txt);font-size:19px;font-weight:600;line-height:1.5}
.mission{margin-top:10px;padding-top:24px;border-top:1px solid var(--line);font-weight:600;color:var(--txt);display:flex;gap:14px;align-items:flex-start}
.mission svg{flex-shrink:0;margin-top:3px}
.mosaic{display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:1fr;gap:16px}
.mosaic img{width:100%;height:100%;object-fit:contain;background:var(--bg);border-radius:18px;border:1px solid var(--line);transition:.35s}
.mosaic img:hover{transform:scale(1.025);border-color:rgba(77,216,255,.4)}
#about .mosaic{position:relative;top:-124px;padding:18px;box-sizing:border-box;border:1px solid rgba(255,255,255,.28);border-radius:24px;background:rgba(255,255,255,.02);box-shadow:0 18px 50px rgba(0,0,0,.4)}
/* «Про нас» — финальное положение/масштаб трёх рамок (утверждено 2026-06-25). transform = статичное позиционирование (не анимация, в reduced-motion не отключать); специфичность через #about намеренно перебивает .rv.on{transform:none}; у .mosaic top:-124px остаётся отдельным правилом выше */
#about .wrap > .rv{transform:translate(-86px,15px) scale(1.16);transform-origin:center}
#about .about-card{transform:translate(-86px,0px) scale(1.15);transform-origin:center}
#about .mosaic{transform:translate(135px,12px) scale(1.34);transform-origin:center}

/* services — базовая сетка/карточки */
.srv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:60px}
.srv{background:var(--bg2);border:1px solid var(--line);border-radius:20px;padding:34px 28px;transition:.3s;position:relative;overflow:hidden}
.srv::after{content:'';position:absolute;inset:0;background:radial-gradient(420px 180px at 50% 0%,rgba(77,216,255,.09),transparent);opacity:0;transition:.3s;pointer-events:none}
#services .srv:hover{transform:translateY(-6px) scale(1.05);border-color:rgba(77,216,255,.35);z-index:2}  /* #services для приоритета над .rv.on */
.srv:hover::after{opacity:1}
.srv .ic{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,rgba(77,216,255,.12),rgba(139,124,255,.12));border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.srv .ic svg{width:26px;height:26px;stroke:var(--cyan);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.srv h3{font-size:20px;margin-bottom:12px}
.srv p{color:var(--txt2);font-size:14px}
/* номера 01–04 в кружках, статично подсвечены (без пульса) */
.srv .num{position:absolute;top:22px;right:22px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(77,216,255,.28);box-shadow:0 0 8px rgba(77,216,255,.1);border-radius:50%;font-family:'Space Grotesk';font-size:13px;color:var(--txt);opacity:.9}

/* заголовочный блок «Послуги» (кикер+заголовок+подзаголовок) — одна пульсирующая рамка, по центру; пульс = aboutFramePulse (как у «Про нас», чтобы не задеть framePulse hero) */
#services .wrap > .rv{display:block;width:calc(50% - 32px);box-sizing:border-box;margin-left:auto;margin-right:auto;padding:26px 38px 30px;border:1px solid var(--line);border-radius:22px;background:var(--glass);position:relative;overflow:hidden;animation:aboutFramePulse 2.6s ease-in-out infinite}
#services .wrap > .rv::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),transparent)}
#services .sec-kicker{display:inline-flex;align-items:center;gap:10px;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:24px;letter-spacing:-.02em;text-transform:none;color:var(--cyan);margin-bottom:14px;padding:0;border:0;background:none}
#services .sec-kicker::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--cyan);animation:aboutPulse 2.2s ease-in-out infinite}
#services h2{font-family:'Space Grotesk',sans-serif;font-size:20.5px;margin-bottom:12px}
#services .sec-sub{font-size:15.5px;max-width:none}

/* === АНИМАЦИИ ИКОНОК (комбо): все «едут» вправо, чип .ic растягивается как дорога === */
.srv .ic{justify-content:flex-start;overflow:hidden;animation:icoRoad 4.5s linear infinite}
.srv .ic svg{animation:icoDrive 4.5s linear infinite}
.srv:nth-child(1) .ic svg circle{animation:icoSlide 2.6s ease-in-out infinite}
.srv:nth-child(1) .ic svg circle:nth-of-type(2){animation-delay:.45s}
.srv:nth-child(1) .ic svg circle:nth-of-type(3){animation-delay:.9s}
.srv:nth-child(4) .ic svg .wr{transform-box:fill-box;transform-origin:center;animation:icoWrench 2.4s ease-in-out infinite}
@keyframes icoSlide{0%,100%{transform:translateX(-2px)}50%{transform:translateX(3px)}}
@keyframes icoWrench{0%,100%{transform:rotate(0)}25%{transform:rotate(-16deg)}60%{transform:rotate(11deg)}}
.srv:nth-child(2) .ic svg .eye{animation:icoBlink 3.2s ease-in-out infinite}
.srv:nth-child(2) .ic svg .sig{animation:icoSignal 1.4s ease-out infinite}
@keyframes icoRoad{0%,5%{width:54px}80%{width:175px}90%{width:175px}100%{width:54px}}
@keyframes icoBlink{0%,90%,100%{opacity:1}95%{opacity:.12}}
@keyframes icoSignal{0%{r:1.1;opacity:.85;stroke-width:1.4}70%,100%{r:7;opacity:0;stroke-width:.3}}
@keyframes icoDrive{0%{transform:translateX(0);opacity:0}5%{opacity:1}80%{transform:translateX(140px);opacity:1}90%{transform:translateX(150px);opacity:0}100%{transform:translateX(0);opacity:0}}
@media (prefers-reduced-motion:reduce){.srv .ic svg,.srv .ic svg circle,.srv .ic svg .wr,.srv .ic{animation:none;width:54px}}

/* мягкий белый пульс заголовков карточек (фазы смещены) */
.srv h3{animation:titleGlow 3s ease-in-out infinite}
.srv:nth-child(2) h3{animation-delay:.4s}
.srv:nth-child(3) h3{animation-delay:.8s}
.srv:nth-child(4) h3{animation-delay:1.2s}
@keyframes titleGlow{0%,100%{opacity:.82;text-shadow:0 0 0 rgba(255,255,255,0)}50%{opacity:1;text-shadow:0 0 12px rgba(255,255,255,.45)}}
@media (prefers-reduced-motion:reduce){.srv h3{animation:none}}

/* статичная разделительная полоса между секциями (между «Про нас» и «Послуги») */
.divider{position:relative;top:-56px;width:60%;max-width:760px;height:2px;margin:14px auto;border-radius:2px;background:linear-gradient(90deg,transparent,rgba(77,216,255,.55),rgba(139,124,255,.45),transparent);box-shadow:0 0 14px rgba(77,216,255,.22)}

/* «Послуги» — финальный масштаб/зазор (утверждено 2026-06-25); transform статичный (reduced-motion не трогаем), специфичность #services перебивает базовый gap:20px и .rv.on{transform:none} */
#services .wrap > .rv{transform:scale(1.13);transform-origin:center}
#services .srv-grid{transform:scale(1.10);transform-origin:top center;gap:40px}

/* gallery cta */
.gcta{position:relative;border-radius:28px;overflow:hidden;border:1px solid var(--line)}
.gcta img{width:100%;height:440px;object-fit:cover;opacity:.45}
.gcta-in{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;background:radial-gradient(ellipse at center,rgba(10,13,18,.1),rgba(10,13,18,.75));padding:0 24px}
.gcta-in h2{max-width:640px}

/* partners */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:34px 0;margin-top:64px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.track{display:flex;gap:64px;width:max-content;animation:scroll 40s linear infinite}
.marquee:hover .track{animation-play-state:paused}
.track img{height:46px;width:auto;object-fit:contain;filter:grayscale(1) brightness(2.2);opacity:.5;transition:.25s}
.track img:hover{filter:none;opacity:1}
@keyframes scroll{to{transform:translateX(-50%)}}

/* contact + map */
.contact-card{background:linear-gradient(135deg,rgba(77,216,255,.07),rgba(139,124,255,.07));border:1px solid var(--line);border-radius:28px;padding:60px;display:grid;grid-template-columns:1fr 1fr;gap:60px}
.c-row{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:17px 0;border-bottom:1px solid var(--line);font-size:15px}
.c-row span:first-child{color:var(--txt2);flex-shrink:0}
.c-row a:hover{color:var(--cyan)}
.form input,.form textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:12px;padding:16px;color:#fff;font-family:inherit;font-size:15px;margin-bottom:14px}
.form input::placeholder,.form textarea::placeholder{color:var(--txt2)}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--cyan)}
.map-frame{margin-top:24px;border-radius:28px;overflow:hidden;border:1px solid var(--line);position:relative}
.map-frame iframe{width:100%;height:380px;border:0;filter:grayscale(1) invert(.92) contrast(.9) hue-rotate(180deg);display:block}
.map-tag{position:absolute;top:18px;left:18px;background:rgba(10,13,18,.85);backdrop-filter:blur(10px);border:1px solid var(--line);border-radius:12px;padding:12px 18px;font-size:13px;max-width:320px}
.map-tag b{display:block;font-family:'Space Grotesk';margin-bottom:2px}
.map-tag span{color:var(--txt2);font-size:12.5px}

/* footer */
footer{border-top:1px solid var(--line);padding:56px 0 32px;background:var(--bg2)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;margin-bottom:44px}
.foot-grid img{height:40px;width:auto;margin-bottom:18px}
.foot-grid p{color:var(--txt2);font-size:13.5px;max-width:320px}
.foot-grid h4{font-family:'Space Grotesk';font-size:15px;margin-bottom:16px}
.foot-grid ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:14px;color:var(--txt2)}
.foot-grid ul a:hover{color:var(--cyan)}
.foot-bottom{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;color:var(--txt2);font-size:13px;flex-wrap:wrap;gap:10px}

/* reveal + totop */
.rv{opacity:0;transform:translateY(28px);transition:opacity .8s,transform .8s}
.rv.on{opacity:1;transform:none}
.totop{position:fixed;bottom:20px;right:20px;z-index:90;width:46px;height:46px;border-radius:12px;background:var(--glass);backdrop-filter:blur(10px);border:1px solid var(--line);color:#fff;font-size:18px;cursor:pointer;opacity:0;pointer-events:none;transition:.3s}
.totop.show{opacity:1;pointer-events:auto}
.totop:hover{border-color:var(--cyan);color:var(--cyan)}

@media(max-width:1000px){
  .menu,.nav-contact{display:none}
  .burger{display:flex}
  .about-grid,.contact-card{grid-template-columns:1fr}
  .srv-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr}
  .contact-card{padding:36px}
  .wrap{padding:0 22px}
  .hero{min-height:auto;padding:70px 0 150px}
}
@media(max-width:560px){
  .srv-grid{grid-template-columns:1fr}
  .nav .btn{display:none}
  .hero-chips{gap:10px}
  .chip{padding:13px 16px}
}
/* lang dropdown (тільки поточна мова + випадаючий список інших) */
.lang{position:relative;background:none;border:none;padding:0}
.lang-cur{display:flex;align-items:center;gap:7px;background:var(--glass);border:1px solid var(--line);border-radius:10px;padding:8px 13px;font-size:12.5px;font-weight:600;color:#fff;cursor:pointer;font-family:'Inter',sans-serif}
.lang-cur svg{width:11px;height:11px;stroke:var(--txt2);fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;transition:.25s}
.lang.open .lang-cur svg{transform:rotate(180deg)}
.lang-cur:hover{border-color:rgba(77,216,255,.4)}
.lang-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:100%;background:rgba(10,13,18,.96);backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:10px;padding:4px;display:none;flex-direction:column;gap:2px;z-index:60}
.lang.open .lang-menu{display:flex}
.lang-menu a{padding:8px 16px;border-radius:7px;color:var(--txt2);font-size:12.5px;font-weight:600;transition:.2s;text-align:center;white-space:nowrap}
.lang-menu a:hover{background:linear-gradient(92deg,rgba(77,216,255,.18),rgba(139,124,255,.18));color:#fff}
/* --- mobile polish: суцільна шапка, контакти на мобілі, компоновка фону --- */
.mobile-contact{display:none}
@media(max-width:1000px){
  header{position:fixed;top:0;left:0;right:0;background:#0A0D12;box-shadow:0 6px 24px rgba(0,0,0,.45)}
  body{padding-top:76px}
  .hero-bg img{left:0;width:100%;object-position:center}
  .mobile-contact{display:flex;gap:20px;align-items:center;justify-content:center;flex-wrap:wrap;background:#0A0D12;border-bottom:1px solid var(--line);padding:10px 16px;font-size:12.5px}
  .mobile-contact a{display:flex;align-items:center;gap:7px;color:var(--txt2);font-weight:600}
  .mobile-contact svg{width:15px;height:15px;stroke:var(--cyan);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
  .mobile-contact a:active{color:var(--cyan)}
}