html {
    font-size:21px;
}

:root {
  --primary-color: #3ABEFF;
  --secondary-color: #A0F0ED;
  --third-color:#999999;
  --primary-font: "Space Grotesk", sans-serif;
  --secondary-font: "Outfit", sans-serif;
  --bg:#0b0b0d;
    --box:#64b5f6;        /* barva karet */
    --text:#0a1720;       /* text v kartách */
    --arrow:#b7f6e3;      /* barva šipek */
    --radius:1rem;

}

.font-primary {
    font-family:var(--primary-font);
}

.font-secondary {
    font-family:var(--secondary-font);
}

.grey-text {
    color:var(--third-color);
}

.display-7{
    font-size:2rem;
}

.display-8{
    font-size:1.5rem;
}

a{
    text-decoration:none;

}

a:hover {
    text-decoration:underline;
    color:var(--primary-color);
}

.menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
}

.menu li {
  margin-right: 2.8rem; /* spacing between menu items */
  font-weight:500;
}
.menu li:hover {
  text-decoration: underline;
}

.menu li:last-child {
  margin-right: 0; /* no margin after last item */
}

img.logo { max-height: 80px; }

body, p, a {
    font-size:21px;
    color: #E0E0E0;
    font-family:'Outfit', sans-serif;
}

h1,h2,h3,h4,h5 {
    font-family: var(--primary-font);
}

h1 {
    font-weight: bold;
    font-size:3rem;
    color:var(--primary-color);
}

.btn-contact {
    background-color: var(--primary-color)!important;
    font-family:var(--primary-font);
    border-radius:0;
    text-transform:uppercase;
    font-size:0.9rem;
    font-weight:bold;
}

.btn-contact:hover {
    background-color: var(--secondary-color)!important;
        border-radius:0;

}
#main {
    background-color:black;
}

.hero .container{
  min-height: calc(100vh - 145px);
  justify-content:center;
  display:flex;
  align-items: center;
}


.usp {
    text-align:center;
    .number {
        color:var(--secondary-color);
        font-size: 1.8rem;
        margin-bottom:0px;
    }
    img {
        max-width:56px;
    }
    .text {
        font-size:0.85rem;
        color:var(--third-color);
        padding: 0 0.6rem;
    }
}

.grecaptcha-badge {
  display:none!important;
}


@media (min-width: 992px) { 
  .row.usps {
  margin-left:-50px;
}

 }

.hero-text{
    font-size:2.3rem;
    font-weight: 500;
    line-height:2.9rem;
    span {
        color:var(--primary-color);
    }
}

#particle-image {
    height: 100%;
    width: 100%;
}

.loader{

  position:relative;
  width: 300px;
  height: 300px;
  box-sizing: border-box;
}
.loader .face{
  position: absolute;
  border:2px solid #121212;
}
.loader .face.face1{
  top: 0;
  left:0;
  right: 0;
  bottom: 0;
  background:090909;
  box-shadow:0 0 10px rgba(0,0,0,1);
  border-radius: 50%;
  border-left: 2px solid var(--primary-color);
  border-top: 2px solid var(--primary-color);
  animation: ani1 3s linear infinite;
}
.loader .face.face2{
  top: 30px;
  left:30px;
  right: 30px;
  bottom: 30px;
  background:#090909;
  box-shadow:0 0 10px rgba(0,0,0,1);
  border-radius: 50%;
  border-right: 2px solid var(--secondary-color);
  border-bottom: 2px solid var(--secondary-color);
  animation: ani2 3s linear infinite;
}
.loader .face .circle{
  position: absolute;
  top: calc(50% - 1px);
  left: 50%;
  width: 50%;
  height: 2px;
  transform-origin: left;
}
.loader .face.face1 .circle{
  transform: rotate(-45deg);
}
.loader .face.face2 .circle{
  transform: rotate(-45deg);
}
.loader .face .circle:before{
  content: "";
  position: absolute;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #fff;
  top: -4px;
  right: -6px;
}
.loader .face.face1 .circle:before{
  background: var(--primary-color);
  box-shadow: 
    0 0 20px var(--primary-color),
    0 0 40px var(--primary-color),
    0 0 60px var(--primary-color),
    0 0 80px var(--primary-color),
    0 0 100px var(--primary-color),
    0 0 0 5px var(--primary-color);
}
.loader .face.face2 .circle:before{
  background: var(--secondary-color);
  box-shadow: 
    0 0 20px var(--secondary-color),
    0 0 40px var(--secondary-color),
    0 0 60px var(--secondary-color),
    0 0 80px var(--secondary-color),
    0 0 100px var(--secondary-color),
    0 0 0 5px var(--secondary-color);
}

@keyframes ani1{
  0%{
    transform:rotate(0deg);
  }
  100%{
    transform:rotate(360deg);
  }
}
@keyframes ani2{
  0%{
    transform:rotate(0deg);
  }
  100%{
    transform:rotate(-360deg);
  }
}


/*. SERVICES */

