/* GENERAL RESET */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    background: #000;
    color: #fff;
    font-family: Helvetica, Arial, sans-serif;
}

/* NAVIGATION */
.nav {
    width: 100%;
    padding: 25px 50px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.logo img {
    width: 150px; /* perfect logo size */
}
/* ============================= */
/* ABOUT PAGE HEADER FIX */
/* ============================= */

.site-header {
    width: 100%;
    padding: 25px 50px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.main-nav {
    display: flex;
    gap: 40px;
}

.main-nav a {
    color: #fff;
    text-decoration: none;
    font-size: 16px;
    letter-spacing: 0.5px;
    transition: opacity 0.2s ease;
}

.main-nav a:hover {
    opacity: 0.7;
}

/* MENU */
nav ul {
    list-style: none;
    display: flex;
    gap: 40px;
}

nav a {
    color: #fff;
    text-decoration: none;
    font-size: 16px;
    letter-spacing: 0.5px;
    transition: opacity 0.2s ease;
}

nav a:hover {
    opacity: 0.7;
}

/* HERO SECTION */
.hero {
    text-align: center;
    max-width: 700px;
    margin: 100px auto 0 auto;
    padding: 0 20px;
}

.hero h1 {
    font-size: 52px;
    font-weight: 600;
    margin-bottom: 20px;
    color: #0055A5; /* brand blue headline */
}

.hero p {
    font-size: 20px;
    line-height: 1.6;
    margin-bottom: 50px;
    color: #cccccc;
}

/* CTA BUTTON */
.cta-btn {
    display: inline-block;
    padding: 14px 32px;
    border: 2px solid #0055A5;
    color: #0055A5;
    text-decoration: none;
    font-size: 16px;
    letter-spacing: 0.7px;
    border-radius: 4px;
    transition: all 0.3s ease;
}

/* ————————————————————————————————
   GENERAL RESET
——————————————————————————————— */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    background: #000;
    color: #fff;
    font-family: Helvetica, Arial, sans-serif;
}



/* ————————————————————————————————
   NAVIGATION — (UNIVERSAL)
——————————————————————————————— */
.navbar {
    width: 100%;
    padding: 25px 50px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.logo img {
    width: 110px; /* consistent across all pages */
}

nav ul {
    list-style: none;
    display: flex;
    gap: 40px;
}

nav a {
    color: #fff;
    text-decoration: none;
    font-size: 16px;
    letter-spacing: 0.5px;
    transition: opacity 0.25s ease;
}

nav a:hover {
    opacity: 0.7;
}



/* ————————————————————————————————
   UNIVERSAL SUBPAGE WRAPPER
——————————————————————————————— */
.page-container {
    max-width: 1200px;
    margin: 120px auto 80px; /* spacing under navbar + bottom breathing room */
    padding: 0 20px;
}



/* ————————————————————————————————
   HEADERS (H1 styling for all subpages)
——————————————————————————————— */
.page-container h1,
.page-hero h1 {
    font-size: 42px;
    font-weight: 600;
    margin-bottom: 20px;
    color: #0055A5;   /* brand blue */
    text-align: center;
}



/* ————————————————————————————————
   ABOUT PAGE
——————————————————————————————— */
.about-container {
  max-width: 900px;
  margin: 0 auto;
  padding: 6rem 2rem;
}

.about-container h1 {
  text-align: center;
  font-size: 3rem;
  margin-bottom: 4rem;
}

.about-container h2 {
  color: #4ea8ff;
  margin-top: 4rem;
  margin-bottom: 1.5rem;
}

.about-container p {
  line-height: 1.75;
  margin-bottom: 1.8rem;
  opacity: 0.9;
}

.about-container ul {
  margin-top: 1.5rem;
  padding-left: 1.2rem;
}

.about-container li {
  margin-bottom: 0.8rem;
  line-height: 1.6;
}


/* ————————————————————————————————
   SOLUTIONS PAGE
——————————————————————————————— */
/* Solutions layout */
.page-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 6rem 2rem;
}

.page-title {
  text-align: center;
  font-size: 3rem;
  margin-bottom: 4rem;
}

/* Section spacing */
.section {
  margin-bottom: 6rem;
}

/* Core & Add-on headers */
.core-title,
.addon-title {
  font-size: 2.2rem;
  margin-bottom: 1rem;
}

.core-title {
  color: #4ea8ff; /* Primary blue – Core Systems */
}

.addon-title {
  color: #7fbfff; /* Lighter blue – Add-ons */
}

.section > p {
  max-width: 700px;
  margin-bottom: 3rem;
  line-height: 1.6;
  opacity: 0.85;
}
/* Solutions list alignment fix */
.solution-block ul {
  list-style-position: inside;
  padding-left: 0;
  margin: 20px auto;
  max-width: 600px;
  text-align: left;
}

.solution-block li {
  margin-bottom: 8px;
  line-height: 1.6;
}

/* Individual solution blocks */
.solution-block {
  margin-bottom: 3rem;
}

.solution-block h3 {
  font-size: 1.4rem;
  margin-bottom: 0.5rem;
}

.solution-block p {
  max-width: 600px;
  line-height: 1.6;
  opacity: 0.85;
}
.solution-block {
  margin: 50px auto;
  max-width: 800px;
}

.solution-block h3 {
  margin-bottom: 10px;
}

.solution-block h4 {
  margin-top: 20px;
  font-size: 16px;
  letter-spacing: 0.04em;
  opacity: 0.8;
}


/* ————————————————————————————————
   CONTACT PAGE
——————————————————————————————— */

/* Page intro */
.page-hero {
    text-align: center;
    margin-top: 120px;
    margin-bottom: 40px;
    padding: 0 20px;
}

.page-hero p {
    font-size: 20px;
    line-height: 1.7;
    color: #cccccc;
    max-width: 700px;
    margin: 0 auto;
}

/* Contact form container */
.contact-container {
    max-width: 700px;
    margin: 40px auto 80px;
    padding: 0 20px;
    font-size: 18px;
    line-height: 1.7;
}

.contact-container h2 {
    text-align: center;
    margin-bottom: 15px;
}

.contact-subtext {
    text-align: center;
    font-size: 17px;
    color: #cccccc;
    margin-bottom: 30px;
}

/* Form styling */
.contact-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.contact-form label {
    font-weight: 500;
}

.contact-form input,
.contact-form textarea {
    width: 100%;
    padding: 12px 15px;
    font-size: 16px;
    border-radius: 6px;
    border: 1px solid #444;
    background: #111;
    color: gray;
}

.contact-form textarea {
    min-height: 140px;
    resize: vertical;
}

/* Button */
.contact-form button {
    border: none;
    padding: 14px 20px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    border-radius: 6px;
    background-color: #0055A5;
    color: gray;
    transition: opacity 0.25s ease;
}

.contact-form button:hover {
    opacity: 0.85;
}

/* Footer note */
.direct-email {
    text-align: center;
    margin-top: 30px;
    font-size: 16px;
}

.direct-email a {
    color: #3FA9F5;
    text-decoration: underline;
}
/* =========================
   CONTACT – subtle overrides
   (added last on purpose)
========================= */

.contact-form input,
.contact-form textarea {
    background-color: #1a1a1a; /* softer gray */
    color: #cccccc;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
    color: rgba(255, 255, 255, 0.45);
}

/* ========== GLOBAL SUBPAGE SYSTEM ========== */

.site-header {
    width: 100%;
    padding: 40px 60px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.site-header .logo img {
    width: 130px; /* balanced for subpages */
}

.main-nav {
    display: flex;
    gap: 36px;
}

.main-nav a {
    color: #fff;
    text-decoration: none;
    font-size: 15px;
    letter-spacing: 0.5px;
    opacity: 0.9;
}

.main-nav a:hover {
    opacity: 1;
}

/* Wrapper that fixes alignment + spacing */
.page-container {
    max-width: 980px;
    margin: 120px auto 140px;
    padding: 0 24px;
}

/* Page titles */
.page-title {
    text-align: center;
    font-size: 42px;
    font-weight: 600;
    margin-bottom: 60px;
    color: #0055A5;
}

/* Body text rhythm */
.page-container p {
    font-size: 18px;
    line-height: 1.8;
    margin-bottom: 32px;
    color: #d4d4d4;
}

/* Lists */
.page-container ul {
    margin: 20px 0 40px 20px;
}

.page-container li {
    margin-bottom: 10px;
}

/* Section spacing */
.section {
    margin-bottom: 120px;
}
/* Normalize logo size across pages */
.logo img {
    width: auto;
    max-width: 56px;
    height: auto;
}
/* ============================= */
/* SOLUTIONS PAGE FIXES */
/* ============================= */

.page-container h2 {
    font-size: 28px;
    margin: 60px 0 20px;
    color: #ffffff;
}

.page-container h3 {
    font-size: 22px;
    margin: 40px 0 10px;
    color: #ffffff;
}

.page-container h4 {
    font-size: 16px;
    margin: 20px 0 10px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #aaaaaa;
}

.solution-block {
    margin-bottom: 60px;
}

.solution-block ul {
    margin-top: 10px;
    padding-left: 20px;
}

.solution-block li {
    margin-bottom: 8px;
    line-height: 1.6;
}
.cta-section {
    margin: 80px auto;
    text-align: center;
}

.cta-section .cta-button {
    display: inline-block;
    margin-top: 20px;
    padding: 14px 28px;
    background-color: #0055A5;
    color: #ffffff;
    text-decoration: none;
    font-weight: 600;
    border-radius: 6px;
}
/* ============================= */
/* SUBPAGE CONTENT ALIGNMENT */
/* (About & Solutions) */
/* ============================= */

.page-container {
    max-width: 900px;
    margin: 0 auto;
    padding: 120px 20px 80px;
    text-align: center;
}

/* Paragraph rhythm */
.page-container p {
    margin-bottom: 28px;
    line-height: 1.8;
    color: #e0e0e0;
}

/* Section spacing */
.section {
    margin-bottom: 80px;
}

/* Lists: readable but centered as a block */
.section ul {
    list-style: disc;
    margin: 30px auto;
    padding-left: 20px;
    max-width: 600px;
    text-align: left;
}

/* Section headers */
.page-title {
    margin-bottom: 60px;
}
/* ============================= */
/* CENTERED READING COLUMN */
/* ============================= */

.section {
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* Constrain text width */
.section p,
.section ul {
    max-width: 720px;
}

/* Paragraphs visually centered */
.section p {
    text-align: center;
}

/* Lists remain readable */
.section ul {
    text-align: left;
    padding-left: 20px;
}
/* CONTACT FORM – FINAL OVERRIDES */
.contact-form input,
.contact-form textarea {
    background-color: #111;   /* dark gray, not pure black */
    border: 1px solid #333;
    color: #ccc;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
    color: #666;
}
.contact-form textarea {
    min-height: 110px;
    resize: vertical;
}
/* === CONTACT PAGE FINAL FIX === */

.contact-form input,
.contact-form textarea {
    background-color: #111;
    border: 1px solid #333;
    color: #ccc;
}

.contact-form input:focus,
.contact-form textarea:focus {
    outline: none;
    border-color: #0055A5;
}

/* Textarea sizing fix */
.contact-form textarea {
    min-height: 110px;
}

/* Button fix */
.contact-form button {
    background-color: #0055A5;
    color: #ffffff;
    border: none;
}

.contact-form button:hover {
    opacity: 0.9;
}
/* =========================
   MOBILE LAYOUT — SAFE FIX
   ========================= */
@media (max-width: 768px) {

    /* Header stays horizontal */
    header,
    .nav,
    .site-header,
    .navbar {
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        padding: 16px 20px;
    }

    /* Logo scaling */
    .logo img {
        width: 90px;
    }

    /* Navigation stays horizontal */
    nav ul,
    .main-nav,
    .nav-links {
        display: flex;
        flex-direction: row;
        gap: 16px;
        align-items: center;
    }

    nav a {
        font-size: 14px;
    }

    /* Page spacing */
    .page-container {
        padding: 0 16px;
    }

    /* Center text WITHOUT breaking lists */
    .page-title,
    h2,
    .section > p {
        text-align: center;
    }

    /* Lists stay readable */
    .section ul {
        max-width: 500px;
        margin: 0 auto 30px;
        text-align: left;
    }
}
