
/* ================================
    Reset all browser css property
   ================================ */

html {
    font-size: 16px;
    line-height: 1.15; 
    -webkit-text-size-adjust: 100%; 
}

body {
    margin: 0;
}

main {
    display: block;
}

h1 {
    font-size: 2rem;
    margin: 0.67rem 0;
}

hr {
    box-sizing: content-box; 
    height: 0; 
    overflow: visible; 
}

pre {
    font-family: monospace, monospace; 
    font-size: 1rem; 
}

a {
    background-color: transparent;
}

abbr[title] {
    border-bottom: none; 
    text-decoration: underline;
    text-decoration: underline dotted;
}

b,
strong {
    font-weight: bolder;
}

code,
kbd,
samp {
    font-family: monospace, monospace; 
    font-size: 1rem; 
}

small {
    font-size: 80%;
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}

sub {
    bottom: -0.25rem;
}

sup {
    top: -0.5rem;
}

img {
    border-style: none;
}

button,
input,
optgroup,
select,
textarea {
    font-family: inherit; 
    font-size: 100%;
    line-height: 1.15; 
    margin: 0;
}

button,
input { 
    overflow: visible;
}

button,
select { 
    text-transform: none;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
    -webkit-appearance: button;
}

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
    border-style: none;
    padding: 0;
}

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
    outline: 0.0625rem dotted ButtonText;
}

fieldset {
    padding: 0.35rem 0.75rem 0.625rem;
}

legend {
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal;
}

progress {
    vertical-align: baseline;
}

textarea {
    overflow: auto;
}

[type="checkbox"],
[type="radio"] {
    box-sizing: border-box;
    padding: 0; 
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
    height: auto;
}

[type="search"] {
    -webkit-appearance: textfield;
    outline-offset: -0.125rem;
}

[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
}

::-webkit-file-upload-button {
    -webkit-appearance: button; 
    font: inherit;
}

details {
    display: block;
}

summary {
    display: list-item;
}

template {
    display: none;
}

[hidden] {
    display: none;
}


/* ======================
    Set base HTML styles
   ====================== */

*,
*:before,
*:after {
	-webkit-tap-highlight-color: rgba(0,0,0,0);
	-webkit-tap-highlight-color: transparent;
}

