/*
Theme Name: Tour Monte Rosa
Theme URI: https://tmr-matterhorn.ch
Description: Custom Theme for Tour Monte Rosa
Author: Roger Burkhard
Author URI: http://www.rogerburkhard.com
*/

/*------------------------------------------------------
VARIABLES
------------------------------------------------------*/

:root {
  --offset: 22px;
  --offset-minus:  -22px;
  --max_width: 100%;
  --columns: 12;
  --gap: 12px;
  --baseline: 0;
  --baseline-offset: 0;
  --font_color: #000;
  --easing:cubic-bezier(0.16, 1, 0.3, 1);
  --color_green:#BDF5DD;
  --color_violet:#D9D5FB;
  --color_violet_light:#F4F2FF;
  --color_blue:#90BDFF;
  --color_red:#FD6D6D;
  --color_grey:#F5F5F5;
  --color_grey_light:#EEEFED;
  --color_beige:#E9DABC;
  --color_dark_blue:#1D3C83;
  --color_light_blue:#D3E0EB;

  --grid_color: hsla(204, 80%, 72%, 0.25);
  --repeating_width: calc(100% / var(--columns));
  --column_width: calc((100% /  (var(--columns)) -  var(--gap)));
  --background_width: calc(100% +  var(--gap));
  --background_columns: repeating-linear-gradient(to right, var(--grid_color), var(--grid_color) var(--column_width), transparent var(--column_width), transparent var(--repeating_width));
  --background_baseline: repeating-linear-gradient(to bottom, var(--grid_color), var(--grid_color) 1px, transparent 1px, transparent var(--baseline));
}

/*------------------------------------------------------
THE BIG FAT RESET
------------------------------------------------------*/

* {
	min-height: 0;
	min-width: 0;
}


html, body, div, span, h1, h2, h3, h4, h5, h6, ul, ol, dl, li, dt, dd, p, blockquote, pre, form, fieldset, table, th, td, header, footer {
	margin: 0;
	padding: 0;
}

sub, sup {
	line-height: 0;
}

/*------------------------------------------------------
IMPORT FONTS
------------------------------------------------------*/

