/*
Theme Name: Divi Child Theme
Description: Divi Child Theme for Oxford Library
Author: DesignDesign
Author URI: https://createwithdd.com/
Template: Divi
Version: Updated for Divi 3+
*/

:root {
  --font-sans: 'Noto Sans', Helvetica, Arial, Lucida, sans-serif;
  --font-serif: 'Noto Serif', Georgia, "Times New Roman", serif;

  --color-blue: #54a3da;
  --color-dark-blue: #0a3b61;
  --color-yellow: #f1a62a;
  --color-dark-yellow: #a97516;
  --color-green: #5ab943;
  --color-dark-green: #067939;
  --color-light-blue: #d1edff;
  --color-light-yellow: #fff2de;
  --color-text: #222;
}

/*
@media (min-width:480px)
@media (min-width:768px)
@media (min-width:981px)
*/

/*====================
  Utilities
  ====================*/

  .visually-hidden{
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px;
  }

/*====================
  Page
  ====================*/

  html, body{
    overflow-x: hidden;
  }

/*====================
  Header
  ====================*/

  #page-container #main-header{
    padding: 0;
  }

  /* Top Bar */

  #top-header{
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    font-family: var(--font-sans);
  }

  .ol-hours{
    align-content: center;
    padding: 0 40px;
    background-color: #bce1f7;
  }

  .ol-hours strong{
    color: var(--color-dark-blue);
  }

  #et-secondary-menu{
    float: none;
    align-content: center;
    flex-grow: 1;
    padding: 0 0 0 40px;
    text-align: right;
  }

  #et-secondary-menu > ul > li a{
    padding: 5px;
    text-decoration-color: var(--color-light-blue);
  }

  #et-secondary-menu > ul > li > a:hover,
  #et-secondary-menu > ul > li > a:focus{
    opacity: 1;
    background-color: #bce1f7;
  }

  .ol-translate{
    align-content: center;
    padding: 5px 40px 5px 30px;
  }

  .ol-translate #gt_float_wrapper{
    position: relative;
  }

  .ol-translate .gt_float_switcher .gt-selected .gt-current-lang,
  .ol-translate-mobile .gt_float_switcher .gt-selected .gt-current-lang{
    padding: 8px 10px;
  }

  .ol-translate .gt_float_switcher img,
  .ol-translate-mobile .gt_float_switcher img{
    width: 28px;
  }

  .ol-translate .gt_float_switcher,
  .ol-translate-mobile .gt_float_switcher{
    font-size: 16px;
  }

  .ol-translate .gt_float_switcher .gt_options{
    position: absolute;
    right: 0;
    z-index: 999999;
    width: max-content;
    background: var(--color-light-yellow);
  }

  .ol-translate .gt_float_switcher .gt_options a:hover,
  .ol-translate .gt_float_switcher .gt_options a:focus{
    background: #ffeccf;
  }

  /* Logo */

  .main-header-wrap{
    display: flex;
    justify-content: space-between;
    padding: 20px;
    flex-direction: column;
  }

  @media (min-width:768px){
    .main-header-wrap{
      padding: 20px 40px;
      flex-direction: row;
    }
  }

  #page-container #main-header .logo_container{
    height: auto;
    text-align: center;
  }

  #main-header .logo_container img{
    width: 240px;
  }

  @media (min-width:768px){
    #main-header .logo_container img{
      width: 295px;
    }
  }

  /* Search */

  .ol-header-search{
    flex-grow: 1;
    align-content: center;
    position: relative;
    padding: 10px 0;
  }

  @media (min-width:768px){
    .ol-header-search{
      padding: 0 0 20px 40px;
    }
  }

  @media (min-width:981px){
    .ol-header-search{
      padding: 0 0 20px 100px;
    }
  }

  .ol-header-search::after{
    content: "";
    position: absolute;
    bottom: -20px;
    display: block;
    width: calc(100% + 20px);
    height: 20px;
    border-radius: 12px 0 0 0;
    background-color: var(--color-green);
  }

  @media (min-width:768px){
    .ol-header-search::after{
      width: 100%;
    }
  }

  .ol-translate-mobile{
    text-align: center;
  }

  @media (min-width:768px){
    .ol-translate-mobile{
      text-align: right;
    }
  }

  @media (min-width:981px){
    .ol-translate-mobile{
      display: none;
    }
  }

  /* Main Nav */

  #et-top-navigation{
    background-color: var(--color-dark-blue);
    text-align: center;
  }

  #page-container #top-menu > li > a{
    padding: 30px 0;
    font-size: 20px;
    font-weight: bold;
    color: #fff;
  }

  #page-container #top-menu > li:hover > a,
  #page-container #top-menu > li:focus > a,
  #page-container #top-menu > li > a:hover,
  #page-container #top-menu > li > a:focus{
    opacity: 1;
    color: var(--color-yellow);
  }

  #top-menu .menu-item-has-children > a:first-child::after,
  #et-secondary-nav .menu-item-has-children > a:first-child::after{
    content: "\43" / "";
    position: static;
    margin-left: 3px;
    color: var(--color-yellow);
    vertical-align: middle;
  }

  /* Sub Nav*/

  #top-menu li{
    position: static;
  }

  #top-menu .sub-menu a{
    width: auto;
  }

  #top-menu .sub-menu a:hover,
  #top-menu .sub-menu a:focus{
    opacity: 1;
    background-color: transparent;
    color: var(--color-dark-green);
  }

  #top-menu > li > .sub-menu{
    display: none;
    justify-content: center;
    gap: 20px;
    left: 0;
    width: 100vw;
    border: 0;
    padding: 40px 0;
    opacity: 0;
    visibility: hidden;
  }

  #top-menu > li > .sub-menu.visible{
    display: flex;
    opacity: 1;
    visibility: visible;
  }

  #top-menu > #menu-item-2763 > .sub-menu::before,
  #top-menu > #menu-item-2766 > .sub-menu::before{
    content: url(images/come-explore-with-us.svg) / "Come Explore With Us";
    width: 180px;
    padding: 0 20px;
  }

  #top-menu .sub-menu li > a{
    font-family: var(--font-serif);
    font-size: 22px;
    font-weight: bold;
    padding: 0;
  }

  #top-menu .sub-menu li > a[href="#"]:hover,
  #top-menu .sub-menu li > a[href="#"]:focus{
    color: inherit;
    cursor: default;
  }

  #top-menu .sub-menu .menu-item-has-children > a:first-child::after{
    content: "";
    display: block;
    margin: 10px 0;
    width: 100%;
    max-width: 80px;
    height: 3px;
    background-color: var(--color-yellow);
  }

  #top-menu .sub-menu .sub-menu{
    display: block;
    position: static;
    visibility: visible;
    opacity: 1;
    width: 100%;
    padding: 0;
    box-shadow: none;
    border: 0;
  }

  #top-menu .sub-menu .sub-menu li{
    display: block;
    padding: 3px 0;
  }

  #top-menu .sub-menu .sub-menu a{
    font-family: var(--font-sans);
    font-size: 20px;
    font-weight: normal;
    padding: 0;
  }

  #top-menu .sub-menu .sub-menu a::before{
    content: "\2022";
    color: var(--color-blue);
    margin: 0 16px 0 8px;
  }

  /* Mobile Nav */

  #page-container #et_mobile_nav_menu{
    margin: 0;
  }

  #main-header #et-top-navigation .mobile_nav{
    background-color: transparent;
    padding: 12px 30px;
  }

  #main-header .mobile_nav .select_page{
    color: var(--color-yellow);
    font-size: 16px;
  }

  #main-header .mobile_nav .mobile_menu_bar:before{
    color: var(--color-yellow);
    top: 7px;
  }

  #main-header .et_mobile_menu{
    top: 47px;
    border: 0;
    background-color: var(--color-light-yellow);
  }

  #main-header .et_mobile_menu li a{
    padding: 10px 0;
    border-color: rgba(0, 0, 0, 0.2);
  }

  #main-header .et_mobile_menu > li > a{
    font-weight: bold;
  }

  #main-header .et_mobile_menu > .menu-item-has-children > a{
    background-color: transparent;
    border-bottom: 3px solid var(--color-yellow);
  }

  #main-header .et_mobile_menu .sub-menu li{
    padding-left: 20px;
  }

  #main-header .et_mobile_menu .sub-menu a{
    font-family: var(--font-serif);
    font-weight: bold;
  }

  #main-header .et_mobile_menu .sub-menu .sub-menu a{
    font-family: var(--font-sans);
    font-weight: normal;
  }

  /* Notification Bar */

  #notification-bar{
    padding: 10px 0;
    background-color: var(--color-yellow);
    text-align: center;
    font-family: var(--font-sans);
    font-weight: bold;
  }

  #notification-bar .container{
    text-align: center;
  }

  #notification-bar .et_pb_button{
    font-size: 1rem;
    margin-left: 15px;
  }

