:root {
  --color-primary-dark: #163e3e;
  --color-primary-light: #dae5c1;
  --color-white: #ffffff;
  --color-text-light: #d2d2d2;
  --color-text-dark: #163e3e;
  --font-poppins: 'Poppins', sans-serif;
  --font-libre: 'Libre Baskerville', sans-serif;
  --font-lato: 'Lato', sans-serif;
}

body {
  margin: 0;
  font-family: var(--font-poppins);
  background-color: #f0f0f0;
  color: var(--color-text-dark);
}

.container {
  width: 100%;
  max-width: 1920px;
  margin: 0 auto;
  padding: 0 80px;
  box-sizing: border-box;
  position: relative;
}

section {
  overflow: hidden;
}

@media (max-width: 1200px) {
  .container {
    padding: 0 40px;
  }
}

@media (max-width: 768px) {
  .container {
    padding: 0 20px;
  }
}


#hero {
  background-image: url("images/close-up-hummingbird.jpg");
  background-size: cover;
  background-position: center;
  height: 1134px;
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 5;
  overflow: visible;
}

.hero-container {
  max-width: 1920px;
  margin: 0 auto;
  width: 100%;
  padding: 0 80px;
  box-sizing: border-box;
  position: relative;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  z-index: 10;       /* establishes a stacking context */
  overflow: visible; /* allows elements to show outside */
}

.hero-header {
  position: relative;      /* relative to hero section */
  width: 417px;            /* keep your logo width */
  margin: 0 auto;          /* centers horizontally */
  padding-top: 105px;      /* distance from top of hero section */
  text-align: center;      /* ensures contents inside are centered if needed */
}

.logo {
  width: 100%;
  height: auto;
  display: block;          /* removes extra inline spacing */
  margin: 0 auto;          /* just in case */
  margin-top: -50px;
}


.hero-content {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 50px;
  margin-top: 229px;
  flex-wrap: nowrap; /* keep all in one line */
}

.feature-card {
  width: 410px;
  height: 410px;
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 40px;
  box-sizing: border-box;
}

.feature-card h3 {
  font-family: var(--font-poppins);
  font-weight: 700;
  font-size: 40px;
  margin: 0 0 15px 0;
}

.feature-card p {
  margin: 0;
  font-family: var(--font-poppins);
  font-weight: 400;
  font-size: 24px;
}

.design-card {
  background-color: rgba(218, 229, 193, 0.1); /* Approximated from visual */
  border: 5px solid var(--color-primary-dark);
  color: var(--color-primary-dark);
  line-height: 50px;
}

.software-card {
  background-color: var(--color-primary-dark);
  color: var(--color-primary-light);
  line-height: 55px;
}

.marketing-card {
  position: relative; /* activates z-index */
  background-color: rgba(218, 229, 193, 0.1);
  border: 5px solid var(--color-primary-dark);
  color: var(--color-primary-dark);
  line-height: 50px;
  z-index: 50;
}


@media (max-width: 1200px) {
  .hero-content {
    flex-wrap: wrap;
    gap: 100px;
    margin-top: 150px;
  }
}

@media (max-width: 1400px) {
  .hero-content {
    gap: 40px;
    transform: scale(0.9);
  }
  .hero-header {
    margin-left: auto;
    margin-right: auto;
    padding-top: 50px;
  }
}

@media (max-width: 1200px) {
  #hero {
    height: auto;
    padding-bottom: 100px;
  }
  .hero-content {
    flex-direction: column;
    gap: 30px;
    margin-top: 50px;
    transform: scale(1);
  }
  .feature-card {
    width: 350px;
    height: 350px;
  }
}

@media (max-width: 768px) {
  .hero-header {
    padding-top: 30px;
    width: 250px;
  }
  .feature-card {
    width: 300px;
    height: 300px;
  }
  .feature-card h3 {
    font-size: 32px;
  }
  .feature-card p {
    font-size: 18px;
    line-height: 1.5;
  }
}



#software-development {
  background-color: var(--color-primary-dark);
  padding: 109px 0; /* 1132 - 1023 = 109 */
}

.dev-content {
  display: flex;
  gap: 57px; /* 16281 - (15783 + 430) = 68, adjusted for icons */
  align-items: flex-start;
}

.dev-services {
  flex: 0 0 556px; /* Max width of title */
}

.dev-title {
  font-family: var(--font-libre);
  font-weight: 700;
  font-size: 64px;
  line-height: 76px;
  color: var(--color-primary-light);
  margin: 0 0 103px 0; /* 1420 - (1218+93) = 109 */
}

.services-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.services-list li {
  display: flex;
  align-items: center;
  gap: 25px;
  margin-bottom: 36px; /* Approx spacing */
}

.services-list img {
  width: 70px;
  height: 70px;
}

.services-list span {
  font-family: var(--font-poppins);
  font-weight: 600;
  font-size: 36px;
  color: var(--color-primary-light);
}

.dev-showcase {
  flex: 1;
  position: relative;
  height: 700px; /* Approximate height to contain elements */
}