#services, #chart {
    h2 span {
    color:var(--primary-color);
  }
}

.service-wrap {
  background-color: var(--primary-color);
  padding:1.5rem;
  
  .title {
    font-size: 1.2rem;
    font-weight:500;
    margin-bottom:10px;
      color: black!important;

  }

  .service-text{
      color: black!important;
      font-size:0.9rem;

  }

  img {
    margin-top:20px;
    max-height:72px;
  }
}

.text-about {
  font-size: 1.4rem;
}

#challenge{

  h2{
    font-weight:bold;
    font-size:2.5rem;
  }
  h2 span {
    color:var(--primary-color);
  }
  p{
    font-size:1.65rem;
  }
  p span {
    text-decoration: underline;
  }

}

#contact{
  h2 {
    padding-left:0.75rem;
    color:var(--primary-color);
  }
  p{
    padding-left:0.75rem;
  }
  p span {
    text-decoration:underline;
  }

  .form-control {
    border-radius:0px;
    border-top:0px;
    border-left:0px;
    border-right:0px;
  }

  label {
    padding-left:15px;
  }

  .contact-small {
    font-size:0.9rem;
    color: var(--third-color); 
  }
}

#about, #contact, #corners{
  padding-top:3rem;
  padding-bottom:3rem;
}


footer .container {
  border-top:1px solid #E0E0E0;
  padding-top:1.2rem;
  padding-bottom:3rem;
}

.footer-logo{
  max-width:150px;
}

.linkedin {
  max-width:33px;
  height:auto;
  position:relative;
  margin-right:10px;
}

footer p
{
  font-size:0.9rem;
  margin-bottom:0px;

}

/* LMP subpage */
#why{
  h2 span {
    color:var(--primary-color);
  }
  ul li{
    margin-bottom:20px;
  }
}

.lmp{
    .btn-primary{ border:2px solid var(--primary-color);}

}

 .btn-inverse {
    background-color: transparent!important;
    color: var(--primary-color);
    border:2px solid var(--primary-color);
    font-family:var(--primary-font);
    border-radius:0;
    text-transform:uppercase;
    font-size:0.9rem;
    font-weight:bold;}

.btn-inverse:hover {
    background-color: var(--primary-color)!important;
    color:black;
    border-radius:0;
}


  .diagram{
    position:relative;
    max-width:1200px;
    margin-inline:auto;
    padding:2.5rem 1rem 4rem;
  }

  /* Box = Bootstrap card s úpravami */
  .block.card{
    background:var(--box);
    color:var(--text);
    border:0;
    border-radius:var(--radius);
    box-shadow:0 1rem 2rem rgba(0,0,0,.25);
  }
  .block .card-title{
    text-transform:uppercase;
    letter-spacing:.4px;
    margin-bottom:.35rem;
  }

  /* Rozmístění – desktop grid přes bootstrap cols */
  @media (min-width:768px){
    .row-logic{ row-gap:2.2rem; }
    .col-mid { order:1; } /* pro čitelnost */
  }

  /* SVG šipky pro ≥md */
  .wires{
    position:absolute;
    inset:0;
    pointer-events:none;
    display:none;
  }
  @media (min-width:768px){ .wires{ display:block; } }
  .wires svg{ width:100%; height:100%; }
  .wires path{
    stroke:var(--arrow);
    stroke-width:4;
    fill:none;
    vector-effect:non-scaling-stroke;
  }
  .wires marker path{ fill:var(--arrow); }

  /* “Mobile” šipka mezi boxy */
  @media (max-width:767.98px){
    .block{ position:relative; }
    .block + .block::before{
      content:"";
      position:absolute;
      top:-12px; left:3rem; right:3rem;
      height:12px;
      border-top:3px solid var(--arrow);
      border-right:3px solid var(--arrow);
      transform:skewY(-40deg);
      border-top-right-radius:.4rem;
    }
  }



/* Hamburger */
.hamburger {
  width: 30px;
  height: 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
}
.hamburger span {
  display: block;
  height: 3px;
  width: 100%;
  background: #fff;
  transition: .3s;
}

/* Slide menu */
.mobile-menu {
  position: fixed;
  top: 0;
  right: -260px;
  width: 260px;
  height: 100vh;
  background: #0b0b0d;
  padding: 80px 30px;
  transition: right .3s ease;
  z-index: 1000;
}
.mobile-menu ul { padding: 0; margin: 0; list-style: none; }
.mobile-menu li { margin-bottom: 25px; }
.mobile-menu li:hover { text-decoration: underline ;}

.mobile-menu a {
  color: #fff;
  font-size: 20px;
  text-transform: uppercase;
  text-decoration: none;
  letter-spacing: .5px;
}

/* active state */
.mobile-menu.active { right: 0; }

.hamburger.active span:nth-child(1) {
  transform: rotate(45deg) translateY(9px);
}
.hamburger.active span:nth-child(2) {
  opacity: 0;
}
.hamburger.active span:nth-child(3) {
  transform: rotate(-45deg) translateY(-9px);
}