@charset "utf-8";
/* CSS Document */

:root {
  --primary-color: #003046;
  --secondary-color: #fff;
  --body-background: #fff;
/*  --light-background: #fff;*/
  --dark-background: #C7C0BB;
  --link-color: #ED6861;
  --light-blue-color: #00B6F1;
}

body {
    font-size: 1rem;
}

/*** only set to change page body width ***/
/*** refrain from applying other rules ***/

.row {
    margin-left: auto;
    margin-right: auto;
    max-width: 62.5rem;
    padding-left: 0.9375rem;
    padding-right: 0.9375rem;
}

.error {
  line-height: 1;
}

.thumbnail {
    /* box-shadow: 2px 4px 6px 1px #ccc; */
    box-shadow: none;
}

h1 {
    color: var(--primary-color);
    /* font-family: oswald, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 2.375rem; */
}

h1, h2, h3, h4, h5, h6 {
    color: #003046;
    color: var(--primary-color);
    font-family: "franklin-gothic-urw", sans-serif;
    font-weight: 700;
    margin: 0 0 10px;
}

h1 {
    font-size: 1.5rem;
}

h2 {
    font-size: 1.25rem;
}

h3 {
    font-size: 1.0rem;
}

h4 {
  font-size: 0.75rem;
}

h5 {
  font-size: 0.75rem;
}

h6 {
  font-size: 0.625rem;
}

ul {
    /* font-family: open-sans, sans-serif;
    font-style: normal;
    font-weight: 400; */
    color: var(--primary-color);
}

ul li {
    color: var(--primary-color);
}

p {
    color: var(--primary-color);
}
/* product index overrides */ 
.alpaLetters, .lensSelect, .expandItems,
.collapsItems, .generic-accordion-title,
.arBExpandItems, .arBcollapsItems, .lab-services-accordion,
.photochromicExpandItems, .photochromicCollapsItems,
.photochromic-accordion-title, .bl-accordion-title, .lens-accordion-title,
.arCoating-accordion-title, #otherSection a, .paragraphCopy p a, .paragraphCopy a,
.scrollToTop.textColor a i, .scrollToTop.textColor a span {
    color: #2ba6cb !important;
}
.sub-accordions-title {
    border-top: 1px solid #2ba6cb !important;
    background: #fff !important;

}
:last-child:not(.is-active)>.sub-accordions-title {
    border-bottom: 1px solid #2ba6cb !important; 
    border-radius: unset;  
}
.lrmLogOut, .lrmLogOut:hover, header .navbar-fixed .dropdown.menu a {
/*    line-height: unset;*/
    padding-top: .8rem !important;
    width: 8rem !important;
    text-align: center;
}
.navLinkContainer a:hover {
    display: inherit;
}
.logout-nav-item, .logout-nav-item:hover {
     width: 0; /* weird fix for windows browser chrome/edge */
}
.headerStick {
   height: 6rem !important;
}
hr {  min-width: 100%;}
.lrmHide {
    display: none;
}
.logout-nav-item a {
    color:#fff !important;
}
/* buttons */
.button.primary, [type="submit"]
{
    color: #fff;
    /* font-family: "Open Sans",sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.375rem;
    background-color: var(--primary-color);

    padding: 1rem 6rem; */
}

.button.secondary
{
    background-color: var(--secondary-color);
    color: var(--primary-color);
    /* font-family: "Open Sans",sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 0.875rem;
    padding: 0.9rem 2.5rem; */
}

