:root {
    --purple: #4b3caf;
    --blue: #141774;
    --blue-bright: #017EFA;
    --light: #E8F6FF;
    --light2: #DCEDF9;
    --black: #151718;
    --yellow: #FDC85D;
    --pink: #F85797;
    --text: #62637D;
}

*                       { margin: 0; padding: 0; }
a                       { text-decoration: none; }
p                       { padding-bottom: 40px; }
ul                      { list-style-type: none; }
div,span                { box-sizing: border-box; }
html                    { scroll-behavior: smooth; }
body                    { font: 14px Outfit,sans-serif; }
.inside                 { max-width: 1200px; margin: 0 auto; padding: 0 30px; }
.center                 { text-align: center; }
.animated               { animation-delay: .5s; animation-duration: 1s; animation-direction: normal; animation-fill-mode: forwards; opacity: 0; }
h1,h2,h3                { letter-spacing: .5px; }
h1                      { font-size: 64px; display: block; text-align: center; margin-bottom: 70px; line-height: 76px; color: var(--blue); }
h2                      { font-size: 50px; margin-bottom: 50px; color: var(--blue); line-height: 1.2; }
h3                      { font-size: 23px; margin-bottom: 50px; color: var(--blue); }

.button                 { line-height: 65px; border-radius: 7px; background: var(--blue-bright); color: #fff; text-transform: uppercase; }
.button                 { font-size: 14px; display: inline-block; padding: 0 30px; font-family: OutfitSemiBold,sans-serif; overflow: hidden; }
.button                 { position: relative; }
.button:after           { content: ''; background: black; width: 110%; height: 500%; display: block; transform: rotate(30deg); }
.button:after           { z-index: 1; position: absolute; top: -200%; left: -140%; transition: all .5s; }
.button span            { position: relative; z-index: 2; }
.button:hover:after     { left: 0; transform: rotate(5deg); }
input.button, button    { border: none; cursor: pointer; }

#header                 { position: absolute; top: 0; left: 0; height: 90px; width: 100%; color: #fff; z-index: 1000; }
#header                 { transition: all .5s; }
#header .inside         { max-width: 100%; padding: 0 90px; }
#header                 { line-height: 90px; }
#header ul              { display: block; text-align: center; font-family: OutfitSemiBold,sans-serif; letter-spacing: 0.5px; }
#header li              { display: inline-block; text-transform: uppercase; font-weight: 600; margin: 0 10px; }
#header a               { color: var(--black); display: block; padding: 0 20px; }
#header .active a       { color: var(--purple); }
#header .logo           { font-size: 30px; font-weight: 400; letter-spacing: 0.5px; text-decoration: none; }
#header .logo           { position: absolute; top: 0; left: 90px; color: var(--black); }
#header .logo img       { position: relative; bottom: -5px; margin-right: 5px; }
#header .phone          { position: absolute; top: 0; right: 90px; color: var(--blue); font-weight: 600; opacity: 0.7; font-size: 16px; }
#header .phone i        { margin-right: 5px; }
#header .button         { position: absolute; top: 20px; right: 90px; height: 55px; line-height: 55px; }
#header .button span    { color: #fff; }
#header .nav_btn        { display: none; }

#main .block            { padding: 120px 0; position: relative; font-size: 18px; line-height: 27px; overflow: hidden; color: var(--text); }
#main .block.blue       { background: var(--blue); color: #fff; }
#main .block.blue h2    { color: #fff; }
#main .block.light      { background: var(--light); color: rgb(20,23,116); }
#main .block h2         { display: block; text-align: center; }
#main .laptop           { position: relative; display: inline-block; width: 40vw; }
#main .laptop .device   { width: 100%; position: relative; z-index: 2; }
#main .laptop .screen   { position: absolute; top: 4%; left: 15%; width: 70%; z-index: 1; }
#main .block p:last-child { padding: 0; }

#main .breadcrumb       { background: url('img/breadcrumb.jpg') top center no-repeat; background-size: cover; height: 450px; }
#main .breadcrumb       { padding: 170px 30px 120px 30px; }
#main .breadcrumb h1    { font-family: PoppinsSemiBold,sans-serif; margin-bottom: 20px; }
#main .breadcrumb span  { letter-spacing: 0.5px; font-size: 15px; font-family: OutfitSemiBold,sans-serif; }
#main .breadcrumb i     { font-size: 17px; display: inline-block; margin: 0 2px; }
#main .breadcrumb h1 i  { font-size: 50px; color: var(--blue); opacity: 0.5; }

#main .first            { min-height: 70vh; }
#main .first h1         { color: #fff; }
#main .block .back      { position: absolute; right: -5%; top: 5%; color: #23259f; transform: rotate(-45deg); opacity: 0.1; }
#main .block .back      { font-size: 600px; z-index: 0; }
#main .block .inside    { position: relative; z-index: 1; }
#main .security         { overflow: hidden; }
#main .security .back   { left: 5%; right: auto; transform: rotate(35deg); font-size: 500px; }

#main .main             { background: transparent url('img/body.png') 0 0 no-repeat; background-size: 100%; height: calc(100vw * 0.528125); }
#main .main             { color: #fff; text-align: center; padding: 120px 0 0 0; transition: background .3s; }
#main .main img         { margin: 0 auto; }

#main .boxes            { display: grid; grid-template-columns: 1fr 1fr 1fr; grid-gap: 30px; color: rgba(0,0,0,0.6); font-size: 16px; }
#main .boxes li         { background: linear-gradient(120deg, #f1f1f1, #e9e9e9); padding: 40px; text-align: center; border-radius: 6px; }
#main .boxes li         { animation-delay: 0s; animation-duration: .3s; }
#main .boxes i          { font-size: 60px; color: var(--purple); display: block; margin-bottom: 20px; }
#main .boxes p          { padding: 0; }
#main .boxes h3         { margin-bottom: 20px; }

#main .pros i           { background: linear-gradient(130deg, #EF8EFF, #51CFF9); display: inline-block; }
#main .pros i           { -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
#main .pros .boxes li   { border: 1px dashed;  border-image-slice: 1; background: #fff; border-radius: 10px; }
#main .pros .boxes li   { border-image-source: linear-gradient(130deg, #EF8EFF, #51CFF9); }

#main .why              { position: relative; z-index: 1; padding: 0; overflow: visible; }
#main .why:before       { content: '\f3ed'; font: bold 300px 'Font Awesome 5 Pro'; position: absolute; left: 5%; top: 10%; color: #23259f; }
#main .why:before       { transform: rotate(-20deg); }
#main .why .inside      { position: relative; padding: 120px 30px; }
#main .why .boxes       { position: absolute; bottom: 0; transform: translateY(50%); left: 0; right: 0; }
#main .why .boxes li    { background: #fff; box-shadow: 1px 1px 20px rgba(0,0,0,0.07); padding: 50px 50px 45px 50px; border-radius: 15px; color: #646580; }
#main .why .boxes strong{ color: var(--blue); font-size: 48px; display: block; margin-bottom: 10px; }

#main .split            { display: grid; grid-template-columns: 1fr 1fr; grid-gap: 100px; }
#main .split:after      { position: absolute; left: 50%; background: var(--blue); top: 60px; bottom: 60px; width: 1px; }
#main .split:after      { opacity: 0.1; display: block; content: ''; }

#main .payment          { text-align: center; font-size: 18px; color: var(--blue); padding-top: 240px; }
#main .payment .split:after { top: 140px; }
#main .payment h2       { margin-bottom: 20px; }
#main .payment ul       { display: grid; grid-template-columns: 1fr 1fr; grid-gap: 30px; }
#main .payment li       { display: inline-block; }
#main .payment img      { width: 80px; height: auto; }
#main .payment .master  { width: 60px; }
#main .payment .paypal  { width: 100px; }

#main form              { display: grid; grid-template-columns: 1fr 1fr; grid-gap: 30px; }
#main form .last        { grid-column: 1 / span 2; text-align: center; }
.text, select, .textarea        { border: 2px solid transparent; color: var(--blue); padding: 0 20px; height: 60px; }
.text, select, .textarea        { font: normal 16px/60px Outfit,sans-serif; border-radius: 10px; background: var(--light); }
#main .text:focus       { outline: none; border-color: var(--purple); }
#main .textarea         { grid-column: 1 / span 2; height: 200px; resize: none; }
#main .light .text      { background: #fff; }

#main .tariffs          { display: grid; grid-template-columns: 1fr 1fr 1fr; grid-gap: 40px; }
#main .tariffs .box     { font-size: 16px; border-radius: 10px; border: 2px solid #45CCFE; }
#main .tariffs .box     { padding: 35px; transition: all .5s; }
#main .tariffs h4       { font: 30px PoppinsSemiBold,sans-serif; color: var(--blue); display: block; margin-bottom: 30px; }
#main .tariffs li       { color: rgba(98,99,125); line-height: 30px; }
#main .tariffs li:before{ width: 10px; height: 10px; content: '\f058'; font: bold 16px 'Font Awesome 5 Pro'; color: #45CCFE; }
#main .tariffs li:before{ margin-right: 10px; }
#main .tariffs .dot:before { content: '\f192'; }
#main .tariffs .std     { border-color: var(--yellow); }
#main .tariffs .std li:before { color: var(--yellow); }
#main .tariffs .pro     { border-color: var(--pink); }
#main .tariffs .pro li:before { color: var(--pink); }
#main .tariffs .price   { font-size: 30px; text-align: center; display: block; margin: 30px 0; }
#main .tariffs .button  { display: block; text-align: center; background: #45CCFE; border-radius: 32.5px; width: 100%; box-sizing: border-box; }
#main .tariffs form     { display: block; }
#main .std .button      { background: var(--yellow); }
#main .pro .button      { background: var(--pink); }
#main .tariffs .hide    { filter: grayscale(1); opacity: 0.5; display: block; border-color: #aaa }
#main .tariffs .hide .button { background: #aaa; }
#main .tariffs .hide li:before { color: #aaa; }
#main .calc             { padding-top: 60px; color: var(--text); }
#main .calc .cont       { position: relative; display: inline-block; }
#main .calc i           { position: absolute; top: 50%; right: 20px; transform: translateY(-50%); color: rgba(0,0,0,0.4); }

#main .funcs            { display: grid; grid-template-columns: 1fr 1fr 1fr; text-align: center; grid-gap: 30px; }
#main .funcs i          { background: linear-gradient(130deg, #EF8EFF, #51CFF9); display: inline-block; }
#main .funcs i          { -webkit-background-clip: text; -webkit-text-fill-color: transparent; font-size: 52px; }
#main .funcs li         { opacity: 0.5; transition: all .5s; }
#main .funcs .active    { opacity: 1; transform: scale(1.3); }

#main .block.faq:before { display: block; height: 1px; background: var(--blue); content: ''; position: absolute; top: 0; width: 100%; opacity: 0.1; }
#main .block.inc:before { display: none; }
#main .faq .bg          { position: absolute; top: 80px; left: 50%; transform: translateX(-50%); width: 90vw; }
#main .faq .item        { background: #fff; border-radius: 10px; padding: 30px; margin-bottom: 30px; position: relative; }
#main .faq .item        { font: normal 16px Outfit,sans-serif; color: var(--text); cursor: pointer; box-shadow: 0 0 2px rgba(0,0,0,0.1); }
#main .faq h4           { color: var(--blue); font: normal 18px PoppinsSemiBold,sans-serif; }
#main .faq .answer      { height: 0; overflow: hidden; transition: all .5s; }
#main .faq .content     { padding-top: 20px; }
#main .faq p            { padding-bottom: 15px; }
#main .faq .item:after  { content: '\f067'; font: 16px 'Font Awesome 5 Pro'; color: var(--text); }
#main .faq .item:after  { position: absolute; top: 35px; right: 30px; transition: all .2s; }
#main .faq .open:after  { transform: rotate(45deg); color: var(--blue); }
#main .faq li           { line-height: 26px; }
#main .faq li:before    { content: '\f058'; font:bold  16px 'Font Awesome 5 Pro'; color: var(--blue-bright); }
#main .faq li:before    { display: inline-block; margin-right: 5px; }

#main .partner img      { height: 50px; }
#main .partner h2       { grid-column: 1 / span 3; }
#main .partner ul       { display: grid; grid-template-columns: 1fr 1fr 1fr; }
#main .partner li       { text-align: center; }
#main .partner .placetel{ height: 40px; }

#main .ref img          { margin: 10px; border-radius: 10px; box-shadow: 0 0 2px rgba(0,0,0,0.3); }

#footer                 { background: var(--blue); color: rgba(255,255,255,0.7); padding: 90px 0; font-size: 16px; }
#footer .logo span      { color: #fff; line-height: 30px; display: inline-block; vertical-align: top; padding-left: 5px; font-size: 20px; }
#footer .inside         { display: grid; grid-template-columns: 1fr 1fr 1fr; line-height: 22px; }
#footer h4              { text-transform: uppercase; display: block; margin-bottom: 10px; }
#footer a               { color: rgba(255,255,255,0.7); }
#footer p               { padding: 0; }
#footer a:hover         { color: #fff; }

.home #header a             { color: rgba(255,255,255,0.7); }
.home #header .active a     { color: #fff; }
.preise #main .block h2     { font: 42px/55px PoppinsSemiBold,sans-serif; letter-spacing: -0.01em; }

.kontakt #main .block h2    { font: 42px/55px PoppinsSemiBold,sans-serif; letter-spacing: -0.01em; }
.kontakt #main .block       { border-bottom: 1px solid var(--light); }
.kontakt #main .split .box  { border: 1px solid var(--light); padding: 40px; text-align: center; }
.kontakt #main .split h3    { margin-bottom: 10px; }
.kontakt #main .split p     { color: rgba(0,0,0,0.6); }
.kontakt #main .split i     { color: var(--blue-bright); font-size: 36px; display: block; margin-bottom: 30px; }
.kontakt #main .split:after { display: none; }

#top #main input.captcha          { background-image: url('/captcha'); background-position: 95% center; background-repeat: no-repeat; }

@media (max-width: 1000px) {
    #main .main     { background-size: auto 100%; background-position: top center; }
    #main .laptop   { width: 80vw; }
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes slideUp {
    from { position: relative; bottom: -20px; opacity: 0; }
    to { position: relative; bottom: 0; opacity: 1; }
}

