/*
 * IMPReSS Isolated Styles
 * 
 * This stylesheet contains all IMPReSS-specific styles nested under the
 * #impresscontent wrapper to ensure style isolation when IMPReSS content
 * is displayed within the NMGN WordPress site.
 * 
 * Include this CSS file in the WordPress template to ensure IMPReSS content
 * maintains its styling when embedded in the main site.
 */

#impresscontent,
.impress-content-wrapper {
  /* Reset any inherited WordPress/NMGN styles that might interfere */
  font-family: "Roboto", sans-serif;
  line-height: 1.3;
  
  /* IMPReSS-specific color variables */
  --impress-primary: #008AAD;
  --impress-secondary: #17a2b8;
  --impress-light: #f8f9fa;
  --impress-dark: #343a40;
  
  /* Ensure box-sizing is consistent */
  *, *::before, *::after {
    box-sizing: border-box;
  }
  
  /* Navigation styles specific to IMPReSS */
  #impressMenu {
    line-height: 36px;
    
    .navbar-nav .nav-link {
      color: #fff !important;
      font-size: 14px !important;
      font-weight: bold !important;
      line-height: 20px !important;
      letter-spacing: .5px !important;
      text-transform: uppercase !important;
    }
    
    .navbar-toggler {
      height: 40px !important;
      color: #fff !important;
      cursor: pointer !important;
      border: none !important;
      
      &:focus {
        border: none !important;
        outline: none !important;
        box-shadow: none !important;
      }
      
      .fal {
        font-size: .9em !important;
        vertical-align: baseline !important;
      }
    }
    
    span {
      cursor: default !important;
    }
  }
  
  #impressMenuCollapse {
    padding: 0 20px !important;
  }
  
  /* IMPReSS menu dropdown styles */
  .impress-menu {
    position: absolute !important;
    top: 100% !important;
    width: 100% !important;
    left: 0 !important;
    z-index: 3 !important;
    background-color: #cde0e6 !important;
    
    .dropdown-columns {
      padding: 35px 0 !important;
    }
    
    ul {
      text-align: left !important;
      list-style: none !important;
      margin: 0 !important;
      padding: 0 !important;
    }
    
    li {
      list-style: none !important;
      margin: 0 !important;
      
      a {
        margin: 0 !important;
        color: var(--impress-primary) !important;
        text-decoration-color: var(--impress-primary) !important;
        font-weight: 400 !important;
      }
    }
    
    a,
    .sub-menu a {
      color: var(--impress-primary) !important;
      text-decoration-color: var(--impress-primary) !important;
      font-weight: 400 !important;
    }
    
    .sub-menu a {
      margin-left: 20px !important;
    }
    
    .nav-heading,
    h6 a {
      color: var(--impress-primary) !important;
      font-weight: bold !important;
      padding: 5px 0 !important;
    }
    
    .nav-heading {
      border-bottom: 1px solid var(--impress-primary) !important;
    }
    
    .sub-pages {
      margin-left: 0 !important;
    }
  }
  
  /* Header styles specific to IMPReSS */
  .header {
    /* Ensure header styles don't get overridden by WordPress */
    
    &__nav {
      height: auto !important;
      
      .submenu {
        line-height: 1 !important;
      }
    }
    
    &__logo {
      max-height: 100% !important;
    }
  }
  
  /* Main content area styles specific to IMPReSS */
  .main {
    /* Ensure main content styling is preserved */
    background: #fff;
    
    .container {
      max-width: 1200px;
    }
  }
  
  /* Search form styles specific to IMPReSS */
  .searchForm {
    .portal-search__input {
      /* IMPReSS search input styles */
      border: 1px solid #ddd !important;
      padding: 8px 12px !important;
      border-radius: 4px !important;
    }
    
    button {
      background: var(--impress-primary) !important;
      color: white !important;
      border: none !important;
      padding: 8px 12px !important;
      border-radius: 4px !important;
      cursor: pointer !important;
    }
  }
  
  /* Table styles specific to IMPReSS */
  .pipeline-list {
    .pipeline {
      margin-bottom: 2rem !important;
      padding: 1rem !important;
      border-left: 3px solid var(--impress-primary) !important;
      background: #f8f9fa !important;
      
      h3 {
        color: var(--impress-primary) !important;
        font-weight: bold !important;
        margin-bottom: 0.5rem !important;
      }
      
      .pipelinekey {
        font-size: 0.9em !important;
        color: #666 !important;
      }
      
      p {
        margin-bottom: 0.5rem !important;
        line-height: 1.5 !important;
      }
      
      .links a {
        color: var(--impress-primary) !important;
        text-decoration: underline !important;
        
        &:hover {
          text-decoration: none !important;
        }
      }
    }
  }
  
  /* DataTables specific styles for IMPReSS */
  .dataTables_wrapper {
    .dataTables_filter input {
      border: 1px solid #ddd !important;
      padding: 4px 8px !important;
    }
    
    .dataTables_length select {
      border: 1px solid #ddd !important;
      padding: 4px 8px !important;
    }
  }
  
  table.dataTable {
    border-collapse: collapse !important;
    
    thead th {
      background: var(--impress-primary) !important;
      color: white !important;
      font-weight: bold !important;
      padding: 8px !important;
    }
    
    tbody td {
      padding: 8px !important;
      border-bottom: 1px solid #ddd !important;
    }
    
    tbody tr:hover {
      background: #f5f5f5 !important;
    }
  }
  
  /* Button styles specific to IMPReSS */
  .btn {
    display: inline-block !important;
    padding: 8px 16px !important;
    border-radius: 4px !important;
    text-decoration: none !important;
    cursor: pointer !important;
    border: none !important;
    font-weight: 400 !important;
    
    &.btn-primary {
      background: var(--impress-primary) !important;
      color: white !important;
    }
    
    &.btn-secondary {
      background: #6c757d !important;
      color: white !important;
    }
    
    &.btn-sm {
      padding: 4px 8px !important;
      font-size: 0.875rem !important;
    }
    
    &:hover {
      opacity: 0.9 !important;
    }
  }
  
  /* Typography overrides for IMPReSS */
  h1, h2, h3, h4, h5, h6 {
    font-family: "Roboto", sans-serif !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    margin-bottom: 1rem !important;
  }
  
  h1 {
    font-size: 2.5rem !important;
  }
  
  h2 {
    font-size: 2rem !important;
    color: var(--impress-primary) !important;
  }
  
  h3 {
    font-size: 1.5rem !important;
  }
  
  /* Link styles specific to IMPReSS */
  a {
    color: var(--impress-primary) !important;
    text-decoration: underline !important;
    padding-right: 20px;
    font-size: .9em;
    
    &:hover {
      text-decoration: none !important;
      opacity: 0.8 !important;
    }
  }
  
  /* Breadcrumb styles */
  .breadcrumbs-people {
    padding: 1rem 0 !important;
    font-size: 0.9rem !important;
    
    a {
      color: var(--impress-primary) !important;
    }
    
    .fa-angle-right {
      margin: 0 0.5rem !important;
      color: #666 !important;
    }
  }
  
  /* Form elements */
  input[type="text"],
  input[type="search"],
  select,
  textarea {
    border: 1px solid #ddd !important;
    padding: 8px 12px !important;
    border-radius: 4px !important;
    font-family: inherit !important;
    
    &:focus {
      border-color: var(--impress-primary) !important;
      outline: none !important;
      box-shadow: 0 0 0 2px rgba(0, 138, 173, 0.2) !important;
    }
  }
  
  /* Footer styles specific to IMPReSS */
  .footer {
    background: #f8f9fa !important;
    color: #333 !important;
    padding: 2rem 0 !important;
    
    a {
      color: var(--impress-primary) !important;
    }
    
    .footer__social {
      list-style: none !important;
      padding: 0 !important;
      margin: 0 !important;
      display: flex !important;
      
      li {
        margin-right: 1rem !important;
        
        a {
          display: inline-block !important;
          width: 40px !important;
          height: 40px !important;
          line-height: 40px !important;
          text-align: center !important;
          border-radius: 50% !important;
          background: var(--impress-primary) !important;
          color: white !important;
          text-decoration: none !important;
          
          &:hover {
            opacity: 0.8 !important;
          }
        }
      }
    }
  }
  
  /* Responsive adjustments */
  @media (max-width: 768px) {
    .pipeline-list .pipeline {
      margin-bottom: 1rem !important;
      padding: 0.75rem !important;
    }
    
    h1 {
      font-size: 2rem !important;
    }
    
    h2 {
      font-size: 1.5rem !important;
    }
    
    .breadcrumbs-people {
      padding: 0.5rem 0 !important;
    }
  }
  
  /* Override any UIKit styles that might interfere */
  .uk-article & {
    /* Ensure IMPReSS content maintains its styling within UK-styled containers */
    
    h1, h2, h3, h4, h5, h6 {
      font-family: "Roboto", sans-serif !important;
    }
    
    p {
      font-family: "Roboto", sans-serif !important;
      line-height: 1.5 !important;
    }
    
    a {
      color: var(--impress-primary) !important;
    }
  }
}