*, *:after, *:before {
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

a,
span,
h1,
h2,
h3,
h4,
h5,
h6,
p {
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

input,
textarea,
pre,
code,
.tel {
  -webkit-touch-callout: text !important;
    -webkit-user-select: text !important;
     -khtml-user-select: text !important;
       -moz-user-select: text !important;
        -ms-user-select: text !important;
            user-select: text !important;
}

a:focus,
a:active,
img:focus,
img:active,
input:focus,
input:active,
button:focus,
button:active,
textarea:focus,
textarea:active {
    outline: none;
}

html {
    color: #222;
    cursor: default;
	line-height: 1.4;
	word-break: break-word;
	-webkit-font-smoothing: antialiased;
	 -moz-osx-font-smoothing: grayscale;
	     -webkit-text-size-adjust: 100%;
	         -ms-text-size-adjust: 100%; 
	                   -moz-tab-size: 4;
	                        tab-size: 4; 
	 
	font-family:
		-apple-system, 
		BlinkMacSystemFont, 
		"Segoe UI", 
		Roboto, 
		Helvetica, 
		Arial, 
		sans-serif, 
		"Apple Color Emoji", 
		"Segoe UI Emoji", 
		"Segoe UI Symbol";
}

::-moz-selection {
    background: #b3d4fc;
    text-shadow: none;
}

::selection {
    background: #b3d4fc;
    text-shadow: none;
}

hr {
    display: block;
    height: 0.0625rem;
    border: 0;
    border-top: 0.0625rem solid #ccc;
    margin: 1rem 0;
    padding: 0;
}

audio,
canvas,
iframe,
img,
svg,
video {
    vertical-align: middle;
}

fieldset {
    border: 0;
    margin: 0;
    padding: 0;
}

textarea {
    resize: none;
}

input,
label,
textarea {
    font-size: 0.8125rem;
	line-height: 1.5;
}

/* ==============================
    Set helper classes if needed
   ============================== */

.im-hidden {
    display: none !important;
}

.im-invisible {
    visibility: hidden;
}

/* ==============================================================
    Hide only visually, but have it available for screen readers
   ============================================================== */

.im-sr-only {
    border: 0;
    clip: rect(0, 0, 0, 0);
    height: 0.0625rem;
    margin: -0.0625rem;
    overflow: hidden;
    padding: 0;
    position: absolute;
    white-space: nowrap;
    width: 0.0625rem;
}

/* ======================================================================
    Extends the .sr-only class to allow the element to be focusable when 
    navigated to via the keyboard
   ====================================================================== */

.im-sr-only.im-focusable:active,
.im-sr-only.im-focusable:focus {
    clip: auto;
    height: auto;
    margin: 0;
    overflow: visible;
    position: static;
    white-space: inherit;
    width: auto;
}

/* ==========================================
    Set clearfix: contain floats (if needed)
   ========================================== */

.im-clearfix:before,
.im-clearfix:after {
    content: " ";
    display: table;
}

.im-clearfix:after {
    clear: both;
}

/* ============================
    Set author's custom styles
   ============================ */

body {
    margin: 0;
}

a {
	color: #06f;
}

a:focus {
	color: #1DA408;
}

h1 {
	font-size: 2.4rem;
}

h2 {
	font-size: 1.7rem;
}

h2, 
h3, 
h4 {
    margin-top: 0;
}

h3, 
h4 {
	margin-bottom: 0.5rem;
}

p, 
ul {
    font-size: 0.9125rem;
	line-height: 1.5;
	margin: 0 0 1.5rem;
}

ol, 
ul {
    list-style: none;
}

code {
    color: #777;
}

iframe {
	border: 0;
	overflow: hidden;
}

html, 
body {
    height:100%;
	overflow: hidden;
}

/**	----------------------------------------
    MAIN, FOOTER AND CONTAINER
------------------------------------------- */

.im-menu {
    width: 100vw;
	height:  100%;
	z-index: 9996;
	overflow-y:scroll;
    position: absolute;
	-webkit-overflow-scrolling: touch;
    overflow-scrolling: touch;
}

.im-content {

	height:  100%;

	overflow-y:scroll;

	-webkit-overflow-scrolling: touch;
    overflow-scrolling: touch;
}

.im-container {
	margin: 2.5rem auto 0 auto;
	max-width: 80rem;
	padding: 1rem 0;
}

.im-wide {
    width: 100%;
	margin-bottom: 1.5rem; 
}

.im-footer {
	padding-top: 1.5rem;
}

.im-desc {
	color: #888;
}

.im-intro {
	padding-bottom: 1.5rem;
}

.im-dotted .im-intro {
	border-bottom: 0.0625rem dotted #bbb;
}

.im-social {
	padding-top: 1.5rem;
    margin-top: 1.5rem;
}

.im-dotted .im-social {
	border-top: 0.0625rem dotted #bbb;

}

.im-aside {
	margin-bottom: 1.5rem;
}

.im-dotted .im-aside {
	border-bottom: 0.0625rem dotted #aaa;
}

/**	----------------------------------------
    DATA BG
-------------------------------------------*/

[background] {
	background-size: cover!important;
	background-position: center!important;
	background-repeat: no-repeat!important;
	opacity:0;
	transition: opacity 1s ease-in-out;	
}

/**	----------------------------------------
    BOX 
-------------------------------------------*/

.im-box, 
.im-box--image, 
.im-box--carousel,
.im-box .im-col,
.im-row.im-col {
    position: relative;
	padding: 0  1.5rem;   
}

.im-box--image,
.im-box--carousel {
	background-color:#D3D3D3!important;
	width:100%;
	height:25rem
}

.im-box--shadow {
	box-shadow: 0 0.25rem 0.625rem 0 rgba(0, 0, 0, 0.2), 0 0.25rem 1.25rem 0 rgba(0, 0, 0, 0.19);
}

.im-row .im-row { 
    margin:  0 -1.5rem; 
}

.im-row:after {
    content: "";
    clear: both;
    display: table;
}

@media only screen { 
    .im-col {
        float: left;
        width: 100%;
        box-sizing: border-box;
    }
}

/**	----------------------------------------
    HEADER
-------------------------------------------*/

.im-header {
    position: absolute;
    pointer-events: none!important;
	height:  3.375rem;
	z-index: 9997;
	width: 100%;
    -webkit-transition: -webkit-transform 0.25s ease-in-out;
        -ms-transition:     -ms-transform 0.25s ease-in-out;
            transition:         transform 0.25s ease-in-out;
}

.im-header--inner {
	pointer-events: all!important;
	width: 100%;
	height: 3.375rem;
	border-radius: 0;
	background-color: rgb(51,51,51);
	position: relative
}

.im-header--inner:after {
    content: '';
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    height: 0.625rem;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.25), transparent);
}

