/* ============================================
   Renewal PC-Specific Styles
   ============================================ */

/* PC Navigation Menu */
.topbar .nav-menu,
.site-topbar .nav-menu {
    list-style: none;
    margin: 0;
    padding: 0;
}

.topbar .nav-menu li,
.site-topbar .nav-menu li {
    display: inline-block;
    margin-left: 18px;
}

.topbar .nav-menu a,
.site-topbar .nav-menu a {
    color: #3b5175;
    padding: 12px 0;
    display: inline-block;
    font-size: 13px;
    text-decoration: none;
}

.topbar .nav-menu a:hover,
.site-topbar .nav-menu a:hover {
    color: #2f73ff;
    text-decoration: none;
}

.topbar .container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.topbar .nav-menu.pull-right {
    float: none;
}

.topbar .nav-menu {
    margin-left: auto;
}

/* Mission Lead - PC specific background */
.mission-lead.pc-bg,
.lead-intro.pc-bg {
    background: #f6f9ff;
}

/* Company Section - PC with side images */
.company .side-img {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    height: 100%;
    max-height: 520px;
    z-index: 0;
}

.company .side-img.left {
    left: 0;
}

.company .side-img.right {
    right: 0;
}

.company .sec-header,
.company .desc,
.company .more-link {
    position: relative;
    z-index: 1;
}

/* What We Do - PC specific */
.wwd {
    background: #e9f1ff;
}

.wwd .sec-header {
    text-align: left;
}

/* Column Section - PC specific */
.column .sec-header {
    text-align: left;
}

/* Contact Section - PC specific background */
.contact.pc-bg {
    background: #e9f1ff;
}

/* Office Grid - PC specific */
.office__grid .col-sm-6 {
    margin-bottom: 16px;
}

/* Container Widths - PC responsive */
@media (min-width: 1200px) {
    .container {
        width: 1170px;
    }
}

@media (min-width: 1400px) {
    .container {
        width: 1400px;
        margin: 0 auto;
    }
}

/* Responsive adjustments */
@media (max-width: 991px) {
    .hero {
        padding: 12px 0 6px;
    }
    
    .company .side-img {
        display: none;
    }
}

/* Full-height layout for contact page (PC) */
html,
body {
    height: 100%;
}

body.contact-page {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

body.contact-page .section.contact {
    flex: 1 0 auto;
}

body.contact-page .site-footer {
    margin-top: auto;
}