/* Additional specificity for when content is inside WordPress/UIKit containers */
.nmgn-article-content #impresscontent,
.nmgn-article-content .impress-content-wrapper {
  /* Ensure all the above styles apply even within NMGN article content */
  font-family: "Roboto", sans-serif !important;
  
  /* Override any inherited text styles */
  * {
    font-family: inherit !important;
  }
}

/* IMPReSS-specific styles for NMGN theme integration */

/* Navigation styling for UIKit navbar */
#impresscontent .uk-navbar-container {
  border-radius: 4px !important;
  margin-bottom: 20px !important;
}

#impresscontent .uk-navbar-nav > li > a {
  color: #008AAD!important;
  font-weight: 500 !important;
  text-transform: none !important;
  letter-spacing: 0.5px !important;
  font-size: 14px !important;
  text-decoration: none !important;
}

#impresscontent .uk-navbar-nav > li > a:hover {
  color: #2e2d62 !important;
}

/* Search form styling specific to IMPReSS */
#impresscontent .uk-search-input {
  background: white !important;
  border: 1px solid #ddd !important;
  border-radius: 20px !important;
  padding: 8px 16px !important;
  font-size: 14px !important;
  width: 300px !important;
}

#impresscontent .uk-search-input:focus {
  border-color: var(--impress-primary) !important;
  box-shadow: 0 0 0 2px rgba(0, 138, 173, 0.2) !important;
}