.text-card {
  position: absolute;
  top: 50px; /* 1270 - 1220 */
  left: 0;
  width: 933px;
  height: 547px;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.4) 17.67%, rgba(255, 255, 255, 0.4) 100%), var(--color-primary-light);
  border-radius: 20px;
  padding: 69px 62px;
  box-sizing: border-box;
  z-index: 0;
}

.text-card h3 {
  font-family: var(--font-poppins);
  font-weight: 400;
  font-size: 48px;
  line-height: 51px;
  color: var(--color-white);
  margin: 0 0 19px 0;
  width: 50%;
}

.text-card p {
  font-family: var(--font-poppins);
  font-weight: 400;
  font-size: 21px;
  line-height: 30px;
  color: #d0d0d0;
  margin: 0;
  max-width: 400px;
  width: 75%;
}

.image-group {
  position: absolute;
  top: 0;
  left: 507px; /* 16788 - 16281 */
  width: 50%;
  height: 50%;
  z-index: 1;
  border-radius: 20px;
  box-shadow: -2px 13px 9px 11px rgba(0, 0, 0, 0.25);
}

.image-group .main-img, .image-group .overlay-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 20px;
  object-fit: fill;
  z-index: 40;
}

.floating-img {
  position: absolute;
  top: -81px; /* 1139 - 1220 */
  left: 850px; /* 17198 - 16281 */
  width: 369px;
  height: 293px;
  border-radius: 20px;
  z-index: 50;
}

@media (max-width: 1600px) {
  .dev-content { flex-direction: column; align-items: center; gap: 60px; }
  .dev-services { text-align: center; }
  .dev-showcase { position: static; height: auto; width: 100%; display: flex; flex-direction: column; align-items: center; }
  .text-card { position: static; width: 90%; max-width: 933px; height: auto; }
  .image-group { position: static; margin-top: -100px; z-index: -1; width: 80%; max-width: 738px; }
  .floating-img { display: none; }
}

@media (max-width: 768px) {
  #software-development { padding: 60px 0; }
  .dev-title { font-size: 48px; line-height: 1.2; margin-bottom: 60px; }
  .services-list li { gap: 15px; margin-bottom: 20px; }
  .services-list img { width: 50px; height: 50px; }
  .services-list span { font-size: 24px; }
  .text-card { padding: 40px; }
  .text-card h3 { font-size: 32px; line-height: 1.2; }
  .text-card p { font-size: 18px; line-height: 1.5; }
}



#discover-go {
  background-color: var(--color-primary-light);
  padding: 40px 0 100px 0;
}

.discover-title {
  font-family: var(--font-poppins);
  font-weight: 700;
  font-size: 96px;
  color: var(--color-text-dark);
  text-align: center;
  margin: 0 0 40px 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}

.go-logo-title {
  width: 211px;
  height: 211px;
}

.discover-content {
  display: flex;
  align-items: center;
  gap: 60px;
}

.discover-text {
  flex: 1;
}

.discover-text p {
  font-family: var(--font-poppins);
  font-weight: 400;
  font-size: 40px;
  line-height: 60px;
  color: var(--color-text-dark);
  margin: 0;
}

.go-logo-text {
  width: 101px;
  height: 101px;
  vertical-align: middle;
  margin-right: 10px;
}

.discover-illustration {
  flex: 1;
  max-width: 750px;
}

.illustration-container {
  position: relative;
  width: 750px;
  height: 500px;
  background-color: rgba(22, 62, 62, 0.3);
  border-radius: 20px;
}

.discover-cta {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin-top: -50px; /* Overlap with text above */
}

.cta-text {
  font-family: var(--font-poppins);
  font-weight: 400;
  font-size: 96px;
  line-height: 1.2;
  color: var(--color-text-dark);
  margin: 0;
  display: inline-block;
  position: relative;
}

.cta-text span {
  display: block;
  text-align: right;
}


.go-logo-cta {
  width: 267px;
  height: 267px;
  margin-left: 54px; /* 16092 - (15751 + 559) */
  margin-top: 120px;
}

@media (max-width: 1400px) {
  .discover-content { flex-direction: column; }
  .discover-text { text-align: center; }
  .discover-cta { justify-content: center; }
}

@media (max-width: 992px) {
  .discover-title { font-size: 64px; }
  .go-logo-title { width: 150px; height: 150px; margin-top: -30px; }
  .discover-text p { font-size: 28px; line-height: 1.5; }
  .go-logo-text { width: 70px; height: 70px; margin-top: -10px; }
  .illustration-container { transform: scale(0.8); margin: -50px auto; }
  .cta-text { font-size: 64px; }
  .go-logo-cta { width: 180px; height: 180px; margin-left: -150px; margin-top: -70px; }
}

@media (max-width: 768px) {
  .discover-title { font-size: 48px; flex-direction: column; gap: 0; }
  .go-logo-title { width: 100px; height: 100px; margin-top: 0; }
  .discover-text p { font-size: 22px; }
  .illustration-container { transform: scale(0.6); margin: -100px auto; }
  .cta-text { font-size: 48px; }
  .go-logo-cta { width: 120px; height: 120px; margin-left: -100px; margin-top: -50px; }
}