.im-menu--first {
	transition: background 0.2s ease-in;
	position: absolute;
	width: 3.375rem;
	height: 3.375rem;
	cursor: pointer;
	top: 0;
	left: 0;
}

.im-menu--second {
	transition: background 0.2s ease-in;
	position: absolute;
	width: 3.375rem;
	height: 3.375rem;
	cursor: pointer;
	top: 0;
	left: 3.375rem;
}

.im-menu--third {
	transition: background 0.2s ease-in;
	position: absolute;
	width: 3.375rem;
	height: 3.375rem;
	cursor: pointer;
	top: 0;
	left: 8.750rem;
}

.im-menu--open {
    z-index: 9998;
    background: rgb(51,51,51);
	transition: background 0.2s ease-in;
	position: absolute;
	width: 3.375rem;
	height: 3.375rem;
	cursor: pointer;
	top: 0;
	right: 0;
}

.im-menu--close {
    z-index: 9997;
    background: rgb(51,51,51);
	transition: background 0.2s ease-in;
	position: absolute;
	width: 3.375rem;
	height: 3.375rem;
	cursor: pointer;
	top: 0;
	right: 0;
}

.im-menu--active .im-menu--open {
    -webkit-transform: scale(0);
    -ms-transform: scale(0); 
    transform: scale(0);
    visibility: hidden;
    transition: all 0.3s ease-in;
}

.im-menu--open {
    -webkit-transform: scale(1);
    -ms-transform: scale(1); 
    transform: scale(1);
    visibility: visible;
    transition: all 0.3s ease-in;
}

.im-menu--active .im-menu--close {
    -webkit-transform: scale(1);
    -ms-transform: scale(1); 
    transform: scale(1);
    visibility: visible;
    transition: all 0.3s ease-in;
}

.im-menu--close {
    -webkit-transform: scale(0);
    -ms-transform: scale(0); 
    transform: scale(0);
    visibility: hidden;
    transition: all 0.3s ease-in;
}

.im-menu--first:focus, 
.im-menu--second:focus, 
.im-menu--third:focus,
.im-menu--open:focus,
.im-menu--close:focus{
	outline: 0;
}

.im-menu--first.im--has-focus-key:focus, 
.im-menu--second.im--has-focus-key:focus, 
.im-menu--third.im--has-focus-key:focus,
.im-menu--open.im--has-focus-key:focus,
.im-menu--close.im--has-focus-key:focus{
	background: #5A5A5A;
}

.im-menu--first i.material-icons, 
.im-menu--second i.material-icons,
.im-menu--third i.material-icons,
.im-menu--open i.material-icons,
.im-menu--close i.material-icons {
	color: #c7c7c7;
}

/**	----------------------------------------
    SHOW/HIDE MENU
-------------------------------------------*/
html,
body {
    width: 100%;
    height: 100%;
    overflow: hidden;
}
.im-flex-container.im-tabs--content {
	overflow-y: scroll;
	display: none;
	opacity: 0;

    -webkit-animation: fade-In 0.5s ease 1 forwards; /* Chr, Saf */
            animation: fade-In 0.5s ease 1 forwards; /* IE >9, Fx >15, Op >12.0 */

}

.im-flex-container.im-tabs--content.im-tabs--active {
	display: -webkit-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -moz-flex;
    display: -moz-box;
    display: flexbox;
    display: flex;
    display: box;	
}