/* Search input placeholder styling */
#impresscontent .uk-search-input.portal-search__input::placeholder {
    color: #999999 !important;
    opacity: 1 !important;
}

/* For older browsers */
#impresscontent .uk-search-input.portal-search__input::-webkit-input-placeholder {
    color: #999999 !important;
    opacity: 1 !important;
}

#impresscontent .uk-search-input.portal-search__input::-moz-placeholder {
    color: #999999 !important;
    opacity: 1 !important;
}

#impresscontent .uk-search-input.portal-search__input:-ms-input-placeholder {
    color: #999999 !important;
    opacity: 1 !important;
}

#impresscontent .uk-search-input.portal-search__input:-moz-placeholder {
    color: #999999 !important;
    opacity: 1 !important;
}

#impresscontent .uk-search-icon-flip {
  color: var(--impress-primary) !important;
}

/* Table styling example for testing */
#impresscontent .impress-content-wrapper table {
  background-color: #f8f9fa !important;
  border: 1px solid #dee2e6 !important;
  border-radius: 4px !important;
  overflow: hidden !important;
}

#impresscontent .impress-content-wrapper table thead th {
  background-color: var(--impress-primary) !important;
  color: white !important;
  font-weight: bold !important;
  padding: 12px 8px !important;
  border-bottom: 2px solid var(--impress-primary) !important;
}

#impresscontent .impress-content-wrapper table tbody td {
  padding: 10px 8px !important;
  border-bottom: 1px solid #dee2e6 !important;
}

#impresscontent .impress-content-wrapper table tbody tr:nth-child(even) {
  background-color: #f8f9fa !important;
}

#impresscontent .impress-content-wrapper table tbody tr:hover {
  background-color: #e9ecef !important;
}

/* DataTables integration styling */
#impresscontent .dataTables_wrapper .dataTables_length,
#impresscontent .dataTables_wrapper .dataTables_filter,
#impresscontent .dataTables_wrapper .dataTables_info,
#impresscontent .dataTables_wrapper .dataTables_processing,
#impresscontent .dataTables_wrapper .dataTables_paginate {
  color: #333 !important;
  font-size: 14px !important;
}