.button.secondary:focus,
.button.secondary:hover
{
    background-color: #2285a2;
    color: #0a0a0a;
}
/*.framesandCoatingContainer {
    display: flex;
    padding-left: 2rem;
    padding-bottom: 3rem;
    margin-bottom: 2rem;
    border-bottom: 1px #ccc solid;
}
.frames-coating-container {
    margin-right: 5rem;
}
.accordion-title:focus, .accordion-title:hover {
    background: transparent;
}
.accordion-title::before {
    content:'\f04b' !important;
    font-family: "Font Awesome 6 Pro";
    position: absolute;
    font-weight: bold;
    left: -6px;
    font-size: .7rem;
    top: 57.5%;
}
li#Lab-Choice-Anti-Reflective-Coatings{
        margin-left: 1.5rem;
}
.is-active>.accordion-title::before {
    content:'\f2ec' !important;
    font-family: "Font Awesome 6 Pro";
    position: absolute;  
    right: unset;
    -webkit-transform: rotate(180deg);
    -moz-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    -o-transform: rotate(180deg);
    transform: rotate(180deg);
}
.accordion-title, .accordion-title:hover {
    text-decoration: none;
    border:none;
    font-size:  0.9375rem;
    font-weight: bold;
    color: #00222C !important;
    padding: 0.8rem;
}
:last-child:not(.is-active)>.accordion-title {
    border: none;
}
.accordion-item a {
    display: flex;
    align-items: center;
}

.accordion-title:focus, .accordion-title:hover {
    text-decoration: none;
}
.accordion, .accordion-content,:last-child>.accordion-content:last-child  {
    background: transparent;
    border:none;
}
.accordion-content .framesandCoatingContainer {
    padding-left: 1rem;
}
:last-child:not(.is-active)>.accordion-title {
    border: none;
}
.accordion-triangle-right {
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 5px 0 5px 10px;
    border-color: transparent transparent transparent #00222c;
}
.accordion-triangle-down { 
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 10px 5px 0 5px;
    border-color: #00222c transparent transparent transparent;
}
.frames-coatings {
    font-size: 15px;
    line-height: 2.8;
    font-weight: 450;
}*/
/* forms */
label {
    /* font-size: 1rem;
    font-weight: 400;
    line-height: 2.1rem; */
    color: var(--primary-color);
}

button, input, optgroup, select, textarea {

}

[type="color"],
[type="date"], [type="datetime-local"], [type="datetime"],
[type="email"], [type="month"], [type="number"], [type="password"],
[type="search"], [type="tel"], [type="text"], [type="time"], [type="url"],
[type="week"], textarea {
    margin-bottom: 0.5rem;
    /* display: block;
    box-sizing: border-box;
    width: 100%;
    height: 3.75rem;
    margin: 0 0 1rem;
    padding: 0.5rem;
    border: 1px solid var(--primary-color);
    border-radius: 0;
    background-color: #ffffff;
    box-shadow: none;
    font-family: inherit;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--primary-color);
    transition: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none; */
}

select {
    margin-bottom: 0.5rem;
}

.button[type="submit"] {
    margin: 2rem 0;
}

.element-outline-container {
  margin-top: 0.75rem;
}

.form-text {
  margin-top: 2rem;
}

.checkbox-element-container .radioButton.ui-checkboxradio-label .ui-icon-background {
    border-radius: 50% !important;
}

.explainer sup {
    top: -3.5em;
}

.headerCenteredLogoNavLR .navLogoContainer {
    text-align: center;
}

.navbar-fixed {
    position: relative;
}



/*** cardGrid ***/
.cardGrid .imageBlock {
    padding: 1.5rem 2rem 1rem 2rem;
}
/*** footer ***/

.fourColumnFooterRow {
  padding-bottom: 2.5rem;
}

.fourColumnFooterRow .footerLogo {
  display: none;
}

.fourColumnFooterRow .row {
  max-width: 60rem;
}

.fourColumnFooterRow .row:first-child {
  border-top: 1px solid #cccccc;
}


.footerLinkContainer:nth-child(3),
.footerLinkContainer:nth-child(4),
.footerLinkContainer:nth-child(5) {
  display: none;
}

.footerLinkContainer a.footerLink,
.footerLinkContainer a:active,
.footerLinkContainer a:visited {
    color: #007ea8;
}

