body {
  margin: 0;
  font-family: "Oswald", sans-serif;
  background: #99ff00;
  color: white;
  -webkit-font-smoothing: antialiased;
  scroll-behavior: smooth;
}
body.menu-open {
  overflow: hidden;
  height: 100vh;
  touch-action: none;
}
body.menu-open::after {
  content: '';
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(4px);
  z-index: 997;
  transition: opacity 0.3s ease;
  opacity: 1;
}
body::after {
  opacity: 0;
  pointer-events: none;
}
* {
  box-sizing: border-box;
}
@media screen and (min-width: 993px) {
  header svg {
    margin-left: 1em;
  }
}
.hero__top {
  gap: 6rem;
  padding-inline: 10%;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  padding-block: 1rem;
  transition: background 0.4s ease, transform 0.3s ease;
}
.hero__logo svg {
  transition: all 0.3s ease;
  height: 117px;
}
.hero__top.sticky {
  background: rgba(153, 255, 0, 0.95);
  backdrop-filter: blur(6px);
  z-index: 9999;
}
.hero__top.sticky svg {
  height: 80px;
  transform: scale(0.95);
}
.hero__top.hide {
  transform: translateY(-100%);
}
.hero__nav {
  display: flex;
  align-items: center;
  gap: 3rem;
  z-index: 10;
  margin-left: auto;
}
.hero__nav a {
  position: relative;
  font-family: "Oswald", sans-serif;
  font-size: 1.6rem;
  text-transform: uppercase;
  text-decoration: none;
  color: #0a0f1a;
  letter-spacing: 0.05em;
  padding: 0.4rem 0.6rem;
  transition: color 0.3s ease;
}
.hero__nav a::before,
.hero__nav a::after {
  content: '';
  position: absolute;
  width: 8px;
  height: 8px;
  border: 2px solid #00658e;
  opacity: 0;
  transition: all 0.3s ease;
}
.hero__nav a::before {
  top: 0;
  left: 0;
  border-right: none;
  border-bottom: none;
  transform: translate(-6px, -6px);
}
.hero__nav a::after {
  bottom: 0;
  right: 0;
  border-left: none;
  border-top: none;
  transform: translate(6px, 6px);
}
.hero__nav a:hover {
  color: #00658e;
}
.hero__nav a:hover::before,
.hero__nav a:hover::after {
  opacity: 1;
  transform: translate(0, 0);
}
.burgerGlowPulse {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 38px;
  height: 26px;
  border: none;
  background: none;
  transition: all .3s ease;
  position: relative;
}
.burgerGlowPulse span {
  display: block;
  width: 100%;
  height: 3px;
  background: #0a0f1a;
  transition: all .4s ease;
  box-shadow: 0 0 0 #00658e;
  position: relative;
  z-index: 3;
}
.burgerGlowPulse::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 40px;
  height: 40px;
  background: radial-gradient(circle, rgba(0,101,142,0.7) 0%, rgba(28,165,165,0.4) 40%, transparent 80%);
  border-radius: 50%;
  transform: translate(-50%,-50%) scale(0);
  opacity: 0;
  z-index: 1;
  filter: blur(4px);
}
.burgerGlowPulse.clicked::before {
  animation: waveSpread 1.2s ease-out forwards;
}
@keyframes waveSpread {
  0% {transform:translate(-50%,-50%) scale(0.2);opacity:0.9}
  50% {transform:translate(-50%,-50%) scale(3.5);opacity:0.5}
  80% {transform:translate(-50%,-50%) scale(6);opacity:0.15}
  100% {transform:translate(-50%,-50%) scale(8);opacity:0}
}
.burgerGlowPulse:hover span {
  box-shadow: 0 0 20px #00658e, 0 0 35px rgba(0,101,142,0.5);
}
.burgerGlowPulse.active {
  position: fixed;
  z-index: 9999;
  right: 6%;
}
.burgerGlowPulse.active span:nth-child(1) {
  transform: translateY(10px) rotate(45deg);
}
.burgerGlowPulse.active span:nth-child(2) {
  opacity: 0;
  transform: translateX(-40px);
}
.burgerGlowPulse.active span:nth-child(3) {
  transform: translateY(-10px) rotate(-45deg);
}
@media screen and (min-width: 993px) {
  .burgerGlowPulse {display:none;}
}
@media (max-width: 992px) {
  .hero__top svg {max-height:50px;}
  .hero__nav {
    position: fixed;
    top: 0;
    right: -100%;
    width: 100%;
    height: 100vh;
    background: #99ff00;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2.5rem;
    transition: right 0.4s ease;
    z-index: 998;
  }
  .hero__nav.active {right:0;}
  .hero__nav a {color:#0a0f1a;font-size:2.2rem;}
  .burger {display:flex;}
  .hero-button {display:none!important;}
}

.hero {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100vh;
  padding: 3% 10%;
  overflow: hidden;
}
.hero-content {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  margin-top: -2vw;
}
@media (min-width: 993px) {
  .hero-content {
    flex-direction: row;
    align-items: flex-start;
    justify-content: flex-start;
  }
}
.hero-title span {
  display: block;
  font-weight: 800;
  text-transform: uppercase;
  font-size: 16vw;
  line-height: 0.9;
  color: transparent;
  -webkit-text-stroke: 2px #00658e;
  text-shadow: 0 0 60px rgba(28,165,165,0.25);
  filter: drop-shadow(0 0 30px rgba(28,165,165,0.3));
  user-select: none;
}
.hero-text {
  position: relative;
  margin-top: 2vw;
  z-index: 10;
}
@media (min-width: 993px) {
  .hero-text {margin-left: -46vw;}
}
.hero-text h1 {
  text-transform: uppercase;
  font-weight: 800;
  line-height: 1.05;
  text-align: right;
  letter-spacing: -0.02em;
}
.text-main {font-size:7vw;color:#007575;}
.text-sub {-webkit-text-stroke:2px #00658e;font-size:6vw;}
.text-accent {font-size:8vw;color:#1ca5a5;}
.text-sub2 {font-size:4rem;}
.hero-text p {
  margin-top: 2.5rem;
  font-size: 1.3rem;
  max-width: 600px;
  color: #b8c4d9;
}
@media (max-width: 1024px) {
  .text-main {font-size:6rem;}
  .text-sub {font-size:3.5rem;}
  .text-accent {font-size:4.5rem;}
  .text-sub2 {font-size:3rem;}
}
@media (max-width: 992px) {
  .hero__top svg {max-width:60px!important;margin-bottom:0;}
  .hero {
    padding:0 6%;
    min-height:auto;
    padding-top:16vh;
    padding-bottom:12vh;
  }
  .hero-title span {
    font-size:16vw;
    -webkit-text-stroke:2px #00658e;
  }
  .hero-text {margin-top:10vw;}
  .text-main {font-size:3.2rem;}
  .text-sub {font-size:2rem;}
  .text-accent {font-size:2.8rem;}
  .text-sub2 {font-size:1.8rem;}
  .hero-text p {font-size:1rem;max-width:90%;}
}
@media (max-width: 480px) {
  .hero {padding:0 5%;padding-top:25vh;padding-bottom:12vh;}
  .text-main {font-size:2.4rem;}
  .text-sub {font-size:2rem;}
  .text-accent {font-size:2.2rem;}
  .text-sub2 {font-size:1.5rem;}
  .hero-text p {font-size:0.95rem;}
}
.hero__top {
  display:flex;
  justify-content:space-between;
  align-items:center;
  z-index:10000;
}
.hero-button {
  position:relative;
  z-index:10;
  display:inline-block;
  font-size:2rem;
  padding:1rem 2rem;
  border:3px solid #00658e;
  text-decoration:none;
  color:#00658e;
  font-weight:400;
  transition:all 0.3s ease;
  cursor:pointer;
}
.hero-button::after {
  content:'';
  width:100%;
  height:100%;
  display:block;
  position:absolute;
  border:3px solid white;
  top:-2px;
  left:-2px;
  pointer-events:none;
  transition:all 0.3s ease;
  opacity:0;
}
.hero-button:hover {
  color:white;
  background:#00658e;
}
.hero-button:hover::after {
  opacity:1;
  transform:translate(10px,10px);
}
@media screen and (max-width:768px) {
  .hero-button {padding:0.5rem 1.5rem;font-size:1rem;}
}
.about {
  background:#006872;
  color:#ffffff;
  padding:10vh 10%;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}
.about-inner {
  display:flex;
  flex-direction:row-reverse;
  align-items:flex-start;
  justify-content:space-between;
  gap:4rem;
  width:100%;
  position:relative;
}
.about-title {
  position:absolute;
  top:0;
  right:0;
  z-index:0;
  opacity:0.2;
  pointer-events:none;
}
.about-title h2 {
  font-family:"Oswald",sans-serif;
  font-size:24vw;
  line-height:0.9;
  color:transparent;
  -webkit-text-stroke:2px #99ff00;
  text-shadow:0 0 40px rgba(153,255,0,0.1);
  filter:drop-shadow(0 0 20px rgba(153,255,0,0.15));
  text-transform:uppercase;
  margin:0;
}
.about-text {
  position:relative;
  z-index:1;
  flex:1;
  font-family:"Oswald",sans-serif;
  font-size:2rem;
  line-height:1.4;
  max-width:700px;
  margin-top:8vw;
}
.about-text strong {color:#99ff00;}
.about-button {
  display:inline-block;
  margin-top:2rem;
  padding:1rem 2rem;
  font-size:1.4rem;
  font-family:"Oswald",sans-serif;
  text-transform:uppercase;
  text-decoration:none;
  border:3px solid #99ff00;
  color:#99ff00;
  transition:all 0.3s ease;
  position:relative;
  z-index:10;
}
.about-button::after {
  content:'';
  position:absolute;
  top:-2px;
  left:-2px;
  width:100%;
  height:100%;
  border:3px solid white;
  opacity:0;
  transition:all 0.3s ease;
  pointer-events:none;
}
.about-button:hover {
  background:#99ff00;
  color:#0a0f1a;
}
.about-button:hover::after {
  opacity:1;
  transform:translate(10px,10px);
}
@media (min-width:992px) {
  .about-inner {flex-direction:column;align-items:flex-start;}
  .about-title {opacity:0.45;}
  .about-title h2 {font-size:32vw;}
  .about-text {margin-top:8vw;}
}
@media (max-width:1400px) {
  .about-title {opacity:0.15;}
  .about-title h2 {font-size:32vw;}
}
@media (max-width:992px) {
  .about-inner {flex-direction:column;align-items:flex-start;gap:2rem;}
  .about-title {position:static;opacity:1;margin-bottom:2rem;}
  .about-title h2 {font-size:24vw;}
  .about-text {margin-top:0;}
}
@media (max-width:600px) {
  .about {padding:8vh 6%;}
  .about-title h2 {font-size:30vw;-webkit-text-stroke:1.5px #99ff00;}
  .about-text {font-size:1.2rem;}
  .about-button {font-size:1rem;padding:0.7rem 1.4rem;}
}
.services {
  background:#0a0f1a;
  color:#ffffff;
  padding:12vh 10%;
  position:relative;
  overflow:hidden;
}
.services-inner {
  position:relative;
  z-index:1;
  padding-top:25vw;
}
.services-title {
  position:absolute;
  top:4%;
  left:0;
  width:100%;
  z-index:0;
  opacity:0.15;
  pointer-events:none;
  text-align:left;
}
.services-title h2 {
  font-family:"Oswald",sans-serif;
  font-size:20vw;
  line-height:0.9;
  text-transform:uppercase;
  color:transparent;
  -webkit-text-stroke:2px #99ff00;
  text-shadow:0 0 40px rgba(153,255,0,0.15);
  filter:drop-shadow(0 0 20px rgba(153,255,0,0.2));
  margin:0;
}
.services-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:3rem;
  position:relative;
  z-index:2;
  margin-top:-6vw;
}
@media (max-width:1400px) {.services-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:768px) {.services-grid{grid-template-columns:1fr;gap:2rem;margin-top:0;}}
.service-box {
  position:relative;
  padding:2.5rem;
  border:3px solid #1ca5a5;
  color:#fff;
  transition:all 0.3s ease;
  cursor:default;
  background:rgba(0,101,142,0.1);
}
.service-box::after {
  content:'';
  width:100%;
  height:100%;
  display:block;
  position:absolute;
  border:3px solid white;
  top:-2px;
  left:-2px;
  pointer-events:none;
  transition:all 0.3s ease;
  opacity:0;
}
.service-box:hover {
  background:rgba(0,101,142,0.2);
  border-color:#99ff00;
  transform:translateY(-6px);
}
.service-box:hover::after {
  opacity:1;
  transform:translate(10px,10px);
}
.service-box h3 {
  font-family:"Oswald",sans-serif;
  text-transform:uppercase;
  font-size:1.8rem;
  margin-bottom:1rem;
  color:#99ff00;
}
.service-box p {
  font-family:"Manrope",sans-serif;
  font-weight:300;
  font-size:1rem;
  line-height:1.6;
  color:rgba(255,255,255,0.9);
}
.services-cta {
  margin-top:6rem;
  text-align:center;
}
.services-button {
  display:inline-block;
  font-family:"Oswald",sans-serif;
  text-transform:uppercase;
  font-size:1.4rem;
  padding:1rem 2rem;
  border:3px solid #1ca5a5;
  text-decoration:none;
  color:#1ca5a5;
  transition:all 0.3s ease;
  position:relative;
  z-index:10;
}
.services-button::after {
  content:'';
  width:100%;
  height:100%;
  display:block;
  position:absolute;
  border:3px solid white;
  top:-2px;
  left:-2px;
  pointer-events:none;
  transition:all 0.3s ease;
  opacity:0;
}
.services-button:hover {
  color:white;
  background:#00658e;
}
.services-button:hover::after {
  opacity:1;
  transform:translate(10px,10px);
}
@media (max-width:992px) {
  .services {padding:10vh 6%;}
  .services-inner {padding-top:0;}
  .services-title {position:static;opacity:0.75;margin-bottom:3rem;text-align:left;}
  .services-title h2 {font-size:24vw;margin-bottom:4rem;}
  .service-box {padding:2rem;}
  .services-button {font-size:1.1rem;padding:0.8rem 1.6rem;}
  .services-grid {margin-top:0;}
}
@media (max-width:600px) {
  .service-box h3 {font-size:1.4rem;}
  .service-box p {font-size:0.95rem;}
  .services h2 {-webkit-text-stroke:1.5px #99ff00;}
}
.footer {
  background:#006872;
  color:#fff;
  padding:8vh 10%;
  position:relative;
  overflow:hidden;
}
.footer-inner {
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  flex-wrap:wrap;
  gap:4rem;
  position:relative;
  z-index:1;
}
.footer-logo {
  font-family:"Oswald",sans-serif;
  font-size:2.4rem;
  text-transform:uppercase;
  color:#fff;
  margin-bottom:0.5rem;
}
.footer-logo span {color:#99ff00;}
.footer-desc {
  font-family:"Manrope",sans-serif;
  font-weight:300;
  font-size:1rem;
  line-height:1.5;
  max-width:420px;
  color:rgba(255,255,255,0.9);
}
.footer-links {
  display:flex;
  gap:1rem;
  margin-top:auto;
}
.footer-links a {
  position:relative;
  display:inline-block;
  font-family:"Oswald",sans-serif;
  text-transform:uppercase;
  text-decoration:none;
  color:#99ff00;
  font-size:1vw;
  letter-spacing:0.03em;
  transition:all 0.3s ease;
  overflow:hidden;
}
.footer-links a::after {
  content:attr(data-text);
  position:absolute;
  left:0;
  top:0;
  color:white;
  transform:translate(0,0);
  opacity:0;
  transition:all 0.3s ease;
  pointer-events:none;
}
.footer-links a:hover::after {
  opacity:1;
  transform:translate(3px,3px);
}
.footer-bottom {
  text-align:center;
  margin-top:6vh;
  font-family:"Oswald",sans-serif;
  font-size:0.9rem;
  color:rgba(255,255,255,0.8);
  letter-spacing:0.02em;
}
.footer::after {
  content:'';
  position:absolute;
  bottom:0;
  right:0;
  width:200px;
  height:200px;
  background:radial-gradient(circle at bottom right, rgba(153,255,0,0.25), transparent 70%);
  opacity:0.3;
  z-index:0;
}
@media (max-width:992px) {
  .footer-inner {flex-direction:column;align-items:flex-start;gap:2rem;}
  .footer-links {flex-wrap:wrap;gap:1.5rem;}
  .footer-links a {font-size:1rem;}
  .footer-logo {font-size:2rem;}
}
@media (max-width:600px) {
  .footer {padding:8vh 6%;}
  .footer-desc {font-size:0.95rem;}
  .footer-links {gap:1rem;}
  .footer-bottom {margin-top:4vh;font-size:0.8rem;}
}
