.mobile .cols:not(.nowrap) {
    display: block !important;
}
.mobile .cols:not(.nowrap) .grow-1,
.mobile .cols:not(.nowrap) .grow-2,
.mobile .cols:not(.nowrap) .grow-3,
.mobile .cols:not(.nowrap) .grow-4 {
    display: block !important;
    width: 100%;
}
.mobile .cols-2:not(.nowrap) { grid-template-columns: 1fr; }
.mobile .cols-3:not(.nowrap) { grid-template-columns: 1fr; }
body > header {
    padding: 1.5em 1em 2em 1em;
}
.mobile > header .logo {
	grid-column: 2;
	grid-row: 1;
	
}
.mobile > header [nuiburger] li {
    padding: 0rem;
    font-size: inherit;
    border-bottom: 1px solid var(--app-color-base);
}
.mobile > header [nuiburger] a {
    font-size: 1.4rem !important;
    display: block;
    padding: 0.3rem 0 0.3rem 2.7rem;
}
.mobile > header [nuiburger] > nav > li > a {
    padding: 1rem 1.5rem;
    display: block;
    font-size: 2rem !important;
    font-family: var(--app-font-title);
    border-bottom: 1px solid var(--app-color-base);
}

.mobile > header [nuiburger] > nav > li a.selected::after, 
.mobile > header [nuiburger] > nav > li > a:hover::after { content: none; }


.mobile > header [nuiburger] {
    grid-column: 1;
	grid-row: 1;
	justify-self: baseline;
}
.mobile.scrolled > header [nuiburger] {
    margin: 1.7rem 0 0 0;
}

.mobile > header [nuiburger]:not(.collapsed) > button,
.mobile.scrolled > header [nuiburger]:not(.collapsed) > button {
    width: 3rem;
    height: 3rem !important;
    font-size: 1.9rem !important;
    padding: 0 !important;
    position: absolute;
    top: 2.7rem;
    z-index: 30;
    align-self: end;
    color: var(--app-color-base);
    justify-self: end;
    left: 0.9rem;
}
.mobile > header [nuiburger]:not(.collapsed) > button {
    margin: -2rem 0 0 0;
}
.mobile article > header {
    font-size: 0.8rem;
    padding: 1rem 1rem 1rem 1rem;
    margin: 0;
}
.mobile article.form {
    max-width:none;
    margin: 0;
}
.mobile article.plain-page {
    padding: 2rem 1rem 4rem 1.5rem !important;
    display: block;
}
.mobile article.text > header {
    z-index: 2;
    position: relative;
    padding: 1rem 1.3rem;
}
.mobile .plain-page {
    padding: 4rem 1rem 3rem 1rem !important;
}
.mobile article.plain-page > header h1 {
    font-size: 3.1rem;
    text-align: left;
    line-height: 113%;
    margin: 0 0 0.6rem 0;
}
.mobile article.text > section {
    padding: 1rem 2rem;
}
.mobile .product > header {
    font-size: 0.8rem;
    padding: 0;
    margin: 0;
    position: relative;
}
.mobile .product > header h1 {
    padding: 0;
    font-size: 1.3rem;
    margin: 0;
    text-align: left;
    display: grid;
    grid-template-columns: min-content auto;
    grid-gap: 1rem;
    align-items: center;
}
.mobile .product > header h1 i {
    align-content: center;
    justify-content: center;
    padding: 0.5rem 0.8rem 0.5rem 0.8rem;
    position: relative;
    width: auto;
    font-size: 2.6rem;
}
.mobile .product > header h1 span {
    margin: 0rem 1rem 0rem 0;
    display: block;
}
.mobile .product > section {
    color: var(--app-color-black);
    margin: 0rem 1.2rem 0 1.2rem !important;
    font-size: smaller;
    line-height: 140%;
    padding: 0 !important;
}
.mobile [nuievents] {
    overflow: hidden;
    display: grid;
    grid-template-columns: min-content auto min-content;
    margin: 2rem -2rem;
}
.mobile [nuievents] [nuibutton] {
    font-size: 2em;
    background: transparent;
    border: none;
    color: var(--app-color-base);
    padding: 0 0.5rem;
}
.mobile [nuievents] .container li article {
    display: inline-block;
    width: 320px;
    height: 240px;
    background: transparent;
    margin: 0 0 0 0.5rem;
}
.mobile .news > header > h1 {
    font-size: 2rem !important;
    padding: 1.3rem 0 0 0;
    text-align: left;
}
.mobile .news > section .picture {
    width: 100%;
    margin: 0;
    float: none;
}
.mobile [nuicalendar] .control button {
    border: none;
    font-size: 1.5rem;
    margin: 0.5rem;
    padding: 0;
    width: 1.9rem;
    height: 1.9rem;
    display: grid;
}
.mobile [nuicalendar] .header label {
    padding: 0;
}
.mobile [nuicalendar] .cell {
    padding: 0.4rem 0;
}
.mobile [nuicalendar] .cell label {
    background: transparent;
    border-radius: 50%;
    width: 1.4rem;
    height: 1.4rem;
    display: grid;
    padding: 0;
    align-content: center;
    text-align: center;
    margin: 0 auto;
}
.mobile .news {
    background: var(--app-color-white);
}
.mobile .news section {
    padding: 0 !important;
    margin: 0;
}
.mobile .news .event {
    display: block !important;
	border: none;
}
.mobile .news .event header {
    position: absolute;
    background: transparent;
    z-index: 3;
    bottom: 0;
}
.mobile .news .event header h2 {
    top: -2.5rem;
    left: 0;
    font-size: 1.3rem;
}
.mobile .news .event section::after {
    background: linear-gradient(0deg,rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
    right: 0;
}
.mobile .news .event section img {
    width: 100vw;
}
.mobile .right section.cols-2 > *:first-child {
    order: 0;
}