@charset "UTF-8";
@-webkit-keyframes beaut-appear {
  0% {
    right: -400px; }
  100% {
    right: 0; } }

@-moz-keyframes beaut-appear {
  0% {
    right: -400px; }
  100% {
    right: 0; } }

@keyframes beaut-appear {
  0% {
    right: -400px; }
  100% {
    right: 0; } }

@-webkit-keyframes beaut-disappear {
  0% {
    right: 0; }
  100% {
    right: -400px; } }

@-moz-keyframes beaut-disappear {
  0% {
    right: 0; }
  100% {
    right: -400px; } }

@keyframes beaut-disappear {
  0% {
    right: 0; }
  100% {
    right: -400px; } }

/* Muli */
@font-face {
  font-family: "Muli";
  font-style: normal;
  font-weight: 200;
  src: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-200.eot?") format("eot"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-200.woff") format("woff"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-200.ttf") format("truetype"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-200.svg#Muli") format("svg");
  font-display: swap; }

@font-face {
  font-family: "Muli";
  font-style: normal;
  font-weight: 300;
  src: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-300.eot?") format("eot"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-300.woff") format("woff"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-300.ttf") format("truetype"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-300.svg#Muli") format("svg");
  font-display: swap; }

@font-face {
  font-family: "Muli";
  font-style: normal;
  font-weight: 400;
  src: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-regular.eot?") format("eot"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-regular.woff") format("woff"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-regular.ttf") format("truetype"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-regular.svg#Muli") format("svg");
  font-display: swap; }

@font-face {
  font-family: "Muli";
  font-style: normal;
  font-weight: 600;
  src: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-600.eot?") format("eot"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-600.woff") format("woff"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-600.ttf") format("truetype"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-600.svg#Muli") format("svg");
  font-display: swap; }

@font-face {
  font-family: "Muli";
  font-style: normal;
  font-weight: 700;
  src: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-700.eot?") format("eot"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-700.woff") format("woff"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-700.ttf") format("truetype"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-700.svg#Muli") format("svg");
  font-display: swap; }

@font-face {
  font-family: "Muli";
  font-style: normal;
  font-weight: 800;
  src: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-800.eot?") format("eot"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-800.woff") format("woff"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-800.ttf") format("truetype"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/muli/muli-v13-latin-800.svg#Muli") format("svg");
  font-display: swap; }

/* Fontello */
@font-face {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  src: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/fontello/font/fontello.eot?") format("eot"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/fontello/font/fontello.woff") format("woff"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/fontello/font/fontello.ttf") format("truetype"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/fontello/font/fontello.svg#fontello") format("svg");
  font-display: swap; }

[class^="icon-"]:before, [class*=" icon-"]:before {
  font-family: 'fontello';
  font-style: normal;
  font-weight: normal;
  speak: none;
  display: inline-block;
  text-decoration: inherit;
  width: 1em;
  margin-right: .2em;
  text-align: center;
  /* opacity: .8; */
  /* For safety - reset parent styles, that can break glyph codes*/
  font-variant: normal;
  text-transform: none;
  /* fix buttons height, for twitter bootstrap */
  line-height: 1em;
  /* Animation center compensation - margins should be symmetric */
  /* remove if not needed */
  margin-left: .2em;
  /* you can be more comfortable with increased icons size */
  /* font-size: 120%; */
  /* Font smoothing. That was taken from TWBS */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  /* Uncomment for 3D effect */
  /* text-shadow: 1px 1px 1px rgba(127, 127, 127, 0.3); */ }

.icon-down-open:before {
  content: '\e800'; }

/* '' */
.icon-left-open:before {
  content: '\e801'; }

/* '' */
.icon-right-open:before {
  content: '\e802'; }

/* '' */
.icon-up-open:before {
  content: '\e803'; }

/* '' */
.icon-check:before {
  content: '\e804'; }

/* '' */
.icon-calendar:before {
  content: '\e805'; }

/* '' */
.icon-phone:before {
  content: '\e806'; }

/* '' */
.icon-monitor:before {
  content: '\e807'; }

/* '' */
.icon-mobile:before {
  content: '\e808'; }

/* '' */
.icon-play:before {
  content: '\e809'; }

/* '' */
.icon-user:before {
  content: '\e80a'; }

/* '' */
.icon-lock:before {
  content: '\e80b'; }

/* '' */
.icon-camera:before {
  content: '\e80c'; }

/* '' */
.icon-location:before {
  content: '\e80d'; }

/* '' */
.icon-mail:before {
  content: '\e80e'; }

/* '' */
.icon-gift:before {
  content: '\e80f'; }

/* '' */
.icon-down:before {
  content: '\e810'; }

/* '' */
.icon-left:before {
  content: '\e811'; }

/* '' */
.icon-right:before {
  content: '\e812'; }

/* '' */
.icon-up:before {
  content: '\e813'; }

/* '' */
.icon-download:before {
  content: '\e814'; }

/* '' */
.icon-basket:before {
  content: '\e815'; }

/* '' */
.icon-doc:before {
  content: '\e816'; }

/* '' */
.icon-quote:before {
  content: '\e817'; }

/* '' */
.icon-ok-circled2:before {
  content: '\e818'; }

/* '' */
.icon-ok-circled:before {
  content: '\e819'; }

/* '' */
.icon-plus:before {
  content: '\e81a'; }

/* '' */
.icon-minus:before {
  content: '\e81b'; }

/* '' */
.icon-cancel:before {
  content: '\e81c'; }

/* '' */
.icon-twitter:before {
  content: '\f099'; }

/* '' */
.icon-facebook:before {
  content: '\f09a'; }

/* '' */
.icon-rss:before {
  content: '\f09e'; }

/* '' */
.icon-menu:before {
  content: '\f0c9'; }

/* '' */
.icon-gplus:before {
  content: '\f0d5'; }

/* '' */
.icon-mail-alt:before {
  content: '\f0e0'; }

/* '' */
.icon-linkedin:before {
  content: '\f0e1'; }

/* '' */
.icon-angle-double-left:before {
  content: '\f100'; }

/* '' */
.icon-angle-double-right:before {
  content: '\f101'; }

/* '' */
.icon-angle-double-up:before {
  content: '\f102'; }

/* '' */
.icon-angle-double-down:before {
  content: '\f103'; }

/* '' */
.icon-youtube:before {
  content: '\f167'; }

/* '' */
.icon-instagram:before {
  content: '\f16d'; }

/* '' */
.icon-box:before {
  content: '\f187'; }

/* '' */
.icon-fax:before {
  content: '\f1ac'; }

/* '' */
.icon-wifi:before {
  content: '\f1eb'; }

/* '' */
.icon-pinterest:before {
  content: '\f231'; }

/* '' */
.icon-tripadvisor:before {
  content: '\f262'; }

/* '' */
.icon-parking:before {
  content: '\f288'; }

/* '' */
/* ---------- Basic styles ---------- */
body {
  font-family: "Muli", sans-serif;
  font-size: 14px;
  line-height: 1.42857143;
  font-weight: 300;
  color: #12516B;
  background-color: #FFFFFF;
  overflow-x: hidden; }

h1, .h1, h2, .h2, h3, .h3 {
  margin: 5px 0; }

img {
  vertical-align: middle;
  display: block;
  max-width: 100%; }

a {
  color: #12516B;
  transition: all .35s; }
  a:hover, a:focus {
    color: #2B2B2B;
    text-decoration: none; }

/* Helpers */
body:not(.user-is-tabbing) button:focus, body:not(.user-is-tabbing) select:focus, body:not(.user-is-tabbing) h3:focus, body:not(.user-is-tabbing) h4:focus {
  outline: none !important; }