#impresscontent .dataTables_wrapper .dataTables_paginate .paginate_button {
  padding: 6px 12px !important;
  margin-left: 2px !important;
  border: 1px solid var(--impress-primary) !important;
  border-radius: 4px !important;
  color: var(--impress-primary) !important;
  background: white !important;
}

#impresscontent .dataTables_wrapper .dataTables_paginate .paginate_button:hover {
  background: var(--impress-primary) !important;
  color: white !important;
}

#impresscontent .dataTables_wrapper .dataTables_paginate .paginate_button.current {
  background: var(--impress-primary) !important;
  color: white !important;
}

/* Form elements within IMPReSS content */
#impresscontent .form-control,
#impresscontent input[type="text"],
#impresscontent input[type="search"],
#impresscontent select,
#impresscontent textarea {
  border: 1px solid #ced4da !important;
  border-radius: 4px !important;
  padding: 8px 12px !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
  background-color: #fff !important;
  color: #495057 !important;
}

#impresscontent .form-control:focus,
#impresscontent input[type="text"]:focus,
#impresscontent input[type="search"]:focus,
#impresscontent select:focus,
#impresscontent textarea:focus {
  border-color: var(--impress-primary) !important;
  box-shadow: 0 0 0 0.2rem rgba(0, 138, 173, 0.25) !important;
  outline: 0 !important;
}

/* Button styling within IMPReSS content */
#impresscontent .btn,
#impresscontent button {
  display: inline-block !important;
  font-weight: 400 !important;
  text-align: center !important;
  vertical-align: middle !important;
  border: 1px solid transparent !important;
  padding: 8px 16px !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
  border-radius: 4px !important;
  cursor: pointer !important;
  text-decoration: none !important;
}

#impresscontent .btn-primary,
#impresscontent button[type="submit"] {
  background-color: var(--impress-primary) !important;
  border-color: var(--impress-primary) !important;
  color: #fff !important;
}

#impresscontent .btn-primary:hover,
#impresscontent button[type="submit"]:hover {
  background-color: #007299 !important;
  border-color: #006a87 !important;
  color: #fff !important;
}

/* Portal search styling */
#impresscontent .portal-search__inputs {
  max-width: 600px !important;
  margin: 0 auto !important;
}

#impresscontent .portal-search__input {
  width: 100% !important;
  padding: 12px 20px !important;
  font-size: 16px !important;
  border: 2px solid var(--impress-primary) !important;
  border-radius: 25px !important;
  background: white !important;
  box-shadow: 0 2px 10px rgba(0, 138, 173, 0.1) !important;
}

#impresscontent .portal-search__input:focus {
  outline: none !important;
  box-shadow: 0 2px 15px rgba(0, 138, 173, 0.2) !important;
  border-color: var(--impress-secondary) !important;
}

/* Pipeline and procedure styling */
#impresscontent .pipeline,
#impresscontent .procedure-item {
  background: #f8f9fa !important;
  border-left: 4px solid var(--impress-primary) !important;
  padding: 20px !important;
  margin-bottom: 20px !important;
  border-radius: 0 8px 8px 0 !important;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}

#impresscontent .pipeline h3,
#impresscontent .procedure-item h3 {
  color: var(--impress-primary) !important;
  font-weight: bold !important;
  margin-bottom: 10px !important;
}

#impresscontent .pipelinekey,
#impresscontent .procedure-key {
  font-family: monospace !important;
  background: #e9ecef !important;
  padding: 2px 6px !important;
  border-radius: 3px !important;
  font-size: 0.9em !important;
  color: #495057 !important;
}

/* Responsive adjustments for mobile */
@media (max-width: 768px) {
  #impresscontent .uk-search-input {
    width: 250px !important;
  }
  
  #impresscontent .uk-navbar-nav {
    flex-direction: column !important;
  }
  
  #impresscontent .portal-search__input {
    font-size: 14px !important;
    padding: 10px 16px !important;
  }
  
  #impresscontent .pipeline,
  #impresscontent .procedure-item {
    padding: 15px !important;
    margin-bottom: 15px !important;
  }
}

