/* ===========================
   CUSTOM STYLES FOR SWS
   =========================== */

/* ----- PRIMARY FIXES: make main menu (incl. 'Connect') black/visible on landing ----- */
/* Top-level nav links: force black color and full visibility */
.header-area .main-nav .nav > li > a {
  color: #000 !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

/* If the template changes colors when sticky, keep them black */
.header-area.header-sticky .main-nav .nav > li > a {
  color: #000 !important;
}

/* Submenu trigger link (e.g., 'Connect', 'Services', etc.) */
.header-area .main-nav .nav > li.submenu > a {
  color: #000 !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

/* Fix dropdown arrow alignment */
.header-area .main-nav .nav li.submenu:after {
  color: #000 !important;
}

/* Submenu panel: readable white background, black text */
.header-area .main-nav .nav li.submenu ul {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,.06);
}

.header-area .main-nav .nav li.submenu ul li a {
  color: #000 !important;
}

.header-area .main-nav .nav li.submenu ul li a:hover {
  background: rgba(0,0,0,.05);
  color: #000 !important;
}

/* Ensure header sits above hero and preloader when visible */
.header-area {
  position: sticky;
  top: 0;
  z-index: 1000;
}

/* Optional: hover color for top-level links */
.header-area .main-nav .nav > li > a:hover {
  color: #0a2540 !important; /* navy hover */
}

/* ===========================
   MOBILE MENU IMPROVEMENTS
   =========================== */

@media (max-width: 991px) {
  /* Keep the template's existing mobile styles but enhance them */
  
  /* Fix logo positioning - keep it in place */
  .header-area .main-nav .logo {
    float: left;
    line-height: 80px;
    position: relative;
    z-index: 1001;
    margin-left: 15px;
  }
  
  .header-area .main-nav .logo p {
    margin: 0;
    line-height: 80px;
  }
  
  .header-area .main-nav .logo img {
    max-height: 55px;
    width: auto;
    vertical-align: middle;
  }
  
  /* Make hamburger menu visible and properly positioned ON RIGHT SIDE */
  .header-area .main-nav .menu-trigger {
    display: block !important;
    position: absolute !important;
    right: 15px !important;
    top: 23px !important;
    left: auto !important;
    z-index: 1002 !important;
    float: none !important;
  }
  
  /* Force it on sticky header too */
  .background-header .main-nav .menu-trigger {
    right: 15px !important;
    left: auto !important;
    top: 23px !important;
    position: absolute !important;
  }
  
  /* Extra strong override */
  .header-area .main-nav .menu-trigger[style] {
    right: 15px !important;
    left: auto !important;
    position: absolute !important;
  }
  
  /* Ensure proper header height */
  .header-area {
    height: 80px !important;
  }
  
  /* Clear floats to prevent layout collapse */
  .header-area .main-nav::after {
    content: "";
    display: table;
    clear: both;
  }
  
  /* Menu styling - positioned to slide in from RIGHT side */
  .header-area .main-nav .nav {
    position: fixed;
    top: 80px;
    right: 0 !important;
    left: auto !important;
    width: 75vw; /* 3/4 of viewport width */
    max-height: calc(75vh - 80px); /* 3/4 of viewport height minus header */
    margin-top: 0 !important;
    padding-top: 0 !important;
    background: #fff;
    box-shadow: -4px 4px 12px rgba(0,0,0,0.1);
    float: none !important;
    overflow-y: auto; /* Allow scrolling if content exceeds height */
    z-index: 999;
  }
  
  /* Override template's margin-top */
  .background-header .main-nav .nav {
    margin-top: 0 !important;
  }
  
  .header-area.header-sticky .nav {
    margin-top: 0 !important;
  }
  
  /* Remove any extra spacing from first menu item */
  .header-area .main-nav .nav li:first-child {
    margin-top: 0 !important;
    padding-top: 0 !important;
    border-top: none !important;
  }
  
  /* Ensure menu items are black on mobile */
  .header-area .main-nav .nav li a {
    color: #000 !important;
  }
  
  /* Submenu styling on mobile */
  .header-area .main-nav .nav li.submenu ul {
    background: #fff !important;
    border-left: 3px solid #0a2540;
    display: none;
  }
  
  /* Show submenu when active class is added */
  .header-area .main-nav .nav li.submenu.active ul {
    display: block !important;
  }
  
  .header-area .main-nav .nav li.submenu ul li {
    background: #fafafa !important;
  }
  
  .header-area .main-nav .nav li.submenu ul li a {
    color: #000 !important;
    padding-left: 30px !important;
  }
  
  .header-area .main-nav .nav li.submenu ul li a:hover {
    background: #e8e8e8 !important;
    color: #fe3f40 !important;
  }
  
  /* Add smooth transition to submenu opening */
  .header-area .main-nav .nav li.submenu ul {
    transition: all 0.3s ease;
    overflow: hidden;
    max-height: 0;
  }
  
  .header-area .main-nav .nav li.submenu.active ul {
    max-height: 500px;
  }
  
  /* Arrow indicator for submenus */
  .header-area .main-nav .nav li.submenu:after {
    transition: transform 0.3s ease;
    color: #000 !important;
  }
  
  /* Rotate arrow when submenu is open */
  .header-area .main-nav .nav li.submenu.active:after {
    transform: rotate(180deg);
  }
  
  /* Make submenu items clickable */
  .header-area .main-nav .nav li.submenu > a {
    cursor: pointer;
  }
  
  /* Add semi-transparent overlay on LEFT side of screen */
  .header-area .main-nav .nav::before {
    content: "";
    position: fixed;
    top: 80px;
    left: 0 !important;
    right: 75vw !important;
    bottom: 0;
    background: rgba(0, 0, 0, 0.3);
    z-index: 998;
    cursor: pointer;
  }
}

/* Desktop: Ensure submenus work properly */
@media (min-width: 992px) {
  .header-area .main-nav .menu-trigger {
    display: none !important;
  }
  
  .header-area .main-nav .nav {
    display: flex !important;
    float: right !important;
    margin-top: 30px !important;
  }
  
  /* Desktop submenu hover states */
  .header-area .main-nav .nav li.submenu:hover ul {
    visibility: visible;
    opacity: 1;
    z-index: 1;
    transform: translateY(0%);
  }
  
  /* Desktop logo sizing */
  .header-area .main-nav .logo {
    float: left !important;
    line-height: 100px !important;
  }
  
  .header-area .main-nav .logo img {
    max-height: 70px;
    width: auto;
  }
}

/* Large desktop screens */
@media (min-width: 1200px) {
  .header-area .main-nav .logo img {
    max-height: 80px;
    width: auto;
  }
  
  .header-area .main-nav .nav {
    margin-top: 35px !important;
  }
}

/* Medium desktop screens - FIX FOR 992-1200px */
@media (min-width: 992px) and (max-width: 1199px) {
  .header-area .main-nav .logo img {
    max-height: 65px;
    width: auto;
  }
  
  .header-area .main-nav .nav {
    margin-top: 32px !important;
    float: right !important;
    margin-right: 0px !important;
  }
  
  /* Reduce spacing between menu items significantly to fit */
  .header-area .main-nav .nav li {
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
  
  /* Reduce font size slightly if needed */
  .header-area .main-nav .nav li a {
    font-size: 14px !important;
  }
  
  /* Fix dropdown arrow positioning */
  .header-area .main-nav .nav li.submenu {
    padding-right: 25px !important;
  }
  
  .header-area .main-nav .nav li.submenu:after {
    right: 15px !important;
    font-size: 11px !important;
  }
}

/* CRITICAL FIX: Override template's 767px breakpoint that forces display flex */
@media (min-width: 767px) and (max-width: 991px) {
  /* Allow the nav to show ONLY when jQuery adds inline display style via slideToggle */
  html body .header-area .main-nav .nav[style*="display: block"] {
    display: block !important;
    visibility: visible !important;
    height: auto !important;
  }
  
  /* Ensure it's positioned correctly on RIGHT side */
  html body .header-area .main-nav .nav {
    position: fixed;
    top: 80px;
    right: 0 !important;
    left: auto !important;
    width: 75vw;
    float: none;
  }
}

/* Additional catch-all for the entire mobile range */
@media (max-width: 991px) {
  /* When menu is hidden by default */
  html body .header-area .main-nav .nav:not([style*="display: block"]) {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    overflow: hidden !important;
  }
}

/* Tablet sizing (768-991px) */
@media (min-width: 768px) and (max-width: 991px) {
  .header-area .main-nav .logo img {
    max-height: 60px;
    width: auto;
  }
}

/* Small mobile devices */
@media (max-width: 767px) {
  .header-area .main-nav .logo img {
    max-height: 50px;
    width: auto;
  }
}

/* Extra small devices */
@media (max-width: 480px) {
  .header-area .main-nav .logo {
    margin-left: 10px;
  }
  
  .header-area .main-nav .logo img {
    max-height: 45px;
    width: auto;
  }
  
  .header-area .main-nav .menu-trigger {
    right: 10px !important;
    top: 18px !important;
  }
  
  .header-area {
    padding: 0px !important;
  }
}

/* ===========================
   VERTICAL TIMELINE STYLES
   =========================== */

/* Vertical timeline */
.branches-timeline {
  position: relative;
  list-style: none;
  padding-left: 28px;
  margin: 10px 0 0 0;
}

/* Vertical line */
.branches-timeline::before {
  content: "";
  position: absolute;
  left: 10px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: rgba(10,37,64,0.15);
}

.timeline-item {
  position: relative;
  margin-bottom: 22px;
}

/* Node dot */
.timeline-dot {
  position: absolute;
  left: 4px;
  top: 6px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #ff4b2b;
  box-shadow: 0 0 0 4px rgba(255,75,43,0.15);
}

/* Card content */
.timeline-content {
  background: #ffffff;
  border: 1px solid rgba(0,0,0,0.06);
  border-left: 4px solid #0a2540;
  border-radius: 8px;
  padding: 14px 16px;
  transition: transform .25s ease, box-shadow .25s ease;
}

.timeline-title {
  margin: 0 0 6px 0;
  font-weight: 600;
  color: #0a2540;
}

.timeline-year {
  display: inline-block;
  font-size: 0.9rem;
  font-weight: 600;
  color: #ff4b2b;
  background: rgba(255,75,43,0.08);
  padding: 3px 8px;
  border-radius: 999px;
  margin-bottom: 6px;
}

.timeline-text {
  margin: 6px 0 0 0;
  color: #444;
}

/* Hover "lift" */
.timeline-content:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 24px rgba(0,0,0,0.12);
}

/* Responsive tweaks for timeline */
@media (max-width: 575.98px) {
  .branches-timeline { 
    padding-left: 22px; 
  }
  .branches-timeline::before { 
    left: 8px; 
  }
  .timeline-dot { 
    left: 2px; 
  }
}

/* FIX: Always show the last menu item (Contact Us) on mobile */
@media (max-width: 992px) {
  .header-area .main-nav .nav li:last-child,
  .background-header .main-nav .nav li:last-child {
    display: block !important;
  }
}