@-webkit-keyframes fade-In {

  0% {
	  opacity: 0;
    -webkit-transform: translate3d(0,15px,0); /* Ch <36, Saf 5.1+, iOS < 9.2, An =<4.4.4 */
        -ms-transform: translate3d(0,15px,0); /* IE 9 */
            transform: translate3d(0,15px,0); /* IE 10, Fx 16+, Op 12.1+ */
  }
  to {
	  opacity: 1;

    -webkit-transform: translate3d(0,0,0); /* Ch <36, Saf 5.1+, iOS < 9.2, An =<4.4.4 */
        -ms-transform: translate3d(0,0,0); /* IE 9 */
            transform: translate3d(0,0,0); /* IE 10, Fx 16+, Op 12.1+ */

  }
}

@keyframes fade-In {
  0% {
	  opacity: 0;
    -webkit-transform: translate3d(0,15px,0); /* Ch <36, Saf 5.1+, iOS < 9.2, An =<4.4.4 */
        -ms-transform: translate3d(0,15px,0); /* IE 9 */
            transform: translate3d(0,15px,0); /* IE 10, Fx 16+, Op 12.1+ */
  }
  to {
	  opacity: 1;
    -webkit-transform: translate3d(0,0,0); /* Ch <36, Saf 5.1+, iOS < 9.2, An =<4.4.4 */
        -ms-transform: translate3d(0,0,0); /* IE 9 */
            transform: translate3d(0,0,0); /* IE 10, Fx 16+, Op 12.1+ */

  }
}

/**	----------------------------------------
    ZOOMA
-------------------------------------------*/

.im-zooma--image {
	position: relative;
	background-size: cover!important;
	background-position: center!important;
	background-repeat: no-repeat!important;
	opacity:0;
	transition: opacity 1s ease-in-out;
}

.im-zooma--image::after {
	content:'';
	position: absolute;
	width: 100%;
	height: 100%;
    background-color: rgba(255,255,255,0.9);
    opacity: 0;
    visibility: hidden;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
	transition: opacity 0.6s cubic-bezier(0.55, 0, 0.1, 1), visibility 0.6s cubic-bezier(0.55, 0, 0.1, 1);
	z-index: 9996;
	top: 0;
	left: 0
}
 
.im-zooma--image.im-zooma--loading::after {
    opacity: 1;
    visibility: visible;

}

.im-zooma--loader {
	position: absolute;
	z-index: 9997;
	overflow: show;
	margin: auto;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	width: 1.5625rem;
	height: 1.5625rem; 
	opacity:0;
	-webkit-transition: opacity 0.65s ease-in-out;
	   -moz-transition: opacity 0.65s ease-in-out;
	    -ms-transition: opacity 0.65s ease-in-out;
	     -o-transition: opacity 0.65s ease-in-out;
	        transition: opacity 0.65s ease-in-out;
}

.im-zooma--image.im-zooma--loading .im-zooma--loader {
	opacity: 1;
}

.im-zooma--loader:before {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(255,255,255,0);
}

.im-zooma--loader:not(:required) {
	font: 0/0 a;
	color: transparent;
	text-shadow: none;
	background-color: transparent;
	border: 0;
}

.im-zooma--loader:not(:required):after {
	content: '';
	display: block;
	font-size: 0.625rem;
	width: 1.5625rem;
	height: 1.5625rem;
	margin-top: -0.5rem;
	border: 0.125rem solid rgba(85,85,85,1.00);
	border-radius: 100%;
	border-bottom-color: transparent;
	-webkit-animation: spinner 1s linear 0s infinite;
	        animation: spinner 1s linear 0s infinite;
}

.im-zooma--figure {
	cursor:inherit;
	width:100%;
	height:100%;
	position:fixed;
	margin: 0;
	top: 0;
	left: 0;
	overflow: hidden;
	z-index: 9999;
	opacity: 0;
	-webkit-backface-visibility: hidden;
            backface-visibility: hidden;
	-webkit-transition: opacity 150ms cubic-bezier(0, 0, .26, 1);
	   -moz-transition: opacity 150ms cubic-bezier(0, 0, .26, 1);
	        transition: opacity 150ms cubic-bezier(0, 0, .26, 1);
}

