:root{
  --brand-navy:#002147;
  --brand-orange:#ff7800;
  --text:#002147;
  --bg:#ffffff;
}

body{
  font-family:"Inter",sans-serif;
  color:var(--text);
  font-size:20px;
}

h2{
  font-size:28px;
  font-weight:900;
  margin:0 0 16px;
}

p{
  font-size:18px;
  line-height:28px;
  font-weight:300;
  margin:0 0 10px;
}

/* Lists */
ul{
  padding-left:20px;
  margin:0 0 10px;
}
ul li{
  font-size:18px;
  line-height:28px;
  font-weight:300;
  list-style:disc;
}

/* Links */
a:hover{
  text-decoration:none;
  color:var(--brand-orange);
}

::selection{
  color:#fff;
  background:var(--brand-orange);
}

.section-heading{
  margin-bottom:65px;
}

.title{
  font-size:30px;
  line-height:1.1;
  font-weight:300;
  margin-bottom:20px;
}

/* Navbar */
.navbar.navbar-default{
  border:0;
  border-radius:0;
  margin-bottom:0;
}
.navbar-default .navbar-nav li a:hover{
  color:var(--brand-orange);
}
.navbar.navbar-default .navbar-toggle{
  margin-top:32px;
}
.navbar-header .navbar-brand{
  padding:0;
}
.navbar-header .navbar-brand img{
  max-width:150px;
  max-height:50px;
  object-fit:contain;
}

#top-bar{
  background:var(--bg);
  transition:all .2s ease-out 0s;
  padding:15px 0;
  box-shadow:0 0 3px 0 rgba(0,0,0,.1);
  border-bottom:1px solid #ededed;
}
#top-bar .navbar-nav li a:hover{
  background:transparent;
}
#top-bar.animated-header{
  padding:20px 0;
  background:var(--bg);
  box-shadow:none;
}
#top-bar .main-menu li{
  position:relative;
}
#top-bar .main-menu li a{
  color:var(--brand-navy);
  font-size:18px;
  font-weight:300;
  border-bottom:2px solid transparent;
  transition:.3s all;
}
#top-bar .main-menu li a:hover{
  color:var(--brand-orange);
}
.navbar-toggle .icon-bar{
  background:var(--brand-navy);
}
.nav .open a,
.nav .open a:focus{
  background-color:transparent;
}

/* Hero */
#hero-area{
  background:url("../images/Cargo_Security_Visibility_by_Syntelus.webp") no-repeat 80% 100%;
  background-size:cover;
  background-attachment:fixed;
  padding:230px 0;
  box-shadow:0 0 8px rgba(0,0,0,.3);
  position:relative;
}
#hero-area:before{
  content:"";
  z-index:9;
  background:rgba(0,0,0,.2);
  position:absolute;
  inset:0;
}
#hero-area .block{
  position:relative;
  z-index:999;
}
#hero-area h1{
  font-size:50px;
  line-height:60px;
  color:#fff;
  font-weight:900;
}

/* Call to action */
#call-to-action{
  background:#fff;
  padding:60px 0;
  text-align:center;
  position:relative;
}
#call-to-action .block{
  position:relative;
  z-index:99;
}
#call-to-action .block h2{
  font-size:28px;
  font-weight:900;
}
#call-to-action .block ul{
  font-size:18px;
  font-weight:300;
  margin-top:10px;
}
#call-to-action .block .btn-contact{
  background:var(--brand-orange);
  border:none;
  color:#fff;
  padding:12px 35px;
  margin-top:20px;
  font-size:18px;
  font-weight:300;
  border-radius:5px;
}
#call-to-action .block .btn-contact:hover{
  background:var(--brand-navy);
  color:#fff;
}

/* About page spacing */
.about{
  margin-top:120px;
}
.about .block h3{
  font-size:22px;
  text-align:left;
  font-weight:800;
  margin-top:20px;
}
.about .block p{
  color:var(--text);
}

/* Problem section */
#problem{
  padding:90px 0;
}
#problem .block{
  padding:20px 20px 0 20px;
}
#problem .block h2{
  margin-bottom:20px;
}
#problem .block p{
  margin-bottom:10px;
}
#problem .row{
  display:flex;
  align-items:stretch;
}
#problem .image-block{
  display:flex;
  align-items:center;
}
#problem .image-block img{
  max-height:100%;
  max-width:100%;
  object-fit:contain;
}

/* Definition */
#definition{
  padding:50px 0;
  background:#E2E1DD;
}
#definition .media{
  margin:0 0 20px 0;
}
#definition .media .media-left{
  font-size:80px;
  color:var(--brand-orange);
  padding-right:25px;
}
#definition h4{
  font-size:18px;
  text-align:left;
  margin:0 0 10px;
  font-weight:700;
}
#definition h6{
  font-size:28px;
  text-align:center;
  margin:40px 0 0 0;
  font-weight:700;
}
#definition p{
  line-height:28px;
  font-size:18px;
}
#definition ul li{
  line-height:24px;
}

/* Solution */
#solution{
  padding:100px 0 60px 0;
}
#solution .block{
  position:relative;
  padding-top:30px;
  z-index:99;
}
#solution .image-block{
  display:flex;
  align-items:center;
}
#solution .image-block img{
  padding-top:10px;
  max-height:100%;
  max-width:100%;
  object-fit:contain;
}

/* Contact */
#contact-section{
  padding:300px 0;
  background:url("../images/contact.webp") no-repeat 50% / cover;
  background-attachment:fixed;
  box-shadow:0 0 8px rgba(0,0,0,.3);
  position:relative;
}
#contact-section p{
  font-size:20px;
  line-height:28px;
  margin:0;
}
#contact-section .email,
#contact-section .phone{
  background:#fff;
  padding:35px 20px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
}
#contact-section ion-icon{
  font-size:38px;
  flex:0 0 auto;
}

/* Footer */
#footer{
  background:var(--brand-navy);
  color:#fff;
  padding:18px 0;
  border-top:1px solid rgba(255,255,255,.08);
}
#footer .footer-container{
  max-width:1100px;
  margin:0 auto;
  padding:0 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
#footer .footer-copy{
  margin:0;
  font-size:14px;
  line-height:1.4;
  opacity:.95;
}
#footer .footer-social{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  align-items:center;
  gap:10px;
}
#footer .footer-social a{
  width:42px;
  height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  text-decoration:none;
}
#footer .footer-social a:hover{
  color:var(--brand-orange);
}
#footer ion-icon{
  font-size:32px;
}

/* Bootstrap/utility list resets where bullets are not desired */
.nav,
.navbar-nav,
.footer-social{
  padding-left:0;
}
.nav li,
.navbar-nav li,
.footer-social li{
  list-style:none;
}

/* Responsive */
@media only screen and (max-width: 767px){
  .title{ font-size:40px; }
  .navbar-header .navbar-brand a{ padding:6px 8px; }

  #hero-area{
    background:url("../images/Cargo_Security_Visibility_by_Syntelus.webp") no-repeat 15% 60%;
    box-shadow:0 0 8px rgba(0,0,0,.3);
    padding:140px 0;
  }

  #problem{
    padding:70px 0;
  }
  #problem .block{
    padding:0;
  }

  .navbar-collapse{
    background:var(--brand-navy);
  }
  #top-bar .main-menu li > a{
    color:#fff;
    padding:21px 10px;
    background:transparent;
  }

  /* Stack the flex row in #problem on small screens */
  #problem .row{
    display:block;
  }
}