.bg-grey {
  background: #f5f5f5; }

.bg-cream {
  background: #F5E7D2; }

.bg-img {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover; }

.white_frame {
  border: 15px solid #fafafa;
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.2); }
  .white_frame:hover {
    opacity: 0.7; }

.relative {
  position: relative; }

.full-page-wrapper {
  overflow: hidden; }

@media (max-width: 767px) {
  .homepage .video-wrapper {
    margin-top: 70px;
    min-height: 375px;
    position: relative;
    overflow: hidden; }
    .homepage .video-wrapper video {
      width: 100%;
      height: 100%;
      object-fit: cover;
      position: absolute;
      top: 0;
      left: 0; } }

.title_container {
  width: 100%; }
  .title_container h2, .title_container.page_title {
    text-transform: uppercase;
    text-align: center;
    color: #4F6D76;
    font-size: 3.5rem;
    margin-top: 0;
    font-weight: 400; }
  .title_container h4, .title_container .h4 {
    display: block;
    text-transform: uppercase;
    text-align: center;
    color: #12516B; }

.content {
  font-size: 1.7rem;
  color: #4F6D76;
  line-height: 2.4rem; }
  .content a {
    font-weight: 600; }

.content_2 {
  column-count: 2;
  column-gap: 5rem; }

.content_center {
  margin: 0 auto;
  float: none;
  text-align: center; }

.container_2000 {
  max-width: 2000px;
  width: 100% !important;
  margin: 0 auto; }

.container_1500 {
  max-width: 1500px;
  width: 100% !important;
  margin: 0 auto; }

.container_1300 {
  max-width: 1300px;
  width: 100% !important;
  margin: 0 auto; }

.padding_30 {
  padding: 30px 0; }

.padding_50 {
  padding: 50px 0; }

.no_padding {
  padding: 0; }

.img_zoom {
  position: relative;
  overflow: hidden;
  display: block;
  transition: all 0.5s ease; }
  .img_zoom:hover img, .img_zoom:hover .item_bg, .img_zoom:hover .item_bg_2 {
    -webkit-transform: scale(1.05);
    -ms-transform: scale(1.05);
    transform: scale(1.05);
    -webkit-transition: transform .8s;
    -o-transition: transform .8s;
    -webkit-transition: -webkit-transform .8s;
    transition: -webkit-transform .8s;
    transition: transform .8s;
    transition: transform .8s,-webkit-transform .8s; }

.intro {
  text-align: center; }

.price {
  text-transform: uppercase;
  font-size: 1.2rem; }
  .price .price_text {
    font-size: 2rem;
    font-weight: 400;
    letter-spacing: .4rem;
    padding-left: 5px; }

/* Buttons */
.button {
  display: inline-block;
  margin: 0;
  padding: 7px 10px;
  text-align: center;
  color: #FFFFFF;
  cursor: pointer;
  background: #12516B;
  border-radius: 0px;
  border: none;
  transition: all 0.2s linear;
  -webkit-appearance: none;
  text-transform: uppercase;
  letter-spacing: .1rem;
  font-weight: 400 !important; }
  .button:hover, .button:focus {
    color: #FFFFFF;
    background: #4F6D76;
    opacity: .9; }
  .button.button_cream {
    background: #F5E7D2;
    color: #2B2B2B; }
    .button.button_cream:hover {
      opacity: .8; }
  .button.button_white {
    background: #FFFFFF;
    color: #4F6D76; }
  .button.button_pink {
    background: #AA1360;
    color: #FFFFFF; }
  .button.dining-popup {
    margin: 20px 0 0 0;
    width: 100%; }

.button_border {
  color: #4F6D76 !important;
  background: none !important;
  border: 1px solid #4F6D76; }

.button_text {
  text-transform: uppercase;
  font-weight: 500; }

.btn-wrapper .button {
  margin-bottom: 5px; }

input, button, select, textarea {
  color: #333; }

.iframe-container iframe {
  height: calc(100vh - 4px);
  width: 100%;
  box-sizing: border-box;
  padding: 100px 0 0; }

/* Slick Slider */
.slick-slider {
  position: relative;
  display: block;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -khtml-user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent; }

.slick-list {
  position: relative;
  display: block;
  overflow: hidden;
  margin: 0;
  padding: 0; }
  .slick-list:focus {
    outline: none; }
  .slick-list.dragging {
    cursor: pointer; }

.slick-slider .slick-track, .slick-slider .slick-list {
  transform: translate3d(0, 0, 0); }

.slick-track {
  position: relative;
  top: 0;
  left: 0;
  display: block; }
  .slick-track:before {
    display: table;
    content: ''; }
  .slick-track:after {
    display: table;
    content: '';
    clear: both; }

.slick-loading .slick-track {
  visibility: hidden; }

.slick-slide {
  display: none;
  float: left;
  height: 100%;
  min-height: 1px; }

[dir='rtl'] .slick-slide {
  float: right; }

.slick-slide img {
  display: block; }

.slick-slide.slick-loading img {
  display: none; }

.slick-slide.dragging img {
  pointer-events: none; }

.slick-initialized .slick-slide {
  display: block; }

.slick-loading .slick-slide {
  visibility: hidden; }

.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent; }

.slick-arrow.slick-hidden {
  display: none; }

.slick-loading .slick-list {
  background: #fff url(/Assets/Images/ajax-loader.gif) center center no-repeat; }

@font-face {
  font-family: "slick";
  font-style: normal;
  font-weight: 400;
  src: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/slick/slick.eot?") format("eot"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/slick/slick.woff") format("woff"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/slick/slick.ttf") format("truetype"), url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/Assets/Styles/fonts/slick/slick.svg#slick") format("svg");
  font-display: swap; }

.slick_slider_item {
  padding: 0 5px;
  position: relative; }

.slick-prev, .slick-next {
  font-size: 0;
  line-height: 0;
  position: absolute;
  display: block;
  width: 100px;
  height: 10px;
  margin-top: -10px;
  margin-top: -10px;
  padding: 0;
  cursor: pointer;
  color: transparent;
  border: none;
  outline: none;
  background: transparent;
  z-index: 100; }

.slick-prev:hover, .slick-prev:focus {
  color: transparent;
  outline: none;
  background: transparent; }

.slick-next:hover, .slick-next:focus {
  color: transparent;
  outline: none;
  background: transparent; }

.slick-prev:hover:before, .slick-prev:focus:before {
  opacity: 1; }

.slick-next:hover:before, .slick-next:focus:before {
  opacity: 1; }

.slick-prev.slick-disabled:before, .slick-next.slick-disabled:before {
  opacity: .25; }

.slick-prev {
  left: -25px; }

[dir='rtl'] .slick-prev {
  right: -25px;
  left: auto; }

.slick-next {
  right: -25px; }

[dir='rtl'] .slick-next {
  right: auto;
  left: -25px; }

.slick-dots {
  position: absolute;
  bottom: -45px;
  display: block;
  width: 100%;
  padding: 0;
  list-style: none;
  text-align: center; }
  .slick-dots li {
    position: relative;
    display: inline-block;
    width: 20px;
    height: 20px;
    margin: 0 5px;
    padding: 0;
    cursor: pointer; }
    .slick-dots li button {
      font-size: 0;
      line-height: 0;
      display: block;
      width: 20px;
      height: 20px;
      padding: 5px;
      cursor: pointer;
      color: transparent;
      border: 0;
      outline: none;
      background: transparent; }
      .slick-dots li button:hover, .slick-dots li button:focus {
        outline: none; }
      .slick-dots li button:hover:before, .slick-dots li button:focus:before {
        opacity: 1; }
      .slick-dots li button:before {
        font-family: 'slick';
        font-size: 6px;
        line-height: 20px;
        position: absolute;
        top: 0;
        left: 0;
        width: 20px;
        height: 20px;
        content: '•';
        text-align: center;
        opacity: .25;
        color: #000000;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale; }
    .slick-dots li.slick-active button:before {
      opacity: .75;
      color: #000000; }

.slick_responsive .slick-prev, .slick_packages .slick-prev {
  background-image: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/assets/images/arrow_left.svg") !important;
  background-repeat: no-repeat !important;
  left: 39%; }

.slick_responsive .slick-next, .slick_packages .slick-next {
  background-image: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/assets/images/arrow_right.svg") !important;
  background-repeat: no-repeat !important;
  right: 39%; }

.slick_responsive .slick-prev, .slick_responsive .slick-next, .slick_packages .slick-prev, .slick_packages .slick-next {
  bottom: 5%; }

.slick_responsive .slick-list, .slick_packages .slick-list {
  padding: 0 10% !important; }
  .slick_responsive .slick-list .slick_slider_item:not(.slick-active), .slick_packages .slick-list .slick_slider_item:not(.slick-active) {
    opacity: .5;
    transition: opacity .6s; }

@media (max-width: 991px) {
  .slick_responsive .slick-prev, .slick_packages .slick-prev {
    left: 10% !important; }
  .slick_responsive .slick-next, .slick_packages .slick-next {
    right: 10% !important; } }

.slick_packages {
  padding-bottom: 40px; }
  .slick_packages .slick-list {
    padding: 0 15% !important; }
    .slick_packages .slick-list img {
      margin: 0 auto; }
    .slick_packages .slick-list h4 {
      max-width: 500px;
      margin: 0 auto; }
  .slick_packages .slick-prev {
    left: 40%; }
  .slick_packages .slick-next {
    right: 40%; }
  @media (max-width: 991px) {
    .slick_packages .slick-list {
      padding: 0 5% !important; } }

.slick_general .slick-prev, .slick_general .slick-next, .slick_general2 .slick-prev, .slick_general2 .slick-next {
  top: 50%;
  display: block;
  width: 20px;
  height: 20px; }

.slick_general .slick-prev:before, .slick_general .slick-next:before, .slick_general2 .slick-prev:before, .slick_general2 .slick-next:before {
  font-family: 'fontello';
  font-size: 20px;
  line-height: 1;
  opacity: .75;
  color: #4F6D76;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

.slick_general .slick-prev:before, .slick_general2 .slick-prev:before {
  content: '\e801'; }

.slick_general [dir='rtl'] .slick-prev:before, .slick_general2 [dir='rtl'] .slick-prev:before {
  content: '\e801'; }

.slick_general .slick-next:before, .slick_general2 .slick-next:before {
  content: '\e802'; }

.slick_general [dir='rtl'] .slick-next:before, .slick_general2 [dir='rtl'] .slick-next:before {
  content: '\e802'; }

/* Nav base */
nav:not(.nav-sec) {
  float: left;
  margin: 0;
  padding: 0; }
  nav:not(.nav-sec) ul, nav:not(.nav-sec) li, nav:not(.nav-sec) a {
    /*float: left;*/
    margin: 0;
    padding: 0; }
  nav:not(.nav-sec) ul {
    list-style: none;
    list-style-image: none; }

/* Forms */
.form {
  width: 100%; }
  .form td {
    padding-bottom: 1em;
    vertical-align: top; }
  .form tr td:first-child {
    width: 35%;
    padding-top: 2px;
    padding-right: 15px; }

.textbox {
  padding: 2px;
  background: #FFFFFF;
  border: 1px solid #999;
  border-radius: 0; }

.form select {
  padding: 2px;
  background: #FFFFFF;
  border: 1px solid #999;
  border-radius: 0;
  padding: 1px; }

.form .textbox, .form select {
  float: left;
  width: 60%; }

.form .button {
  float: left;
  width: 60%;
  margin: 0; }

.form .textbox_medium {
  width: 80%;
  height: 4.7em; }

.form .textbox_large {
  width: 80%;
  height: 9em; }

.form .captcha img {
  width: 100% !important;
  height: auto !important; }

#recaptcha_image {
  width: 100% !important;
  height: auto !important; }

.form .captcha .textbox {
  clear: both;
  margin: 15px 40% 5px 0; }

.form .captcha a {
  float: left;
  margin: 0 15px 0 0;
  font-size: 93%; }

.form .radio input, .form .radio label {
  float: left; }

.form .radio input {
  margin: 3px 0 0 0; }

.form .radio label {
  margin: 0 15px 0 5px; }

.form .multi_input select, .form .multi_input .textbox {
  width: 29%;
  margin-right: 2%; }

.form .multi_input select {
  width: 20%; }

.form .multi_input .textbox {
  width: 38%; }

.form_cal {
  font-size: 93%;
  background: rgba(255, 255, 255, 0.8); }

.icon_cal {
  float: left;
  margin: 2px 0 0 -19px;
  color: #999; }

.icon_cal_wrap {
  float: left;
  position: relative;
  background: #FFFFFF; }
  .icon_cal_wrap input {
    position: relative;
    z-index: 20;
    margin: 0 !important;
    background: none !important; }
  .icon_cal_wrap .icon_cal {
    position: absolute;
    z-index: 10;
    top: 4px;
    right: 5px;
    margin: 0; }

/* Form in 2 blocks */
.form_wrapper {
  float: left;
  width: 100%;
  margin: 20px 0; }
  .form_wrapper .form {
    float: left;
    width: 100%; }
  .form_wrapper .error {
    float: left;
    width: 100%;
    margin: 20px 0; }
  .form_wrapper .form {
    width: 50%; }
    .form_wrapper .form:first-child tr td:last-child {
      padding-right: 15px; }
    .form_wrapper .form:last-child tr td:first-child {
      padding-left: 15px; }
  .form_wrapper .form-control {
    width: 90%; }
  .form_wrapper .TimeDD .form-control {
    width: 45%;
    margin-right: 5px; }
  .form_wrapper .submit_btn {
    display: inline-block; }

/* Google Captcha */
.g-recaptcha {
  position: absolute;
  z-index: 100000; }

@media (max-width: 340px) {
  /* Fix for reCaptcha on small phones */
  .g-recaptcha {
    transform: scale(0.77);
    transform-origin: 0 0; }
    .g-recaptcha > div {
      max-width: 260px !important; } }

/* Video */
.video_res {
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 25px;
  height: 0; }
  .video_res iframe, .video_res object, .video_res embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }

/* Image overlay */
.img_overlay_wrap {
  position: relative;
  float: left;
  width: 100%;
  height: auto;
  overflow: hidden; }

.img_overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto; }

.img_overlay_block {
  left: 50px;
  width: 300px;
  padding: 15px;
  background: rgba(255, 255, 255, 0.8); }

/* ---------- Layout ---------- */
.site-wrapper {
  position: relative;
  z-index: 2; }

@media (min-width: 1920px) {
  .site-wrapper, .header .wrapper {
    max-width: 1920px;
    margin: 0 auto; } }

.noheaderimage .header {
  position: relative;
  background: #F9F9F9;
  height: 70px; }
  .noheaderimage .header .nav_wrapper {
    top: 0 !important; }
    .noheaderimage .header .nav_wrapper .btn-gift {
      border-color: #2B2B2B; }
      .noheaderimage .header .nav_wrapper .btn-gift span {
        display: none; }
  .noheaderimage .header .logo svg {
    width: 100px;
    height: 50px;
    fill: #12516B;
    transition: fill .35s, height .35s, width .35s; }
  .noheaderimage .header .nav-menu a {
    color: #2B2B2B; }
    .noheaderimage .header .nav-menu a.btn-gift svg {
      fill: #2B2B2B; }
  .noheaderimage .header .mob-nav-btn, .noheaderimage .header .btn-gift {
    border-color: #4F6D76; }
  .noheaderimage .header .mob-nav-btn .hamburger::after {
    color: #2B2B2B; }
  .noheaderimage .header .mob-nav-btn.open .hamburger::after {
    color: transparent; }
  .noheaderimage .header .menui {
    background: #2B2B2B; }

/* Header */
.header {
  padding: 10px 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100; }
  .header.stick {
    position: fixed;
    background: #F9F9F9;
    height: 80px; }
    .header.stick .nav_wrapper .btn-gift {
      border-color: #2B2B2B; }
      .header.stick .nav_wrapper .btn-gift span {
        display: none; }
    .header.stick .logo svg {
      width: 100px;
      height: 50px;
      fill: #12516B;
      transition: fill .35s, height .35s, width .35s; }
    .header.stick .nav-menu a {
      color: #2B2B2B; }
      .header.stick .nav-menu a.btn-gift svg {
        fill: #2B2B2B; }
    .header.stick .mob-nav-btn, .header.stick .btn-gift {
      border-color: #4F6D76; }
    .header.stick .mob-nav-btn .hamburger::after {
      color: #2B2B2B; }
    .header.stick .menui {
      background: #2B2B2B !important; }
  .header .inner {
    width: 100%;
    position: relative;
    padding: 0 15px;
    z-index: 100; }
    @media (min-width: 768px) {
      .header .inner .nav_wrapper {
        position: absolute;
        right: 2%;
        display: inline-block; }
        .header .inner .nav_wrapper .nav-menu-wrapper {
          float: right; } }
  .header .logo {
    position: absolute;
    top: 5px;
    left: 2%; }
    .header .logo svg {
      width: 200px;
      height: auto;
      fill: #FFFFFF;
      transition: fill .35s, height .35s, width .35s; }

.mob-nav-btn {
  position: relative;
  float: right;
  padding: 0;
  border: none;
  background-color: rgba(0, 0, 0, 0);
  margin-left: 10px;
  width: 60px;
  height: 60px;
  z-index: 10; }
  .mob-nav-btn .hamburger {
    display: block;
    position: absolute;
    top: 45%;
    left: 50%;
    transform: translate(-45%, -6px);
    width: 25px; }
    .mob-nav-btn .hamburger::after {
      content: attr(data-title);
      color: #12516B;
      line-height: 1;
      font-size: 11px;
      letter-spacing: -.03em;
      text-transform: uppercase;
      position: absolute;
      bottom: -28px;
      left: -15px;
      width: 60px; }
      @media (min-width: 768px) {
        .mob-nav-btn .hamburger::after {
          color: #fff; } }
  .mob-nav-btn .menui {
    background-color: #FFFFFF;
    border-radius: 0;
    position: absolute;
    left: 0;
    height: 1px;
    width: 30px;
    transition: top 0.5s cubic-bezier(0.75, 0, 0.29, 1.01), transform 0.5s cubic-bezier(0.75, 0, 0.29, 1.01), opacity 0.5s cubic-bezier(0.75, 0, 0.29, 1.01), background 0.35s, width 0.5s cubic-bezier(0.75, 0, 0.29, 1.01); }
    .mob-nav-btn .menui.top-menu {
      top: -2px; }
    .mob-nav-btn .menui.mid-menu {
      top: 5px; }
    .mob-nav-btn .menui.bottom-menu {
      top: 12px; }
  .mob-nav-btn.open .menui.top-menu {
    top: 5px;
    transform: rotate(45deg); }
  .mob-nav-btn.open .menui.mid-menu {
    opacity: 0; }
  .mob-nav-btn.open .menui.bottom-menu {
    top: 5px;
    width: 30px;
    transform: rotate(-225deg); }
  .mob-nav-btn.open .hamburger::after {
    color: transparent; }

@media (min-width: 768px) {
  .homepage .menui {
    background-color: #FFFFFF; }
  .mob-nav-btn.open .menui {
    background-color: #FFFFFF !important; }
  .mob-nav-menu {
    display: none !important; } }

@media (max-width: 767px) {
  .menui.bottom-menu {
    right: auto;
    left: 0; }
  .mob-nav-menu {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    padding-top: 70px;
    background: #FFFFFF;
    font-size: 16px;
    overflow: hidden;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
    z-index: 90; }
    .mob-nav-menu ul {
      margin: 0;
      list-style: none;
      padding: 0px; }
    .mob-nav-menu li {
      padding-bottom: 0;
      position: relative; }
    .mob-nav-menu ul li a {
      display: block;
      padding: 10px 15px;
      color: #000000; }
    .mob-nav-menu ul ul {
      background-color: rgba(255, 255, 255, 0.11);
      display: none;
      padding: 0px; }
      .mob-nav-menu ul ul li {
        padding-left: 2%; }
    .mob-nav-menu .icon-down-open {
      cursor: pointer;
      height: 38px;
      line-height: 40px;
      position: absolute;
      right: 0;
      text-align: center;
      top: 0;
      width: 50px; }
    .mob-nav-menu > ul > li > a {
      color: #000000;
      border-bottom: 1px solid #e5e5e5;
      font-size: 14px;
      text-transform: uppercase; }
    .mob-nav-menu .social li {
      width: 23.3%; }
      .mob-nav-menu .social li a {
        text-align: center; }
  .dropdown dt a {
    border-left: none;
    padding: 0; } }

.nav-menu-wrapper .nav-menu ul li {
  position: relative;
  display: inline-block; }
  .nav-menu-wrapper .nav-menu ul li#nav10 li a {
    font-size: 1.3rem; }
  .nav-menu-wrapper .nav-menu ul li a {
    display: block;
    font-size: 15px;
    font-weight: 400;
    text-transform: uppercase;
    text-decoration: none;
    transform: translateY(2px);
    color: #FFFFFF; }
  .nav-menu-wrapper .nav-menu ul li .btn-gift {
    border-right: 1px solid rgba(255, 255, 255, 0.5);
    border-left: 1px solid rgba(255, 255, 255, 0.5);
    padding-right: 20px;
    margin-left: 10px; }
    .nav-menu-wrapper .nav-menu ul li .btn-gift svg {
      width: 30px;
      height: 16px;
      fill: #FFFFFF; }

/* Dropdown Menu */
@media (min-width: 768px) {
  .nav-menu-dropdown {
    display: none;
    background: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/assets/images/menuBG.jpg");
    background-size: cover;
    background-repeat: no-repeat;
    font-size: 1.3rem;
    position: fixed;
    text-align: left;
    text-transform: uppercase;
    letter-spacing: 1.0px;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 9; }
    .nav-menu-dropdown.open {
      flex-flow: column nowrap;
      justify-content: center;
      align-items: center; }
    .nav-menu-dropdown .mm_wrapper {
      border: 20px solid #FFFFFF;
      height: 100%; }
      .nav-menu-dropdown .mm_wrapper .mm_container {
        position: relative;
        display: block;
        background: rgba(20, 33, 51, 0.5);
        height: 100%; }
        .nav-menu-dropdown .mm_wrapper .mm_container .mm_item {
          position: absolute;
          transform: translateY(-50%);
          top: 50%;
          left: 10%;
          width: 100%;
          width: 100%;
          max-width: 1500px;
          margin: 0 auto;
          padding: 0 5%;
          z-index: 2; }
          .nav-menu-dropdown .mm_wrapper .mm_container .mm_item .btn-gift {
            padding: 12px 20px 12px 40px;
            margin-bottom: 10px;
            font-size: 16px;
            position: relative;
            background-color: #c00; }
            .nav-menu-dropdown .mm_wrapper .mm_container .mm_item .btn-gift svg {
              fill: #fff;
              width: 20px;
              height: 20px;
              position: absolute;
              top: 12px;
              left: 10px; }
        .nav-menu-dropdown .mm_wrapper .mm_container .contact_item {
          position: absolute;
          bottom: 2%;
          width: 100%;
          padding: 0 5%;
          text-align: center;
          z-index: 1; }
          .nav-menu-dropdown .mm_wrapper .mm_container .contact_item .address, .nav-menu-dropdown .mm_wrapper .mm_container .contact_item .contact {
            display: inline-block; }
            .nav-menu-dropdown .mm_wrapper .mm_container .contact_item .address a, .nav-menu-dropdown .mm_wrapper .mm_container .contact_item .contact a {
              color: #FFFFFF; }
          .nav-menu-dropdown .mm_wrapper .mm_container .contact_item .logo_dd {
            display: block;
            width: 160px;
            height: auto;
            fill: #FFFFFF;
            transition: fill .35s, height .35s, width .35s;
            margin: 0 auto; }
    .nav-menu-dropdown nav {
      padding: 0 30px 0 0;
      position: relative; }
      .nav-menu-dropdown nav > ul {
        column-count: 2;
        column-gap: 20px; }
        .nav-menu-dropdown nav > ul > li {
          padding: 3px 5px 3px 0;
          width: 100%; }
          .nav-menu-dropdown nav > ul > li > a {
            display: inline-block;
            color: #FFFFFF;
            padding: 0;
            font-size: 2.5rem;
            text-transform: uppercase;
            line-height: 40px; }
          .nav-menu-dropdown nav > ul > li i {
            color: #FFFFFF;
            cursor: pointer;
            font-size: 2.5rem;
            line-height: 40px; }
        .nav-menu-dropdown nav > ul ul {
          display: block; }
          .nav-menu-dropdown nav > ul ul a {
            color: #FFFFFF;
            font-size: 18px;
            text-transform: none;
            line-height: 35px;
            padding-left: 5px; }
          .nav-menu-dropdown nav > ul ul li {
            display: inline-block;
            margin-right: 5px; }
            .nav-menu-dropdown nav > ul ul li:after {
              content: '/';
              color: rgba(255, 255, 255, 0.8);
              padding: 0 10px;
              font-size: 1.8rem;
              line-height: 35px; }
            .nav-menu-dropdown nav > ul ul li a {
              padding-left: 5px; }
          .nav-menu-dropdown nav > ul ul li:last-child:after {
            display: none; }
          .nav-menu-dropdown nav > ul ul ul {
            display: none; }
      .nav-menu-dropdown nav a:hover {
        opacity: .8; }
    .nav-menu-dropdown .promo_wrapper {
      position: relative;
      display: inline-block;
      border: 20px solid #FFFFFF; }
      .nav-menu-dropdown .promo_wrapper .panel-offer {
        position: absolute;
        margin: 0 auto;
        display: block;
        text-align: center;
        z-index: 10;
        height: 100%; }
        .nav-menu-dropdown .promo_wrapper .panel-offer .grid_text {
          padding: 10px 0;
          margin: 0 auto;
          display: inline-block; }
          .nav-menu-dropdown .promo_wrapper .panel-offer .grid_text h3 {
            color: #FFFFFF; }
        .nav-menu-dropdown .promo_wrapper .panel-offer .btn-wrapper {
          position: absolute;
          bottom: 20px;
          width: 100%; }
          .nav-menu-dropdown .promo_wrapper .panel-offer .btn-wrapper .btn {
            font-size: 18px;
            padding: 15px 20px; } }

@media (min-width: 992px) {
  .nav-menu-dropdown nav {
    float: left;
    width: 100%; } }

@media (min-width: 1600px) {
  .nav-menu-dropdown .menu-panel a {
    padding: 160px 40px 40px; } }

/* Content */
.contentpage .offers_panel {
  margin-bottom: 20px; }
  .contentpage .offers_panel .slick_responsive {
    background: #FFFFFF; }

.contentpage .content {
  font-size: 1.6rem;
  text-align: center !important;
  line-height: 3rem;
  margin-bottom: 40px; }
  .contentpage .content img {
    margin: 0 auto !important; }
  .contentpage .content .btn-wrapper {
    margin-top: 20px; }
    .contentpage .content .btn-wrapper .button {
      margin-bottom: 10px;
      padding: 10px 20px;
      margin-right: 10px;
      opacity: .8; }
      .contentpage .content .btn-wrapper .button:hover {
        opacity: 1;
        transition: opacity .6s; }
  .contentpage .content ul {
    letter-spacing: .16rem;
    margin-bottom: 20px;
    margin-top: 5px;
    padding: 0; }
    .contentpage .content ul li {
      list-style: none; }

/**Content SO**/
@media (min-width: 768px) {
  .content-so .booking.booking-landscape {
    display: none !important; } }

.contentpage-so .flex-row {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: flex-start;
  padding: 0; }
  .contentpage-so .flex-row .flex-col {
    flex: 0 0 100%;
    width: 100%;
    padding: 30px 0; }
    .contentpage-so .flex-row .flex-col-40 {
      order: 1; }
      .contentpage-so .flex-row .flex-col-40 .content, .contentpage-so .flex-row .flex-col-40 .btn_wrapper {
        margin-bottom: 20px; }
    .contentpage-so .flex-row .flex-col-60 {
      order: 2; }
    @media (min-width: 768px) {
      .contentpage-so .flex-row .flex-col {
        padding: 0 20px; }
        .contentpage-so .flex-row .flex-col-40 {
          flex: 0 0 40%;
          width: 40%;
          order: 2; }
        .contentpage-so .flex-row .flex-col-60 {
          flex: 0 0 60%;
          width: 60%;
          border-right: 1px solid #cecece;
          order: 1; } }
    .contentpage-so .flex-row .flex-col-content {
      text-align: justify !important; }
      @media (min-width: 1200px) {
        .contentpage-so .flex-row .flex-col-content {
          padding-right: 40px; } }

.contentpage-so .content {
  text-align: left !important; }

.general_panel .item {
  padding: 0 10px; }
  .general_panel .item a {
    position: relative;
    width: 100%;
    display: block;
    height: 100%; }
  .general_panel .item .item_bg {
    padding-bottom: 70%;
    background-position: center;
    background-size: cover; }
  .general_panel .item .img_overlay {
    background: -moz-linear-gradient(top, rgba(0, 0, 0, 0) 100%, rgba(0, 0, 0, 0.2) 0%);
    background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 100%, rgba(0, 0, 0, 0.2) 0%);
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 100%, rgba(0, 0, 0, 0.2) 0%);
    height: 100%;
    top: 0;
    z-index: 2; }
  .general_panel .item .border {
    width: 100%;
    height: 100%;
    padding: 0 20px;
    position: absolute;
    z-index: 100; }
    .general_panel .item .border:before {
      z-index: 10;
      -webkit-transition: all .5s linear;
      -o-transition: all .5s linear;
      transition: all .5s linear;
      border: 1px solid rgba(255, 255, 255, 0.5);
      content: "";
      position: absolute;
      top: 15px;
      bottom: 15px;
      left: 15px;
      right: 15px; }
    .general_panel .item .border:hover:before {
      top: 0;
      left: 0;
      right: 0;
      bottom: 0; }
  .general_panel .item .block_text {
    position: absolute;
    color: #FFFFFF;
    text-align: left;
    padding: 0 20px;
    bottom: 10%; }
    .general_panel .item .block_text .title_container h2, .general_panel .item .block_text .title_container h4 {
      text-align: left;
      color: #FFFFFF; }
    .general_panel .item .block_text .title_container h4 {
      margin: 0; }
    .general_panel .item .block_text .title_container .button {
      margin-top: 10px; }

.signuppage .page_title {
  margin-bottom: 0; }

.signuppage .newsletter_wrapper {
  margin: 15px auto 0;
  width: 480px;
  max-width: 100%; }
  .signuppage .newsletter_wrapper .newsletter-categories {
    margin-bottom: 10px; }
    .signuppage .newsletter_wrapper .newsletter-categories label {
      padding: 0 0 2px 10px; }
    .signuppage .newsletter_wrapper .newsletter-categories input[type="checkbox"] {
      transform: translateY(2px); }
  .signuppage .newsletter_wrapper .newsletter_signup_dialog label, .signuppage .newsletter_wrapper .newsletter_signup_dialog .form-control {
    float: left;
    margin-bottom: 10px; }
  .signuppage .newsletter_wrapper .newsletter_signup_dialog label {
    width: 30%;
    height: 34px;
    padding: 6px 0; }
  .signuppage .newsletter_wrapper .newsletter_signup_dialog .form-control {
    width: 70%; }
  .signuppage .newsletter_wrapper .newsletter_signup_dialog .btn {
    width: 125px; }

/* Navigation */
.nav-menu, .mob-nav-menu {
  display: none; }

/* Primary Nav */
@media (min-width: 768px) {
  .nav-menu-wrapper .nav-menu {
    height: 50px; }
  .nav-menu {
    display: block;
    float: right; }
    .nav-menu ul ul {
      display: none;
      position: absolute; }
    .nav-menu ul li {
      position: relative;
      padding: 5px 0; }
      .nav-menu ul li a {
        display: block;
        float: none;
        padding: 10px;
        font-size: 12px;
        color: #FFFFFF;
        text-transform: uppercase;
        text-decoration: none; }
      .nav-menu ul li.last a {
        padding-right: 14px; }
    .nav-menu > ul {
      margin-left: 0; }
      .nav-menu > ul > li {
        float: left; }
        .nav-menu > ul > li > a {
          color: #000000; }
        .nav-menu > ul > li ul {
          width: 200px; }
        .nav-menu > ul > li > ul {
          top: 100%;
          left: 0; }
          .nav-menu > ul > li > ul li {
            background-color: #000000;
            display: block;
            width: 100%; }
            .nav-menu > ul > li > ul li a {
              display: block;
              padding: 5px;
              border-bottom: 1px solid #2f2f2f; }
              .nav-menu > ul > li > ul li a:hover {
                background-color: #F79226; }
          .nav-menu > ul > li > ul ul {
            top: 0;
            left: 100%; } }

/* Mobile Navigation */
@media (max-width: 991px) {
  .mob-nav-menu {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    padding-top: 70px;
    background: #FFFFFF;
    font-size: 12px;
    text-transform: uppercase;
    overflow: hidden;
    z-index: 90; }
    .mob-nav-menu ul {
      margin: 0;
      list-style: none;
      padding: 0px; }
    .mob-nav-menu li {
      padding-bottom: 0;
      position: relative; }
    .mob-nav-menu ul li a {
      display: block;
      padding: 10px 15px;
      border-bottom: 1px solid #ebebeb;
      color: #3f3f3f; }
    .mob-nav-menu ul ul {
      background-color: rgba(255, 255, 255, 0.11);
      display: none;
      padding: 0px; }
      .mob-nav-menu ul ul li {
        padding-left: 2%; }
    .mob-nav-menu .icon-down-open {
      cursor: pointer;
      font-size: 18px;
      height: 38px;
      line-height: 40px;
      position: absolute;
      right: 0;
      text-align: center;
      top: 0;
      width: 50px; } }

@media (max-width: 767px) {
  .mob-nav-menu {
    padding-top: 70px; }
  .general_panel .item_bg {
    padding-bottom: 100% !important; } }

/* Header image */
.slider {
  margin: 0 auto;
  height: 100%;
  z-index: 10;
  opacity: 0; }
  .slider.slick-initialized {
    opacity: 1;
    transition: opacity .2s .35s; }
  .slider .overlay {
    background: -moz-linear-gradient(top, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0) 100%);
    background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0) 100%);
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0) 100%);
    height: 100%;
    top: 0;
    z-index: 2; }
  .slider .slick-list, .slider .slick-track {
    height: 100%; }
  .slider .item {
    height: 100%;
    min-height: 400px;
    max-height: 1080px;
    outline: none; }
    .slider .item .bg-img {
      position: absolute;
      width: 100%;
      height: 100%;
      top: 0;
      left: 0;
      background-image: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019//uploads/images/default.jpg");
      background-position: center;
      background-repeat: no-repeat;
      background-size: cover;
      z-index: 1; }

.homepage .title_container {
  width: 100%; }
  .homepage .title_container h2, .homepage .title_container.page_title {
    font-size: 3rem; }

.homepage .header_images {
  overflow: hidden; }

.homepage .slider .item {
  height: calc((100vh) - 200px); }

.secondarypage .slider .slick-slide {
  height: 90vh; }
  .secondarypage .slider .slick-slide .item {
    height: 90vh; }

.secondarypage .slider .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  background: -moz-linear-gradient(top, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0) 100%);
  background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0) 100%);
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0) 100%); }

.header_image_wrapper {
  position: relative;
  padding-top: 0;
  overflow: hidden;
  z-index: 10;
  margin: 0 auto; }
  .header_image_wrapper img {
    margin: 0 auto; }
  .header_image_wrapper .slider_panel img {
    margin: 10px auto; }
  .header_image_wrapper .header_video {
    background-image: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/uploads/images/hp_video_bg.jpg");
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    height: 100vh;
    max-height: 1080px;
    z-index: 1; }
    .header_image_wrapper .header_video video {
      position: absolute;
      min-width: 100%;
      min-height: 100%;
      top: 50%;
      left: 50%;
      -moz-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      -o-transform: translate(-50%, -50%);
      -webkit-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%); }
    .header_image_wrapper .header_video .overlay {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      z-index: 1;
      background: -moz-linear-gradient(top, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0.1) 100%);
      background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0.1) 100%);
      background: linear-gradient(to bottom, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0.1) 100%); }
    .header_image_wrapper .header_video .header_image_tag {
      position: absolute;
      text-transform: uppercase;
      letter-spacing: 2px;
      color: #FFFFFF;
      text-align: left;
      max-width: 800px;
      min-width: 300px;
      width: 50%;
      bottom: 8%;
      left: 2%;
      z-index: 100; }
      .header_image_wrapper .header_video .header_image_tag h2 {
        font-size: 4rem;
        font-weight: 400; }
      .header_image_wrapper .header_video .header_image_tag h4 {
        font-weight: 100; }

@media (min-width: 768px) {
  .homepage .slider .overlay {
    background: -moz-linear-gradient(top, rgba(0, 0, 0, 0.4) 0%, rgba(0, 0, 0, 0.2) 100%);
    background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0.4) 0%, rgba(0, 0, 0, 0.2) 100%);
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.4) 0%, rgba(0, 0, 0, 0.2) 100%);
    height: 100%; } }

@media (max-width: 767px) {
  .booking {
    display: none; }
  .homepage .booking_mob .booking {
    display: block !important; }
  .homepage .slider .header_image_tag {
    display: none; }
  .homepage .offers_panel .title_container {
    background: #F9F9F9;
    padding-bottom: 10px; }
    .homepage .offers_panel .title_container h2 {
      font-size: 2.9rem; }
  .homepage .offers_panel .slick_responsive {
    padding-top: 20px;
    padding-bottom: 20px; }
    .homepage .offers_panel .slick_responsive .slick-list {
      padding: 0 !important; }
    .homepage .offers_panel .slick_responsive .slick-arrow {
      display: none !important; } }

.header_image_tag {
  position: absolute;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: #FFFFFF;
  text-align: left;
  max-width: 800px;
  min-width: 300px;
  width: 50%;
  bottom: 8%;
  left: 2%;
  z-index: 100; }
  .header_image_tag h2 {
    font-size: 4rem;
    font-weight: 400; }
  .header_image_tag h4 {
    font-weight: 100; }

/* Booking Panel */
.booking {
  width: 240px;
  padding: 20px;
  z-index: 80; }
  .booking .day_group {
    float: left;
    width: 50%;
    text-align: center;
    overflow: hidden;
    text-transform: uppercase; }
    .booking .day_group label {
      display: block;
      margin: 0 0 5px;
      color: #FFFFFF;
      font-weight: 400;
      font-size: 10px;
      letter-spacing: 1px; }
    .booking .day_group.day_group_arrive {
      border-right: 2px solid rgba(0, 0, 0, 0); }
    .booking .day_group.day_group_depart {
      border-left: 2px solid rgba(0, 0, 0, 0); }
  .booking .date_box {
    background-color: #FFFFFF;
    color: #333;
    cursor: pointer;
    margin: 10px 0;
    padding: 8px 8px 2px;
    position: relative;
    font-weight: 400;
    text-align: center;
    transition: background-color .35s; }
    .booking .date_box:hover {
      background-color: #ebebeb; }
    .booking .date_box .booking_arrow_icons {
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 0 4px 6px 4px;
      border-color: transparent transparent #fff transparent;
      position: absolute;
      top: -6px;
      left: 50%;
      margin-left: -4px; }
    .booking .date_box input {
      position: absolute;
      left: 0;
      top: 0;
      background: none;
      border: none;
      cursor: pointer;
      width: 100%;
      height: 100%;
      opacity: 0; }
    .booking .date_box .day_formatted, .booking .date_box .departday_formatted {
      font-size: 36px;
      line-height: 30px;
      margin: 0;
      padding: 5px 0; }
    .booking .date_box .ArriveMonth, .booking .date_box .DepartMonth {
      padding-bottom: 2px;
      font-size: 12px;
      color: #4F6D76; }
    .booking .date_box i {
      line-height: 10px;
      font-size: 12px;
      color: #4F6D76; }
  .booking .booking_panel_button {
    display: block;
    text-transform: uppercase;
    background-color: #12516B;
    color: #FFFFFF;
    padding: 8px; }

@media (min-width: 1200px) {
  body:not(.noheaderimage) .booking {
    right: 3%; } }

@media (min-width: 768px) {
  body:not(.noheaderimage) .booking {
    width: 240px;
    padding: 20px;
    position: absolute;
    right: 30px;
    top: 100px; }
  .booking {
    width: 240px;
    padding: 20px;
    position: absolute; } }

@media (max-width: 767px) {
  .booking {
    position: relative !important;
    width: 100%; }
    .booking label {
      color: #12516B !important; }
    .booking .date_box {
      background: #F9F9F9; } }

/**Booking Landscape - Offers Landing **/
.booking.booking-landscape {
  display: flex;
  height: 60px;
  width: 360px;
  padding: 0;
  position: absolute;
  overflow: hidden;
  right: 0;
  top: 70px;
  z-index: 8; }
  @media (max-width: 767px) {
    .booking.booking-landscape {
      top: 70px;
      position: absolute !important; } }
  @media (max-width: 359px) {
    .booking.booking-landscape {
      display: none; } }
  .booking.booking-landscape .booking_panel {
    background: none;
    background-color: transparent;
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
    align-items: stretch;
    height: 100%;
    width: 100%; }
    .booking.booking-landscape .booking_panel .booking_panel_button {
      border-color: #166281;
      background-color: #166281;
      display: block;
      height: 100%;
      line-height: 60px;
      margin: 0;
      font-size: 14px;
      letter-spacing: -0.03em;
      padding: 0 15px;
      max-width: 30%;
      z-index: 10; }
      .booking.booking-landscape .booking_panel .booking_panel_button:hover, .booking.booking-landscape .booking_panel .booking_panel_button:focus {
        color: #FFFFFF;
        background: #4F6D76;
        opacity: .9; }
  .booking.booking-landscape .day_group-container {
    background-color: rgba(255, 255, 255, 0.9);
    display: flex;
    width: 70%;
    transform: translateX(0);
    transition: transform .6s linear;
    z-index: 5; }
  .booking.booking-landscape .day_group {
    padding: 0;
    margin: 0;
    width: 50%; }
    .booking.booking-landscape .day_group.arrive_group {
      border-right: 1px solid #f1f1f1; }
  .booking.booking-landscape .date_box {
    background-color: transparent;
    border: none;
    height: 100%;
    width: 100%;
    margin: 0;
    padding: 0 0 0 20px;
    display: flex;
    align-items: flex-start;
    flex-flow: nowrap;
    transition: all .4s linear; }
    .booking.booking-landscape .date_box input {
      background-image: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019//Assets/Images/datepicker.png");
      background-color: transparent;
      background-repeat: no-repeat;
      background-position: 8% 27px;
      font-size: 15px;
      opacity: 1;
      padding-left: 30px;
      padding-top: 15px;
      padding-bottom: 0px;
      height: 100%;
      width: 100%;
      transition: all .4s ease-in; }
    .booking.booking-landscape .date_box label {
      color: #4F6D76;
      font-size: 11px;
      margin-left: -11px;
      position: relative;
      text-align: left;
      padding: 10px 0;
      transition: all .4s linear .1s; }
    .booking.booking-landscape .date_box:hover {
      background-color: #ebebeb; }

.booking.is-sticky .day_group-container {
  transform: translateX(100%); }

/* End Booking Landscape*/
.offers_panel {
  padding: 0; }
  .offers_panel .slick_responsive {
    background: #F9F9F9;
    padding-bottom: 80px; }
    .offers_panel .slick_responsive img {
      margin: 0 auto; }
    .offers_panel .slick_responsive .grid_block .inner {
      margin: 0 auto;
      max-width: 450px;
      background: #FFFFFF; }
      .offers_panel .slick_responsive .grid_block .inner .grid_text {
        text-align: center; }
        .offers_panel .slick_responsive .grid_block .inner .grid_text h4 {
          text-transform: uppercase; }
      .offers_panel .slick_responsive .grid_block .inner .btn_wrapper {
        text-align: center;
        padding: 15px 0; }
        .offers_panel .slick_responsive .grid_block .inner .btn_wrapper .button:last-child {
          margin-left: 5px; }

.highlights_panel .masonry {
  column-count: 2;
  column-gap: 20px; }
  .highlights_panel .masonry .item {
    break-inside: avoid;
    margin-bottom: 20px;
    padding: 0px; }
    .highlights_panel .masonry .item a {
      position: relative;
      width: 100%;
      display: block;
      height: 100%; }
    .highlights_panel .masonry .item .border {
      width: 100%;
      height: 100%;
      padding: 0 20px;
      position: absolute;
      z-index: 100; }
      .highlights_panel .masonry .item .border:before {
        z-index: 10;
        -webkit-transition: all .5s linear;
        -o-transition: all .5s linear;
        transition: all .5s linear;
        border: 1px solid rgba(255, 255, 255, 0.5);
        content: "";
        position: absolute;
        top: 15px;
        bottom: 15px;
        left: 15px;
        right: 15px; }
      .highlights_panel .masonry .item .border:hover:before {
        top: 0;
        left: 0;
        right: 0;
        bottom: 0; }
    .highlights_panel .masonry .item .block_text {
      position: absolute;
      color: #FFFFFF;
      text-align: left;
      padding: 0 20px;
      bottom: 10%; }
      .highlights_panel .masonry .item .block_text .title_container h2, .highlights_panel .masonry .item .block_text .title_container h4 {
        text-align: left;
        color: #FFFFFF; }
      .highlights_panel .masonry .item .block_text .title_container h4 {
        margin: 0; }
      .highlights_panel .masonry .item .block_text .title_container .button {
        margin-top: 10px; }
    .highlights_panel .masonry .item .item_bg {
      padding-bottom: 65%;
      background-position: center;
      background-size: cover; }
    .highlights_panel .masonry .item .item_bg_2 {
      padding-bottom: 85%;
      background-position: center;
      background-size: cover; }

.homepage .content_container, .roomspage .content_container, .weddingspage .content_container {
  text-align: center; }
  .homepage .content_container .logo svg, .roomspage .content_container .logo svg, .weddingspage .content_container .logo svg {
    width: 190px;
    height: 92px;
    fill: #12516B;
    transition: fill .35s, height .35s, width .35s; }
  .homepage .content_container h1, .roomspage .content_container h1, .weddingspage .content_container h1 {
    text-transform: uppercase;
    color: #4F6D76;
    font-size: 1.8rem; }
  .homepage .content_container .content, .roomspage .content_container .content, .weddingspage .content_container .content {
    text-align: left;
    font-size: 1.8rem;
    letter-spacing: .06rem;
    color: #4F6D76; }

.home_bottom_panel .panel_wrapper {
  column-count: 2;
  column-gap: 20px; }
  .home_bottom_panel .panel_wrapper .block_text {
    position: absolute;
    color: #FFFFFF;
    text-align: left;
    padding: 0 20px;
    bottom: 0%; }
    .home_bottom_panel .panel_wrapper .block_text .title_container h2, .home_bottom_panel .panel_wrapper .block_text .title_container h4 {
      text-align: left;
      color: #FFFFFF; }
    .home_bottom_panel .panel_wrapper .block_text .title_container h4 {
      margin: 0; }
    .home_bottom_panel .panel_wrapper .block_text .title_container .button {
      margin-top: 10px; }
  .home_bottom_panel .panel_wrapper .border {
    width: 100%;
    height: 100%;
    padding: 20px;
    position: absolute;
    z-index: 100; }
    .home_bottom_panel .panel_wrapper .border:before {
      z-index: 10;
      -webkit-transition: all .5s linear;
      -o-transition: all .5s linear;
      transition: all .5s linear;
      border: 1px solid rgba(255, 255, 255, 0.5);
      content: "";
      position: absolute;
      top: 15px;
      bottom: 15px;
      left: 15px;
      right: 15px; }
    .home_bottom_panel .panel_wrapper .border:hover:before {
      top: 0;
      left: 0;
      right: 0;
      bottom: 0; }
  .home_bottom_panel .panel_wrapper .item_img {
    padding-bottom: 60%;
    background-position: center;
    background-size: cover; }

.home_bottom_panel .panel_container {
  break-inside: avoid;
  margin-bottom: 20px;
  padding: 0px; }
  .home_bottom_panel .panel_container .title_container {
    letter-spacing: 0.3rem;
    padding: 20px 0 50px;
    margin-top: 20px;
    min-width: 100px; }
    .home_bottom_panel .panel_container .title_container h4 {
      color: #4F6D76;
      font-size: 1.4rem; }
    .home_bottom_panel .panel_container .title_container h2 {
      font-size: 3.6rem; }
    .home_bottom_panel .panel_container .title_container .button_white {
      margin-top: 25px; }

@media (min-width: 992px) {
  .home_bottom_panel .item_first .title_container {
    border-right: 1px solid #4F6D76; } }

@media (max-width: 991px) {
  .home_bottom_panel .panel_wrapper {
    column-count: 1; }
    .home_bottom_panel .panel_wrapper h2 {
      font-size: 2.5rem !important; }
    .home_bottom_panel .panel_wrapper h4 {
      font-size: 15px; }
    .home_bottom_panel .panel_wrapper .item_img {
      padding-bottom: 80%; }
  .home_bottom_panel .item_first .title_container {
    width: 100%;
    margin: 0 auto;
    border-bottom: 1px solid #4F6D76; }
    .home_bottom_panel .item_first .title_container h2 {
      font-size: 2.6rem; } }

.page_gallery_panel {
  position: relative;
  display: inline-block;
  width: 100%; }
  .page_gallery_panel .full-bg-image {
    width: 100%;
    float: left;
    background-size: cover;
    transition: top 0.05s ease;
    height: calc(60vh);
    min-height: 400px; }
  .page_gallery_panel .page_gallery_item {
    position: relative;
    display: inline-block;
    letter-spacing: .3rem; }
    .page_gallery_panel .page_gallery_item .text_container {
      position: absolute;
      color: #FFFFFF;
      text-align: center;
      padding: 0;
      height: auto;
      width: 100%;
      bottom: 10%;
      z-index: 100; }
      .page_gallery_panel .page_gallery_item .text_container .text_wrapper {
        position: relative;
        display: block;
        z-index: 100; }
      .page_gallery_panel .page_gallery_item .text_container svg {
        width: 100%;
        height: 90px;
        fill: #FFFFFF;
        transition: fill .35s, height .35s, width .35s;
        margin-bottom: 40px; }
      .page_gallery_panel .page_gallery_item .text_container h2, .page_gallery_panel .page_gallery_item .text_container h4 {
        color: #FFFFFF !important;
        margin: 0; }
      .page_gallery_panel .page_gallery_item .text_container h2 {
        text-shadow: 0.02em 0.02em 0.05em rgba(0, 0, 0, 0.3); }
      .page_gallery_panel .page_gallery_item .text_container h4 {
        font-size: 1.4rem; }

/* Secondary Nav */
.nav-sec-toggle {
  display: block;
  padding: 8px 20px; }

.nav-sec {
  padding: 15px;
  text-align: center;
  margin-bottom: 30px; }
  .nav-sec .btn-nav {
    color: #FFFFFF;
    background-color: #4F6D76;
    border-color: #4F6D76; }
    .nav-sec .btn-nav:active {
      background-color: #12516B; }

.nav_secondary ul {
  display: block;
  text-align: center;
  padding: 0; }
  .nav_secondary ul li, .nav_secondary ul a {
    display: block;
    text-align: center;
    padding: 3px 0; }
  .nav_secondary ul li.selected > a:first-child {
    color: #000000;
    background-color: #F5F5F5;
    font-style: italic; }
  .nav_secondary ul ul {
    display: none; }
    .nav_secondary ul ul a {
      border: none; }
    .nav_secondary ul ul ul a {
      padding-left: 20px; }
    .nav_secondary ul ul ul ul a {
      padding-left: 35px; }

.nav_secondary > ul > li.selected {
  position: relative; }
  .nav_secondary > ul > li.selected:before {
    content: '';
    position: absolute;
    top: 0px;
    left: 100%;
    width: 0;
    height: 0;
    border: 20px solid transparent;
    border-left: 20px solid #F5F5F5; }

@media (max-width: 991px) {
  .nav_secondary {
    display: none; } }

@media (min-width: 992px) {
  .nav-sec-toggle {
    display: none !important; }
  .nav-sec {
    padding: 30px 15px; }
  .nav_secondary ul {
    display: block;
    text-align: center;
    padding: 0; }
    .nav_secondary ul li, .nav_secondary ul a {
      display: inline-block;
      text-align: center; }
    .nav_secondary ul a {
      margin: 0 5px 10px 0;
      padding: 15px 20px;
      text-transform: uppercase;
      border: 1px solid #4F6D76;
      padding: 20px;
      min-width: 160px; }
      .nav_secondary ul a:hover {
        text-decoration: none;
        background: #F9F9F9;
        transition: background .15s ease-in-out; } }

.page_title {
  margin: .5em 0; }

/* Grid of multiple blocks and gallery */
.grid {
  margin: 0; }

.grid .grid_block {
  margin-bottom: 0px; }

.grid_block {
  float: left;
  width: 100%; }

.grid_text {
  padding: 10px 0; }

/* ---------- Modules ---------- */
/* Isotope Grid */
.isotope_filters {
  margin-bottom: 30px; }
  .isotope_filters.offer_filters {
    margin-top: 80px; }
  .isotope_filters .button {
    box-shadow: none;
    margin-bottom: 5px;
    min-width: 100px; }
    .isotope_filters .button.active {
      border-color: #4F6D76 !important;
      color: #12516B !important;
      outline: none;
      background: rgba(18, 81, 107, 0.2) !important; }

.isotope-grid {
  margin: 0;
  transition: height .5s; }
  .isotope-grid.offers-grid .btn_wrapper {
    text-align: right; }
  .isotope-grid .item {
    width: 100%;
    padding: 0 0 15px; }
    .isotope-grid .item img {
      width: 100%; }
    .isotope-grid .item .panel {
      background-color: #FFFFFF;
      padding: 20px 10px; }
      .isotope-grid .item .panel .button {
        margin: 0 0 20px;
        padding: 10px 20px; }
      .isotope-grid .item .panel img {
        height: auto;
        min-height: 210px; }

@media (min-width: 768px) {
  .isotope-grid {
    margin: 0 -7.5px; }
    .isotope-grid .item {
      width: 50%;
      padding: 0 7.5px 15px; } }

@media (min-width: 992px) {
  .isotope-grid .item {
    width: 33.33333%;
    border-right: 1px solid #4F6D76; } }

.roomspage .room_list_item {
  background: #FFFFFF;
  float: left;
  width: 100%;
  letter-spacing: .2rem; }
  .roomspage .room_list_item:last-child {
    margin-bottom: 60px; }
  .roomspage .room_list_item:nth-of-type(even) .room_list_image {
    float: right; }
  .roomspage .room_list_item .room_list_image {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    padding-bottom: 50%;
    float: left;
    position: relative; }
  .roomspage .room_list_item .room_list_desc {
    top: 50%;
    padding: 5% 10%;
    width: 100%;
    margin: 0 auto;
    transform: translateY(10%); }
    .roomspage .room_list_item .room_list_desc h3 {
      text-transform: uppercase;
      color: #4F6D76;
      font-size: 2.8rem; }
    .roomspage .room_list_item .room_list_desc .room_number {
      padding-bottom: 30px;
      color: #12516B;
      font-size: 3rem; }
    .roomspage .room_list_item .room_list_desc p {
      color: #4F6D76;
      margin: 20px 0;
      clear: left;
      width: 100%;
      line-height: 2.4rem; }
    .roomspage .room_list_item .room_list_desc .button {
      padding: 15px 25px; }
  @media (max-width: 767px) {
    .roomspage .room_list_item .image-overlay {
      content: "";
      display: block;
      height: 100%;
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      background-color: rgba(0, 0, 0, 0.3); }
    .roomspage .room_list_item .room_list_desc {
      position: relative;
      text-align: center;
      transform: none !important;
      z-index: 10; } }

.roomspage .room_nav {
  padding: 30px 0;
  text-align: center; }
  .roomspage .room_nav .room_nav_item a {
    display: inline-block;
    padding: 10px;
    margin: 0;
    color: #12516B;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 1.6rem; }
    .roomspage .room_nav .room_nav_item a:hover {
      opacity: .85;
      transition: opacity .15s ease-in-out; }
  .roomspage .room_nav .room_nav_item.roomsNavSelected {
    font-style: italic; }

.roomspage .rooms_landing .room_nav_item {
  display: inline-block; }

.roomspage .room_details h1 {
  text-align: left; }

.roomspage .room_details h2 {
  text-transform: uppercase;
  color: #4F6D76;
  font-size: 2.8rem;
  text-align: left; }

.roomspage .room_details .price {
  display: inline-block; }

.roomspage .room_details .button {
  padding: 15px 25px; }

.roomspage .room_details .items {
  padding-bottom: 60px; }

.roomspage .services-amenities .wrapper {
  padding-top: 50px;
  padding-bottom: 50px; }

.roomspage .services-amenities img {
  width: 100%;
  padding-bottom: 30px; }

.roomspage .services-amenities ul {
  padding-left: 0;
  margin-bottom: 20px; }

.roomspage .services-amenities h4 {
  font-size: 30px;
  margin: 0 0 20px; }

.roomspage .services-amenities .section-title {
  margin: 0 0 20px; }

.roomspage .services-amenities .review-score {
  padding-bottom: 40px; }
  .roomspage .services-amenities .review-score a {
    text-decoration: none; }
  .roomspage .services-amenities .review-score span {
    font-size: 70px;
    color: #2B2B2B;
    line-height: 70px; }
  .roomspage .services-amenities .review-score div {
    color: #2B2B2B; }
  .roomspage .services-amenities .review-score i {
    color: #957448;
    margin-top: 5px;
    display: inline-block;
    margin-left: -4px; }
    .roomspage .services-amenities .review-score i:last-child {
      margin-left: -6px; }

@media (min-width: 768px) {
  .roomspage .services-amenities {
    padding-top: 0;
    padding-bottom: 0; }
    .roomspage .services-amenities img, .roomspage .services-amenities .wrapper, .roomspage .services-amenities .review-score {
      padding-top: 60px;
      padding-bottom: 40px; }
    .roomspage .services-amenities .wrapper {
      padding-left: 30px; }
      .roomspage .services-amenities .wrapper .content {
        color: #4F6D76; }
        .roomspage .services-amenities .wrapper .content ul {
          padding-left: 0; }
    .roomspage .services-amenities h4 {
      font-size: 36px; }
  .roomspage .border_left {
    border-left: 2px solid #4F6D76; }
  .roomspage .border_right {
    border-right: 2px solid #4F6D76;
    left: 2px; } }

@media (min-width: 1200px) {
  .roomspage .services-amenities .wrapper {
    padding-left: 100px;
    padding-right: 100px; }
  .roomspage .items {
    padding-left: 100px;
    padding-right: 100px; } }

.roomspage .booking {
  position: relative;
  margin: 0 auto;
  background-color: #F9F9F9; }
  .roomspage .booking label {
    color: #4F6D76; }
  .roomspage .booking .button {
    padding: 10px 25px; }

.padding_30.offer-list {
  padding-top: 70px; }

.offerdetailspage .offer-dtls .container.padding_30 {
  padding-top: 70px; }

.offerdetailspage .offer-dtls .title-panel {
  margin-bottom: 40px; }
  .offerdetailspage .offer-dtls .title-panel h1 {
    text-transform: uppercase;
    text-align: left;
    color: #4F6D76;
    font-size: 2.6rem;
    font-weight: 400;
    padding: 10px 0; }

.offerdetailspage .offer-dtls .terms {
  margin-bottom: 40px; }
  .offerdetailspage .offer-dtls .terms .content {
    font-style: italic;
    font-size: 14px; }

.offerdetailspage .offer-dtls .content, .offerdetailspage .offer-dtls .content div, .offerdetailspage .offer-dtls .content p, .offerdetailspage .offer-dtls .content ul {
  text-align: left !important;
  font-size: 1.7rem;
  color: #4F6D76;
  width: 100%;
  line-height: 2.4rem; }
  .offerdetailspage .offer-dtls .content div, .offerdetailspage .offer-dtls .content div div, .offerdetailspage .offer-dtls .content p div, .offerdetailspage .offer-dtls .content ul div {
    padding-bottom: 10px; }

.offerdetailspage footer {
  display: none; }

.offerslistpage footer {
  display: block; }

@media (min-width: 768px) {
  .offers-grid .item .panel h3 {
    min-height: 35px; }
  .offers-grid .item .panel .content {
    min-height: 68px; }
  .offerdetailspage .offer-dtls .container.padding_30 {
    padding-top: 30px; }
  .offer-dtls {
    padding-left: 50px; }
    .offer-dtls .bg-img {
      width: 50px;
      height: calc((100%) - 70px);
      position: fixed;
      left: 0;
      background-image: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019//Assets/Images/offer_details_bg.jpg"); }
    .offer-dtls .offers-next-prev {
      position: fixed;
      bottom: 0;
      right: 30px; }
      .offer-dtls .offers-next-prev .prev, .offer-dtls .offers-next-prev .next {
        display: inline-block;
        color: #444B4D;
        font-size: 14px;
        text-transform: uppercase;
        padding: 6px 5px 5px;
        background-color: rgba(255, 255, 255, 0.5); }
        .offer-dtls .offers-next-prev .prev:hover, .offer-dtls .offers-next-prev .next:hover {
          color: #12516B; }
      .offer-dtls .offers-next-prev .prev {
        margin-right: 5px; }
  .offerdtlspage .footer {
    display: none; } }

@media (min-width: 992px) {
  .offer-dtls {
    padding-left: 100px; }
    .offer-dtls .bg-img {
      width: 100px;
      height: 100%;
      position: fixed;
      left: 0; } }

@media (min-width: 1200px) {
  .offer-dtls {
    padding-left: 250px; }
    .offer-dtls .bg-img {
      width: 250px;
      height: 100%;
      position: fixed;
      left: 0; } }

/* Image/Content Grid */
.module-grid .bg-img {
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover; }

.module-grid .box {
  margin: 0 0 20px;
  position: relative; }
  .module-grid .box .box-top > h3 {
    font-size: 18px;
    margin: 0 0 20px;
    line-height: 1.6;
    text-transform: uppercase; }
  .module-grid .box .box-top > .content {
    margin: 0 0 20px; }

@media (max-width: 767px) {
  .module-grid .box.box-left {
    height: 250px; } }

@media (min-width: 768px) {
  .module-grid .box {
    float: left;
    width: 50%;
    height: 350px; }
    .module-grid .box.box-left {
      margin: 0;
      border-right: 5px solid #FFFFFF; }
    .module-grid .box.box-right {
      border-left: 5px solid #FFFFFF; }
    .module-grid .box .box-top {
      height: 100%; }
  .module-grid a .bg-img {
    opacity: 1;
    -webkit-transition: opacity .35s;
    -moz-transition: opacity .35s;
    transition: opacity .35s; }
  .module-grid a:hover .bg-img {
    opacity: .85; }
  /* CUSTOM CSS FOR SPECIFIC ROOM */
  .room-1 .module-grid .box.box-left {
    background-position: center right; } }

@media (min-width: 768px) and (max-width: 991px) {
  .module-grid .box .box-top .btn {
    padding: 8px 15px; } }

@media (min-width: 992px) {
  .module-grid .box {
    height: 450px; }
    .module-grid .box.box-left, .module-grid .box.box-right {
      border-width: 10px; }
    .module-grid .box .box-top, .module-grid .box .box-bottom {
      height: 225px;
      overflow: hidden; }
    .module-grid .box .box-top {
      border-bottom: 10px solid #FFFFFF; }
    .module-grid .box .box-bottom {
      border-top: 10px solid #FFFFFF; } }

@media (min-width: 1200px) {
  .module-grid .box {
    height: 500px; }
    .module-grid .box .box-top, .module-grid .box .box-bottom {
      height: 250px; }
    .module-grid .box .box-top {
      padding: 10px 20px; } }

.next_prev_container {
  display: inline-block;
  width: 100%;
  border-top: 1px solid #4F6D76;
  padding: 20px 0;
  text-transform: uppercase;
  background: #FFFFFF; }
  .next_prev_container a {
    width: 49%;
    display: inline-block;
    color: #4F6D76;
    max-width: 300px; }
    .next_prev_container a:hover .arrow_text:not(span) {
      opacity: 1; }
    .next_prev_container a .arrow {
      background-repeat: no-repeat;
      height: 25px;
      width: 40px;
      width: 30px;
      display: inline-block;
      margin: 0px 10px; }
  .next_prev_container span {
    color: #12516B;
    display: block; }
  .next_prev_container .prev {
    float: left;
    text-align: right;
    position: relative;
    z-index: 10; }
  .next_prev_container .arrow_text {
    display: inline-block;
    font-size: 16px;
    color: #12516B; }
    .next_prev_container .arrow_text span {
      color: #4F6D76; }
    .next_prev_container .arrow_text:not(span) {
      opacity: 1; }
  .next_prev_container .next {
    float: right;
    position: relative;
    z-index: 10; }

/* Weddings */
.weddingspage .header_video, .weddingscontentpage .header_video {
  background-image: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/uploads/images/video_bg.jpg"); }

.weddingspage .contact_panel, .weddingscontentpage .contact_panel {
  position: absolute;
  width: 280px;
  padding: 10px;
  right: 30px;
  top: 100px;
  z-index: 80;
  background: #FFFFFF; }
  .weddingspage .contact_panel svg, .weddingscontentpage .contact_panel svg {
    width: 50px;
    margin: 20px 0;
    height: 20px;
    fill: #AA1360;
    transition: fill .35s, height .35s, width .35s;
    float: left; }
  .weddingspage .contact_panel .button, .weddingscontentpage .contact_panel .button {
    font-size: 0.9rem;
    letter-spacing: 0.2rem;
    padding: 0;
    width: 100%;
    margin-top: 5px; }
    .weddingspage .contact_panel .button .line, .weddingscontentpage .contact_panel .button .line {
      height: 65px;
      height: 65px;
      float: left; }
    .weddingspage .contact_panel .button:hover, .weddingscontentpage .contact_panel .button:hover {
      opacity: .8; }
  .weddingspage .contact_panel .button_pink_border, .weddingscontentpage .contact_panel .button_pink_border {
    background: #FFFFFF;
    border: 1px solid #AA1360;
    color: #AA1360 !important; }
    .weddingspage .contact_panel .button_pink_border svg, .weddingscontentpage .contact_panel .button_pink_border svg {
      float: left; }
    .weddingspage .contact_panel .button_pink_border .line, .weddingscontentpage .contact_panel .button_pink_border .line {
      width: 1px;
      height: 65px;
      vertical-align: top !important;
      display: inline-block;
      background: #AA1360;
      margin: 0 !important;
      float: left; }
  .weddingspage .contact_panel .text, .weddingscontentpage .contact_panel .text {
    display: inline-block;
    text-align: left;
    padding: 20px 5px;
    vertical-align: top; }
    .weddingspage .contact_panel .text span, .weddingscontentpage .contact_panel .text span {
      display: block; }
  .weddingspage .contact_panel h3, .weddingscontentpage .contact_panel h3 {
    font-size: 1.4rem;
    text-transform: uppercase;
    text-align: center; }
    .weddingspage .contact_panel h3 svg, .weddingscontentpage .contact_panel h3 svg {
      width: 40px;
      height: 15px;
      margin: 0;
      display: inline-block;
      vertical-align: middle; }

.weddingspage .title_container h4, .weddingspage .title_container h2, .weddingscontentpage .title_container h4, .weddingscontentpage .title_container h2 {
  color: #003950; }

.weddingspage .wedding_panel, .weddingscontentpage .wedding_panel {
  position: relative;
  display: inline-block; }
  .weddingspage .wedding_panel .title_container h4, .weddingspage .wedding_panel .title_container h2, .weddingscontentpage .wedding_panel .title_container h4, .weddingscontentpage .wedding_panel .title_container h2 {
    text-align: left; }
  .weddingspage .wedding_panel .content, .weddingscontentpage .wedding_panel .content {
    color: #908A8C;
    line-height: 3rem;
    font-size: 1.4rem;
    letter-spacing: .1rem;
    padding: 5% 0; }
  .weddingspage .wedding_panel .image_container, .weddingscontentpage .wedding_panel .image_container {
    position: relative;
    display: block;
    break-inside: avoid;
    margin-bottom: 20px;
    padding: 0px; }
    .weddingspage .wedding_panel .image_container .item_bg, .weddingscontentpage .wedding_panel .image_container .item_bg {
      padding-bottom: 65%;
      background-position: center;
      background-size: cover; }
    .weddingspage .wedding_panel .image_container .border, .weddingscontentpage .wedding_panel .image_container .border {
      width: 100%;
      height: 100%;
      padding: 0 20px;
      position: absolute;
      z-index: 100; }
      .weddingspage .wedding_panel .image_container .border:before, .weddingscontentpage .wedding_panel .image_container .border:before {
        z-index: 10;
        -webkit-transition: all .5s linear;
        -o-transition: all .5s linear;
        transition: all .5s linear;
        border: 1px solid rgba(255, 255, 255, 0.5);
        content: "";
        position: absolute;
        top: 15px;
        bottom: 15px;
        left: 15px;
        right: 15px; }
      .weddingspage .wedding_panel .image_container .border:hover:before, .weddingscontentpage .wedding_panel .image_container .border:hover:before {
        top: 0;
        left: 0;
        right: 0;
        bottom: 0; }
  .weddingspage .wedding_panel .text_wrapper, .weddingscontentpage .wedding_panel .text_wrapper {
    transform: translateY(5%);
    padding: 5% 14%;
    width: 100%; }
  .weddingspage .wedding_panel .button_pink span, .weddingscontentpage .wedding_panel .button_pink span {
    vertical-align: middle;
    display: inline-block;
    line-height: 60px;
    float: right;
    margin: 0px 10px; }
  .weddingspage .wedding_panel .button_pink .line, .weddingscontentpage .wedding_panel .button_pink .line {
    margin: 0 3px !important; }

.weddingspage .package_panel svg, .weddingscontentpage .package_panel svg {
  width: 50px;
  margin-left: 5px;
  margin: 0;
  height: 20px;
  fill: #AA1360 !important;
  transition: fill .35s, height .35s, width .35s; }

.weddingspage .package_panel .slick_packages h4, .weddingscontentpage .package_panel .slick_packages h4 {
  background: #FFFFFF;
  text-transform: uppercase;
  text-align: center;
  padding: 40px 0;
  margin-top: 0; }

.weddingspage .masonry, .weddingscontentpage .masonry {
  column-count: 3;
  column-gap: 20px;
  margin-top: 40px; }
  .weddingspage .masonry .item, .weddingscontentpage .masonry .item {
    break-inside: avoid;
    padding: 0px; }
    .weddingspage .masonry .item .item_bg, .weddingscontentpage .masonry .item .item_bg {
      padding-bottom: 70%;
      background-position: center;
      margin: 0 0 20px 0;
      background-size: cover; }
    .weddingspage .masonry .item .item_bg_h, .weddingscontentpage .masonry .item .item_bg_h {
      padding-bottom: 70%;
      padding-right: 105%;
      background-position: center;
      margin: 0 0 20px 0;
      background-size: cover; }

.weddingspage .page_gallery_panel .text_container, .weddingscontentpage .page_gallery_panel .text_container {
  background: #FFFFFF;
  max-width: 450px;
  padding: 20px;
  right: 5%;
  bottom: 30%; }
  .weddingspage .page_gallery_panel .text_container h4, .weddingspage .page_gallery_panel .text_container h2, .weddingscontentpage .page_gallery_panel .text_container h4, .weddingscontentpage .page_gallery_panel .text_container h2 {
    color: #003950 !important; }
  .weddingspage .page_gallery_panel .text_container h2, .weddingscontentpage .page_gallery_panel .text_container h2 {
    font-size: 2.4rem; }
  .weddingspage .page_gallery_panel .text_container h4, .weddingscontentpage .page_gallery_panel .text_container h4 {
    font-size: 1.6rem; }
  .weddingspage .page_gallery_panel .text_container svg, .weddingscontentpage .page_gallery_panel .text_container svg {
    width: 50px;
    margin-left: 5px;
    margin: 10px 0;
    height: 35px;
    fill: #AA1360 !important;
    transition: fill .35s, height .35s, width .35s; }
  .weddingspage .page_gallery_panel .text_container .button_pink, .weddingscontentpage .page_gallery_panel .text_container .button_pink {
    display: block;
    padding: 10px 20px; }
    .weddingspage .page_gallery_panel .text_container .button_pink span, .weddingscontentpage .page_gallery_panel .text_container .button_pink span {
      display: block; }
  .weddingspage .page_gallery_panel .text_container .text_wrapper, .weddingscontentpage .page_gallery_panel .text_container .text_wrapper {
    padding: 15% 20px; }
  .weddingspage .page_gallery_panel .text_container.border, .weddingscontentpage .page_gallery_panel .text_container.border {
    width: 100%;
    padding: 0 20px;
    position: absolute;
    z-index: 100; }
    .weddingspage .page_gallery_panel .text_container.border:before, .weddingscontentpage .page_gallery_panel .text_container.border:before {
      z-index: 10;
      -webkit-transition: all .5s linear;
      -o-transition: all .5s linear;
      transition: all .5s linear;
      border: 1px solid #4F6D76;
      content: "";
      position: absolute;
      top: 15px;
      bottom: 15px;
      left: 15px;
      right: 15px; }
    .weddingspage .page_gallery_panel .text_container.border:hover:before, .weddingscontentpage .page_gallery_panel .text_container.border:hover:before {
      top: 0;
      left: 0;
      right: 0;
      bottom: 0; }

.weddingscontentpage .header_image_container {
  height: 100%;
  padding: 0;
  float: right;
  right: 0;
  max-height: calc((100vh) - 70px); }
  .weddingscontentpage .header_image_container .item {
    min-height: calc((100vh) - 70px); }

.weddingscontentpage .content_container {
  float: left;
  padding-top: 50px;
  min-height: calc((100vh) - 70px);
  max-width: 100%;
  height: auto;
  padding-right: 5%;
  padding-left: 5%; }
  .weddingscontentpage .content_container .page_title {
    color: #003950;
    text-align: left;
    letter-spacing: .3rem; }
    .weddingscontentpage .content_container .page_title .h4 {
      text-align: left; }
  .weddingscontentpage .content_container h4 {
    text-transform: uppercase;
    padding-top: 10px; }
  .weddingscontentpage .content_container .content {
    color: #908A8C;
    font-size: 1.6rem; }

.weddingscontentpage .footer {
  display: inline-block;
  width: 100%; }

@media (max-width: 991px) {
  .weddingscontentpage .header_image_container {
    max-height: calc((70vh) - 70px);
    overflow: hidden; }
    .weddingscontentpage .header_image_container .item {
      min-height: calc((70vh) - 70px); }
  .page_gallery_item {
    width: 100%; }
  blockquote {
    width: 100% !important; } }

@media (max-width: 767px) {
  .page_gallery_item .text_container {
    right: 0% !important; } }

/* Testimonials Panel */
.testimonials_container {
  margin: 0px auto;
  max-width: 100%;
  padding: 5% 0; }
  .testimonials_container .slick-dots {
    bottom: 0 !important; }
  .testimonials_container .testimonals_wrapper {
    position: relative;
    z-index: 20; }
  .testimonials_container .testimonials_container_bg:after {
    content: "";
    display: block;
    height: 100%;
    z-index: 0;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    background: -moz-linear-gradient(top, white 0%, rgba(255, 255, 255, 0) 100%);
    background: -webkit-linear-gradient(top, white 0%, rgba(255, 255, 255, 0) 100%);
    background: linear-gradient(to bottom, white 0%, rgba(255, 255, 255, 0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#00ffffff',GradientType=0 ); }
  .testimonials_container .testimonials_item {
    float: left;
    width: 100%; }
    .testimonials_container .testimonials_item .title_wrapper {
      font-size: 1.6rem;
      margin-top: 20px; }
    .testimonials_container .testimonials_item img {
      margin: 10px auto;
      padding: 40px 0; }
    .testimonials_container .testimonials_item .testimonials_title {
      font-size: 4rem;
      width: 100%;
      float: left; }
    .testimonials_container .testimonials_item .testimonials_description {
      text-align: center;
      width: 80%;
      margin: 0 auto;
      font-size: 14px;
      line-height: 30px;
      letter-spacing: 1.3px; }
      .testimonials_container .testimonials_item .testimonials_description:before {
        content: open-quote; }
      .testimonials_container .testimonials_item .testimonials_description:after {
        content: close-quote; }
      .testimonials_container .testimonials_item .testimonials_description::before, .testimonials_container .testimonials_item .testimonials_description:after {
        position: relative;
        top: 20px;
        display: block;
        color: #4F6D76;
        font-size: 70px; }
  .testimonials_container .testimonials_container .title {
    color: #4F6D76; }
  .testimonials_container .testimials_list_border {
    border-top: 2px dashed #8a3356; }
  .testimonials_container .button_text {
    color: #AA1360 !important; }

blockquote {
  border-left-color: #AA1360;
  background-color: #F9F9F9;
  padding: 30px;
  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.1);
  width: 80%;
  margin: 0 auto 30px; }
  blockquote .page_title {
    color: #003950 !important; }
  blockquote .content {
    margin: 0 0 20px; }
  blockquote:nth-child(even) {
    border-left: none;
    border-right: 5px solid #AA1360;
    text-align: right; }
  blockquote blockquote footer {
    color: #666;
    font-size: 13px; }
  blockquote span {
    font-size: 1.8rem;
    color: #003950; }
  blockquote .testimonials_description {
    text-align: justify;
    -moz-text-align-last: center;
    text-align-last: center;
    margin: 0 auto 10px;
    font-size: 1.4rem;
    line-height: 30px;
    letter-spacing: 1.3px;
    font-style: italic;
    color: #908A8C; }
    blockquote .testimonials_description:before {
      content: open-quote; }
    blockquote .testimonials_description:after {
      content: close-quote; }
    blockquote .testimonials_description::before, blockquote .testimonials_description:after {
      position: relative;
      display: inline-block;
      color: #AA1360;
      font-size: 25px;
      line-height: 0; }

.button_pink {
  padding: 0;
  letter-spacing: .3rem; }
  .button_pink:hover {
    opacity: .9; }
  .button_pink svg {
    width: 50px;
    margin-left: 5px;
    margin: 15px 0;
    height: 25px;
    fill: #FFFFFF !important;
    transition: fill .35s, height .35s, width .35s; }
  .button_pink .line {
    width: 1px;
    height: 60px;
    vertical-align: top !important;
    display: inline-block;
    background: rgba(255, 255, 255, 0.5);
    margin: 0; }

/* Landing Page */
.landingpage .item img {
  margin: 0 auto; }

.landingpage .item .grid_text {
  padding: 10px 15px;
  background: #F9F9F9;
  min-height: 170px;
  max-width: 400px;
  margin: 0 auto 20px; }
  .landingpage .item .grid_text h3 {
    text-transform: uppercase; }
  .landingpage .item .grid_text .content {
    font-size: 1.5rem; }
  .landingpage .item .grid_text .button {
    margin-top: 10px; }

/* Gallery */
.gallery {
  overflow: hidden; }
  .gallery .titles-wrapper {
    margin: 0; }

.gallery-filters .button {
  box-shadow: none;
  margin: 0 0 5px;
  position: relative;
  background-color: rgba(255, 255, 255, 0.5);
  border: none;
  padding: 10px 15px;
  color: #003950;
  box-shadow: none !important;
  outline: 0 !important;
  margin: 5px -2px 5px 2px;
  font-size: 15px; }
  .gallery-filters .button:hover {
    color: #4F6D76;
    font-style: italic; }
  .gallery-filters .button:focus, .gallery-filters .button.active {
    outline: none;
    color: #4F6D76;
    font-style: italic; }

.gallery-grid {
  margin: 0 -5px;
  overflow: hidden;
  transition: height .5s; }
  .gallery-grid .item {
    width: 100%;
    padding: 0 0 10px; }
    .gallery-grid .item img {
      width: 100%; }
    .gallery-grid .item figure {
      position: relative;
      overflow: hidden;
      text-align: center; }
      .gallery-grid .item figure figcaption {
        position: absolute;
        width: 100%;
        bottom: 0;
        background: rgba(0, 0, 0, 0.4);
        padding: 10px 15px; }
        .gallery-grid .item figure figcaption span {
          color: #FFFFFF;
          font-size: 15px;
          font-weight: 400;
          text-transform: uppercase; }

@media (min-width: 768px) {
  .gallery-grid {
    margin: 0 -10px; }
    .gallery-grid .item {
      width: 50%;
      padding: 0 5px 10px; } }

@media (min-width: 992px) {
  .gallery-grid .item {
    width: 33.33333%; } }

@media (min-width: 1200px) {
  .gallery-grid .item {
    width: 25%; }
    .gallery-grid .item figure figcaption {
      position: absolute;
      height: 100%;
      width: 100%;
      top: 0;
      background: rgba(0, 0, 0, 0.4);
      opacity: 0;
      transition: opacity .35s; }
    .gallery-grid .item figure:hover figcaption {
      opacity: 1; }
    .gallery-grid .item figure figcaption span {
      left: 0;
      position: absolute;
      right: 0;
      top: 50%;
      text-transform: uppercase;
      transform: translateY(-50%); } }

/* ---------- Sitemap ---------- */
.nav_sitemap {
  width: 100%; }
  .nav_sitemap ul, .nav_sitemap li, .nav_sitemap a {
    width: 100%; }
  .nav_sitemap ul a {
    margin: 0 0 4px 0;
    padding: 5px 1%;
    background: #E4E4E4; }
  .nav_sitemap ul ul a {
    padding-left: 3%;
    background: #F4F4F4; }
  .nav_sitemap ul ul ul a {
    padding-left: 6%;
    background: #f8f8f8; }
  .nav_sitemap ul ul ul ul a {
    padding-left: 9%;
    background: #FFFFFF; }
  .nav_sitemap ul ul ul ul ul a {
    padding-left: 12%; }

/* ---------- Maps ---------- */
.map img, .map_directions img {
  max-width: none !important;
  width: auto !important; }

.map {
  width: 100%;
  min-height: 500px; }

.map_marker {
  white-space: nowrap; }
  .map_marker .button {
    margin-top: 5px; }
  .map_marker .button_directions {
    background: none;
    padding: 0;
    border: none;
    box-shadow: none;
    color: #337ab7; }
    .map_marker .button_directions:hover {
      text-decoration: underline; }

.map_directions_controls label, .map_directions_controls .textbox {
  float: left; }

.map_directions_controls label {
  padding: 0 5px 0 0;
  min-width: 20%; }

.map_directions_controls .textbox {
  width: 80%; }

.map_directions_controls .button {
  width: 80%;
  float: right; }

.map_directions {
  clear: both; }
  .map_directions > div:first-child, .map_directions table {
    width: 100%; }

.nav_attractions {
  width: 100%; }
  .nav_attractions ul, .nav_attractions a {
    width: 100%; }
  .nav_attractions li {
    width: 50%; }
  .nav_attractions a {
    padding-right: 5%;
    padding-left: 0;
    margin: 0 0 5px 0; }

.promotion_hp {
  position: fixed;
  bottom: 145px;
  z-index: 10;
  width: 100%;
  max-width: 400px;
  background-color: rgba(255, 255, 255, 0.7);
  right: 0;
  color: #2B2B2B;
  -webkit-animation-duration: 1.5s;
  -moz-animation-duration: 1.5s;
  -o-animation-duration: 1.5s;
  animation-duration: 1.5s;
  -webkit-animation-delay: .8s;
  -moz-animation-delay: .8s;
  -o-animation-delay: .8s;
  animation-delay: .8s;
  -webkit-animation-name: beaut-appear;
  -moz-animation-name: beaut-appear;
  -o-animation-name: beaut-appear;
  animation-name: beaut-appear;
  -moz-animation-fill-mode: both;
  -o-animation-fill-mode: both;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -moz-animation-timing-function: ease;
  -o-animation-timing-function: ease;
  -webkit-animation-timing-function: ease;
  animation-timing-function: ease; }
  .promotion_hp .content {
    padding: 20px;
    display: inline-block;
    max-width: 60%;
    width: 100%; }
    .promotion_hp .content h3 {
      font-size: 2.5rem;
      text-transform: uppercase;
      line-height: 3.2rem;
      color: #2B2B2B; }
  .promotion_hp .price {
    font-weight: bold;
    color: #12516B;
    font-weight: 400;
    padding-left: 5px; }
    .promotion_hp .price span {
      font-weight: normal;
      color: rgba(42, 44, 47, 0.5);
      text-transform: uppercase;
      font-size: 1.5rem; }
    .promotion_hp .price .price_text {
      color: #12516B;
      font-weight: 400;
      padding-left: 5px;
      font-size: 2.4rem; }
  .promotion_hp .wrapper {
    top: 20px;
    position: relative;
    float: right; }
    .promotion_hp .wrapper .button {
      margin: 0 20px 0 0;
      min-width: 130px;
      padding: 10px 10px; }
  .promotion_hp .reveal {
    opacity: 0;
    transform: rotate(-90deg);
    position: absolute;
    top: 0;
    left: -98px;
    margin: 0;
    height: 48px;
    width: 150px;
    transition: opacity 0.8s ease-out 0.2s;
    font-size: 1.8rem; }
  .promotion_hp.hide_offer .reveal {
    opacity: 1;
    transition: opacity 0.8s ease-in 2s; }

.hide_offer {
  -webkit-animation-name: beaut-disappear;
  -moz-animation-name: beaut-disappear;
  -o-animation-name: beaut-disappear;
  animation-name: beaut-disappear;
  -moz-animation-fill-mode: both;
  -o-animation-fill-mode: both;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -moz-animation-timing-function: ease;
  -o-animation-timing-function: ease;
  -webkit-animation-timing-function: ease;
  animation-timing-function: ease; }

/* Attractions (Split) */
.att-item {
  max-width: 600px;
  margin: 0 auto; }
  .att-item .att-content {
    position: relative;
    padding: 30px 15px 15px;
    background-color: #FFFFFF; }
    .att-item .att-content h2 {
      margin: 0 0 20px;
      font-size: 28px; }

.att-list {
  padding: 80px 15px 60px; }
  .att-list .att-item {
    display: block;
    margin-bottom: 30px; }
    .att-list .att-item .inner {
      box-shadow: 0px 8px 20px rgba(0, 0, 0, 0.1); }
    .att-list .att-item img {
      width: 100%; }

@media (min-width: 768px) {
  .attractions_map {
    height: 100%;
    position: fixed;
    width: 50%; }
    .attractions_map .map_attractions {
      width: 100%;
      height: 100%; }
  .att-list {
    width: 50%;
    float: right;
    min-height: 100vh;
    clear: both;
    padding: 40px 30px; } }

@media (min-width: 1300px) {
  footer .nav_footer .nav_buttons {
    min-width: 160px !important; }
    footer .nav_footer .nav_buttons svg {
      height: 16px; } }

@media (max-width: 1200px) {
  .footer .col-xs-12 {
    text-align: left; }
    .footer .col-xs-12 .social ul {
      padding-top: 10px;
      width: 100%; }
  .footer .nav_buttons {
    text-align: center;
    width: 50%;
    border-bottom: 1px solid #F5E7D2;
    border-left: 1px solid #F5E7D2;
    padding: 5px 0; }
    .footer .nav_buttons:last-child {
      border-left: none !important; }
  .footer .nav_footer {
    border: none !important; }
    .footer .nav_footer .nav_foot {
      border-top: 1px solid #F5E7D2;
      border-bottom: 1px solid #F5E7D2;
      width: 100%;
      padding: 10px 5px; }
  .footer .address, .footer .contact {
    width: 100%; } }

@media (min-width: 1200px) {
  .att-list .att-item {
    width: 50%;
    display: inline-block;
    margin-right: -4px; }
    .att-list .att-item:nth-child(odd) {
      padding: 0 10px 0 0; }
    .att-list .att-item:nth-child(even) {
      padding: 0 0 0 10px; } }

/**Home Notification Popup**/
.newsletter_panel {
  width: 100%;
  background: rgba(255, 255, 255, 0.95);
  outline: 1px solid #bacace;
  outline-offset: -10px;
  padding: 20px 30px;
  -webkit-transition: transform .4s linear;
  transition: transform .4s linear;
  opacity: 0;
  z-index: 999; }
  .newsletter_panel.stick {
    position: fixed;
    bottom: 0;
    left: 0;
    opacity: 1;
    transition: opacity .2s .35s; }
  .newsletter_panel h4 {
    color: #000000;
    font-weight: 200; }
  .newsletter_panel .button {
    float: right;
    padding: 10px 20px;
    line-height: 25px;
    margin: 5px 0; }
    .newsletter_panel .button svg {
      width: 25px;
      height: 15px;
      fill: #000000;
      padding-right: 10px; }

/* ---------- Footer ---------- */
.footer {
  color: #F5E7D2;
  position: relative;
  z-index: 10; }
  .footer .main_footer {
    background-color: #4F6D76; }
    .footer .main_footer .contact a {
      margin-right: 15px;
      line-height: 3rem; }
    .footer .main_footer .nav_buttons:first-child {
      border-right: 1px solid #F5E7D2; }
    .footer .main_footer .nav_footer {
      border-top: 1px solid #F5E7D2;
      border-bottom: 1px solid #F5E7D2;
      text-transform: uppercase; }
      .footer .main_footer .nav_footer .nav_foot a {
        line-height: 40px;
        padding-right: 10px; }
      .footer .main_footer .nav_footer .nav_buttons {
        display: inline-block;
        float: right;
        min-width: 125px;
        text-align: center;
        border-left: 1px solid #F5E7D2; }
        .footer .main_footer .nav_footer .nav_buttons.last-child {
          border-right: 1px solid #F5E7D2; }
        .footer .main_footer .nav_footer .nav_buttons a {
          line-height: 45px;
          padding: 0 5px; }
        .footer .main_footer .nav_footer .nav_buttons svg {
          width: 25px;
          height: 16px;
          fill: #F9F9F9; }
  .footer a {
    color: #F5E7D2;
    opacity: 1; }
    .footer a:hover {
      color: #F5E7D2;
      opacity: .8; }
  .footer .address, .footer .contact {
    display: inline-block;
    margin-right: 15px;
    font-size: 15px; }
  .footer .rights_footer {
    background: #F9F9F9;
    display: inline-block;
    width: 100%;
    text-align: center;
    padding: 15px 0;
    color: #4F6D76; }
    .footer .rights_footer a {
      color: #4F6D76; }
  .footer .button {
    color: #FFFFFF;
    background-color: #B75F00;
    text-decoration: none; }
  .footer .scroll-to-top {
    right: 15px;
    position: absolute;
    top: -50px;
    z-index: 50;
    width: 35px;
    height: 50px;
    background: #F5E7D2;
    text-align: center;
    cursor: pointer; }
    .footer .scroll-to-top svg {
      width: 30px;
      height: 50px;
      fill: #12516B;
      transition: fill .35s, height .35s, width .35s; }

.nav_foot li {
  display: inline-block; }
  .nav_foot li a {
    width: 100%;
    padding: 2px; }

.social ul {
  float: right;
  padding-left: 0; }
  .social ul li {
    float: none;
    display: inline-block; }
  .social ul a {
    display: block;
    margin: 0 5px 5px 0;
    padding: 5px;
    color: #F5E7D2;
    font-size: 15px;
    text-align: center;
    border-radius: 50%;
    border: 1px solid #F5E7D2; }
    .social ul a:hover, .social ul a:focus {
      text-decoration: none; }

/* Mobile Nav */
@media (max-width: 767px) {
  .header {
    padding: 0; }
    .header.stick {
      height: 70px; }
    .header .mob-nav-btn .menui {
      background-color: #12516B !important; }
    .header .nav_wrapper {
      position: absolute;
      left: 0;
      background: #FFFFFF;
      width: 100%;
      height: 70px;
      overflow: hidden;
      border-bottom: 1px solid #12516B; }
      .header .nav_wrapper .button-mob {
        color: #FFFFFF;
        width: 150px;
        float: left;
        display: inline-block !important;
        line-height: 70px;
        padding: 0;
        font-size: 13px; }
      .header .nav_wrapper .mob-nav-btn {
        height: 65px; }
      .header .nav_wrapper .nav_primary_mobile {
        float: left;
        height: 70px;
        display: block !important; }
        .header .nav_wrapper .nav_primary_mobile .btn-gift, .header .nav_wrapper .nav_primary_mobile .phone {
          display: inline-block;
          height: 70px;
          font-size: 2.5rem;
          line-height: 70px;
          text-align: center;
          text-transform: uppercase;
          width: 63px;
          float: left;
          border-right: 1px solid rgba(20, 33, 51, 0.5);
          color: #2B2B2B; }
          .header .nav_wrapper .nav_primary_mobile .btn-gift svg, .header .nav_wrapper .nav_primary_mobile .phone svg {
            width: 25px;
            height: 25px;
            fill: #2B2B2B; }
        .header .nav_wrapper .nav_primary_mobile .btn-gift {
          display: inline-block;
          height: 70px;
          font-size: 2.5rem;
          line-height: 70px;
          text-align: center;
          text-transform: uppercase;
          width: 63px;
          float: left; }
  footer .address, footer .contact {
    margin-bottom: 20px; }
    footer .address a, footer .contact a {
      display: block;
      margin-bottom: 10px; }
  .newsletter_panel .button {
    float: left; } }

/*Responder dialog*/
.dialog_newsletter {
  padding: 20px; }

/* Awards widget */
.slick_logos img {
  margin: 0 auto;
  max-height: 80px; }

/* Datepicker calendar icon */
.hasDatepicker {
  background-color: #fff;
  background-image: url("https://scdn.aro.ie/Sites/50/ballyliffinlodge2019/assets/images/datepicker.png");
  background-repeat: no-repeat;
  background-position: 98% center; }

/**Exit Intent Pop Up**/
.mfp-window {
  width: 100% !important;
  height: 100% !important;
  position: fixed !important;
  z-index: 1; }

.mfp-wrap .exit-popup {
  width: auto;
  display: block;
  position: relative;
  max-width: 500px; }

.exit-popup {
  width: 500px;
  max-width: 100%;
  margin: 0 auto;
  padding: 10px; }

.exit-popup-inner {
  position: relative;
  z-index: 999;
  background-color: #FFFFFF;
  outline-offset: 10px;
  margin: 0 auto; }
  .exit-popup-inner .mfp-close {
    opacity: 1;
    border-radius: 13px 0 13px 0;
    font-size: 24px;
    padding: 0 0 10px 3px;
    cursor: pointer;
    z-index: 100;
    margin-top: 10px;
    margin-right: 5px; }
  .exit-popup-inner .panel_wrapper {
    position: relative;
    width: 100%;
    display: inline-block; }
    .exit-popup-inner .panel_wrapper .title_container {
      padding: 5px 10px; }
    .exit-popup-inner .panel_wrapper img {
      margin: 0 auto;
      z-index: 10; }
  .exit-popup-inner h2 {
    font-size: 3rem; }
  .exit-popup-inner h4 {
    margin-bottom: 0;
    padding: 10px 0 5px;
    font-size: 1.7rem; }
  .exit-popup-inner .button {
    padding: 10px 25px; }
  .exit-popup-inner .text_container {
    padding: 10px 0 15px; }

.wedding_popup iframe {
  background: #FFFFFF !important; }

/* Magnific Popup CSS */
.mfp-bg {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1042;
  overflow: hidden;
  position: fixed;
  background: #0b0b0b;
  opacity: 0.8;
  filter: alpha(opacity=80); }

.mfp-wrap {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1043;
  position: fixed;
  outline: none !important;
  -webkit-backface-visibility: hidden; }

.mfp-container {
  text-align: center;
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  padding: 0 15px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }
  .mfp-container:before {
    content: '';
    display: inline-block;
    height: 100%;
    vertical-align: middle; }

.mfp-align-top .mfp-container:before {
  display: none; }

.mfp-content {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  margin: 0 auto;
  text-align: left;
  z-index: 1045; }

.mfp-inline-holder .mfp-content, .mfp-ajax-holder .mfp-content {
  width: 100%;
  cursor: auto; }

.mfp-ajax-cur {
  cursor: progress; }

.mfp-zoom-out-cur {
  cursor: -moz-zoom-out;
  cursor: -webkit-zoom-out;
  cursor: zoom-out; }
  .mfp-zoom-out-cur .mfp-image-holder .mfp-close {
    cursor: -moz-zoom-out;
    cursor: -webkit-zoom-out;
    cursor: zoom-out; }

.mfp-zoom {
  cursor: pointer;
  cursor: -webkit-zoom-in;
  cursor: -moz-zoom-in;
  cursor: zoom-in; }

.mfp-auto-cursor .mfp-content {
  cursor: auto; }

.mfp-close, .mfp-arrow, .mfp-preloader, .mfp-counter {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none; }

.mfp-loading.mfp-figure {
  display: none; }

.mfp-hide {
  display: none !important; }

.mfp-preloader {
  color: #cccccc;
  position: absolute;
  top: 50%;
  width: auto;
  text-align: center;
  margin-top: -0.8em;
  left: 8px;
  right: 8px;
  z-index: 1044; }
  .mfp-preloader a {
    color: #cccccc; }
    .mfp-preloader a:hover {
      color: white; }

.mfp-s-ready .mfp-preloader, .mfp-s-error .mfp-content {
  display: none; }

button.mfp-close, button.mfp-arrow {
  overflow: visible;
  cursor: pointer;
  background: transparent;
  border: 0;
  -webkit-appearance: none;
  display: block;
  outline: none;
  padding: 0;
  z-index: 1046;
  -webkit-box-shadow: none;
  box-shadow: none;
  font-size: 200%;
  color: #FFFFFF; }

button::-moz-focus-inner {
  padding: 0;
  border: 0; }

.mfp-close {
  width: 44px;
  height: 44px;
  line-height: 44px;
  position: absolute;
  right: 0;
  top: 0;
  text-decoration: none;
  text-align: center;
  opacity: 0.65;
  padding: 0 0 18px 10px;
  color: white;
  font-style: normal;
  font-size: 28px; }
  .mfp-close:hover, .mfp-close:focus {
    opacity: 1; }
  .mfp-close:active {
    top: 1px; }

.mfp-close-btn-in .mfp-close {
  color: #333333; }

.mfp-image-holder .mfp-close, .mfp-iframe-holder .mfp-close {
  color: white;
  right: -6px;
  text-align: right;
  padding-right: 6px;
  width: 100%; }

.mfp-counter {
  position: absolute;
  top: 0;
  right: 0;
  color: #cccccc;
  font-size: 12px;
  line-height: 18px; }

.mfp-arrow {
  position: absolute;
  opacity: 0.65;
  margin: 0;
  top: 50%;
  margin-top: -55px;
  padding: 0;
  width: 90px;
  height: 110px;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }
  .mfp-arrow i {
    position: relative; }
  .mfp-arrow:active {
    margin-top: -54px; }
  .mfp-arrow:hover, .mfp-arrow:focus {
    opacity: 1; }
  .mfp-arrow:before, .mfp-arrow:after, .mfp-arrow .mfp-b, .mfp-arrow .mfp-a {
    /*content: '';*/
    display: block;
    width: 0;
    height: 0;
    position: absolute;
    left: 0;
    top: 0;
    margin-top: 35px;
    margin-left: 35px;
    border: medium inset transparent; }
  .mfp-arrow:after, .mfp-arrow .mfp-a {
    border-top-width: 13px;
    border-bottom-width: 13px;
    top: 8px; }
  .mfp-arrow:before, .mfp-arrow .mfp-b {
    border-top-width: 21px;
    border-bottom-width: 21px; }

.mfp-arrow-left {
  left: 0; }
  .mfp-arrow-left:after, .mfp-arrow-left .mfp-a {
    border-right: 17px solid transparent;
    margin-left: 31px !important; }
  .mfp-arrow-left:before, .mfp-arrow-left .mfp-b {
    margin-left: 25px !important;
    border-right: 27px solid transparent; }

.mfp-arrow-right {
  right: 0;
  text-align: right; }
  .mfp-arrow-right:after, .mfp-arrow-right .mfp-a {
    border-left: 17px solid transparent;
    margin-right: 39px !important; }
  .mfp-arrow-right:before, .mfp-arrow-right .mfp-b {
    margin-right: 25px !important;
    border-right: 5px solid transparent; }
  .mfp-arrow-right:before {
    right: 0;
    left: auto; }

.mfp-iframe-holder {
  padding-top: 40px;
  padding-bottom: 40px; }
  .mfp-iframe-holder .mfp-content {
    line-height: 0;
    width: 100%;
    max-width: 900px; }
    .mfp-iframe-holder .mfp-content.media-popup {
      max-width: 1200px; }
  .mfp-iframe-holder .mfp-close {
    top: -40px; }

.mfp-iframe-scaler {
  width: 100%;
  height: 0;
  overflow: hidden;
  padding-top: 56.25%; }
  .mfp-iframe-scaler iframe {
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
    background: black; }

/* Main image in popup */
img.mfp-img {
  width: auto;
  max-width: 100%;
  height: auto;
  display: block;
  line-height: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  padding: 40px 0 40px;
  margin: 0 auto; }

/* The shadow behind the image */
.mfp-figure {
  line-height: 0; }
  .mfp-figure:after {
    content: '';
    position: absolute;
    left: 0;
    top: 40px;
    bottom: 40px;
    display: block;
    right: 0;
    width: auto;
    height: auto;
    z-index: -1;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
    background: #444444; }
  .mfp-figure small {
    color: #bdbdbd;
    display: block;
    font-size: 12px;
    line-height: 14px; }

.mfp-bottom-bar {
  margin-top: -36px;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  cursor: auto; }

.mfp-title {
  text-align: left;
  line-height: 18px;
  color: #f3f3f3;
  word-wrap: break-word;
  padding-right: 36px; }

.mfp-image-holder .mfp-content {
  max-width: 100%; }

.mfp-gallery .mfp-image-holder .mfp-figure {
  cursor: pointer; }

/*Ezine Validation*/
.noshow {
  display: none; }

/* jQuery UI Datepicker */
.ui-helper-clearfix:before {
  content: '';
  display: table;
  border-collapse: collapse; }

.ui-helper-clearfix:after {
  content: '';
  display: table;
  border-collapse: collapse;
  clear: both; }

.ui-state-disabled {
  cursor: default !important; }

.ui-icon {
  display: block;
  overflow: hidden; }

.ui-datepicker {
  background: #FFFFFF;
  padding: 15px;
  font-size: 90%;
  font-weight: 400;
  border: none;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  border-radius: 0;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15);
  float: left;
  z-index: 99999 !important;
  position: relative;
  display: none; }
  .ui-datepicker .ui-datepicker-header {
    border: none;
    background: #FFFFFF;
    font-weight: normal;
    font-size: 15px;
    color: #4F6D76;
    position: relative; }
    .ui-datepicker .ui-datepicker-header .ui-state-hover {
      background: transparent;
      border-color: transparent;
      cursor: pointer;
      -webkit-border-radius: 0;
      -moz-border-radius: 0;
      border-radius: 0; }
  .ui-datepicker .ui-datepicker-title {
    color: #4F6D76;
    font-size: 14px;
    text-align: center;
    text-transform: uppercase; }
  .ui-datepicker .ui-datepicker-prev {
    height: 1.8em;
    position: absolute;
    top: 2px;
    width: 1.8em;
    color: #4F6D76;
    background-color: rgba(0, 0, 0, 0); }
  .ui-datepicker .ui-datepicker-next {
    height: 1.8em;
    position: absolute;
    top: 2px;
    width: 1.8em;
    color: #4F6D76;
    background-color: rgba(0, 0, 0, 0);
    right: 2px; }
  .ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover, .ui-datepicker .ui-datepicker-next, .ui-datepicker .ui-datepicker-prev {
    top: -2px;
    border: none; }
  .ui-datepicker .ui-state-disabled .ui-icon {
    opacity: 0.5; }
  .ui-datepicker .ui-datepicker-next span {
    color: #4F6D76;
    display: block;
    font-weight: normal;
    height: 20px;
    left: 50%;
    margin-left: -8px;
    margin-top: 0;
    position: absolute;
    top: 0;
    width: 20px;
    text-indent: initial; }
  .ui-datepicker .ui-datepicker-prev span {
    color: #4F6D76;
    display: block;
    font-weight: normal;
    height: 20px;
    left: 50%;
    margin-left: -8px;
    margin-top: 0;
    position: absolute;
    top: 0;
    width: 20px;
    text-indent: initial;
    background-position: -96px 0; }
  .ui-datepicker table {
    margin: 0; }
  .ui-datepicker th {
    padding: 5px 0 2px;
    color: #aaa;
    font-size: 13px;
    font-weight: normal;
    border: none;
    text-align: center; }
  .ui-datepicker td {
    background: #FFFFFF;
    border: 1px solid #dcdada;
    padding: 0; }
    .ui-datepicker td .ui-state-default {
      background: transparent;
      border: none;
      text-align: center;
      padding: 5px 8px;
      margin: 0;
      font-weight: normal;
      color: #666;
      font-size: 14px; }
  .ui-datepicker .ui-state-disabled {
    opacity: 1; }
  .ui-datepicker td span, .ui-datepicker td a {
    display: block;
    padding: 0.2em;
    text-align: right;
    text-decoration: none; }
  .ui-datepicker .ui-state-disabled .ui-state-default {
    color: #acacac; }
  .ui-datepicker td .ui-state-active, .ui-datepicker td .ui-state-hover {
    background: #12516B;
    color: #FFFFFF; }

/**Christmas Bauble**/
.swing {
  top: 55px;
  left: 50px;
  position: absolute;
  transform-origin: top center;
  animation: swing ease-in-out 1s infinite alternate;
  transform: translate3d(-40%, 0, 0);
  backface-visibility: hidden;
  z-index: 20;
  max-width: 90px; }
  @media (min-width: 768px) {
    .swing {
      max-width: 100px;
      top: -5px;
      left: calc(10vw + 250px); } }
  @media (min-width: 992px) {
    .swing {
      max-width: 130px; } }
  @media (min-width: 768px) {
    .noheaderimage .swing {
      max-width: 65px;
      top: -5px;
      left: 3.5vw; } }

@keyframes swing {
  0% {
    transform: rotate(3deg); }
  100% {
    transform: rotate(-3deg); } }

/**FAQs**/
.faq_panel {
  background: #f0f4f5;
  width: 100%;
  margin-top: 30px; }
  .contentpage .faq_panel {
    background: none; }
  .faq_panel b, .faq_panel strong {
    font-weight: 500; }
  .faq_panel .faq_wrapper {
    border-top: 1px solid #d1dde0;
    padding: 50px 0; }
    .contentpage .faq_panel .faq_wrapper {
      padding: 30px 0; }
  .faq_panel .title_wrapper {
    padding-bottom: 30px; }
  .faq_panel h3 {
    font-weight: 300;
    text-align: center;
    text-transform: uppercase; }
  .faq_panel .faq_container {
    max-width: 1000px;
    width: 70%;
    margin: 0 auto; }
    .contentpage .faq_panel .faq_container {
      width: 100%; }
    @media (max-width: 767px) {
      .faq_panel .faq_container {
        padding: 0 20px;
        width: 100%; } }
    .faq_panel .faq_container .item {
      background: #fff;
      margin: 10px 0; }
      .contentpage .faq_panel .faq_container .item {
        background: #f0f4f5; }

/*  CSS Accordion */
.css-accordion {
  margin: 50px auto; }
  .css-accordion label {
    margin: 0;
    padding: 20px;
    position: relative;
    z-index: 20;
    display: block;
    cursor: pointer;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center; }
    .css-accordion label h4 {
      margin: 0;
      padding: 0;
      text-align: left;
      max-width: 90%;
      padding: 0;
      position: relative;
      text-transform: none;
      cursor: pointer;
      font-size: 1.6rem;
      font-weight: 300;
      text-align: left;
      flex: 0 0 90%; }
    .css-accordion label i {
      height: 25px;
      position: relative;
      flex: 0 0 10%;
      max-width: 25px; }
      .css-accordion label i:before, .css-accordion label i:after {
        content: "";
        position: absolute;
        background-color: #12516B;
        width: 1px;
        height: 10px;
        transition: transform .2s;
        top: 6px;
        left: 12px; }
      .css-accordion label i:before {
        transform: translate(3px, 0) rotate(45deg); }
      .css-accordion label i:after {
        transform: translate(-4px, 0) rotate(-45deg); }
  .css-accordion input {
    display: none; }
  .css-accordion .content-wrapper {
    margin-top: -1px;
    overflow: hidden;
    max-height: 0;
    position: relative;
    z-index: 10;
    border-bottom: 1px solid #d1dde0;
    transition: max-height 0.35s; }
    .css-accordion .content-wrapper .content {
      font-size: 1.6rem;
      padding: 20px;
      font-weight: 300;
      border-top: 1px dotted #d1dde0;
      background: rgba(245, 231, 210, 0.2); }
      .contentpage .css-accordion .content-wrapper .content {
        background: #fff;
        margin-bottom: 0; }
  .css-accordion input:checked + label i:before {
    transform: translate(-3px, 0) rotate(45deg); }
  .css-accordion input:checked + label i:after {
    transform: translate(3px, 0) rotate(-45deg); }
  .css-accordion input:checked ~ .content-wrapper {
    max-height: 500px;
    transition: max-height .5s; }

/***Popup Promo**/
.home_popup {
  position: fixed;
  top: 50%;
  left: 50%;
  width: 100%;
  max-width: 430px;
  background: #fff;
  z-index: -999;
  visibility: hidden;
  opacity: 0;
  transition: all 0.7s cubic-bezier(0.5, -0.25, 0.4, 1);
  transform: translate3d(-50%, 150%, 0) scale(0.8); }
  .home_popup-show {
    visibility: visible;
    opacity: 1;
    transform: translate3d(-50%, -50%, 0) scale(1);
    transition-delay: 1s;
    z-index: 999; }
    @media (max-width: 640px) {
      .home_popup-show {
        transform: translate3d(-50%, 0, 0) scale(1); } }
  .bg-img .home_popup {
    background: #4F6D76;
    border: 5px solid #fff; }
  @media (max-width: 640px) {
    .home_popup {
      top: 0;
      width: 100%; } }
  .home_popup .close {
    position: absolute;
    top: 0;
    right: 0;
    opacity: 1;
    font-size: 32px;
    font-weight: 300;
    color: #12516B;
    width: 40px;
    height: 40px;
    transition: all 0.2s linear; }
    .home_popup .close:hover, .home_popup .close:focus {
      color: #777; }
    .bg-img .home_popup .close {
      background: #F5E7D2; }
      .bg-img .home_popup .close:hover, .bg-img .home_popup .close:focus {
        background: rgba(245, 231, 210, 0.8); }
  .home_popup img {
    display: block;
    max-width: 100%;
    margin: 0 auto;
    width: auto; }
  .home_popup .btn_wrapper {
    text-align: center;
    margin: 20px 0 auto;
    padding: 0; }
    .home_popup .btn_wrapper .button {
      margin: 0; }
      .bg-img .home_popup .btn_wrapper .button {
        background: #F5E7D2;
        border: #F5E7D2;
        color: #333; }
        .bg-img .home_popup .btn_wrapper .button:hover, .bg-img .home_popup .btn_wrapper .button:focus {
          background: rgba(245, 231, 210, 0.8);
          border: rgba(245, 231, 210, 0.8); }
    .home_popup .btn_wrapper div {
      display: inline-block; }
  .home_popup_inner {
    padding: 40px 12px 12px 12px; }
    .bg-img .home_popup_inner {
      border: 5px solid #F5E7D2; }
  .home_popup_content {
    color: #333;
    padding: 0;
    text-align: center; }
    .bg-img .home_popup_content {
      color: #fff; }
  .home_popup_content_inner {
    padding: 25px 15px;
    text-align: center;
    font-size: 14px; }
    .home_popup_content_inner h3 {
      margin: 0 0 20px;
      text-transform: uppercase;
      font-size: 22px; }
      .bg-img .home_popup_content_inner h3 {
        color: #fff; }
    .home_popup_content_inner .content {
      font-size: 14px; }
      .bg-img .home_popup_content_inner .content {
        color: #fff; }
      .home_popup_content_inner .content a {
        color: #12516B; }
      .home_popup_content_inner .content p {
        margin-bottom: 5px;
        font-size: 14px; }

#flake {
  color: #fff;
  font-size: 48px;
  position: absolute;
  top: -90px;
  z-index: 9999; }

/* ----- Responsive styles ----- */
/*min = greater than or equal to
max = less than or equal to*/
@media (max-width: 991px) {
  a.nav_mob_button {
    display: block;
    right: 5px;
    top: 0px;
    position: fixed;
    color: #FFFFFF;
    z-index: 1000;
    font-size: 18px;
    text-shadow: 0.1em 0.1em 0.05em rgba(0, 0, 0, 0.8); }
  .mobile-nav {
    display: block; }
  .room_details .booking {
    display: none; }
  .content_2 {
    column-count: 1; }
  .roomspage .room_list_item {
    margin-bottom: 15px; }
  .offers-grid .panel {
    padding: 20px 15px !important;
    border: 1px solid #4F6D76;
    max-width: 400px;
    margin: 0 auto; }
  .homepage .header_video .header_image_tag {
    width: 45%; }
    .homepage .header_video .header_image_tag h2 {
      font-size: 3.5rem; } }

@media (max-width: 767px) {
  .grid .grid_block {
    margin-bottom: 15px; }
  .gallery a, .gallery img, .gallery .video_res {
    margin-bottom: 5px; }
  .form_wrapper .form {
    width: 100%; }
    .form_wrapper .form:first-child tr td:last-child {
      padding-right: 0; }
    .form_wrapper .form:last-child tr td:first-child {
      padding-left: 0; }
  .booking_landscape {
    display: none; }
  .mobileBooking {
    display: block; }
  /* Mobile Buttons */
  .mobile-menu {
    padding: 1.5px 0;
    position: absolute;
    display: block;
    bottom: 0;
    width: 100%;
    z-index: 100; }
    .mobile-menu .menu .button {
      float: left;
      margin: 0;
      width: calc((50%) - 0px);
      font-size: 16px;
      color: #FFFFFF;
      text-transform: uppercase;
      padding: 15px 0;
      background: rgba(18, 80, 107, 0.5);
      border-top: 1px solid rgba(255, 255, 255, 0.4);
      border-right: 1px solid rgba(255, 255, 255, 0.4); }
      .mobile-menu .menu .button:focus, .mobile-menu .menu .button:active {
        background: rgba(255, 255, 255, 0.3);
        color: #FFFFFF; }
  .weddingspage .wedding_panel .text_wrapper {
    padding: 5% 0; } }

@media (max-width: 600px) {
  .form .textbox, .form select, .form .button {
    width: 100%; } }

/* Image effect on scroll */
.fade-in {
  opacity: 0;
  transition: opacity .5s, transform .5s; }

.fade-in-v, .fade-in-h-r, .fade-in-h-l {
  transform: translate(0, 50px); }

.fade-in-gallery {
  opacity: 0;
  transition: opacity .35s .2s; }

@media (min-width: 768px) {
  .fade-in-v {
    transform: translate(0, 80px); }
  .fade-in-h-l {
    transform: translate(-80px, 0); }
  .fade-in-h-r {
    transform: translate(80px, 0); } }

.faded-in {
  opacity: 1;
  transform: translate(0, 0); }

/* Breadcrumbs */
.breadcrumb-wrapper {
  border-top: 1px solid rgba(0, 0, 0, 0.15);
  background: #fff; }
  .offer-dtls .breadcrumb-wrapper {
    position: absolute;
    bottom: 0;
    left: 50px;
    width: 100%; }
    @media (min-width: 992px) {
      .offer-dtls .breadcrumb-wrapper {
        left: 100px; } }
    @media (min-width: 1200px) {
      .offer-dtls .breadcrumb-wrapper {
        left: 250px; } }
  .offerslistpage .breadcrumb-wrapper {
    margin-top: 60px; }

.breadcrumb {
  background-color: transparent;
  margin: 0 !important;
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
  align-items: center;
  padding: 5px 20px; }
  .breadcrumb li {
    color: #2B2B2B;
    font-size: 1rem;
    text-transform: uppercase;
    padding: 0 !important;
    margin: 0 0 2px 0 !important; }
    .breadcrumb li a {
      color: #12516B;
      text-transform: uppercase; }

.holiday-event-btn {
  padding: 12px 20px 12px 40px;
  margin-bottom: 10px;
  font-size: 16px;
  position: relative;
  background-color: #c00;
  display: none; }
  .holiday-event-btn svg {
    fill: #fff;
    width: 20px;
    height: 20px;
    position: absolute;
    top: 12px;
    left: 10px; }
  .mobile-menu .holiday-event-btn,
  .booking .holiday-event-btn {
    margin-bottom: 0; }
  .booking .holiday-event-btn {
    margin-top: 8px;
    padding: 7px 10px;
    font-size: 14px; }
    .booking .holiday-event-btn svg {
      width: 16px;
      height: 16px;
      top: 8px; }
  .secondarypage .holiday-event-btn svg {
    left: calc(50% - 65px); }
  .holiday-event-btn.show {
    display: block; }