@font-face {
    font-family: 'Buenos Aires Book';
    src:  url('styles/fonts/BuenosAiresWeb-Book.woff2') format('woff2'),
         url('styles/fonts/BuenosAiresWeb-Book.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Euclid Circular Regular';
    src:  url('styles/fonts/EuclidCircularA-Regular-WebS.woff2') format('woff2'),
         url('styles/fonts/EuclidCircularA-Regular-WebS.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Euclid Circular Semibold';
    src:  url('styles/fonts/EuclidCircularA-Semibold-WebS.woff2') format('woff2'),
         url('styles/fonts/EuclidCircularA-Semibold-WebS.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

/*------------------------------------------------------
GRID HELPER
------------------------------------------------------*/

/* Grid */

/*
html::before {
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin-right: auto;
	margin-left: auto;
	width: calc(100% - (2 * var(--offset)));
	max-width: var(--max_width);
	min-height: calc(100vh - 86px);
	content: '';
	background-image: var(--background_columns), var(--background_baseline);
	background-size: var(--background_width) 100%;
	background-position: 0 var(--baseline-offset);
	z-index: 1000;
	pointer-events: none;
}

/* Squares */

/*
$square: transparent 0 calc(20px - 1px),#ccc 0 20px;

body {
	width: 100%;
	height: 100%;
	margin: 0 auto;
	background: repeating-linear-gradient(to right, $square), repeating-linear-gradient(to bottom,$square) #fff;
}
*/

/*------------------------------------------------------
GENERAL
------------------------------------------------------*/

html {
	width: 100%;
	height: 100%;
	background: #fff;
	margin:0 !important;
	-webkit-text-size-adjust: 100%;
}

body {
	width: -moz-calc(100% - (var(--offset))*2);
	width: -webkit-calc(100% - (var(--offset))*2);
	width: -o-calc(100% - (var(--offset))*2);
	width: calc(100% - (var(--offset))*2);
	padding: 0 var(--offset);
	font: normal 22px/30px 'Euclid Circular Regular', Helvetica, Arial, Verdana, sans-serif;
	color: var(--font_color);
	overflow-x: hidden;
	min-width: 320px;
	-webkit-font-smoothing: antialiased;
	-moz-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-smoothing: antialiased;
}

body.noscroll {
	overflow: hidden;
}

body.wait, body.wait a {
	cursor:wait;
	overflow-y:hidden;
}

#wpadminbar {
	display:none !important;
}

div:focus {
	outline: none;
	ie-dummy: expression(this.hideFocus=true);
}

::selection {
  background: #F2F2F2;
  color:var(--font_color);
}

::-moz-selection {
  background: #F2F2F2;
  color:var(--font_color);
}

a::selection {
	color:var(--font_color) !important;
}

a::-moz-selection {
	color:var(--font_color) !important;
}

.ie_message {
	display: none;
	padding: 10px;
}

/*------------------------------------------------------
TYPOGRAPHY
------------------------------------------------------*/

h1 {
	font: normal 80px/80px 'Buenos Aires Book', Helvetica, Arial, Verdana, sans-serif;
}

h2 span.big {
	font: normal 70px/70px 'Buenos Aires Book', Helvetica, Arial, Verdana, sans-serif;
}

h2 {
	font: normal 50px/55px 'Buenos Aires Book', Helvetica, Arial, Verdana, sans-serif;
}

h3 {
	font: normal 32px/38px 'Buenos Aires Book', Helvetica, Arial, Verdana, sans-serif;
}

nav ul li a {
	font: normal 40px/45px 'Buenos Aires Book', Helvetica, Arial, Verdana, sans-serif;
}

.small_type {
	font-size:14px;
	line-height:16px;
}

p, .wysiwig_content ul, .wysiwig_content ol {
	margin-bottom: 30px;
}

b, strong {
	font-weight: normal;
	font-family: 'Euclid Circular Semibold';
}

/*------------------------------------------------------
GENERAL LINKS
------------------------------------------------------*/

a {
	outline: none;
	text-decoration: none;
	cursor: pointer;
	color: #000;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}

a.no_decoration {
	text-decoration:none;
}

:focus {
	-moz-outline-style: none;
}

/*------------------------------------------------------
IMAGES
------------------------------------------------------*/

img {
	display: block;
	border: none 0;
}

.lazyload, .lazyloading {
	opacity: 0;
}

.lazyloaded {
	opacity: 1;
	-webkit-transition:opacity 0.5s;
	transition: opacity 0.5s;
}

/*------------------------------------------------------
VIDEO
------------------------------------------------------*/

video {
	display:block;
	outline: 0;
	-moz-outline-style: none;
}

/* Responsive iFrame */

.video_wrap {
	position: relative;
	padding-bottom: 56.25%; /* 16:9 */
	padding-top: 25px;
	height: 0;
}

.video_wrap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/*------------------------------------------------------
CLEAR
------------------------------------------------------*/

.clear {
	clear: both;
}

/*------------------------------------------------------
Focus Input & Textarea
------------------------------------------------------*/

input, textarea {
	-webkit-border-radius: 0px;
	-moz-border-radius: 0px;
	border-radius: 0px;
	resize: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-results-decoration { 
	display: none; 
}

textarea:focus, input:focus, select:focus {
    outline: 0;
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

input[type="button"], button {
   outline:none !important;
}
input[type="button"]::-moz-focus-inner, button::-moz-focus-inner {
   border: 0 !important;
}

/*------------------------------------------------------
WYSIWIG CONTENT
------------------------------------------------------*/

.wysiwig_content img {
	display: block;
	width: 100%;
	height: auto;
}

.wysiwig_content ul {
    list-style: none;
    margin-left: 0;
    padding-left: 1em;
}

.wysiwig_content ol {
	margin-left: 0;
	padding-left: 1em;
}

.wysiwig_content ol {
	margin-left:var(--offset);
}

.wysiwig_content ol > li {
	padding-left:4px;
}

.wysiwig_content ul > li {
	padding-left:25px;
	background:url('images/listpoint.svg') no-repeat top 15px left;
	background-size:4px 4px;
}

.wysiwig_content hr {
	border-top: 1px solid var(--font_color);
	border-bottom:0;
	margin-top:-5px;
	margin-bottom:22px;
}

.wysiwig_content a {
	position:relative;
	-webkit-transition:color 0.5s var(--easing);
	transition:color 0.5s var(--easing);
}

.wysiwig_content a.link_no_border {
	text-decoration:none !important;
}

.wysiwig_content a.link_no_border:after {
	display:none;
}

body.no_touch .wysiwig_content a:hover {
	color:var(--color_dark_blue);
}

.wysiwig_content a:after {
	display:inline-block;
	content:'';
	width:18px;
	height:18px;
	margin-left:5px;
	margin-right:2px;
	background:url('images/link_arrow.svg') no-repeat center center;
	background-size:100% auto;
	-webkit-transition:margin  0.5s var(--easing), -webkit-transform 0.5s var(--easing);
	transition:margin  0.5s var(--easing), transform 0.5s var(--easing);
}

body.no_touch .wysiwig_content a:hover:after {
	background:url('images/link_arrow_rollover.svg') no-repeat center center;
	background-size:100% auto;
	margin-left:7px;
	margin-right:0;
}

.wysiwig_content a[target="_blank"]:after,
.wysiwig_content a[href^="mailto:"]:after {
	background:url('images/link_arrow_external.svg') no-repeat center center;
	background-size:100% auto;
	margin-right:0;
	margin-top:0;
}

body.no_touch .wysiwig_content a[target="_blank"]:hover::after,
body.no_touch .wysiwig_content a[href^="mailto:"]:hover::after {
	background:url('images/link_arrow_external_rollover.svg') no-repeat center center;
	background-size:100% auto;
	-webkit-transform: translateY(-2px);
	transform: translateY(-2px);
}

.wysiwig_content a[href$=".pdf"]:after,
.wysiwig_content a[href$=".doc"]:after,
.wysiwig_content a[href$=".docx"]:after,
.wysiwig_content a[href$=".xls"]:after,
.wysiwig_content a[href$=".xlsx"]:after,
.wysiwig_content a[href$=".ppt"]:after,
.wysiwig_content a[href$=".pptx"]:after,
.wysiwig_content a[href$=".zip"]:after,
.wysiwig_content a[href$=".rar"]:after,
.wysiwig_content a[href$=".jpg"]:after,
.wysiwig_content a[href$=".png"]:after,
.wysiwig_content a[href$=".gif"]:after,
.wysiwig_content a[href$=".mp4"]:after,
.wysiwig_content a[href$=".mp3"]:after {
	background:url('images/link_arrow_download.svg') no-repeat right bottom;
	background-size:100% auto;
	margin-right:0;
	-webkit-transform: translateY(4px);
	transform: translateY(4px);
}

body.no_touch .wysiwig_content a[href$=".pdf"]:hover:after,
body.no_touch .wysiwig_content a[href$=".doc"]:hover:after,
body.no_touch .wysiwig_content a[href$=".docx"]:hover:after,
body.no_touch .wysiwig_content a[href$=".xls"]:hover:after,
body.no_touch .wysiwig_content a[href$=".xlsx"]:hover:after,
body.no_touch .wysiwig_content a[href$=".ppt"]:hover:after,
body.no_touch .wysiwig_content a[href$=".pptx"]:hover:after,
body.no_touch .wysiwig_content a[href$=".zip"]:hover:after,
body.no_touch .wysiwig_content a[href$=".rar"]:hover:after,
body.no_touch .wysiwig_content a[href$=".jpg"]:hover:after,
body.no_touch .wysiwig_content a[href$=".png"]:hover:after,
body.no_touch .wysiwig_content a[href$=".gif"]:hover:after,
body.no_touch .wysiwig_content a[href$=".mp4"]:hover:after,
body.no_touch .wysiwig_content a[href$=".mp3"]:hover:after {
	background:url('images/link_arrow_download_rollover.svg') no-repeat right bottom;
	background-size:100% auto;
	margin-right:0;
	-webkit-transform: translateY(6px);
	transform: translateY(6px);
}

/*------------------------------------------------------
COOKIE BANNER
------------------------------------------------------*/

#moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme {
	background:#90BCFF !important;
	color:var(--font_color) !important;
	text-align:center !important;
	padding:60px 0 !important;
	border-top:none 0 !important;
}

#moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme p,
#moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme p a,
#moove_gdpr_cookie_info_bar .moove-gdpr-button-holder button {
	font: normal 22px/30px 'Euclid Circular Regular', Helvetica, Arial, Verdana, sans-serif !important;
	color:var(--font_color) !important;
	font-weight:normal !important;
}

#moove_gdpr_cookie_info_bar .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content {
	display:block !important;
	text-align:center !important;
	max-width:80% !important;
	margin:0 auto !important;
}

#moove_gdpr_cookie_info_bar .moove-gdpr-info-bar-container .moove-gdpr-cookie-notice {
	margin-bottom:30px !important;
}

#moove_gdpr_cookie_info_bar .moove-gdpr-button-holder {
	display:block !important;
}

#moove_gdpr_cookie_info_bar .moove-gdpr-button-holder button {
	background:#fff !important;
	color:var(--font_color) !important;
	border-radius:10px !important;
	border:1px solid #000 !important;
	margin: 0 15px !important;
}

