@charset "UTF-8";

@import url("https://fonts.googleapis.com/css2?family=Ibarra+Real+Nova:ital,wght@0,400..700;1,400..700&family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap");

@media screen {
  
  /* ----- ROOT ----- */
  :root {
    --color-brand-1: #17355A;
    --color-brand-2: #B02839;
    --color-brand-3: #FDFBF8;
    --color-brand-4: #DCE5F1;
    --color-brand-5: #212121;
    --color-brand-7: #213F64;
    --color-black: #000000;
    --color-white: #FFFFFF;
    --font-faily-1: "Open Sans", sans-serif;
    --font-faily-2: "Ibarra Real Nova", serif;
    
    /*--border-radius-1x: 8px;*/
    --transition-default: all 0.5s ease;
  }
  
  body {
    background-color: var(--color-brand-3);
    
    font-family: var(--font-faily-1);
    /* font-size: 16px; */ /* Too big and throws visual balance off */
  }

  #header .logo h3.noname {
    display: none;
  }

  .avvio-calendar-container,
  .avvio-calendar__month {
    border-radius: var(--border-radius-1x)!important;
  }

  .button-icon:hover .button-icon__icon,
  .button-icon--secondary .button-icon__icon {
    width: 100%;
    height: 100%;
    color: var(--color-black);
    background-color: transparent;
    border-radius: var(--border-radius-1x)!important;
    /*border: var(--border-black);*/
    transition: var(--transition-default);
  }

  .button-icon:hover:not(.disabled) .button-icon__icon {
    color: var(--color-white);
    background-color: var(--color-brand-1);
  }

  .checkbox-field__input + .checkbox-field__icon {
    background-color: transparent;
  }

  .underline {
    text-decoration: none;
  }
  
  .header a i,
  .footer a i {
    margin-right: 0px;
  }
  
  .main-be-area {
    background-color: var(--color-white);
  }
  
  .content {
    background-color: var(--color-brand-3);
    
    margin-bottom: -1px;
  }
  
  ::selection {
    color: var(--color-brand-3);
    background: var(--color-brand-1);
  }
  
  .header *::selection,
  .footer *::selection {
    color: var(--color-brand-1);
    background: var(--color-brand-3);
  }
  
  
  
  /* ----- Header ----- */
  .header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    
    background: var(--color-brand-1);
    
    height: 100px;
    padding-block: 10px;
  }
  
  .header .responsive-width {
    display: flex;
    justify-content: center;
    align-items: center;
    
    width: 100% !important;
    max-width: 100% !important;
    padding-inline: 24px;
  }
  
  .header .logo {
    text-align: center;
  }
  
  .header .logo img { 
    height: 100%;
    width: 100%;
    
    transition: var(--transition-default);
  }
  
  .header .logo img:hover {
    filter: grayscale(1) brightness(0.8);
  }
  
  .header h3 {
    color: var(--color-brand-3);
    
    font-size: 22px;
    font-weight: 400;
    
    margin-top: 0px;
    margin-bottom: 6px;
  }
  
  .header a {
    display: block;
    
    color: var(--color-brand-3);
    
    text-decoration: none;
    
    height: 50px;
    width: 100%;
  }
  
  .header .backtosite {
    position: absolute;
    box-sizing: content-box;
    height: 50px;
    width: 190px;
    margin-inline: 0px;
    top: 25px;
    right: 30px;
  }
  
  /* --- Back to Site Navigation --- */
  .header .backtosite a {
    background-color: var(--color-brand-2);
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--color-brand-2);
    border-radius: var(--border-radius-1x);
    font-size: 1.125rem;
    font-weight: 700;
    text-decoration: none;
    text-align: center;
    text-transform: uppercase;
    line-height: 24px;
    padding-block: 5px;
    padding-inline: 15px;
    letter-spacing: 0.125rem;

    transition: var(--transition-default);
  }

  .header .backtosite:hover a {
    background-color: var(--color-brand-2);
    border: 1px solid var(--color-brand-1);
    box-shadow: 0 3px 4px #0000001F, 0 2px 4px #00000024;
  }
  
  button.button.button--secondary.white-space-nowrap {
    border-radius: var(--border-radius-1x);
  }
  
  /* --- rate strikethrough --- */
  .card-information__strike {
    color: var(--color-brand-4);
    font-size: 90%;
  }
  
  /* --- button underlining --- */
  /* - I think these just apply to the backtosite - */
  a.underline-btn {
    position: relative;
  }
  
  a.underline {
    position: relative;
    
    padding-bottom: 8px;
  }
  
  a.underline-btn::before,
  a.underline::before {
    content: "";
    position: absolute;
    
    background-color: var(--color-brand-3);
    
    width: 0;
    height: 1px;
    left: 50%;
    bottom: 0;
    
    transition: var(--transition-default);
  }
  
  a.underline-btn::before {
    width: 60px;
    left: calc(50% - 30px);
    bottom: 6px;
  }
  
  a.underline-btn:hover::before {
    width: calc(100% - 60px);
    left: 30px;
  }
  
  a.underline:hover::before {
    width: 100%;
    left: 0;
  }
  
  /* - other assorted buttons - */
  .checkin-label.button--secondary.active {
    position: relative;
    
    color: var(--color-white);
    background: var(--color-brand-1);
    /* background: transparent; */
    
    font-family: var(--font-faily-1);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 1px;
    line-height: 20px;
    text-transform: uppercase;
    
    padding: 1rem 1.5rem;
    border: 1px solid var(--color-brand-1);
    border-radius: var(--border-radius-1x);
    
    transition: var(--transition-default);
  }
  
  .card-information__book-now,
  .button--branded {
    position: relative;
    
    color: var(--color-white);
    background: var(--color-brand-1);
    
    font-family: var(--font-faily-1);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 1px;
    line-height: 20px;
    text-transform: uppercase;
    
    padding: 1rem 1.5rem;
    border: 1px solid var(--color-brand-1);
    border-radius: var(--border-radius-1x);
    
    transition: var(--transition-default);
  }
  
  .button--branded .button__text {
    font-family: var(--font-faily-1);
    font-size: 1rem;
    letter-spacing: 1px;
    line-height: 20px;
    text-transform: uppercase;
  }

  .checkout-label.button--secondary.disabled {
    color: var(--color-white);
    background: var(--color-brand-1);
    
    font-family: var(--font-faily-1);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 1px;
    line-height: 20px;
    text-transform: uppercase;
    
    padding-block: 12px;
    padding-inline: 36px;
    border: 1px solid var(--color-brand-1);
    border-radius: var(--border-radius-1x);
    transition: var(--transition-default);
  }
  
  /*.button--small, */
  .button--plain.button--underlined.occupancy-modal__add-room,
  .button--secondary:not(.discount-bubble) {
    position: relative;
    
    color: var(--color-white) !important;
    background: var(--color-brand-1);
    
    font-family: var(--font-faily-1);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 1px;
    line-height: 20px;
    text-transform: uppercase;
    
    padding-block: 12px;
    padding-inline: 36px;
    border: 1px solid var(--color-brand-1);
    
    transition: var(--transition-default);
  }
  
  .button--secondary.modal-promo-code__skip {
    padding-block: 1rem;
    padding-inline: 1.5rem;
  }
  
  .button--plain.button--underlined.occupancy-modal__add-room .button__text {
    text-decoration: none;
  }
  
  .button--secondary:not(.discount-bubble) .button__text {
    font-family: var(--font-faily-1);
    font-size: 1rem;
    letter-spacing: 1px;
    line-height: 20px;
    text-transform: uppercase;
  }
  
  .button--plain.button--underlined.occupancy-modal__add-room::before,
  .button--secondary:not(.discount-bubble)::before,
  .card-information__book-now::before,
  .button--branded::before,
  .checkin-label.button--secondary.active::before {
    content: "";
    position: absolute;
    
    background-color: var(--color-white);
    
    width: 60px;
    height: 1px;
    left: calc(50% - 30px);
    bottom: 6px;
    
    transition: var(--transition-default);
  }
  
  .button--plain.button--underlined.occupancy-modal__add-room:hover::before,
  .button--secondary:not(.discount-bubble):hover::before,
  .card-information__book-now:hover::before,
  .button--branded:hover::before,
  .checkin-label.button--secondary.active:hover::before {
    width: calc(100% - 40px);
    left: 20px;
  }
  
  .button--plain.button--underlined.occupancy-modal__add-room:hover,
  .button--secondary:not(.discount-bubble):hover,
  .checkin-label.button--secondary.active:hover {
    color: var(--color-white);
    background-color: var(--color-brand-1) !important;
    
    border: 1px solid var(--color-brand-1);
  }
  
  .card-information__book-now:hover,
  .button--branded:hover,
  .avvio-calendar .hovered, 
  .avvio-calendar__date.available:hover {
    color: var(--color-white);
    background-color: var(--color-brand-1) !important;
    
    border: 1px solid var(--color-brand-1);
  }
  
  .card-grid__area .button--primary.button--small {
    position: relative;
    
    color: var(--color-brand-1);
    
    font-size: 14px;
    letter-spacing: 0.01em;
    line-height: 20px;
    
    padding: 15px;
    border: 0px solid transparent;
    
    transition: var(--transition-default);
  }
  
  .page-control-panel .button.button--plain {
    position: relative;
    
    color: var(--color-brand-1);
    
    font-size: 18px;
    letter-spacing: 0.01em;
    line-height: 20px;
    text-transform: uppercase;
    
    padding: 15px;
    
    transition: var(--transition-default);
  }
  
  .page-control-panel .button.button--plain.button--underlined .button__text {
    text-decoration: none;
  }
  
  .card-grid__area .button--primary.button--small::before,
  .page-control-panel .button.button--plain::before {
    content: "";
    position: absolute;
    
    background-color: var(--color-brand-1);
    
    width: 40px;
    height: 3px;
    left: calc(50% - 10px);
    bottom: 6px;
    
    transition: var(--transition-default);
  }
  
  .card-grid__area .button--primary.button--small::before {
    width: 60px;
    left: calc(50% - 30px);
  }
  
  .card-grid__area .button--primary.button--small:hover::before,
  .page-control-panel .button.button--plain:hover::before {
    width: calc(100% - 20px);
    left: 10px;
  }
  
  .page-control-panel .button.button--underlined {
    text-underline-offset: 12px;
  }

  .button__text.paragraph {
    font-family: var(--font-faily-1);
  }
  
  #ipulse .actionbutton,
  #ipulse .bookbutton,
  #ipulse #login_submit_button {
    color: var(--color-white);
    background: var(--color-brand-1);
    
    font-family: var(--font-faily-1);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 1px;
    line-height: 20px;
    text-transform: uppercase;
    
    padding-block: 1rem;
    padding-inline: 1.5rem;
    border: 1px solid var(--color-brand-1);
    border-radius: var(--border-radius-1x);
    
    transition: var(--transition-default);
  }

  #login_submit_button:hover {
    color: var(--color-brand-1);
    background: transparent;
    
    border: 1px solid var(--color-brand-1);
  }
  
  /* --- Footer container ---  */
  #ipulse .poweredby a,
  #ipulse .privacy-policy-container a {
    color: var(--color-brand-1);
    
    /* font-weight: 600; */
    
    transition: var(--transition-default);
  }
  
  #ipulse .poweredby a:hover,
  #ipulse .privacy-policy-container a:hover {
    color: var(--color-brand-2);
  }
  
  /* --- Calendar stuff --- */
  .avvioCalendarFragment .label.selected:after {
    display: none !important;
  }
  
  .calendar-strip__item-start-date,
  .avvio-calendar :is(.check-in, .check-out) {
    background-color: var(--color-brand-1) !important;
    
    font-family: var(--font-faily-1);
  }
  
  .avvio-calendar-container {
    background-color: var(--color-brand-1) !important;
  }
  
  /* --- Button ribbon ---*/
  .full-ribbon-one {
    background-color: var(--color-brand-4);
    
    border-bottom: 1px solid var(--color-brand-4);
  }
  
  .full-ribbon-one .header-grid .button--plain.button--primary {
    background-color: transparent;
    
    transition: var(--transition-default);
  }
  
  /* --- Discount / warning banner --- */
  /* .banner--warning,
  .discount-list,
  .discount-bubble {
    color: var(--color-brand-1);
    background-color: var(--color-brand-4);
    
    border-color: var(--color-brand-1);
  } */
  
  .discount-list span.button__text {
    color: var(--color-brand-1);
  }
  
  .banner--warning {
    padding-block: 4px;
    padding-inline: 10px;
  }
  
  /* --- Headers --- */
  h1, h2, h3, h4, h5, h6,
  #ipulse .header1, #ipulse .header2, #ipulse .header3, #ipulse .header4, #ipulse .header5, #ipulse .header6 {
    font-family: var(--font-faily-2) !important;
  }
  
  #ipulse h1, #ipulse h2, #ipulse h3, #ipulse h4, #ipulse h5, #ipulse h6,
  #ipulse .header1, #ipulse .header2, #ipulse .header3, #ipulse .header4, #ipulse .header5, #ipulse .header6 {
    color: var(--color-brand-1);
  }
  
  
  
  
  
  /* ---------- FOOTER ---------- */
  .footer {
    display: flex;
    flex-direction: column;
    align-items: center;
    
    background-color: var(--color-brand-1);
    background-image: url("https://mcdesign.avvio.com/017/058/000/7441/cust/imgs/footer-bg.png");
    background-position-x: 50%;
    background-position-y: 110%;
    background-repeat: no-repeat;
    background-size: 24%;
    color: var(--color-brand-3);
    
    width: 100%;
    height: auto;
    padding-top: 60px;
    padding-bottom: 0px;
  }
  
  .footer .responsive-width {
    display: flex;
    flex-direction: column;
    justify-content: center;
    box-sizing: border-box;
    
    width: 100%;
    max-width: unset !important;
    padding-inline: 0px;
  }
  
  .footer .responsive-width .footer-row-1,
  .footer .responsive-width .footer-row-2,
  .footer .responsive-width .footer-row-3 {
    display: flex;
    justify-content: center;
    
    width: 100%;
  }
  
  .footer .responsive-width .contact {
    width: 30%;
  }
  
  .footer .responsive-width .footer-row-2 {
    padding-bottom: 40px;
  }
  
  .footer .responsive-width .footer-row-3 {
    background-color: var(--color-brand-7);
    
    padding-block: 10px;
  }
  
  .footer .footer-row-3 a.underline {
    color: var(--color-white);
  }
  
  /* .footer a:hover {
    color: var(--color-brand-4);
  } */
  
  /* --- Contact --- */
  .footer .contact h3 {
    font-size: 24px;
    font-weight: 500;
    line-height: 32px;
    
    padding-top: 9px;
    margin-top: 0px;
    margin-bottom: 16px;
  }
  
  .footer .details {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    
    margin-bottom: 16px;
  }
  
  .footer .contact > div.details > a,
  .footer .contact > div.details > p {
    position: relative;
    display: block;
    
    color: var(--color-brand-3);
    
    font-size: 14px;
    font-weight: 400;
    line-height: 24px;
    text-decoration: none;
    
    /* padding-left: 32px; */
    border-bottom: 1px solid transparent;
    margin-bottom: 8px;
    margin-top: 0px;
    
    transition: var(--transition-default);
  }
  
  .footer .contact > div.details > a > i,
  .footer .contact > div.details > p > i {
    position: absolute;
    
    left: 0px;
  }
  
  /* --- Socials --- */
  .footer .responsive-width .socials {
    display: flex;
    justify-content: center;
    align-items: center;
    
    margin-bottom: 16px;
  }
  
  .footer .responsive-width .socials .icon {
    display: flex;
    justify-content: space-between;
    align-items: center;
    
    padding-top: 8px;
    padding-inline: 12px;
    margin-bottom: 8px;
    margin-right: 20px;
  }
  
  .footer .responsive-width .socials .icon i {  
    color: var(--color-white);
    
    font-size: 25px;
    
    margin-right: 0px;
    
    transition: var(--transition-default);
  }
  
  .footer .responsive-width .socials .icon:hover i { 
    color: var(--color-brand-2);
  }
  
  /* --- Footer logo --- */
  .footer .responsive-width .footer-logo {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    flex-direction: column;
  }
  
  .footer .responsive-width .footer-logo img {
    display: block;
    
    width: 220px;
    height: auto;
    padding-bottom: 30px;
    margin-inline: auto;
    
    transition: var(--transition-default);
  }
  
  .footer .responsive-width .footer-logo img:hover {
    filter: grayscale(100%);
  }
  
}