#impresscontent table {
  width: 100% !important;
  background-color: #ffffff !important;
  border: 1px solid #dee2e6 !important;
  border-radius: 4px !important;
  overflow: hidden !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  margin-bottom: 1rem !important;
  font-size: 14px !important;
}

#impresscontent table thead {
  background-color: var(--impress-primary) !important;
}

#impresscontent table th {
  background-color: var(--impress-primary) !important;
  color: white !important;
  font-weight: bold !important;
  padding: 12px 8px !important;
  border-bottom: 2px solid var(--impress-primary) !important;
  text-align: left !important;
  vertical-align: middle !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
}

#impresscontent table tbody{
  background-color: #ffffff !important;
}

#impresscontent table tbody td {
  padding: 10px 8px !important;
  border-bottom: 1px solid #dee2e6 !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
  vertical-align: middle !important;
  color: #333333 !important;
  background-color: inherit !important;
}

#impresscontent table tbody tr:nth-child(even),
#impresscontent .impress-content-wrapper table tbody tr:nth-child(even),
.nmgn-article-content #impresscontent table tbody tr:nth-child(even) {
  background-color: #f8f9fa !important;
}

#impresscontent table tbody tr:nth-child(odd),
#impresscontent .impress-content-wrapper table tbody tr:nth-child(odd),
.nmgn-article-content #impresscontent table tbody tr:nth-child(odd) {
  background-color: #ffffff !important;
}

#impresscontent table tbody tr:hover,
#impresscontent .impress-content-wrapper table tbody tr:hover,
.nmgn-article-content #impresscontent table tbody tr:hover {
  background-color: #e9ecef !important;
}

#impresscontent table tbody tr:hover td,
#impresscontent .impress-content-wrapper table tbody tr:hover td,
.nmgn-article-content #impresscontent table tbody tr:hover td {
  background-color: inherit !important;
}

/* DataTables specific overrides */
#impresscontent table.dataTable,
#impresscontent .impress-content-wrapper table.dataTable,
.nmgn-article-content #impresscontent table.dataTable {
  border-collapse: separate !important;
  border-spacing: 0 !important;
}

#impresscontent table.dataTable thead th,
#impresscontent .impress-content-wrapper table.dataTable thead th,
.nmgn-article-content #impresscontent table.dataTable thead th {
  border-bottom: 2px solid var(--impress-primary) !important;
  background-color: var(--impress-primary) !important;
  color: white !important;
}

#impresscontent table.dataTable tbody td,
#impresscontent .impress-content-wrapper table.dataTable tbody td,
.nmgn-article-content #impresscontent table.dataTable tbody td {
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
}

/* Search input placeholder styling */
#impresscontent .uk-search-input.portal-search__input::placeholder {
    color: #999999 !important;
    opacity: 1 !important;
}

/* For older browsers */
#impresscontent .uk-search-input.portal-search__input::-webkit-input-placeholder {
    color: #999999 !important;
    opacity: 1 !important;
}

#impresscontent .uk-search-input.portal-search__input::-moz-placeholder {
    color: #999999 !important;
    opacity: 1 !important;
}

#impresscontent .uk-search-input.portal-search__input:-ms-input-placeholder {
    color: #999999 !important;
    opacity: 1 !important;
}

#impresscontent .uk-search-input.portal-search__input:-moz-placeholder {
    color: #999999 !important;
    opacity: 1 !important;
}
/* IMPReSS Protocol Page Fixes */
.protocol-icons {
    float: left;
    margin-right: 10px;
}

.protocol-icons a {
    display: inline-block;
    margin-right: 5px;
}

/* Jump navigation - inline list items */
ul li {
    display: inline-block !important;
    margin-right: 10px;
}

/* Parameters section heading with icons */
h2.parameters-heading {
    clear: both;
}


/* IMPReSS Protocol Page Fixes */
#printMenu {
    float: left;
    margin-right: 15px;
    margin-top: 5px;
}

#printMenu a {
    display: inline-block;
    margin-right: 5px;
}

/* Jump navigation - inline list items */
.page-content > p + ul li,
.page-content > ul li {
    display: inline-block !important;
    margin-right: 5px;
    margin-bottom: 5px;
}

/* Clear float after jump navigation */
.page-content .ptcl-item,
.page-content > div[id] {
    clear: both;
}