#services-grid {
  position: relative;
  padding: 0 0 100px 0;
  background-image: url('images/Rectangle\ 1405.png'), linear-gradient(to right, #c4c4c4 50%, #dae5c1 50%);
  background-size: cover, 100% 100%;
  background-position: center, center;
  background-blend-mode: overlay; /* This is an approximation */
}
#services-grid::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 307px;
  background-image: url('images/arkafoto.png');
  background-size: cover;
}

.services-grid-header {
  display: flex;
  justify-content: space-around;
  align-items: center;
  padding: 95px 0;
  position: relative;
  z-index: 1;
}

.services-grid-header h2 {
  font-family: var(--font-poppins);
  font-weight: 700;
  font-size: 64px;
  line-height: 76px;
  color: var(--color-primary-light);
  text-align: center;
  margin: 0;
  flex-basis: 480px;
}

.services-grid-content {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: start;
  gap: 80px;
  position: relative;
}

.grid-column {
  display: flex;
  flex-direction: column;
  gap: 110px; /* Approx (3465-3255) - 110 */
}

.grid-item {
  display: flex;
  align-items: center;
  gap: 50px;
}

.grid-item img {
  width: 110px;
  height: 110px;
  flex-shrink: 0;
}

.grid-item p {
  font-family: var(--font-poppins);
  font-weight: 700;
  font-size: 40px;
  line-height: 1.2;
  margin: 0;
}
.grid-column:nth-child(1) .grid-item p {
  color: var(--color-primary-light);
}
.grid-column:nth-child(3) .grid-item p {
  color: var(--color-text-dark);
}

.grid-divider {
  width: 5px;
  background-color: var(--color-primary-light);
  align-self: stretch;
  position: relative;
}

.divider-bird {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 142px;
  height: 156px;
}

@media (max-width: 1200px) {
  .services-grid-content {
    grid-template-columns: 1fr;
    gap: 60px;
  }
  .grid-divider { display: none; }
  .services-grid-header { flex-direction: column; gap: 20px; padding: 60px 0; }
  .grid-column { gap: 60px; }
  .grid-item { flex-direction: column; text-align: center; gap: 20px; }
  .grid-item p { font-size: 28px; }
  .grid-column:nth-child(3) .grid-item p { color: var(--color-primary-light); }
  #services-grid { background-image: url('${ASSET_PATH}/009676a85f12c996eddb80c77577cff9b6bfc5da.png'), #c4c4c4; }
}

@media (max-width: 768px) {
  .services-grid-header h2 { font-size: 48px; line-height: 1.2; }
  .grid-item p { font-size: 24px; }
}



#footer {
  background-color: var(--color-primary-dark);
  padding: 47px 0 30px 0;
  color: var(--color-white);
}

.footer-container {
  display: flex;
  justify-content: space-between;
  gap: 60px;
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}

.footer-brand {
  flex: 0 0 530px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.footer-logo {
  width: 530px;
  height: 118px;
  object-fit: contain;
  align-self: flex-start;
}

.footer-slogan {
  font-family: var(--font-lato);
  font-weight: 700;
  font-size: 18px;
  line-height: 20px;
  text-align: right;
  margin: 0;
  padding-right: 115px; /* Approximation */
}

.footer-links {
  display: flex;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px; /* For the borders */
  flex-grow: 1;
}

.links-column {
  padding: 0 20px;
  background-color: var(--color-primary-dark);
}

.links-column h4 {
  font-family: var(--font-lato);
  font-weight: 400;
  font-size: 26px;
  margin: 0 0 10px 0;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}

.links-column ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.links-column li {
  margin-bottom: 10px;
}

.links-column a {
  font-family: var(--font-lato);
  font-weight: 400;
  font-size: 18px;
  color: var(--color-white);
  text-decoration: none;
}
.links-column a:hover {
  text-decoration: underline;
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 20px;
}

.copyright, .legal-links a {
  font-family: var(--font-lato);
  font-size: 18px;
  color: var(--color-text-light);
  text-decoration: none;
}

.social-icons {
  display: flex;
  gap: 42px;
}

.legal-links {
  display: flex;
  gap: 46px;
}

@media (max-width: 1600px) {
  .footer-container { flex-direction: column; }
  .footer-brand { flex-basis: auto; align-items: center; text-align: center; }
  .footer-logo { width: 400px; }
  .footer-slogan { text-align: center; padding: 20px 0 0 0; }
}

@media (max-width: 992px) {
  .footer-links { grid-template-columns: repeat(2, 1fr); }
  .footer-bottom { flex-direction: column; gap: 20px; }
}

@media (max-width: 768px) {
  .footer-links { grid-template-columns: 1fr; }
  .footer-logo { width: 300px; }
  .social-icons { gap: 20px; }
  .legal-links { flex-direction: column; gap: 10px; align-items: center; }

}