body.no_touch #moove_gdpr_cookie_info_bar .moove-gdpr-button-holder button:hover {
	background:#1D3C83 !important;
	color:#fff !important;
	border:1px solid #1D3C83 !important;
}

/*------------------------------------------------------
GRID
------------------------------------------------------*/

.grid {
	display: -ms-grid;
	display: grid;
	grid-gap: var(--gap);
	grid-row-gap: 0px;
	grid-template-columns: repeat(var(--columns), 1fr);
	align-items: start;
}

.full_columns {
	-ms-grid-columns: 1 / 13;
	grid-column:1 / 13;
}

.inside_max_width {
	display:block;
	max-width:1450px;
	margin: 0 auto !important;
}

/*------------------------------------------------------
HEADER
------------------------------------------------------*/

header {
	position:fixed;
	top:0;
	left:0;
	right:0;
	height:114px;
	z-index:100;
	-webkit-transition:background 0.2s var(--easing), height 0.5s var(--easing);
	transition:background 0.2s var(--easing), height 0.5s var(--easing);
}

header.active_nav {
	pointer-events:none;
}

header.sticky {
	background:#fff;
	height:52px;
}

header.active_nav {
	background:transparent;
}

header a.home_logo {
	position:absolute;
	top:15px;
	left:50%;
	margin-left:-76px;
	width:152px;
	height:79px;
	background:url('images/logo_color.svg') no-repeat center center;
	background-size:100% 100%;
	pointer-events:all;
	-webkit-transition:width 0.5s var(--easing), height 0.5s var(--easing), margin 0.5s var(--easing);
	transition:width 0.5s var(--easing), height 0.5s var(--easing), margin 0.5s var(--easing);
}

body.home header.sticky a.home_logo,
header.sticky a.home_logo {
	width:152px;
	height:20px;
	margin-left:-76px;
	background:url('images/text_logo.svg') no-repeat center center;
	background-size:100% 100%;
}

header.active_nav a.home_logo {
	display:none;
}

body.home header a.home_logo {
	background:url('images/logo_white.svg') no-repeat center center;
	background-size:100% 100%;
}

header a.hamburger {
	display:block;
	width:36px;
	height:14px;
	position:absolute;
	top:36px;
	left:var(--offset);
	pointer-events:all;
	-webkit-transition:top 0.5s var(--easing);
	transition:top 0.5s var(--easing);
}

header.sticky a.hamburger {
	top:20px;
}

header a.hamburger span {
	position:absolute;
	left:0;
	width:100%;
	height:3.5px;
	background:var(--font_color);
	border-radius:4px;
	transform: rotate(0deg);
	-webkit-transform: -webkit-rotate(0deg);
	transform-origin: center center;
	-webkit-transform-origin: center center;
	-webkit-transition: -webkit-transform 0.5s var(--easing), width 0.5s var(--easing), color 0.5s var(--easing);
	transition: transform 0.5s var(--easing), width 0.5s var(--easing), color 0.5s var(--easing);
}

body.home header a.hamburger span {
	background:#fff;
}

body.home header.active_nav a.hamburger span,
body.home header.sticky a.hamburger span {
	background:#000;
}

header a.hamburger span.line_1 {
	top:0;
}

header a.hamburger span.line_2 {
	top:10px;
}

body.no_touch header:not(.active_nav) a.hamburger:hover span.line_2 {
	width:12px;
}

header a.hamburger.active span.line_1 {
	transform: rotate(45deg);
	-webkit-transform: -webkit-rotate(45deg);
	top:5px;
}

header a.hamburger.active span.line_2 {
	transform: rotate(-45deg);
	-webkit-transform: -webkit-rotate(-45deg);
	top:5px;
}

/*------------------------------------------------------
NAVIGATION
------------------------------------------------------*/