.im-zooma--figure img {
	max-width: none;
}
.im-zooma--figure.figcaption::after {
	position: absolute;
	content: '';
	bottom: 0;
	left: 0;
	width:100%;
	height:100%;
	z-index: 9994;
    background:
url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAB4CAYAAAAzOJiAAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAMNJREFUeNp80W1Hg2EYBuD72XrZepH1YqlMpaRJsowiM0mSSCKKREkk/ZmUqFFSv3OO58PNzdr54eB0uT6dIYSQhSRZXwo9KPZlIDIYGYoMp5RQxghGU8YwjomUCiYxhWnMoBqZxRzmsYAaFrGEZaxgFWtYRx0b2MQWGthGEzvYxR5aaGMfBzjEEY5xglOc4RwXuMQVrnGDW9zhHg94xBOezVCIFHvUnCy9Zv+95Uu/4BVveMcHPtHBF77xg1/85XQFGABtPRTYaxM3DAAAAABJRU5ErkJggg==) bottom repeat-x;
}

.im-zooma--figcaption {
	padding: 1rem;
	color: #fff;
	z-index: 9995;
	position: fixed;
	margin: 0;
	bottom: 0;
	left: 0;
	text-shadow:-0.0625rem 0 0.0625rem rgba(0,0,0,0.4);
	word-spacing: 0.0125rem;
	-webkit-font-smoothing:antialiased;
}

.im-zooma--caption-title {
	margin: 0;
	padding: 0;
	font-weight: normal;
	font-size: .95rem;
	letter-spacing: 0.00625rem;
	text-align:left;
	background: none;
}

/**	-------------------------------------------
    BUTTONS
----------------------------------------------*/

.im-circle-bottom--button {
    width: 3.375em;
	height: 3.375em;
	background-color: rgb(51,51,51);
	position: absolute;
	bottom: 3em;
	right: 3em;
	border-radius: 100%;
	box-shadow: 0 0.1875rem 0.375rem rgba(0,0,0,0.16), 0 0.1875rem 0.375rem rgba(0,0,0,0.23);
	pointer-events: all!important;
}

.im-circle-bottom--button i {
    color: #fff
}