/*====================
  Footer
  ====================*/

  #main-footer{
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 20px;
    padding: 20px;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
    position: relative;
    z-index: 2;
    border-bottom: 15px solid var(--color-light-blue);
    font-family: var(--font-sans);
  }

  @media (min-width:768px){
    #main-footer{
      flex-direction: row;
      padding: 40px;
      gap: 30px 60px;
    }
  }

  @media (min-width:981px){
    #main-footer{
      flex-wrap: nowrap;
      gap: 60px;
    }
  }

  #main-footer .logo_container{
    display: flex;
    flex-grow: 1;
    flex-direction: column;
    justify-content: space-between;
    width: 100%;
  }

  @media (min-width:981px){
    #main-footer .logo_container{
      width: auto;
    }
  }

  #main-footer .logo_container img{
    width: 240px;
  }

  @media (min-width:768px){
    #main-footer .logo_container img{
      width: 295px;
    }
  }

  #footer-widgets .wp-block-heading,
  #et-footer-nav h2{
    font-size: 20px;
    font-weight: bold;
    font-family: var(--font-sans);
    color: var(--color-dark-blue);
  }

  #main-footer #et-footer-nav .bottom-nav a:hover,
  #main-footer #et-footer-nav .bottom-nav a:focus,
  #footer-widgets .footer-widget a:hover,
  #footer-widgets .footer-widget a:focus{
    color: var(--color-dark-green);
    opacity: 1;
  }

  #footer-widgets{
    padding: 0;
  }

  #footer-widgets .et-social-icons,
  #footer-widgets .footer-widget,
  #footer-widgets .et_pb_widget{
    float: none;
  }

  #footer-widgets .footer-widget.footer-widget:nth-child(n){
    margin-bottom: 0 !important;
  }

  #footer-widgets .et-social-icons{
    text-align: left;
    margin-top: 15px;
  }

  #footer-widgets .et-social-icons li{
    margin: 0 5px 0 0;
  }

  #footer-widgets .et-social-icon a{
    line-height: 1;
    background-color: var(--color-yellow);
    padding: 6px 6px 5px;
    border-radius: 6px;
    color: #fff;
  }

  #footer-widgets .et-social-icon a:hover,
  #footer-widgets .et-social-icon a:focus{
    background-color: var(--color-dark-green);
    color: #fff;
  }

  #menu-footer-navigation{
    columns: 2;
    gap: 30px;
    text-align: left;
  }

  .bottom-nav{
    padding: 0;
  }

  .bottom-nav li{
    display: block;
    padding: 0;
  }

  #main-footer #et-footer-nav .bottom-nav a{
    font-weight: normal;
  }

  .footer-copyright{
    font-size: 12px;
    color: #757575;
  }

  @media (min-width:768px){
    .footer-copyright{
      font-size: 14px;
    }
  }

  @media (min-width:981px){
    .footer-copyright{
      margin-bottom: -30px;
    }
  }

  .footer-copyright a{
    font-weight: bold;
    color: #757575;
  }

  .footer-copyright a:hover,
  .footer-copyright a:focus{
    color: var(--color-dark-green);
  }