nav {
	display:none;
	position:fixed;
	top:0;
	left:0;
	right:0;
	bottom:0;
	z-index:99;
	background:var(--color_violet);
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-khtml-user-select: none; 
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

nav > div,
nav ul.sub-menu {
	padding:81px var(--offset) var(--offset) var(--offset);
}

nav ul.nav-menu {
	display:block;
	list-style:none;
	overflow-x:hidden;
	overflow-y:auto;
	scrollbar-width: none;
}

nav ul.nav-menu::-webkit-scrollbar {
    display: none;
}

nav ul.nav-menu li {
	display:block;
	margin-bottom:10px;
}

nav ul.nav-menu > li > a,
.lang_switch {
	opacity:0;
	display:table;
	-webkit-transform: translateY(20px);
	transform: translateY(20px);
	-webkit-transition: -webkit-transform 0.6s var(--easing), opacity 0.6s var(--easing);
	transition: transform 0.6s var(--easing), opacity 0.6s var(--easing);
}

nav.show ul.nav-menu > li > a,
nav.show .lang_switch {
	opacity:1;
	-webkit-transform: translateY(0);
	transform: translateY(0);
}

nav ul.nav-menu > li:nth-child(1) > a {
	-webkit-transition-delay: 0.05s;
	transition-delay: 0.05s;
}

nav ul.nav-menu > li:nth-child(2) > a {
	-webkit-transition-delay: 0.1s;
	transition-delay: 0.1s;
}

nav ul.nav-menu > li:nth-child(3) > a {
	-webkit-transition-delay: 0.15s;
	transition-delay: 0.15s;
}

nav ul.nav-menu > li:nth-child(4) > a {
	-webkit-transition-delay: 0.2s;
	transition-delay: 0.2s;
}

nav ul.nav-menu > li:nth-child(5) > a {
	-webkit-transition-delay: 0.25s;
	transition-delay: 0.25s;
}

nav ul.nav-menu > li:nth-child(6) > a {
	-webkit-transition-delay: 0.3s;
	transition-delay: 0.3s;
}

nav ul.nav-menu > li:nth-child(7) > a {
	-webkit-transition-delay: 0.35s;
	transition-delay: 0.35s;
}

nav ul.nav-menu > li:nth-child(8) > a,
nav.show .lang_switch {
	-webkit-transition-delay: 0.4s;
	transition-delay: 0.4s;
}

/*
body.no_touch nav ul.nav-menu li.menu-item-has-children:hover ul.sub-menu {
	display:block;
}
*/

nav ul.nav-menu li a {
	text-decoration:none;
}

nav ul.nav-menu li.current_page_item a,
body.no_touch nav ul.nav-menu li a:hover,
ul.lang_switch li.current-lang a,
ul.nav-menu li.current-menu-ancestor > a {
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 4px;
}

nav ul.sub-menu {
	display:none;
	position:fixed;
	width:50%;
	top:0;
	bottom:0;
	right:0;
	background:var(--color_violet_light);
	overflow-x:hidden;
	overflow-y:auto;
	scrollbar-width: none;
}

nav ul.sub-menu::-webkit-scrollbar {
    display: none;
}

ul.lang_switch {
	position:absolute;
	bottom:0;
	padding-bottom:var(--offset);
	left:0;
	padding-left:var(--offset);
	background:var(--color_violet);
	width:50%;
}

ul.lang_switch li {
	display:inline-block;
	margin-right:15px;
}

ul.lang_switch li a {
	text-transform:uppercase;
	text-decoration:none;
	color:#7B7B7B;
	-webkit-transition:color 0.5s var(--easing);
	transition:color 0.5s var(--easing);
}

ul.lang_switch li.current-lang a,
body.no_touch ul.lang_switch li a:hover {
	color:var(--font_color);
}

/*------------------------------------------------------
HOME
------------------------------------------------------*/

.intro_section,
.intro_section .mobile_bg .subgrid {
	display: -ms-grid;
	display: grid;
	grid-gap: 0;
	grid-row-gap: 0px;
	grid-template-columns: repeat(3, 1fr);
	align-items: start;
	margin-left:var(--offset-minus);
	margin-right:var(--offset-minus);
	pointer-events:none;
}

.intro_section .intro_column,
.intro_section .mobile_bg .letter {
	height: calc(var(--vh, 1vh) * 100);
	display: flex;
	justify-content: center;
	align-items: center;
	font-size:27.3vw;
	color:#fff;
}

.intro_section .intro_column span,
.intro_section .mobile_bg .letter {
	opacity:0;
	-webkit-transform: translateY(100px);
	transform: translateY(100px);
	-webkit-transition: -webkit-transform 0.6s var(--easing), opacity 0.6s var(--easing);
	transition: transform 0.6s var(--easing), opacity 0.6s var(--easing);
}

.intro_section.show .intro_column span,
.intro_section.show .mobile_bg .letter {
	opacity:1;
	-webkit-transform: translateY(0);
	transform: translateY(0);
}

.intro_section.show .intro_column.column_bild_links span,
.intro_section.show .mobile_bg .letter:nth-child(1) {
	-webkit-transition-delay: 0.1s;
	transition-delay: 0.1s;
}

.intro_section.show .intro_column.column_bild_mitte span,
.intro_section.show .mobile_bg .letter:nth-child(2) {
	-webkit-transition-delay: 0.2s;
	transition-delay: 0.2s;
}

.intro_section.show .intro_column.column_bild_rechts span,
.intro_section.show .mobile_bg .letter:nth-child(3) {
	-webkit-transition-delay: 0.3s;
	transition-delay: 0.3s;
}

.intro_section .mobile_bg {
	display:none;
}

.etappen_status {
	display:block;
	margin-top:30px;
	column-count: 2;
	column-gap: var(--gap);
}

.etappen_status .etappe {
	break-inside: avoid-column;
	padding-left:43px;
	padding-bottom:10px;
}

.etappen_status .etappe.status_0 {
	background:url('images/etappe_0.svg') no-repeat top 3px left;
	background-size:27px 27px;
}

.etappen_status .etappe.status_1 {
	background:url('images/etappe_1.svg') no-repeat top 3px left;
	background-size:27px 27px;
}

/*------------------------------------------------------
DEFAULT
------------------------------------------------------*/

.page_default {
	display:block;
	padding:120px 0 0 0;
}

.page_default h1 {
	max-width:1450px;
	margin-left:auto;
	margin-right:auto;
}

/*------------------------------------------------------
FLEXIBLE CONTENT
------------------------------------------------------*/

.flexible_content_row_outer {
	margin-left:var(--offset-minus);
	margin-right:var(--offset-minus);
	padding:60px var(--offset) 60px;
}

.flexible_content_row p:last-child {
	margin-bottom:0;
}

 .page_default .flexible_content_row.flexible_content_row_0 {
	padding-top:0;
}

.page_default .flexible_content_row.flexible_content_row_0 .column_right {
	margin-top:-74px;
}

.flexible_content_row_outer:last-child {
	padding-bottom:120px;
}

/*------------------------------------------------------
FLEXIBLE CONTENT | BG COLORS
------------------------------------------------------*/

/* Home (Blue and Grey) */

.flexible_content > .flexible_content_row_outer:nth-child(4n + 2) {
    background-color: var(--color_blue);
}

.flexible_content > .flexible_content_row_outer:nth-child(4n + 0) {
    background-color: var(--color_green);
}

/* Etappe (Green and Grey) */
/*
.page_etappe .flexible_content > .flexible_content_row_outer:nth-child(4n + 2) {
    background-color: var(--color_beige);
}

.page_etappe  .flexible_content > .flexible_content_row_outer:nth-child(4n + 0) {
    background-color: var(--color_grey);
}
*/

/* Default */
/*
.page_default .flexible_content > .flexible_content_row_outer:nth-child(even) {
    background-color: var(--color_grey);
}
*/

/* Red */

.flexible_content_row_outer.is_red {
	background:var(--color_red) !important;
	margin-left:var(--offset-minus);
	margin-right:var(--offset-minus);
	padding-left:var(--offset);
	padding-right:var(--offset);
}

/*------------------------------------------------------
FLEXIBLE CONTENT | STICKY TITLES
------------------------------------------------------*/

h2.sticky {
	display:none;
	position:fixed;
	top:70px;
}

h2.original.hide {
	opacity:0;
	pointer-events:none;
}

/*------------------------------------------------------
FLEXIBLE CONTENT SUBGRID
------------------------------------------------------*/

.flexible_content_row.subgrid,
.logo_section.subgrid {
	display: -ms-grid;
	display: grid;
	grid-gap: var(--gap);
	grid-row-gap: 0px;
	grid-template-columns: repeat(var(--columns), 1fr);
	align-items: start;
	width:100%;
}

.flexible_content_row.subgrid .column_left,
.flexible_content_row.flexible_content_text_media .title_section {
	-ms-grid-columns: 1 / 7;
	grid-column:1 / 7;
	margin-top:-5px;
}

.flexible_content_row.subgrid .column_right {
	-ms-grid-columns: 7 / 13;
	grid-column:7 / 13;
}

/*------------------------------------------------------
FLEXIBLE CONTENT | TEXT AND IMAGE / VIDEO
------------------------------------------------------*/

.flexible_content_row.flexible_content_text_media .title_section {
	margin-bottom:50px;
}

.flexible_content_row.flexible_content_text_media .media_section {
	-ms-grid-columns: 3 / 11;
	grid-column:3 / 11;
	margin-bottom:60px;
}

.flexible_content_row.flexible_content_text_media .media_section img,
.flexible_content_row.flexible_content_text_media .media_section video {
	display:block;
	width:100%;
	height:auto;
	aspect-ratio: 3 / 2;
	object-fit:cover;
}

.flexible_content_row.flexible_content_text_media .text_section {
	-ms-grid-columns: 7 / 13;
	grid-column:7 / 13;
}

/*------------------------------------------------------
FLEXIBLE CONTENT | GALLERY
------------------------------------------------------*/

.flexible_content_row.flexible_content_gallery .gallery_item {
	margin-bottom:60px;
}

.flexible_content_row.flexible_content_gallery .gallery_item:last-child {
	margin-bottom:0;
}

.flexible_content_row.flexible_content_gallery img {
	display:block;
	width:100%;
	height:auto;
}

.flexible_content_row.flexible_content_gallery .gallery_item_0 {
	-ms-grid-columns: 1 / 6;
	grid-column:1 / 6;
	margin-top:0;
}

.flexible_content_row.flexible_content_gallery .gallery_item_0:first-child {
	margin-top:0;
}

.flexible_content_row.flexible_content_gallery .gallery_item_1 {
	-ms-grid-columns: 7 / 13;
	grid-column:7 / 13;
	margin-top:120px;
}

.flexible_content_row.flexible_content_gallery .gallery_item_1:first-child {
	margin-top:0
}

.flexible_content_row.flexible_content_gallery .gallery_item_2 {
	-ms-grid-columns: 1 / 7;
	grid-column:1 / 7;
	margin-top:120px;
}

.flexible_content_row.flexible_content_gallery .gallery_item_3 {
	-ms-grid-columns: 8 / 13;
	grid-column:8 / 13;
	margin-top:100px;
}

.flexible_content_row.flexible_content_gallery .gallery_item_0 img,
.flexible_content_row.flexible_content_gallery .gallery_item_3 img {
	aspect-ratio:4 / 5;
	object-fit:cover;
}

.flexible_content_row.flexible_content_gallery .gallery_item_1 img,
.flexible_content_row.flexible_content_gallery .gallery_item_2 img {
	aspect-ratio:5 / 4;
	object-fit:cover;
}


/*------------------------------------------------------
FLEXIBLE CONTENT | LOGOS
------------------------------------------------------*/

.flexible_content_logos .logo_section {
	margin-bottom:60px;
}

.flexible_content_logos .logo_section:last-child {
	margin-bottom:0;
}

.logo_listing {
	display: -ms-grid;
	display: grid;
	grid-gap: var(--gap);
	grid-row-gap: 0px;
	-ms-grid-columns: 1 / 7;
	grid-column:1 / 7;
	grid-template-columns: repeat(3, 1fr);
	align-items: start;
}

.logo_listing .logo_box {
	height:13vw;
}

.logo_listing .logo_box a {
	width:100%;
	height:13vw;
	display: flex;
	justify-content: center;
	align-items: center;
}

.logo_listing .logo_box img {
	width:70%;
	height:70%;
	object-fit: contain;
	object-position: center center;
	mix-blend-mode: multiply;
	transform: translate3d(0,0,0);
}

/*------------------------------------------------------
FLEXIBLE CONTENT | OUTDOOR ACTIVE
------------------------------------------------------*/

.outdooractive_content {
	width:100%;
	aspect-ratio:1/1;
	background:#ccc;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top:3px;
}

.open_routes {
	margin-top:20px;
}

/*------------------------------------------------------
FACTS
------------------------------------------------------*/

.facts {
	position:fixed;
	bottom:0;
	left:0;
	right:0;
	height:104px;
	background:rgba(242,242,242,0.95);
	display: -ms-grid;
	display: grid;
	grid-gap: var(--gap);
	grid-row-gap: 0px;
	grid-template-columns: repeat(3, 1fr);
	align-items: start;
	padding:0 var(--offset);
	cursor:pointer;
	-webkit-transform: translateY(100%);
	transform: translateY(100%);
	-webkit-transition: -webkit-transform 0.6s var(--easing);
	transition: transform 0.6s var(--easing);
}

.facts.hide {
	display:none;
}

.facts.no_click {
	pointer-events:none;
}

.facts.show {
	-webkit-transform: translateY(0);
	transform: translateY(0);
}

.facts .facts_column {
	display: flex;
	justify-content: center;
	align-items: center;
	height:100%;
}

.facts .facts_column_left .facts_inside {
	padding-left:64px;
	background:url('images/icon_bergwanderweg.svg') no-repeat top left;
	background-size:49px 49px;
}

.facts .facts_column_middle .facts_inside {
	padding-left:64px;
	background:url('images/icon_hoehenmeter.svg') no-repeat top left;
	background-size:49px 49px;
}

.facts .facts_column_right .facts_inside {
	padding-left:64px;
	background:url('images/icon_hoechster_punkt.svg') no-repeat top left;
	background-size:49px 49px;
}

/*------------------------------------------------------
ETAPPE
------------------------------------------------------*/

.page_etappe, .page_unterkuenfte {
	padding-top:130px;
}

.page_etappe .header_image {
	margin-left:var(--offset-minus);
	margin-right:var(--offset-minus);
	height:68vh;
	margin-top:36px;
}

.top_title_section {
	display: -ms-grid;
	display: grid;
	grid-gap: var(--gap);
	grid-row-gap: 0px;
	grid-template-columns: repeat(var(--columns), 1fr);
	align-items: end;
	padding-bottom:15px;
}

.top_title_section .title_section {
	-ms-grid-columns: 1 / 11;
	grid-column:1 / 11;
}

.top_title_section .paging {
	-ms-grid-columns: 11 / 13;
	grid-column:11 / 13;
	text-align:center;
}

.top_title_section .paging .outer_prev,
.top_title_section .paging .outer_next {
	display:inline-block;
}

.top_title_section .paging a {
	text-decoration:none;
	position:relative;
	padding-top:37px;
	padding-bottom:4px;
	margin-bottom:-30px;
}

.top_title_section .paging span {
	display:block;
	position:absolute;
	bottom:0;
	opacity:0;
	color:var(--color_dark_blue);
	-webkit-transition:opacity 0.4s var(--easing);
	transition:opacity 0.4s var(--easing);
}

body.no_touch .top_title_section .paging a:hover span {
	opacity:1;
}

.top_title_section .paging a.prev,
.top_title_section .paging a.next {
	display:inline-block;
	width:43px;
	height:28px;
	-webkit-transition:background 0.4s var(--easing);
	transition:background 0.4s var(--easing);
}

.top_title_section .paging a.prev span {
	left:0;
}

.top_title_section .paging a.right span {
	right:0;
}

.top_title_section .paging a.prev {
	background:url('images/arrow_left.svg') no-repeat top right;
	background-size:100% auto;
}

body.no_touch .top_title_section .paging a.prev:hover {
	background:url('images/arrow_left_rollover.svg') no-repeat top right;
	background-size:100% auto;
}

.top_title_section .paging a.next {
	background:url('images/arrow_right.svg') no-repeat top left;
	background-size:100% auto;
	margin-left:42px;
}

body.no_touch .top_title_section .paging a.next:hover {
	background:url('images/arrow_right_rollover.svg') no-repeat top left;
	background-size:100% auto;
}

/*------------------------------------------------------
UNTERKÜNFTE
------------------------------------------------------*/

.page_unterkuenfte .accommodation_section {
	border-bottom:1px solid #000;
}

.page_unterkuenfte .accommodation_section.accommodation_section_0.no_accommomadions,
.page_unterkuenfte .accommodation_section:last-child {
	border-bottom:none 0;
}

.page_unterkuenfte .accommodation_section.accommodation_section_0.no_accommomadions .accommedation_section_title {
	margin-bottom:0;
}

.page_unterkuenfte .accommedation_section_title {
	margin-top:60px;
	margin-bottom:30px;
}

.page_unterkuenfte .accommedation_section_title a {
	display:table;
	margin-top:15px;
}

.acoommodations {
	display: -ms-grid;
	display: grid;
	grid-gap: var(--gap);
	grid-row-gap: 0px;
	grid-template-columns: repeat(3, 1fr);
	align-items: start;
}

.acoommodations .acoommodation_box {
	margin-bottom:60px;
}

.acoommodations .acoommodation_box a {
	text-decoration:none;
}

.acoommodations .acoommodation_box .image_box {
	aspect-ratio: 1 / 1;
	width:100%;
	height:auto;
	margin-bottom:18px;
	overflow:hidden;
}

.acoommodations .acoommodation_box .image_box img {
	width:100%;
	height:auto;
	aspect-ratio: 1 / 1;
	-ms-transform: scale(1.1);
	-webkit-transform: scale(1.1);
	transform: scale(1.1);
	transform-origin: center center;
	-webkit-transform-origin: center center;
	-webkit-transition: -webkit-transform 0.5s var(--easing);
	transition: transform 0.5s var(--easing);
}

.acoommodations .acoommodation_box .image_box:hover img {
	-ms-transform: scale(1);
	-webkit-transform: scale(1);
	transform: scale(1);
}

/*------------------------------------------------------
FOOTER
------------------------------------------------------*/

footer {
	display:block;
	background:var(--color_blue);
	margin:0 var(--offset-minus) 0 var(--offset-minus);
	padding:40px var(--offset) 60px var(--offset);
}

footer .subgrid {
	display: -ms-grid;
	display: grid;
	grid-gap: var(--gap);
	grid-row-gap: 0px;
	grid-template-columns: repeat(3, 1fr);
	align-items: start;
}

/*------------------------------------------------------
IE
------------------------------------------------------*/

.ie_message {
	display: none;
	padding: 10px;
}

.ie_message a {
	text-decoration: underline;
}

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {  
	.ie_message {
		display: block !important;
	}
   header, main, footer {
    display: none !important
   }
}

/*------------------------------------------------------
BIGGER THAN MAX SIZE
------------------------------------------------------*/

@media (min-width: 1500px) {

	.flexible_content_row.flexible_content_gallery .gallery_item_0:first-child {
		margin-top:0;
	}

	.flexible_content_row.flexible_content_gallery .gallery_item_3 {
		margin-top:10px;
	}

	.flexible_content_row.flexible_content_gallery .gallery_item_0 {
		margin-top:0;
	}

	.flexible_content_row.flexible_content_gallery .gallery_item_1 {
		margin-top:60px;
	}

	.flexible_content_row.flexible_content_gallery .gallery_item_2 {
		margin-top:120px;
	}

}

/*------------------------------------------------------
TABLET
------------------------------------------------------*/

@media all and (max-width: 960px) and (min-width: 0) {

	:root {
	  --offset: 36px;
	  --offset-minus:  -36px;
	  --max_width: 100%;
	  --columns: 8;
	  --gap: 16px;
	}

	body {
	  font-size:22px;
	  line-height:30px;
	}

	.full_columns,
	.page_etappe .header_image,
	.top_title_section .title_section,
	.top_title_section .paging {
	  -ms-grid-columns: 1 / 9;
	  grid-column:1 / 9;
	}

	h1, h2 span.big  {
	  font-size:46px;
	  line-height:52px;
	}

	h2 {
	  font-size:34px;
	  line-height:38px;
	}

	h3 {
	  font-size:22px;
	  line-height:26px;
	}

	nav ul li a {
	  font: normal 40px/45px 'Buenos Aires Book', Helvetica, Arial, Verdana, sans-serif;
	}

	p, .wysiwig_content ul, .wysiwig_content ol {
	  margin-bottom: 20px;
	}

	.flexible_content_row.subgrid .column_left,
	.flexible_content_row.flexible_content_text_media .title_section {
		-ms-grid-columns: 1 / 5;
		grid-column: 1 / 5;
	}

	.flexible_content_row.subgrid .column_right {
		-ms-grid-columns: 5 / 9;
		grid-column: 5 / 9;
	}

	.etappen_status {
		column-count: 1;
	}

	.flexible_content_row.flexible_content_gallery .gallery_item_0 {
		-ms-grid-columns: 1 / 4;
		grid-column: 1 / 4;
	}

	.flexible_content_row.flexible_content_gallery .gallery_item_1 {
		-ms-grid-columns: 5 / 9;
		grid-column: 5 / 9;
	}

	.flexible_content_row.flexible_content_gallery .gallery_item_2 {
		-ms-grid-columns: 1 / 5;
		grid-column: 1 / 5;
	}

	.flexible_content_row.flexible_content_gallery .gallery_item_3 {
		-ms-grid-columns: 6 / 9;
		grid-column: 6 / 9;
	}

	.flexible_content_row.flexible_content_text_media .media_section {
		-ms-grid-columns: 2 / 9;
		grid-column: 2 / 9;
	}

	.flexible_content_row.flexible_content_text_media .text_section {
		-ms-grid-columns: 3 / 9;
		grid-column: 3 / 9;
	}

	.acoommodations {
		grid-template-columns: repeat(2, 1fr);
	}

	.flexible_content_row.subgrid .column_left,
	h2.sticky {
		overflow-wrap: break-word;
		-webkit-hyphens: auto;
		-moz-hyphens: auto;
		hyphens: auto;
		hyphenate-limit-chars: 6 3 2;
		hyphenate-limit-last: always;
	}

	.intro_section .mobile_bg {
		display:block;
		height: calc(var(--vh, 1vh)* 100);
		width:100%;
		overflow-x:hidden;
	}

	.intro_section .intro_column {
		display:none;
	}

	.intro_section .mobile_bg .letter {
		text-align:center;
	}

	.intro_section {
		grid-template-columns: repeat(1, 1fr);
	}

	.page_default .flexible_content_row.flexible_content_row_0 .column_right {
		margin-top:-50px;
	}

	.top_title_section .paging {
		margin-top:30px;
	}
	
	.top_title_section .paging {
		display: -ms-grid;
		display: grid;
		grid-gap: var(--gap);
		grid-row-gap: 0px;
		grid-template-columns: repeat(2, 1fr);
		align-items: start;
	}

	.top_title_section .paging .outer_prev {
		text-align:left;
	}

	.top_title_section .paging .outer_next {
		text-align:right;
	}

	.top_title_section .paging a.prev, .top_title_section .paging a.next {
		width: 90px;
		height: auto;
	}

	.top_title_section .paging span {
		opacity:1;
		position:relative;
		color:var(--font_color);
	}

	.top_title_section .paging a.prev {
		padding-top:0;
		padding-left:30px;
		background:url('images/arrow_left.svg') no-repeat left center;
		background-size:20px 13px;
	}

	.top_title_section .paging a.next {
		padding-top:0;
		padding-right:30px;
		background:url('images/arrow_right.svg') no-repeat right center;
		background-size:20px 13px;
	}

	.top_title_section {
		padding-bottom:0;
	}

}

/*------------------------------------------------------
MOBILE
------------------------------------------------------*/

@media all and (max-width: 768px) and (min-width: 0) {

	:root {
		  --offset: 20px;
		  --offset-minus:  -20px;
		  --max_width: 100%;
		  --columns: 4;
		  --gap: 11px;
		}

		body {
			font-size:16px;
			line-height:24px;
		}

		.wysiwig_content a:after {
			width:11px;
			height:11px;
		}

		header a.hamburger,
		header.sticky a.hamburger {
			top:18px;
		}

		header a.home_logo {
			top:15px;
		}

		.page_etappe, .page_unterkuenfte {
			padding-top:125px;
		}

		.full_columns,
		.page_etappe .header_image,
		.flexible_content_row.subgrid .column_left,
		.flexible_content_row.subgrid .column_right,
		.flexible_content_row.flexible_content_gallery .gallery_item_0,
		.flexible_content_row.flexible_content_gallery .gallery_item_1,
		.flexible_content_row.flexible_content_gallery .gallery_item_2,
		.flexible_content_row.flexible_content_gallery .gallery_item_3,
		.flexible_content_row.flexible_content_text_media .media_section,
		.flexible_content_row.flexible_content_text_media .text_section  {
		  -ms-grid-columns: 1 / 5;
		  grid-column:1 / 5;
		}

		.acoommodations,
		footer .subgrid {
			grid-template-columns: repeat(1, 1fr);
		}

		.facts {
			padding-top:20px;
			padding-bottom:24px;
			text-align:center;
		}

		.facts .facts_column_left .facts_inside,
		.facts .facts_column_middle .facts_inside,
		.facts .facts_column_right .facts_inside {
			padding-top:52px;
			padding-left:0;
			background-position:top center;
			overflow-wrap: break-word;
			-webkit-hyphens: auto;
			-moz-hyphens: auto;
			hyphens: auto;
			hyphenate-limit-chars: 6 3 2;
			hyphenate-limit-last: always;
		}

		.facts {
			height:auto;
		}

		.facts .facts_column {
			align-items: start;
		}

		.flexible_content_row_outer.flexible_content_logos {
			padding-top:0;
			padding-bottom:0;
		}

		.flexible_content_row_outer,
		.flexible_content_row_outer.flexible_content_logos .flexible_content_logos  {
			padding-top:50px;
			padding-bottom:50px;
		}

		.flexible_content_row_outer.flexible_content_logos .flexible_content_logos {
			padding-bottom:0;
		}

		.flexible_content_row.subgrid .column_left {
			margin-bottom:20px;
		}

		.flexible_content_row.subgrid .column_left h2.original {
			display:block !important;
		}

		h2.original.hide {
			opacity:1 !important;
			pointer-events:all !important;
		}

		h2.sticky {
			display:none !important;
		}

		.flexible_content_row.flexible_content_gallery .gallery_item {
			margin-bottom:20px;
			margin-top:0;
		}

		.logo_listing .logo_box,
		.logo_listing .logo_box a {
			height:25vw;
		}

		.logo_listing {
			grid-template-columns: repeat(2, 1fr);
		}

		nav {
			overflow-y:auto;
			overflow-x:hidden;
		}

		nav > div, nav ul.sub-menu {
			padding-top:60px;
			margin-left: var(--offset-minus);
			margin-right: var(--offset-minus);
		}

		nav > div li {
			padding-left:var(--offset);
			padding-right:var(--offset);
		}

		nav ul.sub-menu {
			padding-top: 10px;
			margin-top:10px;
	        position: relative;
	        width: auto;
	        left: initial;
	        right: initial;
	        top: initial;
	        bottom: initial;
		}

		nav ul.sub-menu li {
			padding-left:0;
			padding-right:0;
		}

		nav ul.sub-menu li a {
			font-size:23px;
			line-height:30px;
		}

		ul.lang_switch {
			position:relative;
			width:100%;
		}

		nav ul.sub-menu li:last-child {
			margin-bottom:0;
		}

		.flexible_content_row.flexible_content_text_media .title_section {
			margin-bottom:30px;
		}

		.page_default h1 {
			margin-bottom:11px;
		}

		.flexible_content_row.flexible_content_text_media .media_section {
			margin-bottom:30px;
		}

		.page_unterkuenfte .accommedation_section_title {
			margin-top:15px;
			margin-bottom:20px;
		}

		.acoommodations .acoommodation_box img {
			margin-bottom:11px;
		}

		.acoommodations .acoommodation_box {
			margin-bottom:55px;
		}

		.page_unterkuenfte .accommodation_section {
			margin-bottom:40px;
		}

		.page_unterkuenfte .accommodation_section.no_accommomadions {
			margin-bottom:10px;
		}

		footer {
			padding: 30px var(--offset) 20px var(--offset);
		}

		#moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme {
			padding:0 0 15px 0 !important;
		}

		#moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme p,
		#moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme p a,
		#moove_gdpr_cookie_info_bar .moove-gdpr-button-holder button {
			font-size:16px !important;
			line-height:24px !important;
		}

		#moove_gdpr_cookie_info_bar .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content .moove-gdpr-button-holder {
			margin-left:var(--offset-minus);
			margin-right:var(--offset-minus);
		}

		#moove_gdpr_cookie_info_bar .moove-gdpr-button-holder button {
			margin-bottom:10px !important;
		}

		.page_unterkuenfte .accommedation_section_title a {
			margin-top:7px;
		}

		nav ul.nav-menu {
			min-height: -moz-calc((var(--vh, 1vh) * 100) - 145px);
			min-height: -webkit-calc((var(--vh, 1vh) * 100) - 145px);
			min-height: -o-calc((var(--vh, 1vh) * 100) - 145px);
			min-height: calc((var(--vh, 1vh) * 100) - 145px);
		}

		.etappen_status .etappe.status_0 {
		    background: url(images/etappe_0.svg) no-repeat top 1px left;
		    background-size: 24px 24px;
		}

		.etappen_status .etappe.status_1 {
		    background: url(images/etappe_1.svg) no-repeat top 1px left;
		    background-size: 24px 24px;
		}

		.flexible_content_row_outer:last-child {
			padding-bottom:60px;
		}

		.page_default .flexible_content_row.flexible_content_row_0 .column_right {
			margin-top:0;
		}


}