/* ---------------------------------------------------------------------------------------------------- */

@media screen and ( max-width: 1099px ) {
  
  .header {
    padding-block: 24px;
  }
  
  .header .responsive-width {
    justify-content: center;
    
    width: 100%;
  }
  
  .header .logo img {
    height: 60px;
    width: auto;
  }
  
  .header .backtosite {
    display: none;
  }
  
  .footer {
    padding-top: 60px;
    margin-top: 50px;
  }
  
  .footer .responsive-width .socials {
    justify-content: center;
  }
  
  .footer .responsive-width .socials .icons {
    align-items: center;
    
    width: 60%;
    margin-inline: auto;
  }
  
  .footer .footer-logo {
    width: 100%;
  }
  
}



@media screen and ( max-width: 700px ) {
  
  .header {
    padding-block: 12px;
  }
  
  .footer {
    background-size: 60%;
    background-position-y: 64%;
  }
  
  .footer .responsive-width .footer-row-2 {
    flex-direction: column;
    
    padding-top: 40px;
  }
  
  .footer .responsive-width .contact {
    width: 100%;
  }
  
  .footer .responsive-width {
    flex-direction: column;
    align-items: center;
    
    padding-inline: 0px;
    padding-bottom: 0px;
  }
  
  .footer .responsive-width .footer-logo img {
    width: 50%;
    max-width: 220px;
  }
  
}