.footerLinkContainer {
  display: flex;
  width: 100%;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding-left: 5rem;
  padding-right: 5rem;
  padding-top:  1rem;
}

.footerLinkContainer .standardLink {
    flex-grow: 1;
    color: #007ea8;
}

.footerLinkContainer a:hover {
    color: black;
    text-decoration: underline;
    padding: 0;
    margin: 0;
}

.footerLegal
{
    /* display: none; */
}

.cardGrid .imageBlock img {
    height: 93px;
}

.footerRow, .fatFooterRow {
    display: block;
    position: relative;
    padding: 1rem;
    background-color: #003046;
    color: white;
    float: left;
}

/*** tables ***/

table.actionTable tbody tr td
{
  width: 50%;
}

table tbody tr:nth-child(2n) {
    border-bottom: 0;
    background-color: #fff;
}

table thead, table tbody, table tfoot {
    border: none;
    background-color: #fff;
}

table tr th {
    background: #fff;
    color: #000;
    font-weight: bold;
    text-align: center;
}

/******  Stuff I added  ******/

/* uncomment to lockdown sub-menu for styling  */
#XXlrm-policies,
#XXlrm-service,
#XXlrm-products,
#XXlrm-lens-enhancements,
#XXlrm-orders,
#XXlrm-additional-info {
  display: initial;
  visibility: initial;
}

.dropdown-pane .menu li.subnav-item,
.dropdown-pane .menu.expanded li.subnav-item {
  width: initial;
  flex: auto;
  padding: 0 1.5rem;
}

/* tweaks for a very long horizontal menu  */
#lrm-lens-enhancements .menu li.subnav-item,
.dropdown-pane .menu.expanded li.subnav-item {
  padding: 0 1.0rem;
}

/* trim the right padding on the last drop-menu item  */
.dropdown-pane .menu li:last-child,
.dropdown-pane ul.menu li:last-child {
  padding-right: 0;
}

/* trim the left padding on the first drop-menu item  */
.dropdown-pane .menu li:first-child,
.dropdown-pane ul.menu li:first-child {
  padding-left: 0;
}

.hero-section3 {
  padding-top:0;
}

.top-bar .dropdown-pane ul.horizontal {
    width: auto;
    justify-content: flex-end;
    align-content: center;
    align-items: center;
    padding: 0;
    height: 100%;
}

#megamenu .centered-menu {
    max-width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-evenly;
    align-content: center;
    width: 100%;
    margin: 0 auto;
    height: 100%;
}

.dropdown.menu a,
.dropdown.menu a:active,
.dropdown.menu a:hover {
    margin: 0;
/*    font-size: 0.95em;*/
    letter-spacing: 0.7px;
    opacity: 1.0;
    color: #000;
    padding: 0;
    margin: 0;
    text-transform: none;
    font-weight: 500;
}


.menu.expanded li.topnav-item {
    flex: 0 0 auto;
    padding: 0 0.85rem;
}

.topNavContainer {
    max-width: 77.5rem;
    margin-left: auto;
    margin-right: auto;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
    height: 100%;
    background-color: #fff;
}

.navLinkContainer {
    background: #fff;
    width: 100%;
    padding: 1rem 0 1rem 0;
    text-align: left;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
    display: flex;
    flex-direction: column;
    align-items: center;
    height: 100%;
    /* border-bottom: 1px solid #ccc; */
}

header {
    background-color: #fff;
    border-bottom: 1px solid #ccc;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
    height: 7.375rem;
}

.headerRow {
    box-sizing: border-box;
    height: auto;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-align-items: center;
    -ms-flex-align: center;
    -webkit-justify-content: space-between;
    -ms-flex-pack: center;
    flex-direction: column;
    align-items: flex-start;
    justify-content: space-between;
    padding: 0;
    max-width: 77.5rem;
    height: 100%;
}