[class^="im-btn-"] { 
    width: 100%;
    border: none;
    color: white;
    text-decoration: none;
    font-size: 1rem;
    margin:.5em 0;
    cursor: pointer;
	padding: 1rem;
    /* Prevent highlight colour when element is tapped */
    -webkit-tap-highlight-color: rgba(0,0,0,0);
    /* Smooth fonts */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

[class^="im-btn-"].im--has-focus-key:focus {
	box-shadow:inset 0 0 0 0.1875rem #26a69a;
	transition: box-shadow .3s linear;
}

.im-button-group {
    margin: 0 0 1.5rem;
}

.im-button-group.double [class^="im-btn-"]:nth-child(1) { 
	margin-right: 2%;
	width: 100%;
	max-width: 50%;
}

.im-button-group.single-start [class^="im-btn-"]:first-child,
.im-button-group.single-end [class^="im-btn-"]:first-child{ 
	margin-right: 2%;
	width: auto;
	max-width: 50%;
	padding: 1rem 2rem
}

.single-start {
    -webkit-justify-content: flex-start;
    -ms-flex-pack: start;
    justify-content: flex-start;
}

.single-end {
    -webkit-justify-content: flex-end;
    -ms-flex-pack: end;
    justify-content: flex-end;
}

.im-button-group.double [class^="im-btn-"]:last-child {
    width: 100%;
	max-width: 50%;
}

.im-btn-primary {
    background-color: #1a73e8;
    color: #fff; 
	border-radius: 0.25rem;
    border:none;
	transition: background-color .5s linear;
}

.im-btn-primary:hover {
	background-color: #1760BF;
}

.im-btn-dark {
    background-color: #555555;
    color: #fff; 
	border-radius: 0.25rem;
    border:none;
	transition: background-color .5s linear;
}

.im-btn-dark:hover {
	background-color: #373737;
}

.im-btn-gray {
    background-color:#CDCDCD;
    color: #333; 
	border-radius: 0.25rem;
    border: none;
	transition: background-color .5s linear;
}

.im-btn-gray:hover {
	background-color:#8B8B8B;
}

/**	-------------------------------------------
    INPUT
----------------------------------------------*/

.im-textfield--outlined {
  position: relative;
}
.im-textfield--outlined-input {
  font-size: 1rem;
  padding: 0.8125rem 0.9375rem;
  margin-bottom: 1.25rem;
  width: calc(100% - 1.875rem);
  display: block;
  border-radius: 0.25rem;
  border: 0.0625rem solid #ddd;
}
.im-textfield--outlined-input:focus {
  outline: none;
  border: 0.0625rem solid #06f;
}
.im-textfield--outlined-input:focus ~ .im-textfield--outlined-label {
  color: #06f;
  transform: scale(0.75) translate(-0.8125rem, -2.1875rem);
}
.im-textfield--outlined-label {
  color: #ccc;
  background: #fff;
  font-size: 1rem;
  font-weight: normal;
  position: absolute;
  pointer-events: none;
  top: 0.8125rem;
  left: 0.5rem;
  padding: 0 0.5rem;
  transition: 150ms cubic-bezier(0.4, 0, 0.2, 1) all;
  -moz-transition: 150ms cubic-bezier(0.4, 0, 0.2, 1) all;
  -webkit-transition: 150ms cubic-bezier(0.4, 0, 0.2, 1) all;
}

/* Faster transition in Safari for less noticable fractional font-size issue */
@media not all and (min-resolution:.001dpcm) {
    @supports (-webkit-appearance:none) {
        .im-textfield--outlined > input,
        .im-textfield--outlined > input + label,
        .im-textfield--outlined > textarea,
        .im-textfield--outlined > textarea + label {
            transition-duration: 0.1s;
        }
    }
}

/**	-------------------------------------------
    HACK FOR INPUT
----------------------------------------------*/

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

input[type=number] {
    -moz-appearance:textfield; 
}

input::-ms-clear {
    width: 0;
    height: 0;
}

input::-ms-clear {
    display: none;
}

input::-webkit-clear-button {
    display: none;
}

::-webkit-search-cancel-button { 
    -webkit-appearance: none; 
}

::-webkit-search-results-button {
     -webkit-appearance: none; 
}

input[type=search] { 
    -webkit-appearance: none; 
}

/**	-------------------------------------------
    ESSENTIAL FLEX STYLING
----------------------------------------------*/

/* display flex */
.im-flex-container {
    display: -webkit-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -moz-flex;
    display: -moz-box;
    display: flexbox;
    display: flex;
    display: box;
}

/* display inline-flex */
.im-flex-container.inline-flex {
    display: -webkit-inline-flex;
    display: -ms-inline-flexbox;
    display: inline-flex;
}

/* flex-direction row */
.im-flex-container.row {
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
}

/* flex-direction row-reverse */
.im-flex-container.row-reverse {
    -webkit-flex-direction: row-reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

/* flex-direction column */
.im-flex-container.column {
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
}

/* flex-direction column-reverse */
.im-flex-container.column-reverse {
    -webkit-flex-direction: column-reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
}

/* flex-wrap nowrap */
.im-flex-container.nowrap {
    -webkit-flex-wrap: nowrap;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
}

/* flex-wrap wrap */
.im-flex-container.wrap {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

/* flex-wrap wrap-reverse */
.im-flex-container.wrap-reverse {
    -webkit-flex-wrap: wrap-reverse;
    -ms-flex-wrap: wrap-reverse;
    flex-wrap: wrap-reverse;
}

/* align-items flex-start */
.im-flex-container.align-items-start {
    -webkit-align-items: flex-start;
    -ms-flex-align: start;
    align-items: flex-start;
}

/* align-items flex-end */
.im-flex-container.align-items-end {
    -webkit-align-items: flex-end;
    -ms-flex-align: end;
    align-items: flex-end;
}

/* align-items center */
.im-flex-container.align-items-center {
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

/* align-items baseline */
.im-flex-container.align-items-baseline {
    -webkit-align-items: baseline;
    -ms-flex-align: baseline;
    align-items: baseline;
}

/* align-items stretch */
.im-flex-container.align-items-stretch {
    -webkit-align-items: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
}

/* justify-content flex-start */
.im-flex-container.justify-start {
    -webkit-justify-content: flex-start;
    -ms-flex-pack: start;
    justify-content: flex-start;
}

/* justify-content flex-end */
.im-flex-container.justify-end {
    -webkit-justify-content: flex-end;
    -ms-flex-pack: end;
    justify-content: flex-end;
}

/* justify-content center */
.im-flex-container.justify-center {
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
}

/* justify-content space-between */
.im-flex-container.justify-space-between {
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

/* justify-content space-around */
.im-flex-container.justify-space-around {
    -webkit-justify-content: space-around;
    -ms-flex-pack: justify;
    justify-content: space-around;
}

/* align-content: flex-start */
.im-flex-container.align-content-start {
    -webkit-align-content: flex-start;
    -ms-flex-line-pack: start;
    align-content: flex-start;
}

/* align-content: flex-end */
.im-flex-container.align-content-end {
    -webkit-align-content: flex-end;
    -ms-flex-line-pack: end;
    align-content: flex-end;
}

/* align-content: center */
.im-flex-container.align-content-center {
    -webkit-align-content: center;
    -ms-flex-line-pack: center;
    align-content: center;
}

/* align-content: space-between */
.im-flex-container.align-content-space-between {
    -webkit-align-content: space-between;
    -ms-flex-line-pack: justify;
    align-content: space-between;
}

/* align-content: space-around */
.im-flex-container.align-content-space-around {
    -webkit-align-content: space-around;
    -ms-flex-line-pack: justify;
    align-content: space-around;
}

/* align-content: stretch */
.im-flex-container.align-content-stretch {
    -webkit-align-content: stretch;
    -ms-flex-line-pack: stretch;
    align-content: stretch;
}

.large-footer-message {display: none}
.footer-message {display: block;margin-bottom: 3rem;}
.footer-message h4:nth-child(2) {margin-top: 0}
.footer-message h4 {text-align: center}

/* ==========================================================================
   EXAMPLE Media Queries for Responsive Design.
   These examples override the primary ('mobile first') styles.
   Modify as content requires.
   ========================================================================== */

/* from 520px*/
@media only screen and (min-width: 32.5rem) {

    .im-dotted .im-aside .im-xl-3:first-child,
    .im-dotted .im-aside .im-xl-3:nth-child(2),
	.im-dotted .im-aside .im-xl-2:first-child,
	.im-dotted .im-aside .im-sl-2:first-child {
		border-right: 0.0625rem dotted #aaa;
	}
	.im-container {
		padding: 1rem;
	}
	h1 {
		font-size: 2.9rem;
	}
	h2 {
		font-size: 1.8rem;
	}
}

/* from 840px*/
@media only screen and (min-width: 52.5rem) {
	.im-dotted .im-aside {
		border: none;
		border-right: 0.0625rem dotted #aaa;
		margin-bottom: 0;
	}
	.im-dotted .im-aside .im-sl-2:first-child {
		border: none;
	}
	h1 {
		font-size: 3rem;
	}
	h2 {
		font-size: 1.7rem;
	}
}

/* from 1000px*/
@media only screen and (min-width: 62.5rem) {
	.im-dotted .im-side .im-sl-2:first-child {
		border-right: 0.0625rem dotted #aaa;
	}
	h1 {
		font-size: 3.2rem;
	}
	h2 {
		font-size: 1.8rem;
	}
}

/* from 1px to 999.9px*/
@media (min-width: 0.00625rem) and (max-width: 62.49375rem) {}


/* from 0 to 768px*/
@media only screen and (max-width: 48rem) {
    .im-xl-2, 
    .im-sl-2 { width: 100%; } /* 1/12 */
    .im-xl-3 { width: 100%; } /* 1/12 */
}

/* from 769px*/
@media only screen and (min-width: 48.063rem) {
    .im-xl-2, 
    .im-sl-2 { width: 50%;        } /* 6/12 */
    .im-xl-3 { width: 33.333333%; } /* 4/12 */
}


/* from 840px  52.5rem */
/* from 1000px 62.5rem */
@media only screen and (min-width: 62.5rem) {
    .im-aside   { width: 66.666666%; } /* 8/12 */
    .im-side    { width: 33.333333%; } /* 4/12 */
    .im-sl-2    { width: 100%;       } /* 1/12 */
	.large-footer-message {display: block;padding-top: 3rem;}
	.footer-message {display: none}
}

/* from 1000px */
@media only screen and (min-width: 62.5rem) {
    .im-aside   { width: 58.333333%; } /* 7/12 */
    .im-side    { width: 41.666666%; } /* 5/12 */
    .im-sl-2    { width: 50%;        } /* 6/12 */
}

/* from 1px to 999.9px*/
@media (min-width: 0.00625rem) and (max-width: 62.49375rem) {}

/* from 1000px*/
@media (min-width: 62.5rem) {}

/* from 1px to 999.9px*/
@media (min-width: 0.00625rem) and (max-width: 62.49375rem) {
	.im-box--image,
	.im-box--carousel {
		padding: 0;
        height:18.75rem
	} 
	.im-box--shadow {
		box-shadow: none;
	}
}
/* from 0 to 520px*/
@media (max-width: 32.5em) {
    [class^="im-btn-"] {
        margin-right: 0!important;
		width: 100%!important;
        max-width: 100%!important;
	}
    .im-button-group {
        -webkit-flex-wrap: wrap!important;
        -ms-flex-wrap: wrap!important;
        flex-wrap: wrap!important;
    }
}
/* ==========================================================================
   Print styles.
   Inlined to avoid the additional HTTP request:
   https://www.phpied.com/delay-loading-your-print-css/
   ========================================================================== */

@media print,
    (-webkit-min-device-pixel-ratio: 1.25),
    (min-resolution: 1.25dppx),
    (min-resolution: 120dpi) {
        /* Style adjustments for high resolution devices */
}

@media print {
    *,
    *:before,
    *:after {
        background: transparent !important;
        color: #000 !important;
        -webkit-box-shadow: none !important;
        box-shadow: none !important;
        text-shadow: none !important;
    }
    
    a,
    a:visited {
        text-decoration: underline;
    }
    
    a[href]:after {
        content: " (" attr(href) ")";
    }
    
    abbr[title]:after {
        content: " (" attr(title) ")";
    }
    
    a[href^="#"]:after,
    a[href^="javascript:"]:after {
        content: "";
    }
    
    pre {
        white-space: pre-wrap !important;
    }
    
    pre,
    blockquote {
        border: 0.0625rem solid #999;
        page-break-inside: avoid;
    }
    
    thead {
        display: table-header-group;
    }
    
    tr,
    img {
        page-break-inside: avoid;
    }
    
    p,
    h2,
    h3 {
        orphans: 3;
        widows: 3;
    }
    
    h2,
    h3 {
        page-break-after: avoid;
    }
}

.img-responsive {display:block;max-width:100%;height:auto; margin:0 auto}
.img-responsive.taverna {margin-top: 1rem;
    margin-bottom: 1rem;
    border-radius: 6px;
}

.the-bold-font {font-family: 'The Bold Font';}
html {background-color: rgba(198,184,157,1.00);}
body {
	
	background-image: linear-gradient(to bottom, rgba(198, 184, 157, 0.52), rgba(198, 184, 157, 0.73)), url("../img/202.jpg");
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}
@-webkit-keyframes spinner {
  to {
	  -webkit-transform: rotate(360deg);
	  transform: rotate(360deg);
	}
}

@keyframes spinner {
  to {
	  -webkit-transform: rotate(360deg);
	  transform: rotate(360deg);
	}
}
 
html.spinner-regular:before {
	overflow: hidden;
  content: '';
  box-sizing: border-box;
  position: absolute;
	opacity:1;
	-webkit-transition: opacity 0.65s ease-in-out;
	transition: opacity 0.65s ease-in-out;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 20px;
  margin-top: -10px;
  margin-left: -10px;
  border-radius: 50%;
  border: 2px solid #ccc;
  border-top-color: #000;
  -webkit-animation: spinner .6s linear infinite;
  animation: spinner .6s linear infinite;
}
img.lazy {
	opacity:0;
	-webkit-transition: opacity 0.65s ease-in-out;
	transition: opacity 0.65s ease-in-out;
}
.italic {
    font-style: italic;
}
.menu-items > p,
.menu-items > i {
	margin-bottom: .5rem
}
.menu-items > i {
	font-size: .7rem;
}
.menu-items > span {
	font-weight: 400;
}

.seo {
	position: absolute;
	top: -99999px;
	left: -9999px;
	z-index: 99999;
	text-indent: -99999px;
}

.quandoo-popup-container {
	overflow: hidden!important
}

.btn.btn-large.natale {
	color: white;
	text-decoration: none;
	display: block;
	margin-bottom: 1rem;
	background-color: #333333;
}

.btn.btn-large.natale:hover {
	background-color: #292929;
}