/*====================
  Elements
  ====================*/

  a, a:hover, a:focus{
    transition: all 0.4s ease-in-out !important;
  }

  /* Catalog Search */

  .catalog-search{
    display: flex;
  }

  .ol-form-field{
    flex-grow: 1;
    padding: 6px 15px;
    border: 3px solid #ddd;
    border-width: 3px 0 3px 3px;
    border-radius: 12px 0 0 12px;
    font-size: 14px;
    font-weight: bold;
  }

  @media (min-width:768px){
    .ol-form-field{
      padding: 10px 20px;
      font-size: 16px;
    }
  }

  @media (min-width:981px){
    .ol-form-field{
      padding: 10px 30px;
      font-size: 18px;
    }
  }

  .ol-form-field::placeholder{
    color: var(--color-text);
  }

  .ol-form-submit{
    padding: 6px 20px;
    background-color: var(--color-dark-blue);
    border: 0;
    border-radius: 0 12px 12px 0;
    font-family: var(--font-sans);
    font-size: 14px;
    font-weight: bold;
    color: var(--color-yellow);
    cursor: pointer;
    transition: color 0.4s ease-in-out, background-color 0.4s ease-in-out;
  }

  @media (min-width:768px){
    .ol-form-submit{
      padding: 10px 30px;
      font-size: 16px;
    }
  }

  @media (min-width:981px){
    .ol-form-submit{
      padding: 10px 40px;
      font-size: 18px;
    }
  }

  .ol-form-submit:hover,
  .ol-form-submit:focus{
    background-color: var(--color-yellow);
    color: var(--color-dark-blue);
    transition: color 0.4s ease-in-out, background-color 0.4s ease-in-out;
  }

  /* Event Feed */

  .ol-event-feed .s-lc-ea-h3{
    display: none;
  }

  .ol-event-feed table.s-lc-w-table{
    border: 0;
    margin: 0;
  }

  .ol-event-feed tr.s-lc-w-dtr,
  .ol-event-feed tr.s-lc-w-dtr:nth-of-type(odd),
  .ol-event-feed tr.s-lc-w-dtr:nth-of-type(even){
    background-color: transparent;
    border: 0;
    vertical-align: top;
  }

  .ol-event-feed td.s-lc-w-dtd,
  .ol-event-feed td.s-lc-w-ctd{
    border: 0;
    padding: 0 0 25px;
  }

  .ol-event-feed td.s-lc-w-ctd{
    padding: 10px 0 25px 20px;
  }

  .ol-event-feed .s-lc-w{
    padding: 0;
    margin-bottom: 0;
  }

  .ol-event-feed .s-lc-w-date{
    width: auto;
    float: none;
    margin-right: 0;
    border: 0;
    padding: 0;
    border-radius: 8px;
    font-family: var(--font-sans);
  }

  .ol-event-feed .s-lc-w-date-m{
    border-radius: 8px 8px 0 0;
    background-color: var(--color-dark-blue) !important;
    color: var(--color-yellow);
    font-weight: bold;
    font-size: 18px;
  }

  .ol-event-feed .s-lc-w-date-d{
    color: var(--color-dark-green);
    font-weight: bold;
    font-size: 30px;
    margin: 5px 0 -3px;
  }

  .ol-event-feed .s-lc-w-date-t{
    color: #222;
    font-size: 14px;
  }

  .ol-event-feed .s-lc-w-title{
    font-weight: bold;
    font-size: 18px;
    line-height: 1.3;
    color: #222;
  }

  .ol-event-feed .s-lc-w-loc{
    font-size: 16px;
    line-height: 1.3;
    color: #222;
  }

  .ol-event-feed td.s-lc-w-ctd a{
    font-family: var(--font-sans);
    font-size: 16px;
    line-height: 1.3;
    color: #222;
    white-space: nowrap;
  }

  .ol-event-feed td.s-lc-w-ctd a:hover,
  .ol-event-feed td.s-lc-w-ctd a:focus{
    color: var(--color-dark-green);
  }

  .ol-event-feed td.s-lc-w-ctd a::after{
    content: 'E';
    color: #54a3da;
    font-family: ETmodules !important;
    vertical-align: middle;
  }

  /* Hours List */

  .ol-hours-list, .entry-content .ol-hours-list{
    list-style: none;
    padding-left: 0;
  }

  /* Form */

  .nf-form-cont .nf-form-fields-required, .nf-form-cont .nf-error-msg{
    font-size: 14px;
  }

  .nf-form-cont .field-wrap .nf-field-label{
    font-family: var(--font-sans);
    margin-bottom: 4px;
  }

  .nf-form-cont .nf-field-container{
    margin-bottom: 1em;
  }

  .nf-form-cont .ninja-forms-field{
    padding: 10px 20px;
    border-radius: 20px;
    border: 2px solid #ddd;
  }

  .nf-form-cont .ninja-forms-field[type=submit]{
    color: #f1a62a;
    background-color: #0a3b61;
    padding: 12px 30px;
    border-radius: 8px;
    border: 0;
    font-weight: bold;
    font-family: var(--font-sans);
    font-size: 1em;
    transition: background-color 0.3s, color 0.3s;
    cursor: pointer;
  }

  .nf-form-cont .ninja-forms-field[type=submit]:focus,
  .nf-form-cont .ninja-forms-field[type=submit]:hover{
    color: #fff;
    background-color: #067939;
    transition: background-color 0.3s, color 0.3s;
  }

  .nf-form-cont .ninja-forms-field[type=submit][disabled="true"]{
    color: #888;
    background-color: #ccc;
  }

/*====================
  Blog
  ====================*/

  .post-meta{
    font-family: var(--font-sans);
  }

  /* Widgets */

  .et_pb_widget a{
    color: #222;
  }

  .wp-block-latest-posts__post-title{
    display: block;
    line-height: 1.5;
  }

  .wp-block-latest-posts__post-date{
    font-family: var(--font-sans);
  }

  .wp-block-latest-posts__post-excerpt{
    font-size: 16px;
    line-height: 1.8;
  }