.navLogoContainer {
    font-family: "Helvetica Neue",Arial,sans-serif;
    font-weight: bold;
    font-size: 1.3rem;
    color: white;
    text-transform: capitalize;
    display: inline-block;
    letter-spacing: 1px;
    margin-bottom: 0;
    width: 100%;
    padding-right: 3rem;
}

.navLogoContainer a img {
    width: 100%;
}

#megamenu .top-bar .dropdown-pane {
    /* display: flex; */
    justify-content: center;
    align-items: center;
    align-content: center;
    width: 100% !important;
    max-width: 100%;
    left: 0 !important;
    right: 0 !important;
    border: 0;
    border-radius: 0;
    z-index: 550;
    top: 102px;
    background: #0F3044;
    padding: 0;
    box-shadow: 0px 2px 5px 0px rgba(159, 161, 164, .43);
    height: 80px;
}

#megamenu .dropdown-pane a {
  color: #fff;
  text-transform: initial;
}


.hamburger-close::after {
  font-family: "Font Awesome 6 Pro";
  content: "\f067";
  background: unset;
  box-shadow: unset;
  transform: rotate(45deg);
  /* color: #0069b5; */
  color: #000;
  font-size: 1.5rem;
  /* padding-left: 5px; */
}

.hamburger-close.menu-icon:hover::after, .hamburger-close.menu-icon::after{
  background: unset;
  box-shadow: unset;
}


.menu-icon::after {
    background: #000;
    box-shadow: 0 7px 0 #000, 0 14px 0 #000;
    height: 3px;
}

.title-bar {
  padding: 1.5rem 1.5rem 0 1.5rem;
}

.navbar-fixed {
  position: relative;
  /* max-width: 90rem; */
  z-index: 800;
  left: unset;
  top: 0;
}

.top-bar {
  justify-content: center;
  font-family: 'Nunito Sans', sans-serif !important;
  height: 100%;
}

#mega-menu {
  height: 100%;
}

.top-bar a {
  color: #030211;
}

#megamenu {
  height: 100%;
}

#megamenu .top-bar .dropdown-pane {
  height: 4.875rem;
  top: 6.3rem !important;
  background-color: #0f3044;
  /* border-bottom: 1px solid rgba(10,10,10,.2); */
  box-shadow: 0px 2px 5px 0px rgba(159, 161, 164, .43);
  /* width: 122% !important; */
  /* max-width: 122%; */
  /* left: -11% !important; */

}

.top-bar .dropdown-pane ul.vertical {
  width: auto;
  justify-content: flex-start;
  max-width: 25%;
  margin-left: auto;
  margin-right: auto;
}




/***** MEDIA QUERIES START HERE ******/

/*--- SMALL only --------------------------------------------- */
@media screen and (max-width: 39.9375em)
{

    table.actionTable tbody tr td
    {
      width: 100%;
    }

    .button {
        font-size: 0.8rem;
    }

    #mega-menu {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.footerLinkContainer .standardLink {
    font-size: 0.85rem;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
    line-height: 1.1;
}

.footerLinkContainer {
  align-items: flex-start;
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}
.framesandCoatingContainer {
    display: inherit;
}

}

/*--- SMALL and MEDIUM only ----------------------------------- */
@media screen and (max-width: 63.9375em)
{

  .footerLinkContainer {
    /* flex-direction: column; */
    flex-wrap: wrap;
  }

  .footerLinkContainer .standardLink {
      font-size: 0.85rem;
      padding-left: 0.5rem;
      padding-right: 0.5rem;
      line-height: 1.5;
  }

  .headerRow {
    height: 100%;
  }

  .mm-title-bar {
      /* display: flex; */
      display: flex !important;
      flex-basis: 100%;
      margin: 0;
      flex-direction: row;
      text-align: left;
      align-items: center;
      padding: 1rem;
      flex-direction: row-reverse;
      color: #000;
      background-color: #fff;
      padding-right: 1.625rem;
      padding-left: 1.625rem;
      height: 4.375rem;
      height: 100%;
  }

.navLogoContainer {
    display: none;
  }

.top-bar {
    z-index: 500;
    position: absolute;
    background-color: #0f3044;
    top: 6.0rem;
    padding: 0;
    height: auto;
}

.XXmenu.expanded li.topnav-item {
    background-color: #0f3044;
}

#megamenu {
  height: 100%;
  box-shadow: none;
  /* border-bottom: 1px solid #cccccc; */
}

