/* ==========================================================
   BASE / GLOBAL
========================================================== */
body {
  background-color: #fff;
}

#main {
  background-color: #fff;
  padding-top: 0;
  margin-top: 0;
}

#header .nav-header-text {
  font-size: 1.2rem;
}

/* ==========================================================
   BANNER
========================================================== */
#banner {
  margin-top: -4rem;
}

.homeland-banner {
  position: relative;
  width: 100%;
  height: 75vh;
  background: url("../../images/mobile_command.jpg") center / cover no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.banner-overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.55);
  z-index: 1;
}

.banner-content {
  z-index: 1;
  color: #fff;
  padding: 20px;
  margin: auto;
  text-shadow: 2px 2px 4px rgba(0,0,0,.5);
}

.homeland-banner h2 {
  font-family: "Oswald", sans-serif;
  font-weight: 600;
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: 1.2;
  margin-bottom: 1rem;
}

.subtitle strong {
  font-size: clamp(.9rem, 1.6vw, 1.5rem);
  font-weight: 550;
  color: #fff;
}

/* ==========================================================
   BANNER BUTTONS
========================================================== */
.banner-btns-section {
  padding: 0;
}

.banner-btns {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5rem;
  background-color: #1F2A44;
  padding: 2rem;
  margin: 0 auto;
}

.banner-button {
  color: #fff;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  font-size: 1rem;
  font-weight: 900;
  transition: transform .2s ease, color .2s ease;
  border: none;
  text-align: center;
}

.banner-button i {
  font-size: 3rem;
}

.banner-button:hover {
  transform: translateY(-5px);
  color: #78B1DC;
}

/* ==========================================================
   LAYOUT / CONTENT
========================================================== */
.homeland-layout {
  padding-top: 3rem;
}

.homeland-layout a {
  color: #36608d;
}

.homeland-content {
  padding: 1rem;
  width: 100%;
}

.homeland-content b,
.homeland-content strong {
  color: #000 !important;
}

.content-card,
.content-section {
  margin: 1rem auto;
  padding: 2rem 2.25rem;
  background: #fff;
  color: #000;
  border-radius: .75rem;
}

.content-card {
  width: 75%;
  border: 1px solid rgba(0,0,0,.15);
  box-shadow: 0 4px 10px rgba(0,0,0,.15);
}

.content-section {
  width: 80%;
}

.list-section {
  width: 66%;
  text-align: center;
}

/* ==========================================================
   SECTION TITLES
========================================================== */
.section-title {
  font-family: "Oswald", sans-serif;
  text-transform: uppercase;
  border-bottom: 2px solid #2E5A88;
  padding-bottom: .5rem;
  margin: 0 auto 1.5rem auto;
  font-size: clamp(1.4rem, 2.2vw, 2rem);
  color: #1F2A44 !important;
  display: flex;
  justify-content: center;
  gap: .5rem;
  text-align: center;
}

.section-subtitle {
  font-family: "Oswald", sans-serif;
  margin: 2rem auto .5rem auto;
  font-size: clamp(1rem, 1.4vw, 1.2rem);
  color: #1F2A44 !important;
}

/* ==========================================================
   LISTS
========================================================== */
.icon-list {
  list-style: none;
  padding-left: 0;
}

.icon-list li {
  display: flex;
  align-items: flex-start;
  margin-bottom: .75rem;
  font-size: 1.05rem;
}

.icon-list li i {
  margin-right: .65rem;
  font-size: 1.25rem;
  color: #36608d;
}

.icon-list li a {
  color: #36608d !important;
}

.icon-list a:hover {
  color: #1e354e;
}

.custom-list {
  width: 40%;
  margin: auto;
}

.custom-list li {
  display: flex;
  gap: .5rem;
  font-size: 1.15rem;
}

/* ==========================================================
   TYPOGRAPHY
========================================================== */
.content-card p {
  font-size: clamp(1rem, 1.2vw, 1.2rem);
}

p strong,
p b {
  color: #000;
}

/* ==========================================================
   CONTACT CARDS
========================================================== */
.content-section .contact-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
  margin-top: 2rem;
}

.content-section .contact-cards .contact-card {
  background: #fff;
  border-radius: 12px;
  padding: 1.5rem;
  text-align: center;
  box-shadow: 0 4px 10px rgba(0,0,0,.1);
  transition: transform .2s ease, box-shadow .2s ease;
}

.content-section .contact-cards .contact-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 6px 14px rgba(0,0,0,.12);
}

.content-section .contact-cards .contact-card h3 {
  font-size: 1.25rem;
  margin-bottom: 2rem;
  color: #002147;
}