#megamenu .top-bar .dropdown-pane {
      /* display: none; */
      justify-content: center;
      align-items: center;
      align-content: center;
      width: 100% !important;
      max-width: 100%;
      left: 0 !important;
      right: 0 !important;
      border: 0;
      border-radius: 0;
      z-index: 550;
      top: 0 !important;
      background-color: #0f3044;
      padding: 0;
      color: #fff;
      box-shadow: none;
      height: auto;
      margin-bottom: 0;

  }

#megamenu .dropdown-pane a {
      color: #fff;
      text-transform: initial;
        padding-left: 0;
  }

#megamenu .top-bar .dropdown-pane ul.horizontal {
    /* width: auto; */
    width: 100%;
    justify-content: flex-end;
    align-content: flex-start;
    align-items: flex-start;
    padding: 0;
    margin-left: 0;
}


.top-bar .dropdown.menu a,
.top-bar .dropdown.menu a:active,
.top-bar .dropdown.menu a:hover {
    color: #fff;
    font-size: 0.85rem;
}

.menu li .dropdown-pane a,
.menu.expanded li .dropdown-pane a {
    text-transform: uppercase;
    font-size: 0.85rem;
    font-weight: 400;
    padding-left: 0;
}

.navLinkContainer {
      display: block;
      padding: 0;
      height: 100%;
}

.navLinkContainer .navLogoContainer-mobile {
    display: inline-block;
    text-align: left;
    flex-grow: 1;
}

.menu.expanded li.topnav-item {
    border-bottom: 1px solid #999999;
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.XXmenu.expanded li.topnav-item::after {
  font-family: "Font Awesome 6 Pro";
  font-weight: 400;
  content: " \f107";
}

.menu.expanded li.topnav-item:last-child {
    border-bottom: none;
}

.dropdown-pane .menu li:first-child,
.dropdown-pane ul.menu li:first-child {
    padding-left: 1rem;
}

.dropdown-pane .menu li.subnav-item,
.dropdown-pane .menu.expanded li.subnav-item {
    padding: 0 1rem;
    width: 100%;
}

.dropdown-pane .menu li:last-child,
.dropdown-pane ul.menu li:last-child {
    padding-bottom: 0.75rem;
}

.navLinkContainer a.dropdown::before {
    content: none;
    display: none;
}

header {
  /* height: 4.375rem;  */
  height: 6.0rem;
}

.navLinkContainer a[data-toggle]::after {
    font-family: "Font Awesome 6 Pro";
    font-weight: 500;
    content: "\f067";
    float: right;
}

.navLinkContainer a.hover::after {
    content: "\f068";
}

}

/*--- MEDIUM and UP only ------------------------------- */
@media screen and (min-width: 40em)
{

  #XXmega-menu {
    padding-left: 2.5rem;
    padding-right: 2.5rem;
  }


}

/*--- MEDIUM only ------------------------- */
@media screen and (min-width: 40em) and (max-width: 63.9375em)
{



}


/*--- Large and up ------------------------- */
@media screen and (min-width: 64em)
{

  #megamenu {
    padding-left: 2rem;
    padding-right: 2rem;
  }
  .navLogoContainer {
    padding-right: 0.5rem;
  }

  header {
    /* height: 4.5rem; */
    height: 10.5rem;
  }

  .topNavContainer.navbar-fixed .headerRow {
    padding: 0;
    margin: 0;
}


}

/* Large only */
@media screen and (min-width: 64em) and (max-width: 74.9375em)
{


}