.content-section .contact-cards .contact-card em {
  display: block;
  font-size: 1.15rem;
  margin-bottom: .75rem;
}

.content-section .contact-cards .contact-card p {
  font-size: .95rem;
}

.content-section .contact-cards .contact-card a {
  color: #00529b;
  text-decoration: none;
}

.content-section .contact-cards .contact-card a:hover {
  text-decoration: underline;
}

.content-section .contact-cards .contact-card .phone-num {
  color: #555;
}

/* ==========================================================
   FOOTER
========================================================== */
#footer .copyright {
  color: #303030;
}

/* ==========================================================
   RESPONSIVE
========================================================== */
@media (max-width: 1100px) {
  .banner-btns {
    gap: 3rem;
  }
}

@media (max-width: 1024px) {
  .content-section .contact-cards {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  }
}

@media (max-width: 900px) {
  .banner-btns {
    flex-wrap: wrap;
    gap: 2rem;
  }

  .banner-button {
    width: 10rem;
  }
}

@media (max-width: 768px) {
  .homeland-banner {
    height: 60vh;
  }

  .banner-btns {
    gap: 1.5rem;
  }

  .banner-button {
    font-size: 1.25rem;
    width: 12rem;
    height: 12rem;
    border: 2px solid #2E5A88;
    padding: 1rem;
    border-radius: .5rem;
    box-shadow: 2px 2px 4px rgba(0,0,0,.5);
  }

  .banner-button i {
    font-size: 5rem;
  }

  .content-card,
  .content-section {
    width: 90%;
    padding: 1.25rem;
  }

  .section-title {
    flex-direction: column;
  }

  body {
    font-size: .95rem;
    line-height: 1.5;
  }

  #header .nav-header-text {
    font-size: .9rem;
  }
}

@media (max-width: 640px) {
  .custom-list {
    width: 100%;
  }

  .custom-list li {
    font-size: 1rem;
    justify-content: center;
  }

  .icon-list li {
    font-size: .95rem;
  }

  .content-section .contact-cards {
    grid-template-columns: 1fr;
  }

  .content-section .contact-cards .contact-card {
    padding: 1.75rem 1.25rem;
  }
}

@media (max-width: 560px) {
  .banner-button {
    width: 30%;
    height: auto;
    font-size: .9rem;
  }

  .banner-button i {
    font-size: 2rem;
  }
}

@media (max-width: 480px) {
  .banner-content {
    padding: 1.25rem;
  }

  .content-card,
  .content-section {
    padding: 1.25rem 1rem;
  }

  .banner-button {
    min-height: 9rem;
  }
}

/* ==========================================================
   RESPONSIVE ENHANCEMENTS (ADD AFTER EXISTING CSS)
========================================================== */

/* ---------- Large Screens (≥1400px) ---------- */
@media (min-width: 1400px) {
  .content-card {
    width: 70%;
  }

  .content-section {
    width: 75%;
  }

  .list-section {
    width: 60%;
  }

  .homeland-banner {
    height: 80vh;
  }
}

/* ---------- Tablets (≤1024px) ---------- */
@media (max-width: 1024px) {
  .list-section {
    width: 85%;
  }

  .custom-list {
    width: 60%;
  }

  .banner-content {
    max-width: 90%;
  }
}

/* ---------- Small Tablets / Large Phones (≤768px) ---------- */
@media (max-width: 768px) {
  #banner {
    margin-top: -2rem;
  }

  .banner-content h2 {
    line-height: 1.15;
  }

  .banner-btns {
    padding: 1.5rem 1rem;
  }

  .banner-button {
    text-align: center;
  }

  .content-card p,
  .content-section p {
    font-size: 1rem;
  }

  .icon-list li {
    align-items: flex-start;
  }
}

/* ---------- Phones (≤600px) ---------- */
@media (max-width: 600px) {
  .homeland-banner {
    height: 55vh;
  }

  .banner-content {
    max-width: 100%;
  }

  .banner-btns {
    flex-direction: column;
  }

  .banner-button {
    width: 100%;
    max-width: 260px;
  }

  .section-title {
    font-size: 1.35rem;
  }

  .section-subtitle {
    font-size: 1rem;
  }

  .content-card,
  .content-section {
    width: 95%;
  }
}

/* ---------- Small Phones (≤400px) ---------- */
@media (max-width: 400px) {
  body {
    font-size: 0.9rem;
  }

  .banner-button {
    min-height: 7.5rem;
    padding: 0.75rem;
  }

  .banner-button i {
    font-size: 1.75rem;
  }

  .section-title {
    font-size: 1.25rem;
  }

  .icon-list li i {
    font-size: 1.1rem;
  }
}
