@import url('https://cdn.rawgit.com/mfd/f3d96ec7f0e8f034cc22ea73b3797b59/raw/856f1dbb8d807aabceb80b6d4f94b464df461b3e/gotham.css');
@import url('https://fonts.googleapis.com/css?family=Overpass+Mono');
@import url('https://fonts.googleapis.com/icon?family=Material+Icons');
@font-face {
	font-family: 'Digital-7Mono';
	src: url('/fonts/Digital-7Mono.woff"') format('woff'), url('/fonts/Digital-7Mono.ttf') format('truetype'), url('/fonts/Digital-7Mono.svg#Digital-7Mono') format('svg');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'digital-7.mono';
	src: url('/fonts/digital-7.mono.eot');
	src: url('/fonts/digital-7.mono.woff2') format('woff2'), url('/fonts/digital-7.mono.eot?#iefix') format('embedded-opentype');
	font-weight: normal;
	font-style: normal;
}

@font-face {
        font-family: 'gotham-pro';
        src: url('/fonts/gotham-pro.eot');
        src: local('gothambold1'), url('/fonts/gotham-pro.woff') format('woff'), url('/fonts/gotham-pro.ttf') format('truetype');
}
.product-btm.myhome-wrapper {
    margin-top: 35px;
}
footer > a {
    color: transparent;
}footer a img.back {
    object-fit: contain;
}.wrapper img.back.myhome {
    width: 60px;
}.back.myhome:active,.back.myhome:focus{
    opacity: .6;
}
.f-back:active,.f-back:focus{
    opacity: .6;
}
img.back.f-back {
    width: 60px;
    margin-top: 40px;
}
img.back:hover {
    opacity: 0.8;
}
.dice-top .dice img {
    width: 70px;
    height: 75px;
    object-fit: contain;
    border-radius: 50%;
    padding: 0px;

}.dice-top {
    margin-bottom: 13px;
    margin-top: 15px;
}
#solution p {
    margin-bottom: 0;
}
.dice {
    width: fit-content;
    margin: 0 auto;
}
.dice-rotate{
    animation-name: spinning-circle;
    animation-duration: 2s;
	animation-iteration-count: 1;
	animation-delay: 0s;
}
.riddle-container ul li a {
	text-decoration: none;
}
a.lang_icon {
    position: relative;
    z-index: 9999;
    height: 45px;
    width: 45px;
    background: #f3f3f3;
    padding: 0;
    float: right;
    border-radius: 50%;
    text-align: center;
    line-height: 3em;
    margin-right: 80px;
    margin-top: 25px;
}
a.lang_icon img {
    max-width: 25px;
    height: auto;
    margin: 0 auto;
    text-align: center;
}
@-webkit-keyframes spinning-circle {
    0% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
        /*-webkit-transform-origin: 125% 125%;*/
        transform-origin: 45% 45%;
    }
    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
        /*-webkit-transform-origin: 125% 125%;*/
        transform-origin: 45% 45%;
    }
}
.dice-content {
     background: #eaeaea;
     padding: 60px 20px 40px 20px;
     border-radius: 30px;max-width: 400px;
     margin: 0 auto;
     margin-top: -30px;
 }.dice-wrap {
      text-align: center;
      width: 100%;
  }.dice-wrap img {
       width: 300px;
   }
.dice-content {
    display: none;
}
.dice a {
    display: inline-block;
    width: 75px;
    height: 75px;
    object-fit: contain;
    border: 4px solid #eaeaea;
    border-radius: 50%;
    padding: 10px;
    background: white;
}.btn-wrap-dice a.btn.btn-warning:focus {
    opacity: .6;
}
.dice-content .dice-wrap p img {
	width: 100% !important;
	height:auto !important;
}
html {
    scroll-behavior: smooth;
}
html, body {
	margin: 0;
	padding: 0;
	font-family: 'GothamPro', sans-serif;
	font-size: 1.15em;
	line-height: 1.6;
	color: #6db672;
	overflow-x: hidden;
}

body {
	min-height: 100vh;
	height: auto;
	width: 100%;
	position: relative;
}

h1, h2, h4, h5, h6, a, p, span, i {
	font-weight: 300;
	color: #202122;
}

h3 {
	font-weight: 300;
	color: #6db672;
}

code {
    color: #202122;
}

body {
	background: linear-gradient(60deg, rgba(175, 175, 175, 0.3) 5%, rgba(255, 255, 255, 0.15));
}

body.zermelo-tavole {
    background: #87cbd0;
}

body.arte-tavole {
    background: #ff7984;
}

body.tales-tavole {
    background: #dd3c49;
}

body.lullo-tavole {
    background: #cf8eed;
}

body.carte {
    background-image: linear-gradient(to bottom, #6db672 8880px, #e9e9e9 100px);
}



@media (max-width: 767px) {
    body.carte {
        background-image: linear-gradient(to bottom, #6db672 17715px, #e9e9e9 100px);
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    body.carte {
        background-image: linear-gradient(to bottom, #6db672 11260px, #e9e9e9 100px);
    }
}

nav.menu {
	position: absolute;
	top: 25px;
	right: 25px;
	z-index: 1;
}

nav.menu>i {
	background-color: #f3f3f3;
	color: #6db672;
	font-size: 30px !important;
	padding: 7.5px;
	border-radius: 50%;
}

nav.menu>div {
	background-color: #f3f3f3;
	position: absolute;
	right: 0;
	top: 55px;
	border-radius: 7.5px;
	width: 200px;
	z-index: 1;
	-webkit-transition: visibility 0.2s linear, opacity 0.2s linear;
	-moz-transition: visibility 0.2s linear, opacity 0.2s linear;
	-ms-transition: visibility 0.2s linear, opacity 0.2s linear;
	-o-transition: visibility 0.2s linear, opacity 0.2s linear;
	transition: visibility 0.2s linear, opacity 0.2s linear;
}
nav.menu:hover>div {
	visibility: visible !important;
	opacity: 1 !important;
	transition-delay: 0s;
}

nav.menu>div>ul {
	list-style-type: none;
	margin: 0;
	padding: 10px;
	text-align: right;
}

nav.menu>div>ul>li {
	padding: 5px;
	text-transform: uppercase;
}

nav.menu>div>ul>li>div.divider-small {
	float: right;
}

nav.menu>div>ul>li>a {
	text-decoration: none;
	color: #6db672;
	font-size: 18px;
}

nav.menu>div>ul>li>a:hover {
	text-decoration: underline;
}

/* FR menu */
nav.frmenu {
	position: absolute;
	top: 25px;
	right: 25px;
	z-index: 1;
}

nav.frmenu>i {
	background-color: #f3f3f3;
	color: #6db672;
	font-size: 30px !important;
	padding: 7.5px;
	border-radius: 50%;
}
nav.frmenu:hover>div {
	visibility: visible !important;
	opacity: 1 !important;
	transition-delay: 0s;
}

nav.frmenu>div>ul {
	list-style-type: none;
	margin: 0;
	padding: 10px;
	text-align: right;
}

nav.frmenu>div>ul>li {
	padding: 5px;
	text-transform: uppercase;
}

nav.frmenu>div>ul>li>div.divider-small {
	floata right;
}

nav.frmenu>div>ul>li>a {
	text-decoration: none;
	color: #6db672;
	font-size: 18px;
}

nav.frmenu>div>ul>li>a:hover {
	text-decoration: underline;
}
nav.frmenu>div {
	background-color: #f3f3f3;
	position: absolute;
	right: 0;
	top: 55px;
	border-radius: 7.5px;
	width: 250px;
	z-index: 1;
	-webkit-transition: visibility 0.2s linear, opacity 0.2s linear;
	-moz-transition: visibility 0.2s linear, opacity 0.2s linear;
	-ms-transition: visibility 0.2s linear, opacity 0.2s linear;
	-o-transition: visibility 0.2s linear, opacity 0.2s linear;
	transition: visibility 0.2s linear, opacity 0.2s linear;
}
/* Menue2 */
nav.menu2 {
	position: absolute;
	top: 25px;
	right: 50px;
	z-index: 1;
}

nav.menu2>img {
    padding: 11px 0 0 11px;
    max-width: 100%;
    width: 24px;
    position: relative;
}
nav.menu2:before {
    position: absolute;
    content: '';
    width: 45px;
    height: 45px;
    background: #f3f3f3;
    float: left;
    left: 0;
    top: 0;
    border-radius: 50%;
}
nav.menu2>div {
	background-color: #f3f3f3;
	position: absolute;
	right: 0;
	top: 55px;
	border-radius: 7.5px;
	width: 200px;
	z-index: 1;
	-webkit-transition: visibility 0.2s linear, opacity 0.2s linear;
	-moz-transition: visibility 0.2s linear, opacity 0.2s linear;
	-ms-transition: visibility 0.2s linear, opacity 0.2s linear;
	-o-transition: visibility 0.2s linear, opacity 0.2s linear;
	transition: visibility 0.2s linear, opacity 0.2s linear;
}

nav.menu2:hover>div {
	visibility: visible !important;
	opacity: 1 !important;
	transition-delay: 0s;
}

nav.menu2>div>ul {
	list-style-type: none;
	margin: 0;
	padding: 10px;
	text-align: right;
}

nav.menu2>div>ul>li {
	padding: 5px;
	text-transform: uppercase;
}

nav.menu2>div>ul>li>div.divider-small {
	floata right;
}

nav.menu2>div>ul>li>a {
	text-decoration: none;
	color: #6db672;
	font-size: 18px;
}

nav.menu2>div>ul>li>a:hover {
	text-decoration: underline;
}

div.wrapper {
	width: 1000px;
    max-width: 100%;
	padding: 50px;
	text-align: center;
	font-size: 1.3em;
	margin: 3% auto 0;
}

.wrapper img {
    max-width: 100%;
}

div.wrapper-wide {
	width: 90vw;
	height: 75vh;
	top: 40%;
	transform: translate(-50%, -40%);
	overflow-y: auto;
}

div.wrapper-wide>h1 {
	font-size: 3em;
	margin: 0;
	text-shadow: 0 1px 0 rgba(255, 255, 255, .75);
}

div.wrapper-wide>h1>img {
	width: 550px;
}

div.wrapper>img, div.wrapper>a>img {
	width: 400px;
}

.scuola-top-software {
    width: 400px !important;
}

@media screen and (max-width: 767px) {
    .scuola-top-software {
        width: 250px !important;
    }
}

div.wrapper>span.landing-subtitle {
	color: #8c8c8c;
	display: block;
	padding: 10px 15px 0 25px;
	font-size: .52em;
}

div.wrapper>ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

a.button-back, a.buttonize {
	background-color: #BFBFBF69;
	padding: 0;
	width: 175px;
	height: 175px;
	background-size: 175px 175px;
	background-repeat: no-repeat;
	background-position: 50% 50%;
	display: inline-block;
	text-shadow: 1px 1px 1px rgba(255, 255, 255, .22);
	-webkit-border-radius: 1em;
	-moz-border-radius: 1em;
	border-radius: 1em;
	cursor: pointer;
	-webkit-transition: all 0.15s ease;
	-moz-transition: all 0.15s ease;
	-o-transition: all 0.15s ease;
	-ms-transition: all 0.15s ease;
	transition: all 0.15s ease;
	color: #515151;
	-webkit-box-shadow: inset 0px 0px 1.5px rgba(0, 0, 0, .1);
	-moz-box-shadow: inset 0px 0px 1.5px rgba(0, 0, 0, .1);
	box-shadow: inset 0px 0px 1.5px rgba(0, 0, 0, .1);
	/* background: #efefef;
	background: -moz-linear-gradient(top, #efefef 0%, #adadad 100%);
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #efefef), color-stop(100%, #adadad));
	background: -webkit-linear-gradient(top, #efefef 0%, #adadad 100%);
	background: -o-linear-gradient(top, #efefef 0%, #adadad 100%);
	background: -ms-linear-gradient(top, #efefef 0%, #adadad 100%);
	background: linear-gradient(top, #efefef 0%, #adadad 100%); */
}

a.button-back, a.buttonize {
	width: 100px;
	height: 100px;
	background-size: 100px 100px;
	-webkit-border-radius: 15px;
	-moz-border-radius: 15px;
	border-radius: 15px;
}

a.buttonize {
	vertical-align: middle;
	text-decoration: none;
	text-transform: uppercase;
	font-weight: 500;
}

a.button-back {
	margin-top: 30px;
}

div.wrapper>ul>li.bigger>a {
	width: 200px;
	height: 200px;
	background-size: 200px 200px;
}

div.wrapper>ul>li.bigger>a:hover {
	-webkit-box-shadow: inset 0px 0px 10px rgba(160, 111, 0, .3);
	-moz-box-shadow: inset 0px 0px 10px rgba(160, 111, 0, .3);
	box-shadow: inset 0px 0px 10px rgba(160, 111, 0, .3);
}

div.wrapper>ul>li.bigger>a:active {
	-webkit-box-shadow: inset 0px 0px 50px rgba(160, 111, 0, .5);
	-moz-box-shadow: inset 0px 0px 50px rgba(160, 111, 0, .5);
	box-shadow: inset 0px 0px 50px rgba(160, 111, 0, .5);
}

div.wrapper>ul>li>a:active, div.wrapper>ul>li>a:focus, a.button-back:active, a.button-back:focus, a.buttonize:active, a.buttonize:focus {
	outline: none;
}

a.button-back.category-back {
	position: absolute;
	right: 10px;
	margin: 0;
	top: 10px;
	width: 50px;
	height: 50px;
	background-size: 50px 50px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}

div.header, div.content, div.footer {
	position: absolute;
	width: 90vw;
	left: 5vw;
	margin: auto;
	background-color: rgba(255, 255, 255, 0.9);
	border: 1px solid rgba(76, 175, 80, .15);
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}

div.header {
	height: 7vh;
	top: 2.5vh;
	border-top-left-radius: 10px;
	border-top-right-radius: 10px;
}

div.content {
	height: 81vh;
	top: 9.5vh;
	overflow: auto;
	padding: 0;
	border-top: none;
	border-bottom: none;
	font-size: .8em;
}

div.content.header {
	height: 88vh;
	top: 2.5vh;
	border-top: 1px solid rgba(76, 175, 80, .15);
	/* overflow: unset; */
}

/* div.content.header>div.category-content {
	overflow: auto;
}

div.content.header>div.category-content::-webkit-scrollbar {
	display: none;
} */

div.footer {
	height: 7vh;
	bottom: 2.5vh;
	border-bottom-left-radius: 10px;
	border-bottom-right-radius: 10px;
	text-align: center;
	padding-top: 10px;
}

div.footer * {
	color: rgba(5, 136, 74, .7);
}

div.header>h1 {
	padding-left: 15px;
}

div.content>p {
	padding: 50px;
}

div.header>h1, div.header>a {
	font-size: 1.8em;
	text-indent: 20px;
	line-height: 1.9;
	text-shadow: 0 1px 0 rgba(255, 255, 255, .75);
	display: inline;
	-webkit-transition: color 100ms ease-out;
	-moz-transition: color 100ms ease-out;
	-ms-transition: color 100ms ease-out;
	-o-transition: color 100ms ease-out;
	transition: color 100ms ease-out;
}

div.header>h1>img {
	height: calc(100% - 25px);
	margin-left: 20px;
	margin-bottom: 10px;
}

div.header>a:hover {
	color: #016938;
}

div.header>a>img {
	position: absolute;
	right: 20px;
	top: 12px;
	height: 40px;
}

div.container>div.header {
	height: 7vh;
	border-bottom: 1px solid rgba(76, 175, 80, .15);
	padding: 10px 30px;
}

div.container>div.header>img {
	height: 60px;
	position: absolute;
	right: 30px;
	top: 15px;
}

div.container>div.footer {
	height: 5vh;
	width: calc(85vw + 6px);
	position: absolute;
	bottom: 0;
	border-top: 1px solid rgba(76, 175, 80, .15);
	padding: 10px 30px;
	text-align: center;
}

div.container>div.content {
	height: calc(72vh + 3px);
	padding: 30px;
	overflow: auto;
}

div.content::-webkit-scrollbar {
	display: none !important;
}

div.divider {
	height: 2px;
	background-color: #d2d2d27a;
	width: 100%;
	margin: 10px auto;
	border-bottom: 1px solid rgba(255, 255, 255, .9);
}

div.divider-small {
	height: 1px;
	background-color: #dedede;
	width: 50%;
	border-bottom: 1px solid rgba(255, 255, 255, .5);
}

footer {
	width: 100%;
    position: relative;
	bottom: 0;
	padding: 30px 0;
	text-align: center;
}

.p-relative {
	position: relative;
}

div.footer, footer {
	font-size: 10px;
}

div.content>div.videos-container {
	padding: 50px 100px;
}

/* start: temporary */

div.content>div.videos-container {
	position: relative;
	top: 50%;
	transform: translateY(-50%);
}

div.content>div.videos-container>p {
	text-align: center;
}

/* end: temporary */

div.content.header>div.category-caption {
	border-top-left-radius: 10px;
	border-top-right-radius: 10px;
}

div.content>div.category-caption {
	padding: 30px;
	background-repeat: no-repeat;
	background-position: 50% 0%;
	background-size: cover;
	text-shadow: 0 1px 0 rgba(255, 255, 255, .75);
	border-bottom: 1px solid rgba(76, 175, 80, .15);
}

div.content>div.category-caption, div.content>div.category-caption>p {
	margin: 0;
}

div.content>div.category-caption>h1 {
	text-align: center;
}

div.content>div.category-caption>h1>img {
	height: 100px;
	margin-bottom: 10px;
}

div.content>div.category-caption>p>a {
	font-weight: bold;
	text-decoration: underline;
}

div.category-line {
	height: 1px;
	width: 100%;
	border-bottom: 1px solid #d2e9de;
}

p.important {
	font-size: 1.1em;
	font-weight: 400;
}

div.content>div.category-content>div.category-rules {
	line-height: 1em;
}

div.content>div.category-content>div.category-rules ul {
	line-height: 1.5em;
	font-weight: 100;
}

div.content>div.category-content>div.category-classification, div.content>div.category-content>div.category-rules {
	padding: 30px 100px;
	border-bottom: 1px solid #d2e9de;
}

div.content>div.category-content>div.category-classification {
	max-height: 350px;
	overflow-y: auto;
}

div.content>div.category-content>div.category-classification::-webkit-scrollbar {
	display: none;
}

div.content>div.category-content>div.category-classification>h1 {
	margin-bottom: 15px;
}

div.content>div.category-content>div.category-classification>img {
	width: 100%;
}

div.content>div.category-content>div.category-riddles * {
	outline: none;
	text-decoration: none;
}

div.content>div.category-content>div.category-riddles {
	padding: 50px 100px;
}

div.riddle {
	width: 125px;
	height: 125px;
	display: inline-block;
	margin: 5px;
	-webkit-transition: filter 100ms ease-out;
	-moz-transition: filter 100ms ease-out;
	-ms-transition: filter 100ms ease-out;
	-o-transition: filter 100ms ease-out;
	transition: filter 100ms ease-out;
}

div.riddle:hover {
	filter: brightness(75%);
}

div.riddle>span.riddle-counter {
	height: 100%;
	width: 100%;
	vertical-align: middle;
	display: inline-block;
	margin: 0;
	padding-top: 35px;
	font-size: 2em;
	text-shadow: 0 1px 0 rgba(255, 255, 255, 1);
	background-size: 125px;
	text-align: center;
}

div.riddle-popup>span.riddle-popup-label, div.riddle-popup>span.riddle-popup-singleline {
	display: block;
	font-weight: bold;
}

div.riddle-popup>span.riddle-popup-label.riddle-popup-label-solution {
	text-decoration: underline;
	cursor: pointer;
}

div.riddle-popup>p.riddle-popup-content {
	text-align: left;
}

div.riddle-popup img {
	max-width: 100% !important;
	width: 400px !important;
	height: auto !important;
	border-radius: 10px;
}

.field-tip {
	position: relative;
	cursor: help;
}

.field-tip .tip-content {
	position: absolute;
	top: calc(100% + 15px);
	width: 100px;
	left: 35px;
	margin: 0;
	padding: 10px 0px;
	font-size: .5em;
	color: #f3f3f3;
	background: #62449d;
	opacity: 0;
	z-index: 1;
	border-radius: 5px;
	-webkit-box-shadow: 2px 2px 5px #aaa;
	-moz-box-shadow: 2px 2px 5px #aaa;
	box-shadow: 2px 2px 5px #aaa;
	-webkit-transition: opacity 250ms ease-out;
	-moz-transition: opacity 250ms ease-out;
	-ms-transition: opacity 250ms ease-out;
	-o-transition: opacity 250ms ease-out;
	transition: opacity 250ms ease-out;
}

/* .field-tip .tip-content:before {
	content: ' ';
	position: absolute;
	top: -8px;
	left: 80px;
	width: 0;
	height: 0;
	margin-top: -8px;
	border: 8px solid transparent;
	border-right-color: #333;
	transform: rotate(90deg);
} */

.field-tip:hover .tip-content {
	opacity: 1 !important;
}

div.countdown {
	text-align: center;
	font-size: 60px;
}

@media(max-width: 480px) {
	div.countdown {
		font-size: 50px;
	}
}

div.countdown>span {
	color: #9e9e9e;
	margin-bottom: 30px;
	text-shadow: 0 1px 0 rgba(255, 255, 255, .75);
}

div.countdown>span {
	font-family: "digital-7.mono";
	margin: 0;
	display: inline-block;
}

div.countdown>span:after {
	content: ':';
}

div.countdown>span:last-child:after {
	content: '';
}

div.swal2-popup {
	padding: 50px;
}

div.swal2-content * {
	color: #58585a;
	line-height: 1.4;
	font-size: 0.85em;
}

div.swal2-popup .swal2-confirm {
	background-color: #6db672 !important;
}

div.swal2-content img.popup-header-img {
	width: 200px;
	margin: 10px auto 30px;
	border-radius: 10px;
}

.swal2-popup .swal2-actions {
	margin: 2em auto 0 !important;
}

div.content table th img, div.content table td img, img.point {
	width: 25px;
	padding-bottom: 5px;
}

div.top-message {
	position: absolute;
	width: calc(100% - 30px);
	background-color: #6db672;
	z-index: 2;
	color: #fff;
	padding: 15px;
	text-align: center;
}

div.lang-switcher {
	position: absolute;
	display: flex;
	top: 5px;
	right: 5px;
	z-index: 1;
	background-color: #f3f3f3;
	color: #068251;
	font-size: 15px;
	padding: 7.5px;
	border-radius: 7.5px;
}

div.lang-switcher>a {
	display: flex;
	font-size: 17.5px;
	text-decoration: none;
	justify-content: center;
	align-items: center;
	overflow: hidden;
	-webkit-transition: filter 100ms ease-out;
	-moz-transition: filter 100ms ease-out;
	-ms-transition: filter 100ms ease-out;
	-o-transition: filter 100ms ease-out;
	transition: filter 100ms ease-out;
}

div.lang-switcher>a:hover {
	filter: brightness(75%);
}

div.lang-switcher>a>img {
	flex-shrink: 0;
	min-width: 100%;
	min-height: 100%;
	border-radius: 2.5px;
}

div.classification {
	width: 80%;
	margin: 100px auto;
}

div.classification img.point {
	padding: 0;
}

div.classification>div.podium {
	padding: 30px;
	background-color: rgb(251, 247, 238);
	/* background-color: rgba(175, 125, 0, .05); */
	border: 1px solid rgba(175, 125, 0, .15);
	border-radius: 350px 350px 0 0;
}

div.classification>div.podium>div.podium-gold {
	width: 100%;
}

div.classification>div.podium>div.podium-silver, div.classification>div.podium>div.podium-bronze {
	width: 50%;
	display: inline-block;
}

div.classification>div.podium>div.podium-bronze {
	float: right;
}

div.classification>div.extra-podium {
	width: 100%;
	background-color: rgba(175, 125, 0, .025);
	border: 1px solid rgba(175, 125, 0, .1);
	border: 1px solid rgba(175, 125, 0, .1);
	border-radius: 0 0 30px 30px;
	border-top: none;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}

div.classification .podium-user {
	width: 350px;
	height: 200px;
	text-align: center;
	margin: auto;
}

div.classification .podium-user img.podium-user-avatar, div.classification .podium-user a.podium-user-nickname, div.classification .podium-user span.podium-user-points {
	margin: 0;
}

div.classification .podium-user .avatar {
	width: 125px;
	height: 125px;
	margin: auto;
}

div.classification .podium-user a.podium-user-nickname {
	display: block;
	text-decoration: none;
}

div.classification .podium-user span.podium-user-points {}

div.classification div.podium-gold>div.podium-user .avatar {
	width: 150px;
	height: 150px;
}

div.podium-gold>div.podium-user>a.podium-user-nickname, div.podium-gold>div.podium-user>span.podium-user-points {
	font-weight: bold;
}

span.podium-user-position {
	margin-right: 15px;
	font-weight: bolder;
	color: rgba(175, 125, 0, .75);
}

div.classification>div.extra-podium table {
	width: 100%;
}

div.classification>div.extra-podium table:first-child {
	border-bottom: 1px solid rgba(175, 125, 0, .1);
	margin-bottom: 20px;
	padding-top: 30px;
}

div.classification>div.extra-podium table .podium-user td {
	padding: 10px 30px;
	text-align: left;
}

div.classification>div.extra-podium table .podium-user td:nth-child(2) {
	padding: 0;
}

div.classification>div.extra-podium table .podium-user td:first-child {
	width: 30px;
}

div.classification>div.extra-podium table .podium-user td:last-child {
	width: 75px;
}

div.classification>div.extra-podium table .podium-user td:last-child {
	text-align: right;
}

div.classification>div.extra-podium table .podium-user .avatar {
	width: 50px;
	height: 50px;
}

div.classification>div.extra-podium table .podium-user .avatar>.avatar-container {
	border-width: 2px;
}

div.classification>div.extra-podium table .podium-user {
	height: 20px;
}

div.classification>div.extra-podium table.extra-others {
	font-size: .75em;
}

div.classification>div.extra-podium table.extra-others .podium-user .avatar {
	width: 35px;
	height: 35px;
}

/*
div.classification>div.extra-podium table.extra-others .podium-user td:first-child {
	width: 0px;
	padding: 0;
}

div.classification>div.extra-podium table.extra-others .podium-user td:nth-child(2) {
	padding-left: 30px;
}

div.classification>div.extra-podium table.extra-others .podium-user img.podium-user-avatar {
	display: none;
}
*/

div.classification>div.extra-podium div.extra-rules {
	border-top: 1px solid rgba(175, 125, 0, .1);
	padding: 45px;
	font-size: 0.9em;
	font-weight: 200;
}

div.scrollable {
	max-height: 250px;
	overflow-y: scroll;
}

div.scrollable::-webkit-scrollbar {
	display: none;
}

div.avatar {
	width: 150px;
	height: 150px;
	position: relative;
}

div.avatar>div.avatar-container, div.avatar>div.avatar-eyes, div.avatar>div.avatar-beak {
	position: absolute;
}

div.avatar>div.avatar-container {
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	height: calc(90% - 7px);
	width: calc(100% - 7px);
	background-color: #FFF;
	border: 5px solid #6db672;
	border-radius: 50%;
}

div.avatar.avatar-squared>div.avatar-container {
	border-radius: 0;
}

div.avatar.avatar-rhombus>div.avatar-container {
	width: calc(80% - 7px);
	height: calc(80% - 7px);
	border-radius: 0;
	transform: translate(-50%, -50%) rotate(45deg);
}

div.avatar.avatar-inverse>div.avatar-container {
	height: calc(100% - 7px);
	width: calc(90% - 7px);
}

div.avatar.avatar-triangle-up>div.avatar-container, div.avatar.avatar-triangle-down>div.avatar-container, div.avatar.avatar-pentagon-up>div.avatar-container, div.avatar.avatar-pentagon-down>div.avatar-container {
	--color-container-background: #FFF;
	border: none;
	border-radius: 0;
	background-color: #6db672;
	-webkit-clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
	clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
	width: 110%;
	height: 110%;
}

div.avatar.avatar-pentagon-up>div.avatar-container, div.avatar.avatar-pentagon-down>div.avatar-container {
	width: 105%;
	height: 105%;
}

div.avatar.avatar-triangle-up>div.avatar-container::after, div.avatar.avatar-triangle-down>div.avatar-container::after, div.avatar.avatar-pentagon-up>div.avatar-container::after, div.avatar.avatar-pentagon-down>div.avatar-container::after {
	content: ' ';
	position: absolute;
	top: calc(50% + 3px);
	left: 50%;
	transform: translate(-50%, -50%);
	-webkit-clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
	clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
	background-color: var(--color-container-background);
	width: calc(100% - 15px);
	height: calc(100% - 15px);
}

div.avatar.avatar-triangle-down>div.avatar-container, div.avatar.avatar-triangle-down>div.avatar-container::after {
	-webkit-clip-path: polygon(50% 100%, 0% 0%, 100% 0%);
	clip-path: polygon(50% 100%, 0% 0%, 100% 0%);
}

div.avatar.avatar-pentagon-up>div.avatar-container, div.avatar.avatar-pentagon-up>div.avatar-container::after {
	-webkit-clip-path: polygon(50% 0%, 100% 38%, 82% 100%, 18% 100%, 0% 38%);
	clip-path: polygon(50% 0%, 100% 38%, 82% 100%, 18% 100%, 0% 38%);
}

div.avatar.avatar-pentagon-down>div.avatar-container, div.avatar.avatar-pentagon-down>div.avatar-container::after {
	-webkit-clip-path: polygon(50% 100%, 100% 60%, 82% 0, 20% 0, 0 60%);
	clip-path: polygon(50% 100%, 100% 60%, 82% 0, 20% 0, 0 60%);
}

div.avatar.avatar-triangle-down>div.avatar-container::after {
	top: calc(50% - 3px);
}

div.avatar.avatar-pentagon-up>div.avatar-container::after, div.avatar.avatar-pentagon-down>div.avatar-container::after {
	width: calc(100% - 10px);
	height: calc(100% - 10px);
}

div.avatar.avatar-pentagon-up>div.avatar-container::after {
	top: calc(50% + 0.5px);
}

div.avatar.avatar-pentagon-down>div.avatar-container::after {
	top: calc(50% - 0.5px);
}

div.avatar.avatar-triangle-up>div.avatar-eyes {
	top: 65%;
}

div.avatar.avatar-triangle-down>div.avatar-eyes {
	top: 35%;
}

div.avatar.avatar-triangle-up>div.avatar-eyes::before, div.avatar.avatar-triangle-down>div.avatar-eyes::before {
	left: 35%;
}

div.avatar.avatar-triangle-up>div.avatar-eyes::after, div.avatar.avatar-triangle-down>div.avatar-eyes::after {
	left: 65%;
}

div.avatar.avatar-pentagon-up>div.avatar-eyes::before, div.avatar.avatar-pentagon-down>div.avatar-eyes::before {
	left: 30%;
}

div.avatar.avatar-pentagon-up>div.avatar-eyes::after, div.avatar.avatar-pentagon-down>div.avatar-eyes::after {
	left: 70%;
}

div.avatar.avatar-triangle-up>div.avatar-beak {
	top: 75%;
}

div.avatar.avatar-triangle-down>div.avatar-beak {
	top: 50%;
}

div.avatar.avatar-pentagon-up>div.avatar-beak, div.avatar.avatar-pentagon-down>div.avatar-beak {
	top: 65%;
}

div.classification>div.extra-podium table .podium-user div.avatar.avatar-triangle-up>.avatar-container::after {
	width: calc(100% - 7.5px);
	height: calc(100% - 7.5px);
	top: calc(50% + 1px);
}

div.classification>div.extra-podium table .podium-user div.avatar.avatar-triangle-down>.avatar-container::after {
	width: calc(100% - 7.5px);
	height: calc(100% - 7.5px);
	top: calc(50% - 1.5px);
}

div.classification>div.extra-podium table .podium-user div.avatar.avatar-pentagon-up>.avatar-container::after {
	top: calc(50% - 0px);
	width: calc(100% - 5px);
	height: calc(100% - 5px);
}

div.classification>div.extra-podium table .podium-user div.avatar.avatar-pentagon-down>.avatar-container::after {
	top: calc(50% - 0px);
	width: calc(100% - 5px);
	height: calc(100% - 5px);
}

div.avatar>div.avatar-eyes {
	--color-eyes: #6db672;
	width: 100%;
	height: 12.5%;
	top: 55%;
	left: 50%;
	transform: translate(-50%, -50%);
	text-align: center;
	position: relative;
}

div.avatar>div.avatar-eyes::before, div.avatar>div.avatar-eyes::after {
	content: '';
	display: inline-block;
	border-radius: 50%;
	height: 100%;
	width: 12.5%;
	background-color: var(--color-eyes);
	position: absolute;
	transform: translateX(-50%);
}

div.avatar>div.avatar-eyes::before {
	left: 25%;
}

div.avatar>div.avatar-eyes::after {
	left: 75%;
}

div.avatar>div.avatar-beak {
	top: 70%;
	left: 50%;
	transform: translate(-50%, -50%);
	height: 20%;
	width: 15%;
	background-color: #6db672;
	-webkit-clip-path: polygon(50% 15%, 100% 50%, 50% 100%, 0% 50%);
	clip-path: polygon(50% 15%, 100% 50%, 50% 100%, 0% 50%);
}

div.avatar>img.point {
	position: absolute;
	top: -25%;
	left: 50%;
	display: block;
	z-index: 2;
	width: 150px;
	transform: translate(-50%, -50%);
}

div.avatar>img.point.silver, div.avatar>img.point.bronze {
	width: 125px;
}

div.yellow-login-tools {
	width: 100%;
	margin-top: 50px;
	text-align: center;
}

div.yellow-login-tools a.buttonize {
	width: 200px;
	height: 75px;
	background-size: 200px 75px;
	border-radius: 20px;
	line-height: 75px;
	text-shadow: 0 1px 0 #ffffff82;
}

div.yellow-login-tools a.buttonize.profile i {
	font-size: 1.5em;
	line-height: 75px;
}

div.yellow-login-tools a.buttonize.profile i, div.yellow-login-tools a.buttonize.logout {
	color: #424242;
}

div.yellow-login-tools a.buttonize.profile {
	width: 75px;
	background-size: 75px 75px;
}

div.yellow-login-tools a.buttonize.logout {
	width: 120px;
	background-size: 120px 75px;
	margin-left: 5px;
}

div.yellow-login-tools div {
	width: 180px;
	display: inline-block;
	padding: 15px;
	border: 2.5px solid;
	cursor: pointer;
	text-transform: uppercase;
	text-decoration: none;
	font-weight: 500;
	-webkit-transition: filter 0.2s linear, background-color 0.2s linear;
	-moz-transition: filter 0.2s linear, background-color 0.2s linear;
	-ms-transition: filter 0.2s linear, background-color 0.2s linear;
	-o-transition: filter 0.2s linear, background-color 0.2s linear;
	transition: filter 0.2s linear, background-color 0.2s linear;
}

div.yellow-login-tools div:hover {
	filter: brightness(.7);
	background-color: rgba(154, 154, 154, 0.15);
}

div.yellow-login-tools a:first-child div {
	border-top-left-radius: 5px;
	border-bottom-left-radius: 5px;
}

div.yellow-login-tools a:nth-child(2) div {
	border-top-right-radius: 5px;
	border-bottom-right-radius: 5px;
}

div.avatar-customize-pre, div.avatar-customize-post {
	position: absolute;
	transform: translateX(-125%);
}

div.avatar-customize-post {
	right: 0;
	transform: translateX(+125%);
}

div.avatar-customize-pre>button, div.avatar-customize-post>button {
	border: none;
	font-size: .75em;
	background-color: #0d884a1f;
	color: #045831;
	margin: 10px;
	width: 50px;
	height: 50px;
	display: block;
	border-radius: 50%;
	outline: none;
	-webkit-transition: filter 0.2s linear;
	-moz-transition: filter 0.2s linear;
	-ms-transition: filter 0.2s linear;
	-o-transition: filter 0.2s linear;
	transition: filter 0.2s linear;
}

div.avatar-customize-pre>button:hover, div.avatar-customize-pre>button:active, div.avatar-customize-pre>button:focus, div.avatar-customize-pre>button:visited, div.avatar-customize-post>button:hover, div.avatar-customize-post>button:active, div.avatar-customize-post>button:focus, div.avatar-customize-post>button:visited {
	filter: brightness(.5);
}

img.game-header {
	margin: 30px auto;
	display: block;
	max-width: 750px;
}

div.mastermind-container {
	width: 512px;
	height: 728px;
	margin: calc((100vh - 728px) / 2) auto;
	border: 3px solid;
	border-radius: 150px;
	border-color: #6db672b8;
	background-color: #ffffff61;
	position: relative;
	-webkit-user-select: none;
	-moz-user-select: none;
	-khtml-user-select: none;
	-ms-user-select: none;
}

div.mastermind-container>div:first-child {
	height: 150px;
	line-height: 150px;
	font-size: 2.5em;
	font-weight: 100;
	border-bottom: 1px solid #6db6721f;
	text-align: center;
}

div.mastermind-container>div:nth-child(2) {
	padding: 50px;
	font-weight: 100;
}

div.digits-composer {
	text-align: center;
}

input {
	height: 30px;
	width: 100%;
}

textarea {
	width: 100%;
}

input.digit {
	height: 100px;
	width: calc((100% / 4) - 15px);
	border: 3px solid #acd8c3;
	border-radius: 15px;
	background-color: #6db672;
	color: #FFF;
	outline: none;
	font-size: 75px;
	-webkit-user-select: none;
	/* webkit (safari, chrome) browsers */
	-moz-user-select: none;
	/* mozilla browsers */
	-khtml-user-select: none;
	/* webkit (konqueror) browsers */
	-ms-user-select: none;
	/* IE10+ */
	line-height: 100px;
	text-align: center;
	text-shadow: 0 1px 0 #0a5833;
}

input.digit:focus {
	caret-color: #046939;
	background-color: #046939;
}

div.spoken-results {
	padding: 0 60px;
	font-weight: 100;
	font-size: .85em;
}

div.computing-results {
	border: 1px solid #6db6721f;
	border-left: none;
	border-right: none;
	text-align: center;
	word-spacing: -0.30em;
	position: absolute;
	bottom: 150px;
	width: 100%;
}

div.computing-results>div {
	display: inline-block;
	width: calc((100% / 6) - 15px);
	text-align: center;
	border-right: 1px solid #6db6721f;
	height: 75px;
	line-height: 75px;
	font-family: 'Overpass Mono', monospace;
}

div.computing-results>div:last-child {
	border-right: none;
}

div.computing-results>div:nth-child(1), div.computing-results>div:nth-child(3), div.computing-results>div:nth-child(5) {
	font-weight: bold;
}

div.computing-results>div:nth-child(2), div.computing-results>div:nth-child(4), div.computing-results>div:nth-child(6) {
	font-weight: 100;
}

div.submit-try {
	width: 100%;
	height: 150px;
	text-align: center;
	position: absolute;
	bottom: 0;
	line-height: 150px;
	cursor: pointer;
	background-color: #6db672;
	border-radius: 146.5px;
	border-top-left-radius: 0;
	border-top-right-radius: 0;
	-webkit-transition: background-color 0.2s linear;
	-moz-transition: background-color 0.2s linear;
	-ms-transition: background-color 0.2s linear;
	-o-transition: background-color 0.2s linear;
	transition: background-color 0.2s linear;
}

div.submit-try:hover {
	background-color: #056538;
}

div.submit-try>i {
	color: #FFF;
}

.monospace {
	font-family: 'Overpass Mono', monospace;
}

a.back-button-game {
	display: block;
	margin-top: 30px;
	text-align: center;
}

a.back-button-game>div.riddle {
	width: 100px;
	height: 100px;
}

a.back-button-game>div.riddle>span {
	background-size: 100px;
}

div.wrapper-wide.user-customize div.avatar {
	margin: 30px auto;
}

div.wrapper-wide.user-customize input#nickname {
	width: 380px;
	padding: 10px;
	border-radius: 5px;
	border: 1.5px solid #6db672;
	margin: auto;
	outline: none;
	color: #006736;
	font-size: .8em;
	margin-top: 100px;
}

div.wrapper-wide.user-customize button {
	cursor: pointer;
}

div.wrapper-wide.user-customize button#submit {
	display: block;
	margin: auto;
	border-radius: 5px;
	border: 2px solid #6db672;
	background-color: #6db6720d;
	color: #6db672;
	text-transform: uppercase;
	font-weight: bold;
	padding: 10px 15px;
	margin-top: 30px;
	-webkit-transition: background-color 0.2s linear;
	-moz-transition: background-color 0.2s linear;
	-ms-transition: background-color 0.2s linear;
	-o-transition: background-color 0.2s linear;
	transition: background-color 0.2s linear;
}

div.wrapper-wide.user-customize.user-profile>table {
	margin: auto;
	font-weight: 100;
}

div.wrapper-wide.user-customize.user-profile>table tr>td:first-child {
	text-align: left;
}

div.wrapper-wide.user-customize.user-profile>table tr>td:last-child {
	text-align: right;
	width: 20%;
}

div.wrapper-wide.user-customize.user-profile>table tr>td>img.point {
	padding-bottom: 0;
}

div.wrapper-wide.user-customize.user-profile button#submit {
	display: inline-block;
	margin-top: 75px;
	margin-right: 10px;
}

div.wrapper-wide.user-customize button#submit:hover, button#submit:focus, button#submit:visited {
	background-color: #6db67230;
}

div.wrapper-wide.user-customize p#result {
	color: #5a5a5a;
	font-size: 20px;
}

div.wrapper-wide.user-customize div.avatar-customize-pre {
	transform: translate(-125%, -20%);
}

div.wrapper-wide.user-customize div.avatar-customize-post {
	transform: translate(+125%, -20%);
}

div.yellow-login-tools * {
	color: rgba(175, 125, 0, .75);
}

div.yellow-login-tools div:hover {
	background-color: rgba(144, 68, 0, 0.15);
}

div.yellow-login-tools .logout-button * {
	color: #424242;
}

div.yellow-login-tools .logout-button div:hover {
	background-color: rgba(154, 154, 154, 0.15);
}

div.classification>div.extra-podium table.extra-others {
	display: none;
}

div.classification>div.extra-podium>div.extra-podium-tables {
	position: relative;
	height: 550px;
	min-height: 550px;
}

div.classification>div.extra-podium>div.extra-podium-tables>div {
	position: absolute;
	top: 500px;
	width: 100%;
	text-align: center;
	z-index: 2;
}

div.classification>div.extra-podium>div.extra-podium-tables>div>a.show-extra-podium {
	width: 300px;
	text-decoration: none;
	text-transform: uppercase;
	font-weight: 400;
	padding: 15px;
	border-radius: 30px;
	background-color: #decfa6;
	border: 1px solid #c1994742;
	font-size: .85em;
	color: #fff;
	text-shadow: 0 1px 0 rgb(195, 153, 71);
	-webkit-transition: background-color 100ms ease-out;
	-moz-transition: background-color 100ms ease-out;
	-ms-transition: background-color 100ms ease-out;
	-o-transition: background-color 100ms ease-out;
	transition: background-color 100ms ease-out;
}


.tooltips-homepage {
	display: flex;
	flex-direction: column;
	list-style: none;
}

.tooltip {
	background: #fff;
	padding:2px;
	text-decoration: none;
	display: block;
	width: 264px;
	margin: 1em auto;
	border-radius: 40px;
	/* border: 2px solid #99c982; */
	background-image: linear-gradient(rgba(255, 255, 255, 0), rgba(255, 255, 255, 0)), linear-gradient(101deg, #88c378, #289960);
	text-align: left;
}

.tooltip-icon-wrapper {
	color: inherit;
	background: #fff;
	width: 32px;
	border-radius: inherit;
	padding: 16px 25px;
	display: inline-flex;
	align-items: center;
	position: relative;
	box-shadow: 3px 0px 0 rgba(20,20,20,.18);
	vertical-align: middle;
}

.tooltip-icon-wrapper img {
	height: 50px;
}

.tooltip-icon-wrapper span {
	/* flex: 1; */
	margin-left: 1.5em;
	letter-spacing: 2px;
}

.tooltip-icon-wrapper span:before {
	background: rgb(111, 184, 113);
	width: 1px;
	height: 100%;
	position: absolute;
	top: 0;
	left: 85px;
	content: '';
	/* box-shadow: 1px 0 5px rgba(20,20,20,.2); */
}

.tooltip-label {
	flex: 1;
	color: #fff;
	margin-left: 1em;
	text-decoration: none;
	letter-spacing: 2px;
}

#tooltip-videos, #tooltip-games {
	text-decoration: none;
}

.landing-btn {
	font-family: 'gotham-pro', sans-serif;
	width: 270px;
	height: 83px;
	position: relative;
	display: flex;
	margin: .5em auto;
	align-items: center;
	color: #fff;
	font-weight: 800;
	text-decoration: none;
	text-transform: uppercase;
	padding-left: 3.65em;
	box-sizing: border-box;
	letter-spacing: 1.8px;
	font-size: .9em;
}
.landing-btn:hover {
        opacity:0.8;
}
@media (max-width: 480px) {
	.landing-btn {
		padding-left: 5em;
	}
#solution {
    font-size: .9em !important;
}
}

.landing-btn:active,
.landing-btn:focus {
	opacity: .6;
}

.landing-btn img {
	position: absolute;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
}

.landing-btn-school {
    font-family: 'gotham-pro', sans-serif;
    width: 270px;
    height: 83px;
    position: relative;
    display: flex;
    margin: .5em auto;
    align-items: center;
    color: #fff;
    font-weight: 500;
    text-decoration: none;
    text-transform: uppercase;
    text-align: left;
    line-height: normal;
    padding-left: 4.5em;
    box-sizing: border-box;
    letter-spacing: 1px;
    font-size: .7em;
}
.landing-btn-school:hover {
    opacity: 0.8;
}

@media (max-width: 480px) {
    .landing-btn-school {
        padding-left: 6.5em;
    }
    #solution {
        font-size: .9em !important;
    }
}

@media (min-width: 481px) and (max-width: 991px) {
    .landing-btn-school {
        font-size: .6em;
    }
}

.landing-btn-school:active,
.landing-btn-school:focus {
    opacity: .6;
    outline: 0;
}
.landing-btn-school img {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
}

.landing-btn-white {
    font-family: 'gotham-pro', sans-serif;
    width: 450px;
    height: 79px;
    position: relative;
    display: flex;
    margin: .5em auto;
    align-items: center;
    color: #1d1d1b;
    font-weight: 400;
    text-decoration: none;
    text-transform: uppercase;
    padding-left: 3.65em;
    padding-right: 3.65em;
    box-sizing: border-box;
    letter-spacing: 1px;
    line-height: 20px;
    font-size: 19px;
}
.landing-btn-white:hover {
    opacity:0.8;
}
@media (max-width: 480px) {
    .landing-btn-white {
        width: 300px;
        height: 55px;
    }
    #solution {
        font-size: .9em !important;
    }
}

.landing-btn-white:active,
.landing-btn-white:focus {
    opacity: .6;
}

.landing-btn-white img {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
}

.landing-btn-white span {
    margin: auto;
}

.landing-btn-game {
    z-index: 10000;
    margin-top: 85px !important;
    width: 100px;
    height: 100px;
    background-color: #e9e9e9;
}
.landing-btn-game:hover {
    opacity:0.8;
}

.landing-btn-game:active,
.landing-btn-game:focus {
    opacity: .6;
    outline: 0;
}
.landing-btn-game img {
    cursor: pointer;
    width: 100%;
    border: 0;
    text-decoration: none;
    outline: none;
}

@media (min-width: 768px) {
    .landing-btn-game {
        margin-top: 215px !important;
    }
}

@media (max-width: 767px) {
    .button-game-sm {
        font-size: 0.8em;
    }
}

.swal2-container {
	overflow-y: auto !important;
}

.riddle-container {
	width: 680px;
	max-width: 98%;
	margin: auto;
}

.riddle-grid {
	margin: 0;
	padding: 0;
	list-style: none;

	display: flex;
	flex-wrap: wrap;
}

.riddle-grid-item {
	position: relative;
	cursor: pointer;
	/*padding: 1%;*/
	flex: 1 0 33.3333333%;
	clear: both;
	max-width: 33.3333333%;
	padding: 2.5px;
	box-sizing: border-box;
}

.riddle-grid-item:before {
	content: '';
	padding-top: 100%;
	float: left;
}

.riddle-item {
	background-image: url(/res/cornice_oiler_sfocata.png);
	background-size: 100% 100%;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	font-size: 3em;
	color: #fff;
	align-items: center;
}

.riddle-item span {
	line-height: 100%;
	color: #fff;
}

.game img {
	margin: auto;
	max-width: 100%;
}

.game .logo {
	height: 44.8px;
	max-width: 65%;
	display: block;
	margin: 1.5em auto;
	margin-bottom: 25px;
}

@media (max-width: 480px) {
	.game .logo {
		margin-bottom: 20px;
	}
}

.swal2-confirm {
	outline: 0;
	box-shadow: 0 0 0 1px #fff, 0 0 0 3px rgba(50,100,150,.4) !important;
}

* {
	-webkit-tap-highlight-color:  rgba(255, 255, 255, 0);
}

div.swal2-content * {
	font-size: 16px;
}

@media (min-width: 768px) {
	footer {
        width: 100%;
    }
	#banner-home {
		margin-top: 0px;
		max-width: 400px;
	}
}

#banner-riddle-resolution {
	margin-top: 50px;
}

.subtitle {
	font-size: 1.1rem;
}

.btn {
	padding: 1rem 1rem;
	background: #6db672;
	color: #fff;
	text-decoration: none;
	font-size: 1rem;
	letter-spacing: 1.14px;
	border-radius: 37px;
	text-transform: uppercase;
	margin-top: 2em;
	display: inline-block;
	outline: none;
}

.primary-school-categories {
	margin-top: 1.5em;
}

.primary-school-categories a {
	width: 400px;
	margin: .2rem;
	display: inline-block;
	position: relative;
}

.primary-school-categories p {
	position: absolute;
	top: 49%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	margin: 0;
	font-size: 1rem;
	text-shadow: 1px 0 20px rgba(20,20,20,.15);
	text-transform: uppercase;
	letter-spacing: 1.5px;
	color: #6f6f6f;
	line-height: 1;
	font-weight: 500;
}

#index-list, #index-list-mobile {
    padding-inline-start: 20px;
}

#index-list a, #index-list-mobile a {
    word-break: keep-all;
    color: #6db672;
}

#index-list a:hover, #index-list-mobile a:hover {
    text-decoration: none;
    color: #4B814F;
}

.container-index-list ol, .container-index-list-mobile ol {
    counter-reset: item;
}

.container-index-list ol > li, .container-index-list-mobile ol > li {
    counter-increment: item;
}

.container-index-list ol ol > li, .container-index-list-mobile ol ol > li {
    display: block;
}

.container-index-list ol ol > li:before, .container-index-list-mobile ol ol > li:before {
    content: counters(item, ".") ". ";
    margin-left: -20px;
}

/* SCHOOL PRIMARY ACTIVITY BOX */

.tales-topic-preview-title {
    padding: 1rem 3rem;
    background: #f3babe;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.tales-topic-preview-title .title {
    text-transform: uppercase;
    font-weight: 500;
    font-size: 26px;
    color: #dd3c49;
    margin: 0;
}

.tales-topic-preview-title .icon {
    width: 35px;
    vertical-align: middle;
    margin-left: 15px;
}

.tales-container-problems {
    background-color: #f3babe;
}

.tales-container-problems .container-title p {
    color: #dd3c49;
}

.bul-topic-preview-title {
    padding: 1rem 3rem;
    background: #C3E6EA;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.bul-topic-preview-title .title {
    text-transform: uppercase;
    font-weight: 500;
    font-size: 26px;
    color: #3da2ad;
    margin: 0;
}

.bul-topic-preview-title .icon {
    width: 35px;
    vertical-align: middle;
    margin-left: 15px;
}

.bul-container-problems {
    background-color: #C3E6EA !important;
}

.bul-container-problems .container-title p {
    color: #3da2ad !important;
}

.dekart-topic-preview-title {
    padding: 1rem 3rem;
    background: #FD9BA8;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.dekart-topic-preview-title .title {
    text-transform: uppercase;
    font-weight: 500;
    font-size: 26px;
    color: #b5031a;
    margin: 0;
}

.dekart-topic-preview-title .icon {
    width: 35px;
    vertical-align: middle;
    margin-left: 15px;
}

.dekart-container-problems {
    background-color: #FD9BA8 !important;
}

.dekart-container-problems .container-title p {
    color: #b5031a !important;
}

.arte-topic-preview-title {
    padding: 1rem 3rem;
    background: #FFD6DA;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.arte-topic-preview-title .title {
    text-transform: uppercase;
    font-weight: 500;
    font-size: 26px;
    color: #ff7984;
    margin: 0;
}

.arte-topic-preview-title .icon {
    width: 35px;
    vertical-align: middle;
    margin-left: 15px;
}

.arte-container-problems {
    background-color: #FFD6DA !important;
}

.arte-container-problems .container-title p {
    color: #ff7984 !important;
}

.pitagoras-topic-preview-title {
    padding: 1rem 3rem;
    background: #FFEFC2;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.pitagoras-topic-preview-title .title {
    text-transform: uppercase;
    font-weight: 500;
    font-size: 26px;
    color: #ffc933;
    margin: 0;
}

.pitagoras-topic-preview-title .icon {
    width: 35px;
    vertical-align: middle;
    margin-left: 15px;
}

.pitagoras-container-problems {
    background-color: #FFEFC2 !important;
}

.pitagoras-container-problems .container-title p {
    color: #ffc933 !important;
}

.zermelo-topic-preview-title {
    padding: 1rem 3rem;
    background: #E2F2F4;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.zermelo-topic-preview-title .title {
    text-transform: uppercase;
    font-weight: 500;
    font-size: 26px;
    color: #87cbd0;
    margin: 0;
}

.zermelo-topic-preview-title .icon {
    width: 35px;
    vertical-align: middle;
    margin-left: 15px;
}

.zermelo-container-problems {
    background-color: #E2F2F4 !important;
}

.zermelo-container-problems .container-title p {
    color: #87cbd0 !important;
}

.lullo-topic-preview-title {
    padding: 1rem 3rem;
    background: #F0DCF9;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.lullo-topic-preview-title .title {
    text-transform: uppercase;
    font-weight: 500;
    font-size: 26px;
    color: #cf8eed;
    margin: 0;
}

.lullo-topic-preview-title .icon {
    width: 35px;
    vertical-align: middle;
    margin-left: 15px;
}

.lullo-container-problems {
    background-color: #F0DCF9 !important;
}

.lullo-container-problems .container-title p {
    color: #cf8eed !important;
}

.robinson-topic-preview-title {
    padding: 1rem 3rem;
    background: #FFDEAD;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.robinson-topic-preview-title .title {
    text-transform: uppercase;
    font-weight: 500;
    font-size: 26px;
    color: #ffa51f;
    margin: 0;
}

.robinson-topic-preview-title .icon {
    width: 35px;
    vertical-align: middle;
    margin-left: 15px;
}

.robinson-container-problems {
    background-color: #FFDEAD !important;
}

.robinson-container-problems .container-title p {
    color: #ffa51f !important;
}

.lovleis-topic-preview-title {
    padding: 1rem 3rem;
    background: #ECF2F3;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.lovleis-topic-preview-title .title {
    text-transform: uppercase;
    font-weight: 500;
    font-size: 26px;
    color: #0D828E;
    margin: 0;
}

.lovleis-topic-preview-title .icon {
    width: 35px;
    vertical-align: middle;
    margin-left: 15px;
}

.lovleis-container-problems {
    background-color: #ECF2F3 !important;
}

.lovleis-container-problems .container-title p {
    color: #0D828E !important;
}

.pingo-topic-preview-title {
    padding: 1rem 3rem;
    background: #F3D0F5;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.pingo-topic-preview-title .title {
    text-transform: uppercase;
    font-weight: 500;
    font-size: 26px;
    color: #9A52C1;
    margin: 0;
}

.pingo-topic-preview-title .icon {
    width: 35px;
    vertical-align: middle;
    margin-left: 15px;
}

.pingo-container-problems {
    background-color: #F3D0F5 !important;
}

.pingo-container-problems .container-title p {
    color: #9A52C1 !important;
}

.musa-topic-preview-title {
    padding: 1rem 3rem;
    background: #FFBE5C;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.musa-topic-preview-title .title {
    text-transform: uppercase;
    font-weight: 500;
    font-size: 26px;
    color: #E08700;
    margin: 0;
}

.musa-topic-preview-title .icon {
    width: 35px;
    vertical-align: middle;
    margin-left: 15px;
}

.musa-container-problems {
    background-color: #FFBE5C !important;
}

.musa-container-problems .container-title p {
    color: #E08700 !important;
}

.kolman-topic-preview-title {
    padding: 1rem 3rem;
    background: #C783EC;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.kolman-topic-preview-title .title {
    text-transform: uppercase;
    font-weight: 500;
    font-size: 26px;
    color: #7118A0;
    margin: 0;
}

.kolman-topic-preview-title .icon {
    width: 35px;
    vertical-align: middle;
    margin-left: 15px;
}

.kolman-container-problems {
    background-color: #C783EC !important;
}

.kolman-container-problems .container-title p {
    color: #7118A0 !important;
}

.single-topic-previews {
	list-style-type: none;
    padding-left: 13px;
	margin: 0 !important;
	display: block;
}

@media (max-width: 991px) {
    .single-topic-previews {
        padding-left: 0;
        margin-bottom: 50px !important;
    }
}

.single-topic-preview {
	padding: 1rem 1.5rem;
	background: #fff;
	margin: .5rem 0;
    border-radius: 14px;
    box-shadow: 2px 2px 5px 2px #d9d9d9;
    -webkit-box-shadow: 2px 2px 5px 2px #d9d9d9;
    -moz-box-shadow: 2px 2px 5px 2px #d9d9d9;
}

.single-topic-preview .title {
    font-family: 'Patrick Hand SC';
	font-size: 33px;
	font-weight: 600;
	margin: 0;
	line-height: 1;
	letter-spacing: 1.14px;
	color: #85c082;
	text-decoration: none;
}

.single-topic-preview .title-tales {
    color: #dd3c49;
}

.single-topic-preview .title-bul {
    color: #3da2ad;
}

.single-topic-preview .title-dekart {
    color: #b5031a;
}

.single-topic-preview .title-pitagoras {
    color: #ffc933;
}

.single-topic-preview .title-arte {
    color: #ff7984;
}

.single-topic-preview .title-lullo {
    color: #cf8eed;
}

.single-topic-preview .title-zermelo {
    color: #87cbd0;
}

.single-topic-preview .title-robinson {
    color: #ffa51f;
}

.single-topic-preview .title-lovleis {
    color: #0D828E;
}

.single-topic-preview .title-pingo {
    color: #9A52C1;
}

.single-topic-preview .title-musa {
    color: #E08700;
}

.single-topic-preview .title-kolman {
    color: #7118A0;
}

.single-topic-preview .title:hover {
    opacity: 0.7;
}

.single-topic-preview .excerpt {
	margin: 0;
	font-size: 15px;
	color: #292929;
	font-style: italic;
}


.game-button-primary {
    margin-top: 0;
    padding-left: 4em;
    font-size: 1.1em;
}

.game-button-primary:hover {
    text-decoration: none;
    color: #FFFFFF;
}

@media(max-width: 767px) {
    .game-button-primary {
        margin-top: 0;
        padding-left: 4.5em;
        font-size: 1.4em;
    }
}

.btn-smullyan-primary {
    margin-top: 0;
    padding-left: 4em;
    font-size: 1.1em;
}

.btn-smullyan-primary:hover {
    text-decoration: none;
    color: #FFFFFF;
}

@media(max-width: 767px) {
    .btn-smullyan-primary {
        padding-left: 4.2em;
        font-size: 1.4em;
    }
}

.zermelo-tavole-preview {
	padding: 1rem 3rem;
	background: #a2cce3;
	margin: .5rem 0;
}

.arte-tavole-preview {
    padding: 1rem 3rem;
    background: #ff7984;
    margin: .5rem 0;
}

.zermelo-tavole-preview .title {
	font-size: 25px;
	font-weight: bold;
	margin: 0;
	line-height: 1;
	letter-spacing: 1.14px;
	color: #fff;
	text-decoration: underline;
}

.zermelo-tavole-preview .title:hover {
    opacity: 0.7;
}

.arte-tavole-preview .title {
    font-size: 25px;
    font-weight: bold;
    margin: 0;
    line-height: 1;
    letter-spacing: 1.14px;
    color: #fff;
    text-decoration: underline;
}
.arte-tavole-preview .title:hover {
    opacity: 0.7;
}

.zermelo-tavole-preview .excerpt {
	margin: 0;
	font-size: 15px;
	color: #292929;
	font-style: italic;
}

.arte-tavole-preview .excerpt {
    margin: 0;
    font-size: 15px;
    color: #292929;
    font-style: italic;
}

.video-wrapper-cards {
    margin-top: 5px;
}

@media (max-width: 575px) {
    .video-wrapper-cards {
        margin-top: 143px;
    }
}

.tavole-how-to {
    height: 70px;
    background-color: white;
    position: absolute;
    width: 100%;
    left: 0;
    text-align: center;
    text-transform: uppercase;
    font-family: "Patrick Hand SC";
    font-size: 2.5em;
    line-height: 1.3;
    margin-top: 20px;
}

@media (max-width: 575px) {
    .tavole-how-to {
        height: inherit;
    }
}

.tavole-how-to-footer-title {
    font-family: "Patrick Hand SC";
    font-size: 1.6em;
    text-transform: uppercase;
    text-align: left;
    color: black;
    padding-left: 30px;
}

.tavole-how-to-tales {
    color: #ad1f2a;
}

.tavole-how-to-arte {
    color: #ff5c69;
}

.tavole-how-to-zermelo {
    color: #3f9ba2;
}

.tavole-how-to-lullo {
    color: #BC5FE7;
}

.tavole-how-to-cards {
    color: #448849;
}

.tavole-how-to-list-element {
    font-size: 16px;
    font-weight: 400;
    color: #000000;
    margin: 0 30px 20px 0;
    padding: 0;
    border-radius: 15px;
    background: #fff;
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
    text-align: left;;
}

.tavole-how-to-list-element-tales {
    background-color: #f6e1e1;
    border: 2px solid #ad1f2a;
}

.tavole-how-to-list-element-arte {
    background-color: #fde5e7;
    border: 2px solid #ff5c69;
}

.tavole-how-to-list-element-zermelo {
    background-color: #d9e9ec;
    border: 2px solid #3f9ba2;
}

.tavole-how-to-list-element-lullo {
    background-color: #F0DCF9;
    border: 2px solid #BC5FE7;
}

.tavole-how-to-list-element-cards {
    background-color: #d1efd3;
    border: 2px solid #448849;
}

.tavole-how-to-list-element .text {
    float: left;
    padding: 16px 10px;
    max-width: 87%;
    font-weight: 200;
}

.tavole-how-to-list-element .icon {
    float: right;
    margin-right: 10px;
    width: 30px;
    margin-left: 12px;
}

.tavole-how-to-list-element .vertical-bar {
    float: right;
    margin-right: 10px;
    border-right: 2px solid #BFBFBF;
    margin-top: 5px;
    height: 84%;
}

@media (max-width: 575px) {
    .tavole-how-to-list-element .text {
        float: left;
        padding: 16px 10px;
        max-width: 70%;
        font-weight: 200;
    }
}

.tavole-how-to-list-element .icon-tales-1 {
    margin-top: 8px;
}

.tavole-how-to-list-element .icon-tales-2 {
    margin-top: 14px;
}

.tavole-how-to-list-element .icon-tales-3 {
    margin-top: 25px;
}

.tavole-how-to-list-element .icon-tales-4 {
    margin-top: 14px;
}

@media (max-width: 575px) {
    .tavole-how-to-list-element .icon-tales-1 {
        margin-top: 35px;
    }

    .tavole-how-to-list-element .icon-tales-2 {
        margin-top: 40px;
    }

    .tavole-how-to-list-element .icon-tales-3 {
        margin-top: 60px;
    }

    .tavole-how-to-list-element .icon-tales-4 {
        margin-top: 50px;
    }
}

@media (min-width: 576px) and (max-width: 991px) {
    .tavole-how-to-list-element .icon-tales-1 {
        margin-top: 8px;
    }

    .tavole-how-to-list-element .icon-tales-2 {
        margin-top: 14px;
    }

    .tavole-how-to-list-element .icon-tales-3 {
        margin-top: 27px;
    }

    .tavole-how-to-list-element .icon-tales-4 {
        margin-top: 27px;
    }
}

.tavole-how-to-list-element .icon-arte-1 {
    margin-top: 8px;
}

.tavole-how-to-list-element .icon-arte-2 {
    margin-top: 40px;
}

.tavole-how-to-list-element .icon-arte-3 {
    margin-top: 14px;
}

.tavole-how-to-list-element .icon-arte-4 {
    margin-top: 8px;
}

@media (max-width: 575px) {
    .tavole-how-to-list-element .icon-arte-1 {
        margin-top: 45px;
    }

    .tavole-how-to-list-element .icon-arte-2 {
        margin-top: 120px;
    }

    .tavole-how-to-list-element .icon-arte-3 {
        margin-top: 30px;
    }

    .tavole-how-to-list-element .icon-arte-4 {
        margin-top: 50px;
    }
}

@media (min-width: 576px) and (max-width: 991px) {
    .tavole-how-to-list-element .icon-arte-1 {
        margin-top: 20px;
    }

    .tavole-how-to-list-element .icon-arte-2 {
        margin-top: 50px;
    }

    .tavole-how-to-list-element .icon-arte-3 {
        margin-top: 16px;
    }

    .tavole-how-to-list-element .icon-arte-4 {
        margin-top: 22px;
    }
}

.tavole-how-to-list-element .icon-zermelo-1 {
    margin-top: 14px;
}

.tavole-how-to-list-element .icon-zermelo-2 {
    margin-top: 8px;
}

.tavole-how-to-list-element .icon-zermelo-3 {
    margin-top: 14px;
}

.tavole-how-to-list-element .icon-zermelo-4 {
    margin-top: 8px;
}

@media (max-width: 575px) {
    .tavole-how-to-list-element .icon-zermelo-1 {
        margin-top: 65px;
    }

    .tavole-how-to-list-element .icon-zermelo-2 {
        margin-top: 45px;
    }

    .tavole-how-to-list-element .icon-zermelo-3 {
        margin-top: 40px;
    }

    .tavole-how-to-list-element .icon-zermelo-4 {
        margin-top: 45px;
    }
}

@media (min-width: 576px) and (max-width: 991px) {
    .tavole-how-to-list-element .icon-zermelo-1 {
        margin-top: 27px;
    }

    .tavole-how-to-list-element .icon-zermelo-2 {
        margin-top: 22px;
    }

    .tavole-how-to-list-element .icon-zermelo-3 {
        margin-top: 15px;
    }

    .tavole-how-to-list-element .icon-zermelo-4 {
        margin-top: 22px;
    }
}

.tavole-how-to-list-element .icon-cards-1 {
    margin-top: 8px;
}

.tavole-how-to-list-element .icon-cards-2 {
    margin-top: 14px;
}

.tavole-how-to-list-element .icon-cards-3 {
    margin-top: 27px;
}

.tavole-how-to-list-element .icon-cards-4 {
    margin-top: 14px;
}

@media (max-width: 575px) {
    .tavole-how-to-list-element .icon-cards-1 {
        margin-top: 22px;
    }

    .tavole-how-to-list-element .icon-cards-2 {
        margin-top: 50px;
    }

    .tavole-how-to-list-element .icon-cards-3 {
        margin-top: 65px;
    }

    .tavole-how-to-list-element .icon-cards-4 {
        margin-top: 40px;
    }
}

@media (min-width: 576px) and (max-width: 991px) {
    .tavole-how-to-list-element .icon-cards-1 {
        margin-top: 10px;
    }

    .tavole-how-to-list-element .icon-cards-2 {
        margin-top: 27px;
    }

    .tavole-how-to-list-element .icon-cards-3 {
        margin-top: 27px;
    }

    .tavole-how-to-list-element .icon-cards-4 {
        margin-top: 16px;
    }
}

.tavole-bottom a:hover {
    color: #000000;
    text-decoration: none;
}

.tales-how-to-number-container {
    text-align: right;
}

.tales-how-to-number {
    max-width: 45% !important;
}

.tales-how-to-number-two-lines {
    margin-top: 12px;
}

.tales-how-to-number-three-lines {
    margin-top: 25px;
}

@media (max-width: 575px) {
    .tales-how-to-number-container {
        text-align: center;
        margin-bottom: 10px;
    }

    .tales-how-to-number-container-first {
        margin-top: 50px;
    }

    .tales-how-to-number {
        max-width: 20% !important;
    }

    .tales-how-to-number-two-lines {
        margin-top: 0;
    }

    .tales-how-to-number-three-lines {
        margin-top: 0;
    }
}

@media (min-width: 576px) and (max-width: 991px) {
    .tales-how-to-number {
        max-width: 60% !important;
    }

    .tales-how-to-number-two-lines-tablet {
        margin-top: 12px;
    }

    .tales-how-to-number-three-lines {
        margin-top: 38px;
    }
}

/* CARDS */

.cards-rules {
    height: 70px;
    background-color: white;
    position: absolute;
    width: 100%;
    left: 0;
    text-align: center;
    text-transform: uppercase;
    font-family: "Patrick Hand SC";
    font-size: 2.5em;
    line-height: 1.3;
    margin-top: 20px;
}

@media (max-width: 575px) {
    .cards-rules {
        height: inherit;
    }
}

.card-rules-cards {
    color: #448849;
}

.cards-rules-box-rules {
    margin-top: 90px;
}

.cards-rules-list-element {
    font-size: 16px;
    font-weight: 400;
    color: #000000;
    margin: 0 30px 20px 0;
    padding: 0;
    border-radius: 15px;
    background: #fff;
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
    text-align: left;;
}

.cards-rules-list-element-cards {
    background-color: #d1efd3;
    border: 2px solid #448849;
}

.cards-rules-list-element .text {
    float: left;
    padding: 16px 10px;
    max-width: 82%;
    font-weight: 200;
}

.cards-rules-list-element .icon {
    float: right;
    margin-right: 10px;
    width: 30px;
    margin-left: 12px;
}

.cards-rules-list-element .vertical-bar {
    float: right;
    margin-right: 10px;
    border-right: 2px solid #BFBFBF;
    margin-top: 5px;
    height: 84%;
}

@media (max-width: 575px) {
    .cards-rules-list-element .text {
        float: left;
        padding: 16px 10px;
        max-width: 70%;
        font-weight: 200;
    }
}

.cards-rules-list-element .icon-cards-1 {
    margin-top: 8px;
}

.cards-rules-list-element .icon-cards-2 {
    margin-top: 27px;
}

.cards-rules-list-element .icon-cards-3 {
    margin-top: 27px;
}

.cards-rules-list-element .icon-cards-4 {
    margin-top: 27px;
}

@media (max-width: 575px) {
    .cards-rules-box-rules {
        margin-top: 10px;
    }

    .cards-rules-list-element .icon-cards-1 {
        margin-top: 22px;
    }

    .cards-rules-list-element .icon-cards-2 {
        margin-top: 50px;
    }

    .cards-rules-list-element .icon-cards-3 {
        margin-top: 65px;
    }

    .cards-rules-list-element .icon-cards-4 {
        margin-top: 40px;
    }
}

@media (min-width: 576px) and (max-width: 991px) {
    .cards-rules-box-rules {
        margin-top: 30px;
    }

    .cards-rules-list-element .icon-cards-1 {
        margin-top: 10px;
    }

    .cards-rules-list-element .icon-cards-2 {
        margin-top: 27px;
    }

    .cards-rules-list-element .icon-cards-3 {
        margin-top: 27px;
    }

    .cards-rules-list-element .icon-cards-4 {
        margin-top: 16px;
    }
}

.cards-rules-box-first {
    margin: 50px 30px 0 60px;
}

.cards-rules-box {
    margin: 0 30px 0 60px;
}

.cards-rules-number-container {
    text-align: right;
}

.cards-rules-number {
    max-width: 75% !important;
}

.cards-rules-number-two-lines {
    margin-top: 12px;
}

.cards-rules-number-three-lines {
    margin-top: 25px;
}

@media (max-width: 575px) {
    .cards-rules-box-first {
        margin: 50px 30px 0 30px;
    }

    .cards-rules-box {
        margin: 0 30px 0 30px;
    }

    .cards-rules-number-container {
        text-align: center;
        margin-bottom: 10px;
    }

    .cards-rules-number-container-first {
        margin-top: 50px;
    }

    .cards-rules-number {
        max-width: 20% !important;
    }

    .cards-rules-number-two-lines {
        margin-top: 0;
    }

    .cards-rules-number-three-lines {
        margin-top: 0;
    }
}

@media (min-width: 576px) and (max-width: 991px) {
    .cards-rules-box-first {
        margin: 50px 30px 0 30px;
    }

    .cards-rules-box {
        margin: 0 30px 0 30px;
    }

    .cards-rules-number {
        max-width: 60% !important;
    }

    .cards-rules-number-two-lines-tablet {
        margin-top: 12px;
    }

    .cards-rules-number-three-lines {
        margin-top: 38px;
    }
}

.zermelo-image {
	width: 250px !important;
    margin-top: 20px;
}

@media(max-width: 767px) {
	.zermelo-image {
		width: 200px !important;
	}
}

.arte-row-container {
    margin-top: 50px;
    margin-left: 35px !important;
}

.arte-item-container-first {
    padding-right: 0 !important;
}

.arte-item-container {
    padding-right: 0 !important;
}

@media(max-width: 767px) {
    .arte-row-container {
        margin-top: 20px;
    }

    .arte-item-container-first {
        padding-left: 19px !important;
        padding-bottom: 20px;
    }

    .arte-item-container {
        padding-left: 19px !important;
        padding-bottom: 20px;
    }
}

.arte-button-container {
    position: relative;
    text-align: center;
    padding: 0;
    overflow: hidden;
    aspect-ratio: 0.71;
    width: 110%;
}

.arte-button-container A:before{
    content: '';
    display: inline-block;
    height: 48%;
}

.arte-button-container a {
    transition: all 1s ease-out;
    background: rgba(88, 88, 88, 0.5);
    vertical-align: middle;
    padding: 5%;
    color: #FFFFFF;
    position:absolute;
    font-size: 1.125em;
    font-weight: 700;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: inline-block;
    text-decoration: none;
    text-transform: uppercase;
}

.arte-button-container A:hover {
    background: none;
    border: none;
    opacity: 0;
}

.arte-button-container img{
    width: 100%;
    height: auto;
    display: block
}

.lullo-button-container {
    position: relative;
    text-align: center;
    padding: 0;
    overflow: hidden;
    width: 110%;
}

.lullo-button-container A:before{
    content: '';
    display: inline-block;
    height: 51%;
}

.lullo-button-container a {
    transition: all 1s ease-out;
    background: rgba(88, 88, 88, 0.5);
    vertical-align: middle;
    padding: 5%;
    color: #FFFFFF;
    position:absolute;
    font-size: 1.125em;
    font-weight: 700;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: inline-block;
    text-decoration: none;
    text-transform: uppercase;
}

.lullo-button-container A:hover {
    background: none;
    border: none;
    opacity: 0;
}

.lullo-button-container img{
    width: 100%;
    height: auto;
    display: block
}

.cards-button-container {
    position: relative;
    text-align: center;
    padding: 0;
    overflow: hidden;
    border-radius: 10px;
}

.cards-button-container A:before {
    content: '';
    display: inline-block;
    height: 32%;
}

@media (max-width: 575px) {
    .cards-button-container A:before {
        height: 45%;
    }
}

.cards-button-container a {
    transition: all 1s ease-out;
    background: rgba(88, 88, 88, 0.8);
    vertical-align: middle;
    padding: 5%;
    color: #FFFFFF;
    position:absolute;
    font-size: 1.125em;
    font-weight: 700;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    display: inline-block;
    text-decoration: none;
    text-transform: uppercase;
}

.cards-button-container A:hover {
    background: none;
    border: none;
    opacity: 0;
}
.cards-button-container img{
    width: 100%;
    height: auto;
    display: block
}

.cards-pdf-image {
    margin-top: 30px !important;
    margin-left: 0 !important;
}

.cards-images {
    margin-left: 60px;
}

@media (max-width: 991px) {
    .cards-images {
        margin-left: 0 !important;
    }
}

.cards-whist-table td {
    padding: 15px;
    vertical-align: auto;
}

.cards-whist-table td p {
    margin-bottom: 0;
}

/* Responsive table for mobile */
@media (max-width: 767px) {
    .cards-whist-table {
        width: 100%;
        font-size: 12px;
        overflow-x: auto;
        display: block;
        white-space: nowrap;
    }
    
    .cards-whist-table td {
        padding: 8px 4px;
        font-size: 11px;
    }
    
    .cards-whist-table td p {
        font-size: 11px;
        margin-bottom: 0;
    }
}

.cards-footer-par a {
    color: #095cec;
}

.software-row-container {
    flex-wrap: nowrap !important;
    margin-top: 50px;
    margin-left: 0 !important;
}

@media(max-width: 767px) {
    .software-row-container {
        flex-wrap: wrap !important;
        margin-top: 2px;
        margin-left: -5% !important;
    }

    .software-item-container-first {
        padding-left: 19px !important;
        padding-bottom: 20px;
    }

    .software-item-container {
        padding-left: 19px !important;
        padding-bottom: 20px;
    }
}

.contact-module-button {
    padding: 0.7rem 1rem 0.5rem 1rem;
}

@media (max-width: 576px) {
    .contact-module-button {
        white-space: nowrap;
        display: block;
        margin-left: auto;
        margin-right: auto;
        text-align: center;
        max-width: 100%;
        font-size: 1rem;
    }
}

.software-button-container {
    position: relative;
    text-align: center;
    padding: 0;
    overflow: hidden;
}

.software-button-container a:before {
    content: '';
    display: inline-block;
    height: 48%;
}

.software-button-container a {
    transition: all 0.5s ease-out;
    vertical-align: middle;
    padding: 5%;
    color: #FFFFFF;
    position:absolute;
    font-size: 1.125em;
    font-weight: 700;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 90%;
    display: inline-block;
    text-decoration: none;
    text-transform: uppercase;
}

.software-button-container a:hover {
    background: rgba(255, 255, 255, 0.3);
    border: none;
}
.software-button-container img{
    width: 100%;
    height: auto;
    display: block;
}

.software-box-shadow {
    border-radius: 25px;
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}

.school-topic-wrapper-mobile {
    display: none;
}

.school-topic-wrapper .title {
    font-size: 50px;
    font-weight: 400;
    text-transform: uppercase;
    text-decoration: none;
    margin: 0 2em 0.4em;
    padding: 1.2rem 0.5em 0.5rem;
    line-height: 1;
    letter-spacing: 1.14px;
    color: #6db672;
}

.school-topic-wrapper span {
    margin: 0;
}


@media(max-width: 767px) {
    .school-topic-wrapper {
        display: none;
    }

    .school-topic-wrapper .title {
        margin: 0;
        font-size: 26px;
    }

    .school-topic-wrapper-mobile {
        display: inherit;
    }
}

.school-topic-wrapper h3 {
    font-size: 1.3rem;
}

.school-topic-wrapper .container-fixed-height {
    min-height: 800px;
    height: 100%;
    font-size: 16px;
    color: #999999;
    text-align: left;
    margin-right: 30px;
    margin-left: 30px;
    padding: 40px;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}

@media(max-width: 767px) {
    .school-topic-wrapper .container-fixed-height {
        margin-right: 0;
        margin-left: 0;
        padding: 20px;
    }
}

.school-topic-wrapper .container-fixed-height p {
    color: #202122;
}
.school-topic-wrapper .container-fixed-height ul, .school-topic-wrapper .container-fixed-height ol {
    color: #202122;
    font-weight: 300;
}
.school-topic-wrapper .container-fixed-height a {
    color: #095cec;
}

.school-topic-wrapper .container-fixed-height a i {
    color: #095cec;
}

.school-topic-wrapper .container-fixed-height .school-topic-content {
    height: 720px;
    overflow: auto;
    background: #fff;
}

.school-topic-wrapper .col-sm-12 {
    padding-left: 0;
}

.school-topic-wrapper .container-free-height {
    font-size: 16px;
    color: #202122;
    margin: 0 30px 40px 0;
    padding: 20px;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}

.school-topic-wrapper .container-free-height ul {
    font-weight: 300;
}

.school-topic-wrapper .container-free-height:last-child {
    margin-bottom: 0;
}

.school-topic-wrapper .container-free-height p:last-child,
.school-topic-wrapper .container-free-height ol:last-child,
.school-topic-wrapper .container-free-height ul:last-child,
.school-topic-wrapper .container-free-height dl:last-child,
.school-topic-wrapper .container-free-height li:last-child {
    margin-bottom: 0;
}

@media(max-width: 767px) {
    .school-topic-wrapper .container-free-height:first-child {
        margin: 20px 0 20px 0;
    }

    .school-topic-wrapper .container-free-height {
        margin-right: 0;
    }
}

.school-topic-wrapper .container-free-height .container-title,
.school-topic-wrapper .container-warmapp-free-height .container-title {
    font-size: 18px;
    font-weight: 600;
    text-transform: uppercase;
    color: #6db672;
    margin-bottom: 20px;
}

.school-topic-wrapper .container-free-height .container-title p,
.school-topic-wrapper .container-warmapp-free-height .container-title p {
    float: left;
    font-size: 18px;
    font-weight: 600;
    text-transform: uppercase;
    color: #6db672;
    margin: 2px 5px 0 0;
}

.school-topic-wrapper .container-free-height p {
    color: #202122;
}
.school-topic-wrapper .container-free-height a {
    color: #095cec;
}

.school-topic-wrapper .container-warmapp-free-height {
    font-size: 16px;
    color: #999999;
    padding: 20px;
    margin: 0 30px 40px 0;
    border-radius: 12px;
    background: #d6ead8;
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}

.container-warmapp-free-height a, .container-free-height a {
    word-break: break-all;
}

.school-topic-wrapper .container-warmapp-free-height p:last-child,
.school-topic-wrapper .container-warmapp-free-height ol:last-child,
.school-topic-wrapper .container-warmapp-free-height ul:last-child,
.school-topic-wrapper .container-warmapp-free-height dl:last-child,
.school-topic-wrapper .container-warmapp-free-height li:last-child {
    margin-bottom: 0;
}

@media(max-width: 767px) {
    .school-topic-wrapper .container-warmapp-free-height {
        margin: 0 0 20px 0;
    }
}

.school-topic-wrapper .container-warmapp-free-height .container-title {
    font-size: 18px;
    font-weight: 600;
    text-transform: uppercase;
    color: #6db672;
}

.school-topic-wrapper .container-warmapp-free-height p {
    color: #202122;
}
.school-topic-wrapper .container-warmapp-free-height a {
    color: #095cec;
}

.school-topic-wrapper .icon {
    width: 17px;
    vertical-align: middle;
}

.school-topic-detail-mobile {
    display: none;
}

.school-topic-detail a, .school-character-wrapper a {
    color: #007bff;
}

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

    .school-topic-detail-mobile {
        display: inherit;
    }
}

.section-more {
    font-size: 17px;
    font-weight: 400;
    padding-left: 40px;
    padding-top: 20px;
}

@media(max-width: 991px) {
    .section-more {
        padding-left: 0;
        padding-top: 0;
        padding-bottom: 20px;
    }
}

/* SCHOOL PRIMARY BOX */

.school-primary-wrapper {
    padding-left: 0 !important;
}

.school-primary-wrapper .container-free-height {
    font-size: 16px;
    font-weight: 400;
    color: #000000;
    margin: 0 13px 40px 0;
    padding: 20px 20px 40px 20px;
    border-radius: 25px;
    border: 1px solid #6db672;
    background: #fff;
}

.school-primary-wrapper .container-free-height p {
    color: #000000;
    margin-bottom: 0;
}

.school-primary-wrapper .container-free-height ul {
    font-weight: 300;
}

.school-primary-wrapper .container-free-height .container-title {
    font-size: 18px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    text-transform: uppercase;
    color: #6db672;
    margin-bottom: 20px;
}

.school-primary-wrapper .container-free-height .container-title p {
    float: left;
    font-size: 26px;
    font-weight: 500;
    text-transform: uppercase;
    color: #6db672;
    margin: 5px 5px 0 0;
}

.school-primary-wrapper .creators {
    color: #6db672 !important;
}

.school-primary-wrapper .icon {
    width: 35px;
    vertical-align: middle;
    margin-left: 5px;
}

.school-primary-wrapper ul {
    list-style-type: disc !important;
}

@media(max-width: 991px) {
    .school-primary-wrapper {
        padding-left: 15px !important;
    }

    .school-primary-wrapper .container-free-height {
        margin-right: 0;
    }

    .school-primary-wrapper .container-free-height .container-title p {
        font-size: 22px;
    }
}

/* SCHOOL PRIMARY CHARACTER BOX */

.school-character-wrapper .container-free-height {
    font-size: 16px;
    font-weight: 400;
    color: #000000;
    margin: 0 30px 40px 0;
    padding: 20px 20px 40px 20px;
    border-radius: 25px;
    background: #fff;
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}

.school-character-wrapper .container-free-height ul {
    margin-bottom: 0;
}

.school-character-wrapper .container-free-height .container-title {
    font-size: 18px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    text-transform: uppercase;
    color: #6db672;
    margin-bottom: 20px;
}

.school-character-wrapper .container-free-height .container-title p {
    float: left;
    font-size: 28px;
    font-weight: 500;
    text-transform: uppercase;
    color: #6db672;
    margin: 5px 5px 0 0;
}

.school-character-wrapper .creators {
    color: #6db672;
    font-style: italic;
}

.school-character-wrapper .icon {
    width: 35px;
    vertical-align: middle;
    margin-left: 5px;
}

.school-character-wrapper .icon-character {
    width: 25px;
    vertical-align: middle;
    margin-left: 5px;
}

@media (max-width: 767px) {
    .school-character-wrapper .container-free-height {
        margin: 0 0 40px 0;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .school-character-wrapper .container-free-height {
        margin: 0 30px 40px 30px;
    }
}

.school-character-photo {
    width: 350px;
    float: left;
    margin: 0 25px 20px 0;
}

@media (max-width: 767px) {
    .school-character-photo {
        width: 100%;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .school-character-photo {
        width: 250px;
    }
}

.school-character-photo-musa {
    height: 400px;
    width: auto;
}

.school-character-timeline {
    width: 60%;
    margin-top: 30px;
    margin-bottom: 40px;
}

.school-character-map {
    width: 80% !important;
    margin-top: 20px;
}

@media (max-width: 991px) {
    .school-character-timeline {
        width: 100%;
        margin-top: 20px;
        margin-bottom: 20px;
    }

    .school-character-map {
        width: 100% !important;
    }

    .school-character-wrapper .container-free-height .container-title p {
        font-size: 22px;
    }
}

.school-character-wrapper .container-free-height .container-cards-title {
    font-size: 18px;
    font-weight: 600;
    display: flex;
    text-transform: uppercase;
    color: #6db672;
    margin-bottom: 20px;
    margin-top: -5px;
}

.school-character-wrapper .container-free-height .container-cards-title p {
    float: left;
    font-size: 20px;
    font-weight: 400;
    text-transform: uppercase;
    margin: 5px 5px 0 0;
}

.school-character-wrapper .icon-cards-character {
    width: 15px;
    vertical-align: middle;
    margin-left: 5px;
}


.single-topic-wrapper {
	padding: 1rem 3rem;
	background: #3c3c3c;
	margin: 2rem 0;
}

.single-topic-wrapper .title {
	font-size: 45px;
	text-transform: uppercase;
	text-decoration: none;
	margin: 0 2em .5em;
	padding: 1rem 0.5em 0.5rem;
	line-height: 1;
	border-bottom: 1px solid rgba(20,20,20,.1);
	letter-spacing: 1.14px;
	color: #85c082;
}

.single-topic-wrapper .topic-content {
	margin: 0;
	font-size: 20px;
	color: #999999;
	line-height: 200%;
	text-align: left;
}

.single-topic-wrapper .topic-content p {
	color: #999999;
}
.single-topic-wrapper .topic-content a {
    color: white;
}
ul.breadcrumbs li{
	display: flex;}
ul.breadcrumbs {
	display: flex;
	font-size: 14px;
	color: #565656;
	margin: 2em auto 0 !important;
	/*width: 500px;*/
	justify-content: center;
    flex-direction: row;
}

ul.breadcrumbs a, span {
	color: inherit;
	margin: 0 .4em;
}

li.single-topic-attachment {
	display: flex;
	font-size: .9rem;
	align-items: center;
	margin: 1em 0;
}

li.single-topic-attachment img {
	height: 40px;
}

li.single-topic-attachment a {
	text-decoration: none;
	margin-left: .5em;
	color: #999999;
	font-style: italic;
	line-height: 40px;
	flex: 1;
	text-align: left;
}

li.single-topic-attachment a:hover {
    opacity: 0.7;
}

li.single-topic-attachment-sm {
	display: flex;
	font-size: .9rem;
	align-items: center;
	margin: 0;
}

li.single-topic-attachment-sm img {
	height: 30px;
}

li.single-topic-attachment-sm a {
	text-decoration: none;
	margin-left: .5em;
	color: #999999;
	font-style: italic;
	line-height: 40px;
	flex: 1;
	text-align: left;
}

.subtitle-grey {
	color: #202122;
	font-size: 1rem;
	margin-top: 20px;
    padding: 0 30px;
}

@media(max-width: 480px) {
    .no-padding {
        padding-left: 5px !important;
        padding-right: 5px !important;
    }

    .school-character-box-mobile {
        margin-left: -28px !important;
    }
}

@media(max-width: 480px) {
	.subtitle-grey {
		margin-top: 12px;
	}
}

.subtitle-white {
    color: #ffffff;
    font-size: 1rem;
    margin-top: 20px;
    padding: 0 30px;
}

div.wrapper > h1 {
    margin-bottom: 20px;
}

div.classification>div.extra-podium>div.extra-podium-tables>div>a.show-extra-podium:hover {
	background-color: #c7ba94;
}

/* large tablets */

@media screen and (max-width: 1024px) {
    .wrapper {
        padding: 0 !important;
        margin-top: 100px !important;
    }
}

/* medium tablets */

@media screen and (max-width: 767px) {
	html, body {
		font-size: 1em;
	}
	p {
		margin-bottom: .5rem;
	}

	.breadcrumbs {
		display: none !important;
	}

	.single-topic-wrapper .title {
		font-size: 25px;
		padding-left: .5rem;
		padding-right: .5rem;
		margin-left: 0;
		margin-right: 0;
	}

	.single-topic-wrapper {
		padding-left: 1rem;
		padding-right: 1rem;

	}

	.wrapper {
		padding: 0 !important;
		margin-top: 100px !important;
	}

	img, iframe {
		max-width: 100%;
	}

	.primary-school-categories a {
		width: auto;
	}

	div.wrapper>img, div.wrapper.wrapper-wide>h1>img, div.wrapper>a>img {
		width: 250px;
	}
	div.divider {
		width: 250px !important;
	}
	div.wrapper.wrapper-wide>div.divider {
		margin: 0 auto 30px;
	}
	div.wrapper>ul>li.bigger>a {
		width: 100px;
		height: 100px;
		background-size: 100px;
	}
	div.wrapper.wrapper-wide>ul>li {
		margin: 0;
	}
	div.wrapper>ul>li>a>img {
		height: 80px;
	}
	a.button-back, a.buttonize {
		width: 50px;
		height: 50px;
		background-size: 50px;
		-webkit-border-radius: 5px;
		-moz-border-radius: 5px;
		border-radius: 5px;
	}
	div.header {
		height: 10vh;
	}
	div.content {
		height: 75vh;
		top: 12.5vh;
		padding: 0;
	}
	div.footer {
		height: 10vh;
		font-size: 0.7em;
	}
	div.header>h1 {
		font-size: 1.7em;
		line-height: 2;
	}
	.tip-content {
		display: none;
	}
	a.button-back.category-back {
		width: 35px;
		height: 35px;
		background-size: 35px;
	}
	div.header>h1>img {
		margin: 0;
	}
	div.riddle {
		width: 75px;
		height: 75px;
	}
	div.riddle>span.riddle-counter {
		background-size: 75px;
		padding-top: 20px;
	}
	div.content>div.category-content>div.category-riddles {
		padding: 10px;
	}
	div.content>div.category-caption {
		padding: 50px 30px 30px;
	}
	div.swal2-popup {
		padding: 35px;
	}
	div.swal2-content span.riddle-popup-label {
		font-size: 1em;
	}
	div.content>div.category-content {
		padding: 20px 0 !important;
	}
	div.content>div.category-content>div.category-classification, div.content>div.category-content>div.category-rules {
		padding: 25px;
	}
	div.content table th img, div.content table td img, img.point {
		width: 20px;
	}
	div.content>div.category-content>div.category-rules {
		line-height: 1.5em;
	}
	div.content>div.category-caption>h1>img {
		height: 60px;
	}
	.swal2-popup .swal2-input {
		margin: .5em auto;
	}
	div.content>div.category-content>div.category-classification {
		max-height: 270px;
	}
	div.yellow-login-tools a div {
		border-radius: 0px !important;
	}
	div.classification {
		width: 90%;
		margin: 75px auto 20px;
	}
	div.yellow-login-tools {
		margin-top: 25px;
	}
	div.yellow-login-tools a.buttonize {
		display: block;
		margin: 10px auto 0;
	}
	div.yellow-login-tools a.buttonize.profile, div.yellow-login-tools a.buttonize.logout {
		display: inline-block;
	}
	div.yellow-login-tools a.buttonize:first-child {
		margin-top: 0;
	}
	div.classification .podium-user {
		width: 100%;
		height: 225px;
	}
	div.avatar>img.point {
		width: 125px;
	}
	div.classification>div.podium {
		padding: 30px 0;
	}
	div.classification>div.podium>div.podium-gold {
		margin-bottom: 35px;
	}
	div.classification>div.podium>div.podium-silver, div.classification>div.podium>div.podium-bronze {
		height: 100px;
	}
	div.avatar>img.point.silver, div.avatar>img.point.bronze {
		width: 100px;
	}
	div.classification .podium-user .avatar {
		width: 100px;
		height: 100px;
	}
	div.classification>div.extra-podium table:first-child {
		padding-top: 20px;
		padding-bottom: 20px;
	}
	div.classification>div.extra-podium table .podium-user td {
		padding: 5px 15px;
	}
	div.classification>div.extra-podium>div.extra-podium-tables {
		height: 500px;
		min-height: 500px;
	}
	div.classification>div.extra-podium>div.extra-podium-tables>div {
		top: 450px;
	}
	div.mastermind-container {
		width: 315px;
		height: 600px;
		margin: calc((100vh - 600px) / 2) auto;
		border-radius: 100px;
	}
	div.mastermind-container>div:first-child {
		height: 100px;
		line-height: 100px;
	}
	div.submit-try {
		height: 100px;
		line-height: 100px;
		border-radius: 96px;
		border-top-left-radius: 0;
		border-top-right-radius: 0;
	}
	div.mastermind-container>div:nth-child(2) {
		padding: 25px 10px;
	}
	div.spoken-results {
		padding: 0 25px;
	}
	div.computing-results {
		bottom: 100px;
	}
	div.computing-results>div {
		width: calc((100% / 6) - 5px);
	}
	div.wrapper-wide.user-customize {
		top: 30%;
	}
	div.wrapper-wide.user-customize>h1 {
		font-size: 1.3em;
	}
	div.wrapper-wide.user-customize>p {
		font-size: .8em;
	}
	div.wrapper-wide.user-customize div.avatar {
		height: 150px;
		width: 150px;
		margin-top: 50px;
	}
	div.avatar-customize-pre {
		transform: translate(-125%, -15%);
	}
	div.avatar-customize-post {
		transform: translate(+125%, -15%);
	}
	div.wrapper-wide.user-customize input#nickname {
		width: 75%;
		margin-top: 75px;
	}
}

/* smartphones */

@media screen and (max-width: 479px) {}

.feedback-on-click:active {
	opacity: .6;
}

.styled-list {
	list-style-type: circle !important;
}

.single-topic-wrapper .subtitle {
	text-align: left;
	font-size: 25px;
	text-transform: uppercase;
	text-decoration: none;
	margin: 0 0 .5em;
	padding: 1rem 0 0.5rem;
	line-height: 1;
	border-bottom: 1px solid rgba(20,20,20,.1);
	letter-spacing: 1.14px;
	color: #85c082;
}

.single-topic-attachments {
	padding: 0;
	margin: 0;
}



@media (max-width: 480px) {
	body {
		padding-bottom: 110px;
	}

	.wrapper.home {
		margin-top: 8%;
	}
}

ul.games-home {
	list-style-type: none;
	padding :0;
	margin: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	max-width: 100%;
	flex-wrap: wrap;
}

.games-home li {
	width: 100%;
	margin: .5em 0;

}

@media (max-width: 468px) {
	.games-home li {
		width: 100%;
	}
}

@media (max-width: 468px) {
	.games-home li a {
		margin-left: auto;
		margin-right: auto;
	}

	.games-home li a img {
		width: 200px;
		left: 50%;
		top: 50%;
		transform: translate3d(-50%, -50%, 0);
	}
}

.games-home li a {
	display: flex;
	flex-direction: row;
	color: #FFF;
	align-items: center;
	text-decoration: none;
	width: 250px;
	height: 80px;
	font-family: 'Montserrat', sans-serif;
	position: relative;
	justify-content: center;
	font-weight: bold;
	text-transform: uppercase;
	font-size: 20px;
	margin: auto;
	padding-left: 10px;
}

.games-home img {
	width: 250px;
	position: absolute;
	left: 0;
	top: 0;
	z-index: -1;
}

.riddle-item.roman {
	font-size: 1.8em;
}

.swal2-content {
	padding: 0 !important;
}

.swal2-popup {
	padding: 1em !important;
}

img.back {
	/* margin: 50px auto 0; */
	width: 85px;
}

#solution {
    font-size: .75em;
    width: 500px;
    margin: auto;
    text-align: left;
    max-width: 80%;
}

.digit {
  display: inline-block;
  font-size: 100px;
  color: rgba(0, 0, 0, 0.25);
  height: 180px;
  line-height: 1;
}

.time-part-wrapper {
  display: inline-block;
  margin-right: 50px;
  position: relative;
}
.time-part-wrapper:not(:last-child):after {
  content: ":";
  display: block;
  width: 30px;
  height: 230px;
  position: absolute;
  top: 0px;
  right: -30px;
  color: rgba(0, 0, 0, 0.25);
  font-size: 100px;
  line-height: 0.9;
}

.time-part {
  width: 140px;
  text-align: center;
  height: 180px;
  overflow: hidden;
  display: inline-block;
  margin-left: -5px;
  box-sizing: border-box;
}
.time-part .digit-wrapper {
  animation-timing-function: cubic-bezier(1, 0, 1, 0);
}
.time-part.minutes.tens .digit-wrapper {
  animation-name: minutes-tens;
  animation-duration: 3600s;
  animation-iteration-count: 1;
}
.time-part.minutes.ones .digit-wrapper {
  animation-name: minutes-ones;
  animation-duration: 600s;
  animation-iteration-count: 6;
}
.time-part.seconds.tens .digit-wrapper {
  animation-name: seconds-tens;
  animation-duration: 60s;
  animation-iteration-count: 60;
}
.time-part.seconds.ones .digit-wrapper {
  animation-name: seconds-ones;
  animation-duration: 60s;
  animation-iteration-count: 360;
}
.time-part.hundredths.tens .digit-wrapper {
  animation-name: hundredths-tens;
  animation-duration: 60s;
  animation-iteration-count: 3600;
}
.time-part.hundredths.ones .digit-wrapper {
  animation-name: hundredths-ones;
  animation-duration: 60s;
  animation-iteration-count: 36000;
}

@keyframes minutes-tens {
  0% {
    transform: translateY(-180px);
  }
  16.66667% {
    transform: translateY(-360px);
  }
  33.33333% {
    transform: translateY(-540px);
  }
  50% {
    transform: translateY(-720px);
  }
  66.66667% {
    transform: translateY(-900px);
  }
  83.33333% {
    transform: translateY(-1080px);
  }
}
@keyframes minutes-ones {
  0% {
    transform: translateY(-180px);
  }
  10% {
    transform: translateY(-360px);
  }
  20% {
    transform: translateY(-540px);
  }
  30% {
    transform: translateY(-720px);
  }
  40% {
    transform: translateY(-900px);
  }
  50% {
    transform: translateY(-1080px);
  }
  60% {
    transform: translateY(-1260px);
  }
  70% {
    transform: translateY(-1440px);
  }
  80% {
    transform: translateY(-1620px);
  }
  90% {
    transform: translateY(-1800px);
  }
}
@keyframes seconds-tens {
  0% {
    transform: translateY(-180px);
  }
  16.66667% {
    transform: translateY(-360px);
  }
  33.33333% {
    transform: translateY(-540px);
  }
  50% {
    transform: translateY(-720px);
  }
  66.66667% {
    transform: translateY(-900px);
  }
  83.33333% {
    transform: translateY(-1080px);
  }
}
@keyframes seconds-ones {
  0% {
    transform: translateY(-180px);
  }
  10% {
    transform: translateY(-360px);
  }
  20% {
    transform: translateY(-540px);
  }
  30% {
    transform: translateY(-720px);
  }
  40% {
    transform: translateY(-900px);
  }
  50% {
    transform: translateY(-1080px);
  }
  60% {
    transform: translateY(-1260px);
  }
  70% {
    transform: translateY(-1440px);
  }
  80% {
    transform: translateY(-1620px);
  }
  90% {
    transform: translateY(-1800px);
  }
}
@keyframes hundredths-tens {
  0% {
    transform: translateY(-180px);
  }
  10% {
    transform: translateY(-360px);
  }
  20% {
    transform: translateY(-540px);
  }
  30% {
    transform: translateY(-720px);
  }
  40% {
    transform: translateY(-900px);
  }
  50% {
    transform: translateY(-1080px);
  }
  60% {
    transform: translateY(-1260px);
  }
  70% {
    transform: translateY(-1440px);
  }
  80% {
    transform: translateY(-1620px);
  }
  90% {
    transform: translateY(-1800px);
  }
}
@keyframes hundredths-ones {
  0% {
    transform: translateY(-180px);
  }
  10% {
    transform: translateY(-360px);
  }
  20% {
    transform: translateY(-540px);
  }
  30% {
    transform: translateY(-720px);
  }
  40% {
    transform: translateY(-900px);
  }
  50% {
    transform: translateY(-1080px);
  }
  60% {
    transform: translateY(-1260px);
  }
  70% {
    transform: translateY(-1440px);
  }
  80% {
    transform: translateY(-1620px);
  }
  90% {
    transform: translateY(-1800px);
  }
}


.wrapper {
  margin: 100px auto;
  width: 500px;
  position: relative;
}

.wrapper-fluid {
    width: 96%;
    padding: 40px;
    margin-top: 3%;
}

.wrapper img {
    max-width: 100%;
}

/* BOOTSTRAP STYLES */

.container,
.container-fluid,
.container-sm,
.container-md,
.container-lg,
.container-xl {
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
    margin-right: auto;
    margin-left: auto;
}

@media (min-width: 576px) {
    .container, .container-sm {
        max-width: 540px;
    }
}

@media (min-width: 768px) {
    .container, .container-sm, .container-md {
        max-width: 720px;
    }
}

@media (min-width: 992px) {
    .container, .container-sm, .container-md, .container-lg {
        max-width: 960px;
    }
}

@media (min-width: 1200px) {
    .container, .container-sm, .container-md, .container-lg, .container-xl {
        max-width: 1140px;
    }
}

.row {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-right: -15px;
    margin-left: -15px;
}

.no-gutters {
    margin-right: 0;
    margin-left: 0;
}

.no-gutters > .col,
.no-gutters > [class*="col-"] {
    padding-right: 0;
    padding-left: 0;
}

.col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col,
.col-auto, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm,
.col-sm-auto, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md,
.col-md-auto, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg,
.col-lg-auto, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl,
.col-xl-auto {
    position: relative;
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
}

.col {
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    -ms-flex-positive: 1;
    flex-grow: 1;
    max-width: 100%;
}

.row-cols-1 > * {
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
}

.row-cols-2 > * {
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
}

.row-cols-3 > * {
    -ms-flex: 0 0 33.333333%;
    flex: 0 0 33.333333%;
    max-width: 33.333333%;
}

.row-cols-4 > * {
    -ms-flex: 0 0 25%;
    flex: 0 0 25%;
    max-width: 25%;
}

.row-cols-5 > * {
    -ms-flex: 0 0 20%;
    flex: 0 0 20%;
    max-width: 20%;
}

.row-cols-6 > * {
    -ms-flex: 0 0 16.666667%;
    flex: 0 0 16.666667%;
    max-width: 16.666667%;
}

.col-auto {
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    width: auto;
    max-width: 100%;
}

.col-1 {
    -ms-flex: 0 0 8.333333%;
    flex: 0 0 8.333333%;
    max-width: 8.333333%;
}

.col-2 {
    -ms-flex: 0 0 16.666667%;
    flex: 0 0 16.666667%;
    max-width: 16.666667%;
}

.col-3 {
    -ms-flex: 0 0 25%;
    flex: 0 0 25%;
    max-width: 25%;
}

.col-4 {
    -ms-flex: 0 0 33.333333%;
    flex: 0 0 33.333333%;
    max-width: 33.333333%;
}

.col-5 {
    -ms-flex: 0 0 41.666667%;
    flex: 0 0 41.666667%;
    max-width: 41.666667%;
}

.col-6 {
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
}

.col-7 {
    -ms-flex: 0 0 58.333333%;
    flex: 0 0 58.333333%;
    max-width: 58.333333%;
}

.col-8 {
    -ms-flex: 0 0 66.666667%;
    flex: 0 0 66.666667%;
    max-width: 66.666667%;
}

.col-9 {
    -ms-flex: 0 0 75%;
    flex: 0 0 75%;
    max-width: 75%;
}

.col-10 {
    -ms-flex: 0 0 83.333333%;
    flex: 0 0 83.333333%;
    max-width: 83.333333%;
}

.col-11 {
    -ms-flex: 0 0 91.666667%;
    flex: 0 0 91.666667%;
    max-width: 91.666667%;
}

.col-12 {
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
}

.order-first {
    -ms-flex-order: -1;
    order: -1;
}

.order-last {
    -ms-flex-order: 13;
    order: 13;
}

.order-0 {
    -ms-flex-order: 0;
    order: 0;
}

.order-1 {
    -ms-flex-order: 1;
    order: 1;
}

.order-2 {
    -ms-flex-order: 2;
    order: 2;
}

.order-3 {
    -ms-flex-order: 3;
    order: 3;
}

.order-4 {
    -ms-flex-order: 4;
    order: 4;
}

.order-5 {
    -ms-flex-order: 5;
    order: 5;
}

.order-6 {
    -ms-flex-order: 6;
    order: 6;
}

.order-7 {
    -ms-flex-order: 7;
    order: 7;
}

.order-8 {
    -ms-flex-order: 8;
    order: 8;
}

.order-9 {
    -ms-flex-order: 9;
    order: 9;
}

.order-10 {
    -ms-flex-order: 10;
    order: 10;
}

.order-11 {
    -ms-flex-order: 11;
    order: 11;
}

.order-12 {
    -ms-flex-order: 12;
    order: 12;
}

.offset-1 {
    margin-left: 8.333333%;
}

.offset-2 {
    margin-left: 16.666667%;
}

.offset-3 {
    margin-left: 25%;
}

.offset-4 {
    margin-left: 33.333333%;
}

.offset-5 {
    margin-left: 41.666667%;
}

.offset-6 {
    margin-left: 50%;
}

.offset-7 {
    margin-left: 58.333333%;
}

.offset-8 {
    margin-left: 66.666667%;
}

.offset-9 {
    margin-left: 75%;
}

.offset-10 {
    margin-left: 83.333333%;
}

.offset-11 {
    margin-left: 91.666667%;
}

@media (min-width: 576px) {
    .col-sm {
        -ms-flex-preferred-size: 0;
        flex-basis: 0;
        -ms-flex-positive: 1;
        flex-grow: 1;
        max-width: 100%;
    }
    .row-cols-sm-1 > * {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }
    .row-cols-sm-2 > * {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }
    .row-cols-sm-3 > * {
        -ms-flex: 0 0 33.333333%;
        flex: 0 0 33.333333%;
        max-width: 33.333333%;
    }
    .row-cols-sm-4 > * {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }
    .row-cols-sm-5 > * {
        -ms-flex: 0 0 20%;
        flex: 0 0 20%;
        max-width: 20%;
    }
    .row-cols-sm-6 > * {
        -ms-flex: 0 0 16.666667%;
        flex: 0 0 16.666667%;
        max-width: 16.666667%;
    }
    .col-sm-auto {
        -ms-flex: 0 0 auto;
        flex: 0 0 auto;
        width: auto;
        max-width: 100%;
    }
    .col-sm-1 {
        -ms-flex: 0 0 8.333333%;
        flex: 0 0 8.333333%;
        max-width: 8.333333%;
    }
    .col-sm-2 {
        -ms-flex: 0 0 16.666667%;
        flex: 0 0 16.666667%;
        max-width: 16.666667%;
    }
    .col-sm-3 {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }
    .col-sm-4 {
        -ms-flex: 0 0 33.333333%;
        flex: 0 0 33.333333%;
        max-width: 33.333333%;
    }
    .col-sm-5 {
        -ms-flex: 0 0 41.666667%;
        flex: 0 0 41.666667%;
        max-width: 41.666667%;
    }
    .col-sm-6 {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }
    .col-sm-7 {
        -ms-flex: 0 0 58.333333%;
        flex: 0 0 58.333333%;
        max-width: 58.333333%;
    }
    .col-sm-8 {
        -ms-flex: 0 0 66.666667%;
        flex: 0 0 66.666667%;
        max-width: 66.666667%;
    }
    .col-sm-9 {
        -ms-flex: 0 0 75%;
        flex: 0 0 75%;
        max-width: 75%;
    }
    .col-sm-10 {
        -ms-flex: 0 0 83.333333%;
        flex: 0 0 83.333333%;
        max-width: 83.333333%;
    }
    .col-sm-11 {
        -ms-flex: 0 0 91.666667%;
        flex: 0 0 91.666667%;
        max-width: 91.666667%;
    }
    .col-sm-12 {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }
    .order-sm-first {
        -ms-flex-order: -1;
        order: -1;
    }
    .order-sm-last {
        -ms-flex-order: 13;
        order: 13;
    }
    .order-sm-0 {
        -ms-flex-order: 0;
        order: 0;
    }
    .order-sm-1 {
        -ms-flex-order: 1;
        order: 1;
    }
    .order-sm-2 {
        -ms-flex-order: 2;
        order: 2;
    }
    .order-sm-3 {
        -ms-flex-order: 3;
        order: 3;
    }
    .order-sm-4 {
        -ms-flex-order: 4;
        order: 4;
    }
    .order-sm-5 {
        -ms-flex-order: 5;
        order: 5;
    }
    .order-sm-6 {
        -ms-flex-order: 6;
        order: 6;
    }
    .order-sm-7 {
        -ms-flex-order: 7;
        order: 7;
    }
    .order-sm-8 {
        -ms-flex-order: 8;
        order: 8;
    }
    .order-sm-9 {
        -ms-flex-order: 9;
        order: 9;
    }
    .order-sm-10 {
        -ms-flex-order: 10;
        order: 10;
    }
    .order-sm-11 {
        -ms-flex-order: 11;
        order: 11;
    }
    .order-sm-12 {
        -ms-flex-order: 12;
        order: 12;
    }
    .offset-sm-0 {
        margin-left: 0;
    }
    .offset-sm-1 {
        margin-left: 8.333333%;
    }
    .offset-sm-2 {
        margin-left: 16.666667%;
    }
    .offset-sm-3 {
        margin-left: 25%;
    }
    .offset-sm-4 {
        margin-left: 33.333333%;
    }
    .offset-sm-5 {
        margin-left: 41.666667%;
    }
    .offset-sm-6 {
        margin-left: 50%;
    }
    .offset-sm-7 {
        margin-left: 58.333333%;
    }
    .offset-sm-8 {
        margin-left: 66.666667%;
    }
    .offset-sm-9 {
        margin-left: 75%;
    }
    .offset-sm-10 {
        margin-left: 83.333333%;
    }
    .offset-sm-11 {
        margin-left: 91.666667%;
    }
}

@media (min-width: 768px) {
    .col-md {
        -ms-flex-preferred-size: 0;
        flex-basis: 0;
        -ms-flex-positive: 1;
        flex-grow: 1;
        max-width: 100%;
    }
    .row-cols-md-1 > * {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }
    .row-cols-md-2 > * {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }
    .row-cols-md-3 > * {
        -ms-flex: 0 0 33.333333%;
        flex: 0 0 33.333333%;
        max-width: 33.333333%;
    }
    .row-cols-md-4 > * {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }
    .row-cols-md-5 > * {
        -ms-flex: 0 0 20%;
        flex: 0 0 20%;
        max-width: 20%;
    }
    .row-cols-md-6 > * {
        -ms-flex: 0 0 16.666667%;
        flex: 0 0 16.666667%;
        max-width: 16.666667%;
    }
    .col-md-auto {
        -ms-flex: 0 0 auto;
        flex: 0 0 auto;
        width: auto;
        max-width: 100%;
    }
    .col-md-1 {
        -ms-flex: 0 0 8.333333%;
        flex: 0 0 8.333333%;
        max-width: 8.333333%;
    }
    .col-md-2 {
        -ms-flex: 0 0 16.666667%;
        flex: 0 0 16.666667%;
        max-width: 16.666667%;
    }
    .col-md-3 {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }
    .col-md-4 {
        -ms-flex: 0 0 33.333333%;
        flex: 0 0 33.333333%;
        max-width: 33.333333%;
    }
    .col-md-5 {
        -ms-flex: 0 0 41.666667%;
        flex: 0 0 41.666667%;
        max-width: 41.666667%;
    }
    .col-md-6 {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }
    .col-md-7 {
        -ms-flex: 0 0 58.333333%;
        flex: 0 0 58.333333%;
        max-width: 58.333333%;
    }
    .col-md-8 {
        -ms-flex: 0 0 66.666667%;
        flex: 0 0 66.666667%;
        max-width: 66.666667%;
    }
    .col-md-9 {
        -ms-flex: 0 0 75%;
        flex: 0 0 75%;
        max-width: 75%;
    }
    .col-md-10 {
        -ms-flex: 0 0 83.333333%;
        flex: 0 0 83.333333%;
        max-width: 83.333333%;
    }
    .col-md-11 {
        -ms-flex: 0 0 91.666667%;
        flex: 0 0 91.666667%;
        max-width: 91.666667%;
    }
    .col-md-12 {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }
    .order-md-first {
        -ms-flex-order: -1;
        order: -1;
    }
    .order-md-last {
        -ms-flex-order: 13;
        order: 13;
    }
    .order-md-0 {
        -ms-flex-order: 0;
        order: 0;
    }
    .order-md-1 {
        -ms-flex-order: 1;
        order: 1;
    }
    .order-md-2 {
        -ms-flex-order: 2;
        order: 2;
    }
    .order-md-3 {
        -ms-flex-order: 3;
        order: 3;
    }
    .order-md-4 {
        -ms-flex-order: 4;
        order: 4;
    }
    .order-md-5 {
        -ms-flex-order: 5;
        order: 5;
    }
    .order-md-6 {
        -ms-flex-order: 6;
        order: 6;
    }
    .order-md-7 {
        -ms-flex-order: 7;
        order: 7;
    }
    .order-md-8 {
        -ms-flex-order: 8;
        order: 8;
    }
    .order-md-9 {
        -ms-flex-order: 9;
        order: 9;
    }
    .order-md-10 {
        -ms-flex-order: 10;
        order: 10;
    }
    .order-md-11 {
        -ms-flex-order: 11;
        order: 11;
    }
    .order-md-12 {
        -ms-flex-order: 12;
        order: 12;
    }
    .offset-md-0 {
        margin-left: 0;
    }
    .offset-md-1 {
        margin-left: 8.333333%;
    }
    .offset-md-2 {
        margin-left: 16.666667%;
    }
    .offset-md-3 {
        margin-left: 25%;
    }
    .offset-md-4 {
        margin-left: 33.333333%;
    }
    .offset-md-5 {
        margin-left: 41.666667%;
    }
    .offset-md-6 {
        margin-left: 50%;
    }
    .offset-md-7 {
        margin-left: 58.333333%;
    }
    .offset-md-8 {
        margin-left: 66.666667%;
    }
    .offset-md-9 {
        margin-left: 75%;
    }
    .offset-md-10 {
        margin-left: 83.333333%;
    }
    .offset-md-11 {
        margin-left: 91.666667%;
    }
}

@media (min-width: 992px) {
    .col-lg {
        -ms-flex-preferred-size: 0;
        flex-basis: 0;
        -ms-flex-positive: 1;
        flex-grow: 1;
        max-width: 100%;
    }
    .row-cols-lg-1 > * {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }
    .row-cols-lg-2 > * {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }
    .row-cols-lg-3 > * {
        -ms-flex: 0 0 33.333333%;
        flex: 0 0 33.333333%;
        max-width: 33.333333%;
    }
    .row-cols-lg-4 > * {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }
    .row-cols-lg-5 > * {
        -ms-flex: 0 0 20%;
        flex: 0 0 20%;
        max-width: 20%;
    }
    .row-cols-lg-6 > * {
        -ms-flex: 0 0 16.666667%;
        flex: 0 0 16.666667%;
        max-width: 16.666667%;
    }
    .col-lg-auto {
        -ms-flex: 0 0 auto;
        flex: 0 0 auto;
        width: auto;
        max-width: 100%;
    }
    .col-lg-1 {
        -ms-flex: 0 0 8.333333%;
        flex: 0 0 8.333333%;
        max-width: 8.333333%;
    }
    .col-lg-2 {
        -ms-flex: 0 0 16.666667%;
        flex: 0 0 16.666667%;
        max-width: 16.666667%;
    }
    .col-lg-3 {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }
    .col-lg-4 {
        -ms-flex: 0 0 33.333333%;
        flex: 0 0 33.333333%;
        max-width: 33.333333%;
    }
    .col-lg-5 {
        -ms-flex: 0 0 41.666667%;
        flex: 0 0 41.666667%;
        max-width: 41.666667%;
    }
    .col-lg-6 {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }
    .col-lg-7 {
        -ms-flex: 0 0 58.333333%;
        flex: 0 0 58.333333%;
        max-width: 58.333333%;
    }
    .col-lg-8 {
        -ms-flex: 0 0 66.666667%;
        flex: 0 0 66.666667%;
        max-width: 66.666667%;
    }
    .col-lg-9 {
        -ms-flex: 0 0 75%;
        flex: 0 0 75%;
        max-width: 75%;
    }
    .col-lg-10 {
        -ms-flex: 0 0 83.333333%;
        flex: 0 0 83.333333%;
        max-width: 83.333333%;
    }
    .col-lg-11 {
        -ms-flex: 0 0 91.666667%;
        flex: 0 0 91.666667%;
        max-width: 91.666667%;
    }
    .col-lg-12 {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }
    .order-lg-first {
        -ms-flex-order: -1;
        order: -1;
    }
    .order-lg-last {
        -ms-flex-order: 13;
        order: 13;
    }
    .order-lg-0 {
        -ms-flex-order: 0;
        order: 0;
    }
    .order-lg-1 {
        -ms-flex-order: 1;
        order: 1;
    }
    .order-lg-2 {
        -ms-flex-order: 2;
        order: 2;
    }
    .order-lg-3 {
        -ms-flex-order: 3;
        order: 3;
    }
    .order-lg-4 {
        -ms-flex-order: 4;
        order: 4;
    }
    .order-lg-5 {
        -ms-flex-order: 5;
        order: 5;
    }
    .order-lg-6 {
        -ms-flex-order: 6;
        order: 6;
    }
    .order-lg-7 {
        -ms-flex-order: 7;
        order: 7;
    }
    .order-lg-8 {
        -ms-flex-order: 8;
        order: 8;
    }
    .order-lg-9 {
        -ms-flex-order: 9;
        order: 9;
    }
    .order-lg-10 {
        -ms-flex-order: 10;
        order: 10;
    }
    .order-lg-11 {
        -ms-flex-order: 11;
        order: 11;
    }
    .order-lg-12 {
        -ms-flex-order: 12;
        order: 12;
    }
    .offset-lg-0 {
        margin-left: 0;
    }
    .offset-lg-1 {
        margin-left: 8.333333%;
    }
    .offset-lg-2 {
        margin-left: 16.666667%;
    }
    .offset-lg-3 {
        margin-left: 25%;
    }
    .offset-lg-4 {
        margin-left: 33.333333%;
    }
    .offset-lg-5 {
        margin-left: 41.666667%;
    }
    .offset-lg-6 {
        margin-left: 50%;
    }
    .offset-lg-7 {
        margin-left: 58.333333%;
    }
    .offset-lg-8 {
        margin-left: 66.666667%;
    }
    .offset-lg-9 {
        margin-left: 75%;
    }
    .offset-lg-10 {
        margin-left: 83.333333%;
    }
    .offset-lg-11 {
        margin-left: 91.666667%;
    }
}

@media (min-width: 1200px) {
    .col-xl {
        -ms-flex-preferred-size: 0;
        flex-basis: 0;
        -ms-flex-positive: 1;
        flex-grow: 1;
        max-width: 100%;
    }
    .row-cols-xl-1 > * {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }
    .row-cols-xl-2 > * {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }
    .row-cols-xl-3 > * {
        -ms-flex: 0 0 33.333333%;
        flex: 0 0 33.333333%;
        max-width: 33.333333%;
    }
    .row-cols-xl-4 > * {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }
    .row-cols-xl-5 > * {
        -ms-flex: 0 0 20%;
        flex: 0 0 20%;
        max-width: 20%;
    }
    .row-cols-xl-6 > * {
        -ms-flex: 0 0 16.666667%;
        flex: 0 0 16.666667%;
        max-width: 16.666667%;
    }
    .col-xl-auto {
        -ms-flex: 0 0 auto;
        flex: 0 0 auto;
        width: auto;
        max-width: 100%;
    }
    .col-xl-1 {
        -ms-flex: 0 0 8.333333%;
        flex: 0 0 8.333333%;
        max-width: 8.333333%;
    }
    .col-xl-2 {
        -ms-flex: 0 0 16.666667%;
        flex: 0 0 16.666667%;
        max-width: 16.666667%;
    }
    .col-xl-3 {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }
    .col-xl-4 {
        -ms-flex: 0 0 33.333333%;
        flex: 0 0 33.333333%;
        max-width: 33.333333%;
    }
    .col-xl-5 {
        -ms-flex: 0 0 41.666667%;
        flex: 0 0 41.666667%;
        max-width: 41.666667%;
    }
    .col-xl-6 {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }
    .col-xl-7 {
        -ms-flex: 0 0 58.333333%;
        flex: 0 0 58.333333%;
        max-width: 58.333333%;
    }
    .col-xl-8 {
        -ms-flex: 0 0 66.666667%;
        flex: 0 0 66.666667%;
        max-width: 66.666667%;
    }
    .col-xl-9 {
        -ms-flex: 0 0 75%;
        flex: 0 0 75%;
        max-width: 75%;
    }
    .col-xl-10 {
        -ms-flex: 0 0 83.333333%;
        flex: 0 0 83.333333%;
        max-width: 83.333333%;
    }
    .col-xl-11 {
        -ms-flex: 0 0 91.666667%;
        flex: 0 0 91.666667%;
        max-width: 91.666667%;
    }
    .col-xl-12 {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }
    .order-xl-first {
        -ms-flex-order: -1;
        order: -1;
    }
    .order-xl-last {
        -ms-flex-order: 13;
        order: 13;
    }
    .order-xl-0 {
        -ms-flex-order: 0;
        order: 0;
    }
    .order-xl-1 {
        -ms-flex-order: 1;
        order: 1;
    }
    .order-xl-2 {
        -ms-flex-order: 2;
        order: 2;
    }
    .order-xl-3 {
        -ms-flex-order: 3;
        order: 3;
    }
    .order-xl-4 {
        -ms-flex-order: 4;
        order: 4;
    }
    .order-xl-5 {
        -ms-flex-order: 5;
        order: 5;
    }
    .order-xl-6 {
        -ms-flex-order: 6;
        order: 6;
    }
    .order-xl-7 {
        -ms-flex-order: 7;
        order: 7;
    }
    .order-xl-8 {
        -ms-flex-order: 8;
        order: 8;
    }
    .order-xl-9 {
        -ms-flex-order: 9;
        order: 9;
    }
    .order-xl-10 {
        -ms-flex-order: 10;
        order: 10;
    }
    .order-xl-11 {
        -ms-flex-order: 11;
        order: 11;
    }
    .order-xl-12 {
        -ms-flex-order: 12;
        order: 12;
    }
    .offset-xl-0 {
        margin-left: 0;
    }
    .offset-xl-1 {
        margin-left: 8.333333%;
    }
    .offset-xl-2 {
        margin-left: 16.666667%;
    }
    .offset-xl-3 {
        margin-left: 25%;
    }
    .offset-xl-4 {
        margin-left: 33.333333%;
    }
    .offset-xl-5 {
        margin-left: 41.666667%;
    }
    .offset-xl-6 {
        margin-left: 50%;
    }
    .offset-xl-7 {
        margin-left: 58.333333%;
    }
    .offset-xl-8 {
        margin-left: 66.666667%;
    }
    .offset-xl-9 {
        margin-left: 75%;
    }
    .offset-xl-10 {
        margin-left: 83.333333%;
    }
    .offset-xl-11 {
        margin-left: 91.666667%;
    }
}

@media (max-width: 575px) {
    .hidden-xs {
        display: none !important;
    }
}
@media (min-width: 576px) and (max-width: 767px) {
    .hidden-sm {
        display: none !important;
    }
}
@media (min-width: 768px) and (max-width: 991px) {
    .hidden-md {
        display: none !important;
    }
}
@media (min-width: 992px) and (max-width: 1199px) {
    .hidden-lg {
        display: none !important;
    }
}
@media (min-width: 1200px) {
    .hidden-xl {
        display: none !important;
    }
}

.school-description-box {
    border-radius: 2em;
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
    background-color: white;
    margin: 30px 0;
    padding: 15px 20px;
    text-align: left;
}

.school-description-box a {
    color: #202122;
}

img.tales-boxes {
    width: 200px;
    margin-right: 45px;
    /*border-radius: 20px;*/
}
img.tales-fregi-boxes {
    width: 415px;
    margin-right: 18px;
}
img.tales-school-boxes {
    width: 90%;
    border-radius: 10%;
}
img.how-to-tales {
    width: 320px !important;
    border-radius: 13px;
}

@media (max-width: 767px) {
    img.tales-school-boxes {
        width: 65px;
        margin-right: 8px;
        border-radius: 10%;
    }
    img.tales-fregi-boxes {
        width: 130px;
        margin-right: 18px;
    }
    img.how-to-tales {
        width: 320px !important;
    }
}
@media (min-width: 768px) and (max-width: 991px) {
    img.tales-school-boxes {
        width: 150px;
    }
    img.tales-fregi-boxes {
        width: 330px;
        margin-right: 18px;
    }
    img.how-to-tales {
        width: 180px !important;
    }
}

.image-shadow {
    width: 250px;
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
    text-align: center;
}
.shadow {
    border-radius: 70px;
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}
.panel-box-container {
    margin-top: 50px;
    margin-bottom: 50px;
    background-color: #e3e3e3;
    padding: 30px;
    border-radius: 12px;
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}
.panel-box-container p {
    color: black;
}

/* SCUOLA PRIMARIA TABLE */

.school-table-container {
    position: relative;
    text-align: center;
    color: black;
}

.school-box-container {
    padding-right: 0;
    padding-left: 0;
}

.school-table-item {
    opacity: 0;
}

.school-table-item:hover {
    opacity: 0.5;
}

.software-button:hover {
    opacity: 0.6;
}

img.school-box {
    width: 300px;
    margin-top: 0;
}

.overlay:hover {
    opacity: 1;
}

.overlay:hover {
    opacity: 0.7;
}

.tales-link-table {
    position: absolute;
    top: 220px;
    left: 20px;
    width: 180px;
}

.bul-link-table {
    position: absolute;
    top: 220px;
    left: 270px;
    width: 200px;
}

.pitagoras-link-table {
    position: absolute;
    top: 135px;
    left: 525px;
    width: 190px;
}

.lullo-link-table {
    position: absolute;
    top: 135px;
    left: 775px;
    width: 210px;
}

.coming-2022-1-table {
    position: absolute;
    top: 135px;
    left: 20px;
    width: 180px;
}

.coming-2022-2-table {
    position: absolute;
    top: 305px;
    left: 20px;
    width: 180px;
}

.coming-2022-3-table {
    position: absolute;
    top: 305px;
    left: 280px;
    width: 180px;
}

.coming-2022-4-table {
    position: absolute;
    top: 218px;
    left: 540px;
    width: 180px;
}

.coming-2022-5-table {
    position: absolute;
    top: 305px;
    left: 540px;
    width: 180px;
}

.coming-2022-6-table {
    position: absolute;
    top: 218px;
    left: 797px;
    width: 180px;
}

.coming-2022-7-table {
    position: absolute;
    top: 305px;
    left: 797px;
    width: 180px;
}

.coming-soon-table {
    position: absolute;
    top: 135px;
    left: 280px;
    width: 180px;
}

@media(max-width: 480px) {
    img.school-table {
        width: auto;
        margin-top: 20px;
        margin-left: 0;
    }

    .tales-link-table {
        position: absolute;
        top: 254px;
        left: 100px;
        width: 200px;
    }

    .bul-link-table {
        position: absolute;
        top: 697px;
        left: 148px;
        width: 80px;
    }

    .pitagoras-link-table {
        position: absolute;
        top: 1065px;
        left: 82px;
        width: 200px;
    }

    .lullo-link-table {
        position: absolute;
        top: 1515px;
        left: 112px;
        width: 140px;
    }
}

.school-face {
    width: 445px;
    border: 1px solid black;
}

@media(max-width: 480px) {
    .school-face {
        width: 300px !important;
    }
}

.warmapp-row {
    margin-top: 20px;
    background-color: #e2e3e2;
}

@media (min-width: 768px) and (max-width: 991px) {
    .warmapp-row {
        padding: 0 30px;
    }
}

@media (min-width: 768px) {
    .warmapp-row {
        position: relative;
        margin-left: -50vw;
        left: 50%;
    }

    .warmapp-col {
        padding-left: 0;
        padding-right: 0;
    }
}

.center-cropped {
    width: 450px;
    height: 300px;
    background-image: url('/res/scuola/primaria/disegno_dx.svg');
    background-position: center center;
    background-repeat: no-repeat;
    /*background-size: 800px 800px;*/
    overflow: hidden;
    margin-top: -30px;
}

.center-cropped-music {
    background-size: 800px 800px;
}

.center-cropped img {
    min-height: 100%;
    min-width: 100%;
    /* IE 8 */
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    /* IE 5-7 */
    filter: alpha(opacity=0);
    /* modern browsers */
    opacity: 0;
}

@media(max-width: 480px) {
    .center-cropped {
        width: 300px;
        height: 200px;
        background-size: 300px 500px;
    }

    .center-cropped-music {
        width: 300px;
        height: 200px;
        background-size: 350px 550px;
    }
}

.btn-generic {
    border: 2px solid #6e6e6e;
    cursor: pointer;
}

.btn-generic:hover {
    opacity: 0.8;
}

.btn-red {
    width: 100%;
    background-color: #dd444f;
    border-radius: 13px;
    font-size: 1.4rem;
    font-weight: 600;
    letter-spacing: 1px;
    padding: 0.9rem 0.9rem;
}

.btn-red:hover {
    opacity: 0.9;
    color: white;
}

.btn-tales {
    background-color: #dd3c49;
}

.btn-bul {
    background-color: #3da2ad;
}

.btn-dekart {
    background-color: #b5031a;
}

.btn-pitagoras {
    background-color: #ffc933;
}

.btn-arte {
    background-color: #ff7984;
}

.btn-lullo {
    background-color: #cf8eed;
}

.btn-robinson {
    background-color: #ffa51f;
}

.btn-zermelo {
    background-color: #87cbd0;
}

.btn-cards {
    background-color: #6db672;
}

.single-topic-preview .title:hover {
    opacity: 0.7;
    text-decoration: underline;
}

.btn-music-selected {
    background-color: #406b43;
}

.bul-logo {
    height: 115px !important;
}

.pitagoras-logo {
    width: 570px !important;
}

.zermelo-logo {
    width: 560px !important;
}

.cards-logo {
    width: 400px !important;
}

@media(max-width: 480px) {
    .bul-logo {
        height: 70px !important;
    }

    .pitagoras-logo {
        width: 300px !important;
    }

    .zermelo-logo {
        width: 400px !important;
    }
}

.number-circle {
    border-radius: 50%;
    width: 10px;
    height: 10px;
    padding: 8px;

    background: #fff;
    border: 2px solid;
    text-align: center;
    line-height: 11px;
}

/* TABLE */

.table-double-bordered {
    border: 2px solid #ddd !important;
}

.table-double-bordered th,
.table-double-bordered td{
    border: 2px solid #ddd !important;
}

.table {
    border-collapse: collapse !important;
}
.table td,
.table th {
    background-color: #fff !important;
}
.table-bordered th,
.table-bordered td {
    border: 1px solid #ddd !important;
}

table {
    background-color: transparent;
}
table col[class*="col-"] {
    position: static;
    display: table-column;
    float: none;
}
table td[class*="col-"],
table th[class*="col-"] {
    position: static;
    display: table-cell;
    float: none;
}
caption {
    padding-top: 8px;
    padding-bottom: 8px;
    color: #777777;
    text-align: left;
}
th {
    text-align: left;
}
.table {
    width: 100%;
    max-width: 100%;
    margin-bottom: 20px;
}
.table > thead > tr > th,
.table > tbody > tr > th,
.table > tfoot > tr > th,
.table > thead > tr > td,
.table > tbody > tr > td,
.table > tfoot > tr > td {
    padding: 8px;
    line-height: 1.42857143;
    vertical-align: middle;
    border-top: 1px solid #ddd;
}
.table > thead > tr > th {
    vertical-align: middle;
    border-bottom: 2px solid #ddd;
}
.table > caption + thead > tr:first-child > th,
.table > colgroup + thead > tr:first-child > th,
.table > thead:first-child > tr:first-child > th,
.table > caption + thead > tr:first-child > td,
.table > colgroup + thead > tr:first-child > td,
.table > thead:first-child > tr:first-child > td {
    border-top: 0;
}
.table > tbody + tbody {
    border-top: 2px solid #ddd;
}
.table .table {
    background-color: #fff;
}
.table-condensed > thead > tr > th,
.table-condensed > tbody > tr > th,
.table-condensed > tfoot > tr > th,
.table-condensed > thead > tr > td,
.table-condensed > tbody > tr > td,
.table-condensed > tfoot > tr > td {
    padding: 5px;
}
.table-bordered {
    border: 1px solid #ddd;
}
.table-bordered > thead > tr > th,
.table-bordered > tbody > tr > th,
.table-bordered > tfoot > tr > th,
.table-bordered > thead > tr > td,
.table-bordered > tbody > tr > td,
.table-bordered > tfoot > tr > td {
    border: 1px solid #ddd;
}
.table-bordered > thead > tr > th,
.table-bordered > thead > tr > td {
    border-bottom-width: 2px;
}
.table-striped > tbody > tr:nth-of-type(odd) {
    background-color: #f9f9f9;
}
.table-hover > tbody > tr:hover {
    background-color: #f5f5f5;
}
.table > thead > tr > td.active,
.table > tbody > tr > td.active,
.table > tfoot > tr > td.active,
.table > thead > tr > th.active,
.table > tbody > tr > th.active,
.table > tfoot > tr > th.active,
.table > thead > tr.active > td,
.table > tbody > tr.active > td,
.table > tfoot > tr.active > td,
.table > thead > tr.active > th,
.table > tbody > tr.active > th,
.table > tfoot > tr.active > th {
    background-color: #f5f5f5;
}
.table-hover > tbody > tr > td.active:hover,
.table-hover > tbody > tr > th.active:hover,
.table-hover > tbody > tr.active:hover > td,
.table-hover > tbody > tr:hover > .active,
.table-hover > tbody > tr.active:hover > th {
    background-color: #e8e8e8;
}
.table > thead > tr > td.success,
.table > tbody > tr > td.success,
.table > tfoot > tr > td.success,
.table > thead > tr > th.success,
.table > tbody > tr > th.success,
.table > tfoot > tr > th.success,
.table > thead > tr.success > td,
.table > tbody > tr.success > td,
.table > tfoot > tr.success > td,
.table > thead > tr.success > th,
.table > tbody > tr.success > th,
.table > tfoot > tr.success > th {
    background-color: #dff0d8;
}
.table-hover > tbody > tr > td.success:hover,
.table-hover > tbody > tr > th.success:hover,
.table-hover > tbody > tr.success:hover > td,
.table-hover > tbody > tr:hover > .success,
.table-hover > tbody > tr.success:hover > th {
    background-color: #d0e9c6;
}
.table > thead > tr > td.info,
.table > tbody > tr > td.info,
.table > tfoot > tr > td.info,
.table > thead > tr > th.info,
.table > tbody > tr > th.info,
.table > tfoot > tr > th.info,
.table > thead > tr.info > td,
.table > tbody > tr.info > td,
.table > tfoot > tr.info > td,
.table > thead > tr.info > th,
.table > tbody > tr.info > th,
.table > tfoot > tr.info > th {
    background-color: #d9edf7;
}
.table-hover > tbody > tr > td.info:hover,
.table-hover > tbody > tr > th.info:hover,
.table-hover > tbody > tr.info:hover > td,
.table-hover > tbody > tr:hover > .info,
.table-hover > tbody > tr.info:hover > th {
    background-color: #c4e3f3;
}
.table > thead > tr > td.warning,
.table > tbody > tr > td.warning,
.table > tfoot > tr > td.warning,
.table > thead > tr > th.warning,
.table > tbody > tr > th.warning,
.table > tfoot > tr > th.warning,
.table > thead > tr.warning > td,
.table > tbody > tr.warning > td,
.table > tfoot > tr.warning > td,
.table > thead > tr.warning > th,
.table > tbody > tr.warning > th,
.table > tfoot > tr.warning > th {
    background-color: #fcf8e3;
}
.table-hover > tbody > tr > td.warning:hover,
.table-hover > tbody > tr > th.warning:hover,
.table-hover > tbody > tr.warning:hover > td,
.table-hover > tbody > tr:hover > .warning,
.table-hover > tbody > tr.warning:hover > th {
    background-color: #faf2cc;
}
.table > thead > tr > td.danger,
.table > tbody > tr > td.danger,
.table > tfoot > tr > td.danger,
.table > thead > tr > th.danger,
.table > tbody > tr > th.danger,
.table > tfoot > tr > th.danger,
.table > thead > tr.danger > td,
.table > tbody > tr.danger > td,
.table > tfoot > tr.danger > td,
.table > thead > tr.danger > th,
.table > tbody > tr.danger > th,
.table > tfoot > tr.danger > th {
    background-color: #f2dede;
}
.table-hover > tbody > tr > td.danger:hover,
.table-hover > tbody > tr > th.danger:hover,
.table-hover > tbody > tr.danger:hover > td,
.table-hover > tbody > tr:hover > .danger,
.table-hover > tbody > tr.danger:hover > th {
    background-color: #ebcccc;
}
.table-responsive {
    min-height: 0.01%;
    overflow-x: auto;
}
@media screen and (max-width: 767px) {
    .table-responsive {
        width: 100%;
        margin-bottom: 15px;
        overflow-y: hidden;
        -ms-overflow-style: -ms-autohiding-scrollbar;
        border: 1px solid #ddd;
    }
    .table-responsive > .table {
        margin-bottom: 0;
    }
    .table-responsive > .table > thead > tr > th,
    .table-responsive > .table > tbody > tr > th,
    .table-responsive > .table > tfoot > tr > th,
    .table-responsive > .table > thead > tr > td,
    .table-responsive > .table > tbody > tr > td,
    .table-responsive > .table > tfoot > tr > td {
        white-space: nowrap;
    }
    .table-responsive > .table-bordered {
        border: 0;
    }
    .table-responsive > .table-bordered > thead > tr > th:first-child,
    .table-responsive > .table-bordered > tbody > tr > th:first-child,
    .table-responsive > .table-bordered > tfoot > tr > th:first-child,
    .table-responsive > .table-bordered > thead > tr > td:first-child,
    .table-responsive > .table-bordered > tbody > tr > td:first-child,
    .table-responsive > .table-bordered > tfoot > tr > td:first-child {
        border-left: 0;
    }
    .table-responsive > .table-bordered > thead > tr > th:last-child,
    .table-responsive > .table-bordered > tbody > tr > th:last-child,
    .table-responsive > .table-bordered > tfoot > tr > th:last-child,
    .table-responsive > .table-bordered > thead > tr > td:last-child,
    .table-responsive > .table-bordered > tbody > tr > td:last-child,
    .table-responsive > .table-bordered > tfoot > tr > td:last-child {
        border-right: 0;
    }
    .table-responsive > .table-bordered > tbody > tr:last-child > th,
    .table-responsive > .table-bordered > tfoot > tr:last-child > th,
    .table-responsive > .table-bordered > tbody > tr:last-child > td,
    .table-responsive > .table-bordered > tfoot > tr:last-child > td {
        border-bottom: 0;
    }
}

/* Navbar */

.nav {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding-left: 0;
    margin-bottom: 0;
    list-style: none;
}

.nav-link {
    display: block;
    padding: 0.5rem 1rem;
}

.nav-link:hover, .nav-link:focus {
    text-decoration: none;
}

.nav-link.disabled {
    color: #6c757d;
    pointer-events: none;
    cursor: default;
}

.nav-tabs {
    border-bottom: 1px solid #dee2e6;
}

.nav-tabs .nav-link {
    margin-bottom: -1px;
    border: 1px solid transparent;
    border-top-left-radius: 0.25rem;
    border-top-right-radius: 0.25rem;
}

.nav-tabs .nav-link:hover, .nav-tabs .nav-link:focus {
    border-color: #e9ecef #e9ecef #dee2e6;
}

.nav-tabs .nav-link.disabled {
    color: #6c757d;
    background-color: transparent;
    border-color: transparent;
}

.nav-tabs .nav-link.active,
.nav-tabs .nav-item.show .nav-link {
    color: #495057;
    background-color: #fff;
    border-color: #dee2e6 #dee2e6 #fff;
}

.nav-tabs .dropdown-menu {
    margin-top: -1px;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}

.nav-pills .nav-link {
    border-radius: 0.25rem;
}

.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    color: #fff;
    background-color: #007bff;
}

.nav-fill > .nav-link,
.nav-fill .nav-item {
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
    text-align: center;
}

.nav-justified > .nav-link,
.nav-justified .nav-item {
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    -ms-flex-positive: 1;
    flex-grow: 1;
    text-align: center;
}

.tab-content > .tab-pane {
    display: none;
}

.tab-content > .active {
    display: block;
}

.navbar {
    position: relative;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 0.5rem 1rem;
}

@media (max-width: 575.98px) {
    .navbar {

    }
}

.navbar .container,
.navbar .container-fluid, .navbar .container-sm, .navbar .container-md, .navbar .container-lg, .navbar .container-xl {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.navbar-brand {
    display: inline-block;
    padding-top: 0.3125rem;
    padding-bottom: 0.3125rem;
    margin-right: 1rem;
    font-size: 1.25rem;
    line-height: inherit;
    white-space: nowrap;
}

.navbar-brand:hover, .navbar-brand:focus {
    text-decoration: none;
    opacity: 0.5;
}

.navbar-nav {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    padding-left: 0;
    margin-bottom: 0;
    list-style: none;
}

.navbar-nav .nav-link {
    padding-right: 0;
    padding-left: 0;
}

.nav-link:hover {
    opacity: 0.5;
}

.navbar-nav .dropdown-menu {
    position: static;
    float: none;
}

.navbar-text {
    display: inline-block;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.navbar-collapse {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -ms-flex-align: center;
    align-items: center;
}

.navbar-toggler {
    padding: 0;
    font-size: 1.25rem;
    line-height: 1;
    background-color: transparent;
    border: 1px solid transparent;
    border-radius: 0.25rem;
}

.navbar-toggler:hover, .navbar-toggler:focus {
    text-decoration: none;
}

.navbar-toggler-icon {
    display: inline-block;
    width: 1.5em;
    height: 1.5em;
    vertical-align: middle;
    content: "";
    background: 50% / 100% 100% no-repeat;
}

.navbar-nav-scroll {
    max-height: 75vh;
    overflow-y: auto;
}

@media (max-width: 575.98px) {
    .navbar-expand-sm > .container,
    .navbar-expand-sm > .container-fluid, .navbar-expand-sm > .container-sm, .navbar-expand-sm > .container-md, .navbar-expand-sm > .container-lg, .navbar-expand-sm > .container-xl {
        padding-right: 0;
        padding-left: 0;
    }
}

@media (min-width: 576px) {
    .navbar-expand-sm {
        -ms-flex-flow: row nowrap;
        flex-flow: row nowrap;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }
    .navbar-expand-sm .navbar-nav {
        -ms-flex-direction: row;
        flex-direction: row;
    }
    .navbar-expand-sm .navbar-nav .dropdown-menu {
        position: absolute;
    }
    .navbar-expand-sm .navbar-nav .nav-link {
        padding-right: 0.5rem;
        padding-left: 0.5rem;
    }
    .navbar-expand-sm > .container,
    .navbar-expand-sm > .container-fluid, .navbar-expand-sm > .container-sm, .navbar-expand-sm > .container-md, .navbar-expand-sm > .container-lg, .navbar-expand-sm > .container-xl {
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    }
    .navbar-expand-sm .navbar-nav-scroll {
        overflow: visible;
    }
    .navbar-expand-sm .navbar-collapse {
        display: -ms-flexbox !important;
        display: flex !important;
        -ms-flex-preferred-size: auto;
        flex-basis: auto;
    }
    .navbar-expand-sm .navbar-toggler {
        display: none;
    }
}

@media (max-width: 767.98px) {
    .navbar-expand-md > .container,
    .navbar-expand-md > .container-fluid, .navbar-expand-md > .container-sm, .navbar-expand-md > .container-md, .navbar-expand-md > .container-lg, .navbar-expand-md > .container-xl {
        padding-right: 0;
        padding-left: 0;
    }
}

@media (min-width: 768px) {
    .navbar-expand-md {
        -ms-flex-flow: row nowrap;
        flex-flow: row nowrap;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }
    .navbar-expand-md .navbar-nav {
        -ms-flex-direction: row;
        flex-direction: row;
    }
    .navbar-expand-md .navbar-nav .dropdown-menu {
        position: absolute;
    }
    .navbar-expand-md .navbar-nav .nav-link {
        padding-right: 0.5rem;
        padding-left: 0.5rem;
    }
    .navbar-expand-md > .container,
    .navbar-expand-md > .container-fluid, .navbar-expand-md > .container-sm, .navbar-expand-md > .container-md, .navbar-expand-md > .container-lg, .navbar-expand-md > .container-xl {
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    }
    .navbar-expand-md .navbar-nav-scroll {
        overflow: visible;
    }
    .navbar-expand-md .navbar-collapse {
        display: -ms-flexbox !important;
        display: flex !important;
        -ms-flex-preferred-size: auto;
        flex-basis: auto;
    }
    .navbar-expand-md .navbar-toggler {
        display: none;
    }
}

@media (max-width: 991.98px) {
    .navbar-expand-lg > .container,
    .navbar-expand-lg > .container-fluid, .navbar-expand-lg > .container-sm, .navbar-expand-lg > .container-md, .navbar-expand-lg > .container-lg, .navbar-expand-lg > .container-xl {
        padding-right: 0;
        padding-left: 0;
    }
}

@media (min-width: 992px) {
    .navbar-expand-lg {
        -ms-flex-flow: row nowrap;
        flex-flow: row nowrap;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }
    .navbar-expand-lg .navbar-nav {
        -ms-flex-direction: row;
        flex-direction: row;
    }
    .navbar-expand-lg .navbar-nav .dropdown-menu {
        position: absolute;
    }
    .navbar-expand-lg .navbar-nav .nav-link {
        padding-right: 0.5rem;
        padding-left: 0.5rem;
    }
    .navbar-expand-lg > .container,
    .navbar-expand-lg > .container-fluid, .navbar-expand-lg > .container-sm, .navbar-expand-lg > .container-md, .navbar-expand-lg > .container-lg, .navbar-expand-lg > .container-xl {
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    }
    .navbar-expand-lg .navbar-nav-scroll {
        overflow: visible;
    }
    .navbar-expand-lg .navbar-collapse {
        display: -ms-flexbox !important;
        display: flex !important;
        -ms-flex-preferred-size: auto;
        flex-basis: auto;
    }
    .navbar-expand-lg .navbar-toggler {
        display: none;
    }
}

@media (max-width: 1199.98px) {
    .navbar-expand-xl > .container,
    .navbar-expand-xl > .container-fluid, .navbar-expand-xl > .container-sm, .navbar-expand-xl > .container-md, .navbar-expand-xl > .container-lg, .navbar-expand-xl > .container-xl {
        padding-right: 0;
        padding-left: 0;
    }
}

@media (min-width: 1200px) {
    .navbar-expand-xl {
        -ms-flex-flow: row nowrap;
        flex-flow: row nowrap;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }
    .navbar-expand-xl .navbar-nav {
        -ms-flex-direction: row;
        flex-direction: row;
    }
    .navbar-expand-xl .navbar-nav .dropdown-menu {
        position: absolute;
    }
    .navbar-expand-xl .navbar-nav .nav-link {
        padding-right: 0.5rem;
        padding-left: 0.5rem;
    }
    .navbar-expand-xl > .container,
    .navbar-expand-xl > .container-fluid, .navbar-expand-xl > .container-sm, .navbar-expand-xl > .container-md, .navbar-expand-xl > .container-lg, .navbar-expand-xl > .container-xl {
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    }
    .navbar-expand-xl .navbar-nav-scroll {
        overflow: visible;
    }
    .navbar-expand-xl .navbar-collapse {
        display: -ms-flexbox !important;
        display: flex !important;
        -ms-flex-preferred-size: auto;
        flex-basis: auto;
    }
    .navbar-expand-xl .navbar-toggler {
        display: none;
    }
}

.navbar-expand {
    -ms-flex-flow: row nowrap;
    flex-flow: row nowrap;
    -ms-flex-pack: start;
    justify-content: flex-start;
}

.navbar-expand > .container,
.navbar-expand > .container-fluid, .navbar-expand > .container-sm, .navbar-expand > .container-md, .navbar-expand > .container-lg, .navbar-expand > .container-xl {
    padding-right: 0;
    padding-left: 0;
}

.navbar-expand .navbar-nav {
    -ms-flex-direction: row;
    flex-direction: row;
}

.navbar-expand .navbar-nav .dropdown-menu {
    position: absolute;
}

.navbar-expand .navbar-nav .nav-link {
    padding-right: 0.5rem;
    padding-left: 0.5rem;
}

.navbar-expand > .container,
.navbar-expand > .container-fluid, .navbar-expand > .container-sm, .navbar-expand > .container-md, .navbar-expand > .container-lg, .navbar-expand > .container-xl {
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
}

.navbar-expand .navbar-nav-scroll {
    overflow: visible;
}

.navbar-expand .navbar-collapse {
    display: -ms-flexbox !important;
    display: flex !important;
    -ms-flex-preferred-size: auto;
    flex-basis: auto;
}

.navbar-expand .navbar-toggler {
    display: none;
}

.navbar-light .navbar-brand {
    color: rgba(0, 0, 0, 0.9);
}

.navbar-light .navbar-brand:hover, .navbar-light .navbar-brand:focus {
    color: rgba(0, 0, 0, 0.9);
}

.navbar-light .navbar-nav .nav-link {
    color: rgba(0, 0, 0, 0.5);
}

.navbar-light .navbar-nav .nav-link:hover, .navbar-light .navbar-nav .nav-link:focus {
    color: rgba(0, 0, 0, 0.7);
}

.navbar-light .navbar-nav .nav-link.disabled {
    color: rgba(0, 0, 0, 0.3);
}

.navbar-light .navbar-nav .show > .nav-link,
.navbar-light .navbar-nav .active > .nav-link,
.navbar-light .navbar-nav .nav-link.show,
.navbar-light .navbar-nav .nav-link.active {
    color: rgba(0, 0, 0, 0.9);
}

.navbar-light .navbar-toggler {
    color: rgba(0, 0, 0, 0.5);
    border-color: rgba(0, 0, 0, 0.1);
}

.navbar-light .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%280, 0, 0, 0.5%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

.navbar-light .navbar-text {
    color: rgba(0, 0, 0, 0.5);
}

.navbar-light .navbar-text a {
    color: rgba(0, 0, 0, 0.9);
}

.navbar-light .navbar-text a:hover, .navbar-light .navbar-text a:focus {
    color: rgba(0, 0, 0, 0.9);
}

.navbar-dark .navbar-brand {
    color: #fff;
}

.navbar-dark .navbar-brand:hover, .navbar-dark .navbar-brand:focus {
    color: #fff;
}

.navbar-dark .navbar-nav .nav-link {
    color: rgba(255, 255, 255, 0.5);
}

.navbar-dark .navbar-nav .nav-link:hover, .navbar-dark .navbar-nav .nav-link:focus {
    color: rgba(255, 255, 255, 0.75);
}

.navbar-dark .navbar-nav .nav-link.disabled {
    color: rgba(255, 255, 255, 0.25);
}

.navbar-dark .navbar-nav .show > .nav-link,
.navbar-dark .navbar-nav .active > .nav-link,
.navbar-dark .navbar-nav .nav-link.show,
.navbar-dark .navbar-nav .nav-link.active {
    color: #fff;
}

.navbar-dark .navbar-toggler {
    color: rgba(255, 255, 255, 0.5);
    border-color: rgba(255, 255, 255, 0.1);
}

.navbar-dark .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.5%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

.navbar-dark .navbar-text {
    color: rgba(255, 255, 255, 0.5);
}

.navbar-dark .navbar-text a {
    color: #fff;
}

.navbar-dark .navbar-text a:hover, .navbar-dark .navbar-text a:focus {
    color: #fff;
}

.bg-dark {
    background-color: #343a40 !important;
}

.bg-gray-light {
    background-color: #e1e0e0 !important;
}

.bg-green-oiler {
    background-color: #6db672 !important;
}

.bg-green-oiler .nav-link > span {
    color: white;
}

.bg-green-oiler div>ul>li>a {
    color: white !important;
}

a.bg-dark:hover, a.bg-dark:focus,
button.bg-dark:hover,
button.bg-dark:focus {
    background-color: #1d2124 !important;
}

.m-auto {
    margin: auto !important;
}

.mt-auto,
.my-auto {
    margin-top: auto !important;
}

.mr-auto,
.mx-auto {
    margin-right: auto !important;
}

.mb-auto,
.my-auto {
    margin-bottom: auto !important;
}

.ml-auto,
.mx-auto {
    margin-left: auto !important;
}

@media (min-width: 576px) {
    .m-sm-0 {
        margin: 0 !important;
    }
    .mt-sm-0,
    .my-sm-0 {
        margin-top: 0 !important;
    }
    .mr-sm-0,
    .mx-sm-0 {
        margin-right: 0 !important;
    }
    .mb-sm-0,
    .my-sm-0 {
        margin-bottom: 0 !important;
    }
    .ml-sm-0,
    .mx-sm-0 {
        margin-left: 0 !important;
    }
    .m-sm-1 {
        margin: 0.25rem !important;
    }
    .mt-sm-1,
    .my-sm-1 {
        margin-top: 0.25rem !important;
    }
    .mr-sm-1,
    .mx-sm-1 {
        margin-right: 0.25rem !important;
    }
    .mb-sm-1,
    .my-sm-1 {
        margin-bottom: 0.25rem !important;
    }
    .ml-sm-1,
    .mx-sm-1 {
        margin-left: 0.25rem !important;
    }
    .m-sm-2 {
        margin: 0.5rem !important;
    }
    .mt-sm-2,
    .my-sm-2 {
        margin-top: 0.5rem !important;
    }
    .mr-sm-2,
    .mx-sm-2 {
        margin-right: 0.5rem !important;
    }
    .mb-sm-2,
    .my-sm-2 {
        margin-bottom: 0.5rem !important;
    }
    .ml-sm-2,
    .mx-sm-2 {
        margin-left: 0.5rem !important;
    }
    .m-sm-3 {
        margin: 1rem !important;
    }
    .mt-sm-3,
    .my-sm-3 {
        margin-top: 1rem !important;
    }
    .mr-sm-3,
    .mx-sm-3 {
        margin-right: 1rem !important;
    }
    .mb-sm-3,
    .my-sm-3 {
        margin-bottom: 1rem !important;
    }
    .ml-sm-3,
    .mx-sm-3 {
        margin-left: 1rem !important;
    }
    .m-sm-4 {
        margin: 1.5rem !important;
    }
    .mt-sm-4,
    .my-sm-4 {
        margin-top: 1.5rem !important;
    }
    .mr-sm-4,
    .mx-sm-4 {
        margin-right: 1.5rem !important;
    }
    .mb-sm-4,
    .my-sm-4 {
        margin-bottom: 1.5rem !important;
    }
    .ml-sm-4,
    .mx-sm-4 {
        margin-left: 1.5rem !important;
    }
    .m-sm-5 {
        margin: 3rem !important;
    }
    .mt-sm-5,
    .my-sm-5 {
        margin-top: 3rem !important;
    }
    .mr-sm-5,
    .mx-sm-5 {
        margin-right: 3rem !important;
    }
    .mb-sm-5,
    .my-sm-5 {
        margin-bottom: 3rem !important;
    }
    .ml-sm-5,
    .mx-sm-5 {
        margin-left: 3rem !important;
    }
    .p-sm-0 {
        padding: 0 !important;
    }
    .pt-sm-0,
    .py-sm-0 {
        padding-top: 0 !important;
    }
    .pr-sm-0,
    .px-sm-0 {
        padding-right: 0 !important;
    }
    .pb-sm-0,
    .py-sm-0 {
        padding-bottom: 0 !important;
    }
    .pl-sm-0,
    .px-sm-0 {
        padding-left: 0 !important;
    }
    .p-sm-1 {
        padding: 0.25rem !important;
    }
    .pt-sm-1,
    .py-sm-1 {
        padding-top: 0.25rem !important;
    }
    .pr-sm-1,
    .px-sm-1 {
        padding-right: 0.25rem !important;
    }
    .pb-sm-1,
    .py-sm-1 {
        padding-bottom: 0.25rem !important;
    }
    .pl-sm-1,
    .px-sm-1 {
        padding-left: 0.25rem !important;
    }
    .p-sm-2 {
        padding: 0.5rem !important;
    }
    .pt-sm-2,
    .py-sm-2 {
        padding-top: 0.5rem !important;
    }
    .pr-sm-2,
    .px-sm-2 {
        padding-right: 0.5rem !important;
    }
    .pb-sm-2,
    .py-sm-2 {
        padding-bottom: 0.5rem !important;
    }
    .pl-sm-2,
    .px-sm-2 {
        padding-left: 0.5rem !important;
    }
    .p-sm-3 {
        padding: 1rem !important;
    }
    .pt-sm-3,
    .py-sm-3 {
        padding-top: 1rem !important;
    }
    .pr-sm-3,
    .px-sm-3 {
        padding-right: 1rem !important;
    }
    .pb-sm-3,
    .py-sm-3 {
        padding-bottom: 1rem !important;
    }
    .pl-sm-3,
    .px-sm-3 {
        padding-left: 1rem !important;
    }
    .p-sm-4 {
        padding: 1.5rem !important;
    }
    .pt-sm-4,
    .py-sm-4 {
        padding-top: 1.5rem !important;
    }
    .pr-sm-4,
    .px-sm-4 {
        padding-right: 1.5rem !important;
    }
    .pb-sm-4,
    .py-sm-4 {
        padding-bottom: 1.5rem !important;
    }
    .pl-sm-4,
    .px-sm-4 {
        padding-left: 1.5rem !important;
    }
    .p-sm-5 {
        padding: 3rem !important;
    }
    .pt-sm-5,
    .py-sm-5 {
        padding-top: 3rem !important;
    }
    .pr-sm-5,
    .px-sm-5 {
        padding-right: 3rem !important;
    }
    .pb-sm-5,
    .py-sm-5 {
        padding-bottom: 3rem !important;
    }
    .pl-sm-5,
    .px-sm-5 {
        padding-left: 3rem !important;
    }
    .m-sm-n1 {
        margin: -0.25rem !important;
    }
    .mt-sm-n1,
    .my-sm-n1 {
        margin-top: -0.25rem !important;
    }
    .mr-sm-n1,
    .mx-sm-n1 {
        margin-right: -0.25rem !important;
    }
    .mb-sm-n1,
    .my-sm-n1 {
        margin-bottom: -0.25rem !important;
    }
    .ml-sm-n1,
    .mx-sm-n1 {
        margin-left: -0.25rem !important;
    }
    .m-sm-n2 {
        margin: -0.5rem !important;
    }
    .mt-sm-n2,
    .my-sm-n2 {
        margin-top: -0.5rem !important;
    }
    .mr-sm-n2,
    .mx-sm-n2 {
        margin-right: -0.5rem !important;
    }
    .mb-sm-n2,
    .my-sm-n2 {
        margin-bottom: -0.5rem !important;
    }
    .ml-sm-n2,
    .mx-sm-n2 {
        margin-left: -0.5rem !important;
    }
    .m-sm-n3 {
        margin: -1rem !important;
    }
    .mt-sm-n3,
    .my-sm-n3 {
        margin-top: -1rem !important;
    }
    .mr-sm-n3,
    .mx-sm-n3 {
        margin-right: -1rem !important;
    }
    .mb-sm-n3,
    .my-sm-n3 {
        margin-bottom: -1rem !important;
    }
    .ml-sm-n3,
    .mx-sm-n3 {
        margin-left: -1rem !important;
    }
    .m-sm-n4 {
        margin: -1.5rem !important;
    }
    .mt-sm-n4,
    .my-sm-n4 {
        margin-top: -1.5rem !important;
    }
    .mr-sm-n4,
    .mx-sm-n4 {
        margin-right: -1.5rem !important;
    }
    .mb-sm-n4,
    .my-sm-n4 {
        margin-bottom: -1.5rem !important;
    }
    .ml-sm-n4,
    .mx-sm-n4 {
        margin-left: -1.5rem !important;
    }
    .m-sm-n5 {
        margin: -3rem !important;
    }
    .mt-sm-n5,
    .my-sm-n5 {
        margin-top: -3rem !important;
    }
    .mr-sm-n5,
    .mx-sm-n5 {
        margin-right: -3rem !important;
    }
    .mb-sm-n5,
    .my-sm-n5 {
        margin-bottom: -3rem !important;
    }
    .ml-sm-n5,
    .mx-sm-n5 {
        margin-left: -3rem !important;
    }
    .m-sm-auto {
        margin: auto !important;
    }
    .mt-sm-auto,
    .my-sm-auto {
        margin-top: auto !important;
    }
    .mr-sm-auto,
    .mx-sm-auto {
        margin-right: auto !important;
    }
    .mb-sm-auto,
    .my-sm-auto {
        margin-bottom: auto !important;
    }
    .ml-sm-auto,
    .mx-sm-auto {
        margin-left: auto !important;
    }
}

@media (min-width: 768px) {
    .m-md-0 {
        margin: 0 !important;
    }
    .mt-md-0,
    .my-md-0 {
        margin-top: 0 !important;
    }
    .mr-md-0,
    .mx-md-0 {
        margin-right: 0 !important;
    }
    .mb-md-0,
    .my-md-0 {
        margin-bottom: 0 !important;
    }
    .ml-md-0,
    .mx-md-0 {
        margin-left: 0 !important;
    }
    .m-md-1 {
        margin: 0.25rem !important;
    }
    .mt-md-1,
    .my-md-1 {
        margin-top: 0.25rem !important;
    }
    .mr-md-1,
    .mx-md-1 {
        margin-right: 0.25rem !important;
    }
    .mb-md-1,
    .my-md-1 {
        margin-bottom: 0.25rem !important;
    }
    .ml-md-1,
    .mx-md-1 {
        margin-left: 0.25rem !important;
    }
    .m-md-2 {
        margin: 0.5rem !important;
    }
    .mt-md-2,
    .my-md-2 {
        margin-top: 0.5rem !important;
    }
    .mr-md-2,
    .mx-md-2 {
        margin-right: 0.5rem !important;
    }
    .mb-md-2,
    .my-md-2 {
        margin-bottom: 0.5rem !important;
    }
    .ml-md-2,
    .mx-md-2 {
        margin-left: 0.5rem !important;
    }
    .m-md-3 {
        margin: 1rem !important;
    }
    .mt-md-3,
    .my-md-3 {
        margin-top: 1rem !important;
    }
    .mr-md-3,
    .mx-md-3 {
        margin-right: 1rem !important;
    }
    .mb-md-3,
    .my-md-3 {
        margin-bottom: 1rem !important;
    }
    .ml-md-3,
    .mx-md-3 {
        margin-left: 1rem !important;
    }
    .m-md-4 {
        margin: 1.5rem !important;
    }
    .mt-md-4,
    .my-md-4 {
        margin-top: 1.5rem !important;
    }
    .mr-md-4,
    .mx-md-4 {
        margin-right: 1.5rem !important;
    }
    .mb-md-4,
    .my-md-4 {
        margin-bottom: 1.5rem !important;
    }
    .ml-md-4,
    .mx-md-4 {
        margin-left: 1.5rem !important;
    }
    .m-md-5 {
        margin: 3rem !important;
    }
    .mt-md-5,
    .my-md-5 {
        margin-top: 3rem !important;
    }
    .mr-md-5,
    .mx-md-5 {
        margin-right: 3rem !important;
    }
    .mb-md-5,
    .my-md-5 {
        margin-bottom: 3rem !important;
    }
    .ml-md-5,
    .mx-md-5 {
        margin-left: 3rem !important;
    }
    .p-md-0 {
        padding: 0 !important;
    }
    .pt-md-0,
    .py-md-0 {
        padding-top: 0 !important;
    }
    .pr-md-0,
    .px-md-0 {
        padding-right: 0 !important;
    }
    .pb-md-0,
    .py-md-0 {
        padding-bottom: 0 !important;
    }
    .pl-md-0,
    .px-md-0 {
        padding-left: 0 !important;
    }
    .p-md-1 {
        padding: 0.25rem !important;
    }
    .pt-md-1,
    .py-md-1 {
        padding-top: 0.25rem !important;
    }
    .pr-md-1,
    .px-md-1 {
        padding-right: 0.25rem !important;
    }
    .pb-md-1,
    .py-md-1 {
        padding-bottom: 0.25rem !important;
    }
    .pl-md-1,
    .px-md-1 {
        padding-left: 0.25rem !important;
    }
    .p-md-2 {
        padding: 0.5rem !important;
    }
    .pt-md-2,
    .py-md-2 {
        padding-top: 0.5rem !important;
    }
    .pr-md-2,
    .px-md-2 {
        padding-right: 0.5rem !important;
    }
    .pb-md-2,
    .py-md-2 {
        padding-bottom: 0.5rem !important;
    }
    .pl-md-2,
    .px-md-2 {
        padding-left: 0.5rem !important;
    }
    .p-md-3 {
        padding: 1rem !important;
    }
    .pt-md-3,
    .py-md-3 {
        padding-top: 1rem !important;
    }
    .pr-md-3,
    .px-md-3 {
        padding-right: 1rem !important;
    }
    .pb-md-3,
    .py-md-3 {
        padding-bottom: 1rem !important;
    }
    .pl-md-3,
    .px-md-3 {
        padding-left: 1rem !important;
    }
    .p-md-4 {
        padding: 1.5rem !important;
    }
    .pt-md-4,
    .py-md-4 {
        padding-top: 1.5rem !important;
    }
    .pr-md-4,
    .px-md-4 {
        padding-right: 1.5rem !important;
    }
    .pb-md-4,
    .py-md-4 {
        padding-bottom: 1.5rem !important;
    }
    .pl-md-4,
    .px-md-4 {
        padding-left: 1.5rem !important;
    }
    .p-md-5 {
        padding: 3rem !important;
    }
    .pt-md-5,
    .py-md-5 {
        padding-top: 3rem !important;
    }
    .pr-md-5,
    .px-md-5 {
        padding-right: 3rem !important;
    }
    .pb-md-5,
    .py-md-5 {
        padding-bottom: 3rem !important;
    }
    .pl-md-5,
    .px-md-5 {
        padding-left: 3rem !important;
    }
    .m-md-n1 {
        margin: -0.25rem !important;
    }
    .mt-md-n1,
    .my-md-n1 {
        margin-top: -0.25rem !important;
    }
    .mr-md-n1,
    .mx-md-n1 {
        margin-right: -0.25rem !important;
    }
    .mb-md-n1,
    .my-md-n1 {
        margin-bottom: -0.25rem !important;
    }
    .ml-md-n1,
    .mx-md-n1 {
        margin-left: -0.25rem !important;
    }
    .m-md-n2 {
        margin: -0.5rem !important;
    }
    .mt-md-n2,
    .my-md-n2 {
        margin-top: -0.5rem !important;
    }
    .mr-md-n2,
    .mx-md-n2 {
        margin-right: -0.5rem !important;
    }
    .mb-md-n2,
    .my-md-n2 {
        margin-bottom: -0.5rem !important;
    }
    .ml-md-n2,
    .mx-md-n2 {
        margin-left: -0.5rem !important;
    }
    .m-md-n3 {
        margin: -1rem !important;
    }
    .mt-md-n3,
    .my-md-n3 {
        margin-top: -1rem !important;
    }
    .mr-md-n3,
    .mx-md-n3 {
        margin-right: -1rem !important;
    }
    .mb-md-n3,
    .my-md-n3 {
        margin-bottom: -1rem !important;
    }
    .ml-md-n3,
    .mx-md-n3 {
        margin-left: -1rem !important;
    }
    .m-md-n4 {
        margin: -1.5rem !important;
    }
    .mt-md-n4,
    .my-md-n4 {
        margin-top: -1.5rem !important;
    }
    .mr-md-n4,
    .mx-md-n4 {
        margin-right: -1.5rem !important;
    }
    .mb-md-n4,
    .my-md-n4 {
        margin-bottom: -1.5rem !important;
    }
    .ml-md-n4,
    .mx-md-n4 {
        margin-left: -1.5rem !important;
    }
    .m-md-n5 {
        margin: -3rem !important;
    }
    .mt-md-n5,
    .my-md-n5 {
        margin-top: -3rem !important;
    }
    .mr-md-n5,
    .mx-md-n5 {
        margin-right: -3rem !important;
    }
    .mb-md-n5,
    .my-md-n5 {
        margin-bottom: -3rem !important;
    }
    .ml-md-n5,
    .mx-md-n5 {
        margin-left: -3rem !important;
    }
    .m-md-auto {
        margin: auto !important;
    }
    .mt-md-auto,
    .my-md-auto {
        margin-top: auto !important;
    }
    .mr-md-auto,
    .mx-md-auto {
        margin-right: auto !important;
    }
    .mb-md-auto,
    .my-md-auto {
        margin-bottom: auto !important;
    }
    .ml-md-auto,
    .mx-md-auto {
        margin-left: auto !important;
    }
}

@media (min-width: 992px) {
    .m-lg-0 {
        margin: 0 !important;
    }
    .mt-lg-0,
    .my-lg-0 {
        margin-top: 0 !important;
    }
    .mr-lg-0,
    .mx-lg-0 {
        margin-right: 0 !important;
    }
    .mb-lg-0,
    .my-lg-0 {
        margin-bottom: 0 !important;
    }
    .ml-lg-0,
    .mx-lg-0 {
        margin-left: 0 !important;
    }
    .m-lg-1 {
        margin: 0.25rem !important;
    }
    .mt-lg-1,
    .my-lg-1 {
        margin-top: 0.25rem !important;
    }
    .mr-lg-1,
    .mx-lg-1 {
        margin-right: 0.25rem !important;
    }
    .mb-lg-1,
    .my-lg-1 {
        margin-bottom: 0.25rem !important;
    }
    .ml-lg-1,
    .mx-lg-1 {
        margin-left: 0.25rem !important;
    }
    .m-lg-2 {
        margin: 0.5rem !important;
    }
    .mt-lg-2,
    .my-lg-2 {
        margin-top: 0.5rem !important;
    }
    .mr-lg-2,
    .mx-lg-2 {
        margin-right: 0.5rem !important;
    }
    .mb-lg-2,
    .my-lg-2 {
        margin-bottom: 0.5rem !important;
    }
    .ml-lg-2,
    .mx-lg-2 {
        margin-left: 0.5rem !important;
    }
    .m-lg-3 {
        margin: 1rem !important;
    }
    .mt-lg-3,
    .my-lg-3 {
        margin-top: 1rem !important;
    }
    .mr-lg-3,
    .mx-lg-3 {
        margin-right: 1rem !important;
    }
    .mb-lg-3,
    .my-lg-3 {
        margin-bottom: 1rem !important;
    }
    .ml-lg-3,
    .mx-lg-3 {
        margin-left: 1rem !important;
    }
    .m-lg-4 {
        margin: 1.5rem !important;
    }
    .mt-lg-4,
    .my-lg-4 {
        margin-top: 1.5rem !important;
    }
    .mr-lg-4,
    .mx-lg-4 {
        margin-right: 1.5rem !important;
    }
    .mb-lg-4,
    .my-lg-4 {
        margin-bottom: 1.5rem !important;
    }
    .ml-lg-4,
    .mx-lg-4 {
        margin-left: 1.5rem !important;
    }
    .m-lg-5 {
        margin: 3rem !important;
    }
    .mt-lg-5,
    .my-lg-5 {
        margin-top: 3rem !important;
    }
    .mr-lg-5,
    .mx-lg-5 {
        margin-right: 3rem !important;
    }
    .mb-lg-5,
    .my-lg-5 {
        margin-bottom: 3rem !important;
    }
    .ml-lg-5,
    .mx-lg-5 {
        margin-left: 3rem !important;
    }
    .p-lg-0 {
        padding: 0 !important;
    }
    .pt-lg-0,
    .py-lg-0 {
        padding-top: 0 !important;
    }
    .pr-lg-0,
    .px-lg-0 {
        padding-right: 0 !important;
    }
    .pb-lg-0,
    .py-lg-0 {
        padding-bottom: 0 !important;
    }
    .pl-lg-0,
    .px-lg-0 {
        padding-left: 0 !important;
    }
    .p-lg-1 {
        padding: 0.25rem !important;
    }
    .pt-lg-1,
    .py-lg-1 {
        padding-top: 0.25rem !important;
    }
    .pr-lg-1,
    .px-lg-1 {
        padding-right: 0.25rem !important;
    }
    .pb-lg-1,
    .py-lg-1 {
        padding-bottom: 0.25rem !important;
    }
    .pl-lg-1,
    .px-lg-1 {
        padding-left: 0.25rem !important;
    }
    .p-lg-2 {
        padding: 0.5rem !important;
    }
    .pt-lg-2,
    .py-lg-2 {
        padding-top: 0.5rem !important;
    }
    .pr-lg-2,
    .px-lg-2 {
        padding-right: 0.5rem !important;
    }
    .pb-lg-2,
    .py-lg-2 {
        padding-bottom: 0.5rem !important;
    }
    .pl-lg-2,
    .px-lg-2 {
        padding-left: 0.5rem !important;
    }
    .p-lg-3 {
        padding: 1rem !important;
    }
    .pt-lg-3,
    .py-lg-3 {
        padding-top: 1rem !important;
    }
    .pr-lg-3,
    .px-lg-3 {
        padding-right: 1rem !important;
    }
    .pb-lg-3,
    .py-lg-3 {
        padding-bottom: 1rem !important;
    }
    .pl-lg-3,
    .px-lg-3 {
        padding-left: 1rem !important;
    }
    .p-lg-4 {
        padding: 1.5rem !important;
    }
    .pt-lg-4,
    .py-lg-4 {
        padding-top: 1.5rem !important;
    }
    .pr-lg-4,
    .px-lg-4 {
        padding-right: 1.5rem !important;
    }
    .pb-lg-4,
    .py-lg-4 {
        padding-bottom: 1.5rem !important;
    }
    .pl-lg-4,
    .px-lg-4 {
        padding-left: 1.5rem !important;
    }
    .p-lg-5 {
        padding: 3rem !important;
    }
    .pt-lg-5,
    .py-lg-5 {
        padding-top: 3rem !important;
    }
    .pr-lg-5,
    .px-lg-5 {
        padding-right: 3rem !important;
    }
    .pb-lg-5,
    .py-lg-5 {
        padding-bottom: 3rem !important;
    }
    .pl-lg-5,
    .px-lg-5 {
        padding-left: 3rem !important;
    }
    .m-lg-n1 {
        margin: -0.25rem !important;
    }
    .mt-lg-n1,
    .my-lg-n1 {
        margin-top: -0.25rem !important;
    }
    .mr-lg-n1,
    .mx-lg-n1 {
        margin-right: -0.25rem !important;
    }
    .mb-lg-n1,
    .my-lg-n1 {
        margin-bottom: -0.25rem !important;
    }
    .ml-lg-n1,
    .mx-lg-n1 {
        margin-left: -0.25rem !important;
    }
    .m-lg-n2 {
        margin: -0.5rem !important;
    }
    .mt-lg-n2,
    .my-lg-n2 {
        margin-top: -0.5rem !important;
    }
    .mr-lg-n2,
    .mx-lg-n2 {
        margin-right: -0.5rem !important;
    }
    .mb-lg-n2,
    .my-lg-n2 {
        margin-bottom: -0.5rem !important;
    }
    .ml-lg-n2,
    .mx-lg-n2 {
        margin-left: -0.5rem !important;
    }
    .m-lg-n3 {
        margin: -1rem !important;
    }
    .mt-lg-n3,
    .my-lg-n3 {
        margin-top: -1rem !important;
    }
    .mr-lg-n3,
    .mx-lg-n3 {
        margin-right: -1rem !important;
    }
    .mb-lg-n3,
    .my-lg-n3 {
        margin-bottom: -1rem !important;
    }
    .ml-lg-n3,
    .mx-lg-n3 {
        margin-left: -1rem !important;
    }
    .m-lg-n4 {
        margin: -1.5rem !important;
    }
    .mt-lg-n4,
    .my-lg-n4 {
        margin-top: -1.5rem !important;
    }
    .mr-lg-n4,
    .mx-lg-n4 {
        margin-right: -1.5rem !important;
    }
    .mb-lg-n4,
    .my-lg-n4 {
        margin-bottom: -1.5rem !important;
    }
    .ml-lg-n4,
    .mx-lg-n4 {
        margin-left: -1.5rem !important;
    }
    .m-lg-n5 {
        margin: -3rem !important;
    }
    .mt-lg-n5,
    .my-lg-n5 {
        margin-top: -3rem !important;
    }
    .mr-lg-n5,
    .mx-lg-n5 {
        margin-right: -3rem !important;
    }
    .mb-lg-n5,
    .my-lg-n5 {
        margin-bottom: -3rem !important;
    }
    .ml-lg-n5,
    .mx-lg-n5 {
        margin-left: -3rem !important;
    }
    .m-lg-auto {
        margin: auto !important;
    }
    .mt-lg-auto,
    .my-lg-auto {
        margin-top: auto !important;
    }
    .mr-lg-auto,
    .mx-lg-auto {
        margin-right: auto !important;
    }
    .mb-lg-auto,
    .my-lg-auto {
        margin-bottom: auto !important;
    }
    .ml-lg-auto,
    .mx-lg-auto {
        margin-left: auto !important;
    }
}

@media (min-width: 1200px) {
    .m-xl-0 {
        margin: 0 !important;
    }
    .mt-xl-0,
    .my-xl-0 {
        margin-top: 0 !important;
    }
    .mr-xl-0,
    .mx-xl-0 {
        margin-right: 0 !important;
    }
    .mb-xl-0,
    .my-xl-0 {
        margin-bottom: 0 !important;
    }
    .ml-xl-0,
    .mx-xl-0 {
        margin-left: 0 !important;
    }
    .m-xl-1 {
        margin: 0.25rem !important;
    }
    .mt-xl-1,
    .my-xl-1 {
        margin-top: 0.25rem !important;
    }
    .mr-xl-1,
    .mx-xl-1 {
        margin-right: 0.25rem !important;
    }
    .mb-xl-1,
    .my-xl-1 {
        margin-bottom: 0.25rem !important;
    }
    .ml-xl-1,
    .mx-xl-1 {
        margin-left: 0.25rem !important;
    }
    .m-xl-2 {
        margin: 0.5rem !important;
    }
    .mt-xl-2,
    .my-xl-2 {
        margin-top: 0.5rem !important;
    }
    .mr-xl-2,
    .mx-xl-2 {
        margin-right: 0.5rem !important;
    }
    .mb-xl-2,
    .my-xl-2 {
        margin-bottom: 0.5rem !important;
    }
    .ml-xl-2,
    .mx-xl-2 {
        margin-left: 0.5rem !important;
    }
    .m-xl-3 {
        margin: 1rem !important;
    }
    .mt-xl-3,
    .my-xl-3 {
        margin-top: 1rem !important;
    }
    .mr-xl-3,
    .mx-xl-3 {
        margin-right: 1rem !important;
    }
    .mb-xl-3,
    .my-xl-3 {
        margin-bottom: 1rem !important;
    }
    .ml-xl-3,
    .mx-xl-3 {
        margin-left: 1rem !important;
    }
    .m-xl-4 {
        margin: 1.5rem !important;
    }
    .mt-xl-4,
    .my-xl-4 {
        margin-top: 1.5rem !important;
    }
    .mr-xl-4,
    .mx-xl-4 {
        margin-right: 1.5rem !important;
    }
    .mb-xl-4,
    .my-xl-4 {
        margin-bottom: 1.5rem !important;
    }
    .ml-xl-4,
    .mx-xl-4 {
        margin-left: 1.5rem !important;
    }
    .m-xl-5 {
        margin: 3rem !important;
    }
    .mt-xl-5,
    .my-xl-5 {
        margin-top: 3rem !important;
    }
    .mr-xl-5,
    .mx-xl-5 {
        margin-right: 3rem !important;
    }
    .mb-xl-5,
    .my-xl-5 {
        margin-bottom: 3rem !important;
    }
    .ml-xl-5,
    .mx-xl-5 {
        margin-left: 3rem !important;
    }
    .p-xl-0 {
        padding: 0 !important;
    }
    .pt-xl-0,
    .py-xl-0 {
        padding-top: 0 !important;
    }
    .pr-xl-0,
    .px-xl-0 {
        padding-right: 0 !important;
    }
    .pb-xl-0,
    .py-xl-0 {
        padding-bottom: 0 !important;
    }
    .pl-xl-0,
    .px-xl-0 {
        padding-left: 0 !important;
    }
    .p-xl-1 {
        padding: 0.25rem !important;
    }
    .pt-xl-1,
    .py-xl-1 {
        padding-top: 0.25rem !important;
    }
    .pr-xl-1,
    .px-xl-1 {
        padding-right: 0.25rem !important;
    }
    .pb-xl-1,
    .py-xl-1 {
        padding-bottom: 0.25rem !important;
    }
    .pl-xl-1,
    .px-xl-1 {
        padding-left: 0.25rem !important;
    }
    .p-xl-2 {
        padding: 0.5rem !important;
    }
    .pt-xl-2,
    .py-xl-2 {
        padding-top: 0.5rem !important;
    }
    .pr-xl-2,
    .px-xl-2 {
        padding-right: 0.5rem !important;
    }
    .pb-xl-2,
    .py-xl-2 {
        padding-bottom: 0.5rem !important;
    }
    .pl-xl-2,
    .px-xl-2 {
        padding-left: 0.5rem !important;
    }
    .p-xl-3 {
        padding: 1rem !important;
    }
    .pt-xl-3,
    .py-xl-3 {
        padding-top: 1rem !important;
    }
    .pr-xl-3,
    .px-xl-3 {
        padding-right: 1rem !important;
    }
    .pb-xl-3,
    .py-xl-3 {
        padding-bottom: 1rem !important;
    }
    .pl-xl-3,
    .px-xl-3 {
        padding-left: 1rem !important;
    }
    .p-xl-4 {
        padding: 1.5rem !important;
    }
    .pt-xl-4,
    .py-xl-4 {
        padding-top: 1.5rem !important;
    }
    .pr-xl-4,
    .px-xl-4 {
        padding-right: 1.5rem !important;
    }
    .pb-xl-4,
    .py-xl-4 {
        padding-bottom: 1.5rem !important;
    }
    .pl-xl-4,
    .px-xl-4 {
        padding-left: 1.5rem !important;
    }
    .p-xl-5 {
        padding: 3rem !important;
    }
    .pt-xl-5,
    .py-xl-5 {
        padding-top: 3rem !important;
    }
    .pr-xl-5,
    .px-xl-5 {
        padding-right: 3rem !important;
    }
    .pb-xl-5,
    .py-xl-5 {
        padding-bottom: 3rem !important;
    }
    .pl-xl-5,
    .px-xl-5 {
        padding-left: 3rem !important;
    }
    .m-xl-n1 {
        margin: -0.25rem !important;
    }
    .mt-xl-n1,
    .my-xl-n1 {
        margin-top: -0.25rem !important;
    }
    .mr-xl-n1,
    .mx-xl-n1 {
        margin-right: -0.25rem !important;
    }
    .mb-xl-n1,
    .my-xl-n1 {
        margin-bottom: -0.25rem !important;
    }
    .ml-xl-n1,
    .mx-xl-n1 {
        margin-left: -0.25rem !important;
    }
    .m-xl-n2 {
        margin: -0.5rem !important;
    }
    .mt-xl-n2,
    .my-xl-n2 {
        margin-top: -0.5rem !important;
    }
    .mr-xl-n2,
    .mx-xl-n2 {
        margin-right: -0.5rem !important;
    }
    .mb-xl-n2,
    .my-xl-n2 {
        margin-bottom: -0.5rem !important;
    }
    .ml-xl-n2,
    .mx-xl-n2 {
        margin-left: -0.5rem !important;
    }
    .m-xl-n3 {
        margin: -1rem !important;
    }
    .mt-xl-n3,
    .my-xl-n3 {
        margin-top: -1rem !important;
    }
    .mr-xl-n3,
    .mx-xl-n3 {
        margin-right: -1rem !important;
    }
    .mb-xl-n3,
    .my-xl-n3 {
        margin-bottom: -1rem !important;
    }
    .ml-xl-n3,
    .mx-xl-n3 {
        margin-left: -1rem !important;
    }
    .m-xl-n4 {
        margin: -1.5rem !important;
    }
    .mt-xl-n4,
    .my-xl-n4 {
        margin-top: -1.5rem !important;
    }
    .mr-xl-n4,
    .mx-xl-n4 {
        margin-right: -1.5rem !important;
    }
    .mb-xl-n4,
    .my-xl-n4 {
        margin-bottom: -1.5rem !important;
    }
    .ml-xl-n4,
    .mx-xl-n4 {
        margin-left: -1.5rem !important;
    }
    .m-xl-n5 {
        margin: -3rem !important;
    }
    .mt-xl-n5,
    .my-xl-n5 {
        margin-top: -3rem !important;
    }
    .mr-xl-n5,
    .mx-xl-n5 {
        margin-right: -3rem !important;
    }
    .mb-xl-n5,
    .my-xl-n5 {
        margin-bottom: -3rem !important;
    }
    .ml-xl-n5,
    .mx-xl-n5 {
        margin-left: -3rem !important;
    }
    .m-xl-auto {
        margin: auto !important;
    }
    .mt-xl-auto,
    .my-xl-auto {
        margin-top: auto !important;
    }
    .mr-xl-auto,
    .mx-xl-auto {
        margin-right: auto !important;
    }
    .mb-xl-auto,
    .my-xl-auto {
        margin-bottom: auto !important;
    }
    .ml-xl-auto,
    .mx-xl-auto {
        margin-left: auto !important;
    }
}

.fixed-top {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: 1030;
}

.collapse:not(.show) {
    display: none;
}

.nav-dropdown>div {
    background-color: #ebebeb;
    position: absolute;
    right: 0;
    top: 71px;
    border-radius: 7.5px;
    width: 200px;
    z-index: 1;
    -webkit-transition: visibility 0.2s linear, opacity 0.2s linear;
    -moz-transition: visibility 0.2s linear, opacity 0.2s linear;
    -ms-transition: visibility 0.2s linear, opacity 0.2s linear;
    -o-transition: visibility 0.2s linear, opacity 0.2s linear;
    transition: visibility 0.2s linear, opacity 0.2s linear;
}

.nav-dropdown:hover>div {
    visibility: visible !important;
    opacity: 1 !important;
    transition-delay: 0s;
}

.nav-dropdown>div>ul {
    list-style-type: none;
    margin: 0;
    padding: 10px;
    text-align: right;
}

.nav-dropdown>div>ul>li {
    padding: 5px;
    text-transform: uppercase;
}

.nav-dropdown>div>ul>li>div.divider-small {
    float: right;
}

.nav-dropdown>div>ul>li>a {
    text-decoration: none;
    color: #6db672;
    font-size: 18px;
}

.nav-dropdown>div>ul>li>a:hover {
    text-decoration: underline;
}

.nav-link>img {
    vertical-align: top;
}

.navbar-brand>img {
    vertical-align: top;
}

.ultra-light-bold {
    margin: 0 !important;
    font-weight: 400;
}

.light-bold {
    margin: 0 !important;
    font-weight: 500;
}

.medium-bold {
    margin: 0 !important;
    font-weight: 600;
}

.overline {
    margin: 0 !important;
    text-decoration: overline;
}

@media (min-width: 768px) and (max-width: 991px) {
    .col-software {
        max-width: 28%;
        margin-right: 1%;
    }
}

@media (min-width: 992px)  {
    .col-software {
        max-width: 30%;
    }
}

.row-primary-detail {
    margin-left: 190px;
    margin-right: 190px;
    text-align: justify;
}

@media (min-width: 992px) and (max-width: 1199px) {
    .row-primary-detail {
        margin-left: 50px;
        margin-right: 50px;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .row-primary-detail {
        margin-left: 0;
        margin-right: 0;
    }

    .row-primary-table {
        margin-left: 5%;
    }

    .col-3-primary-table {
        max-width: 23%;
    }
}

@media (max-width: 767px) {
    .row-primary-detail {
        margin-left: 0;
        margin-right: 0;
    }

    .row-primary-detail-pres .col-3 {
        padding-left: 0;
        padding-right: 0;
    }
}

.row-primary-detail-pres {
    margin: 30px 160px 30px 160px;
    text-align: center;
}

@media (max-width: 480px) {
    .row-primary-detail-pres {
        margin: 20px 0 15px 0;

    }
}

@media (max-width: 767px) and (min-width: 481px) {
    .row-primary-detail-pres {
        margin: 30px 0 30px 0;

    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .row-primary-detail-pres {
        margin: 30px 0 30px 0;
    }
}

.row-primary-detail-cards {
    margin: 50px;
    text-align: center;
}

@media (max-width: 767px) {
    .row-primary-detail-cards {
        margin: 30px 0 30px 0;

    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .row-primary-detail-cards {
        margin: 30px 0 30px 0;
    }
}

.path-top-theme {
    text-transform: uppercase;
    font-weight: 500;
    font-size: 26px;
    margin-top: 10px;
    margin-bottom: -25px;
}

.tales-top-theme {
    color: #dd3c49;
}

.arte-top-theme {
    color: #ff7984;
}

.dekart-top-theme {
    color: #b5031a;
}

.zermelo-top-theme {
    color: #87cbd0;
}

.bul-top-theme {
    color: #3da2ad;
}

.lovleis-top-theme {
    color: #0D828E;
}

.pitagoras-top-theme {
    color: #ffc933;
}

.robinson-top-theme {
    color: #ffa51f;
}

.musa-top-theme {
    color: #E08700;
}

.lullo-top-theme {
    color: #cf8eed;
}

.pingo-top-theme {
    color: #9A52C1;
}

.kolman-top-theme {
    color: #7118a0;
}

.index-right-box {
    height: 100% !important;;
    border-radius: 0 !important;
}

.index-right-box-tales {
    background-color: #dd3c49 !important;;
}

.index-right-box-arte {
    background-color: #ff7984 !important;;
}

.index-right-box-dekart {
    background-color: #b5031a !important;;
}

.index-right-box-zermelo {
    background-color: #87cbd0 !important;;
}

.index-right-box-bul {
    background-color: #3da2ad !important;;
}

.index-right-box-lovleis {
    background-color: #0D828E !important;;
}

.index-right-box-pitagoras {
    background-color: #ffc933 !important;;
}

.index-right-box-robinson {
    background-color: #ffa51f !important;;
}

.index-right-box-musa {
    background-color: #E08700 !important;;
}

.index-right-box-lullo {
    background-color: #cf8eed !important;;
}

.index-right-box-pingo {
    background-color: #9A52C1 !important;;
}

.index-right-box-kolman {
    background-color: #7118a0 !important;;
}

/* CHI SIAMO */

.whatsapp-text-container {
    padding-left: 0 !important;
}

@media (max-width: 767px) {
    .whatsapp-text-container {
        padding-left: 15px !important;
    }
}

.whatsapp-icon-container {
    padding-left: 50px !important;
    padding-right: 0 !important;
}

@media (max-width: 767px) {
    .whatsapp-icon-container {
        padding-left: 0 !important;
    }
}

/* JP PLAYER */

@media (max-width: 575px) {
    .jp-video-270p {
        width: 380px !important;
    }
}

@media (max-width: 991px) and (min-width: 576px) {
    .music-player-container {
        margin-left: 20% !important;
    }
}

/* CUSTOM COLUMNS */

@media (max-width: 991px) and (min-width: 576px) {
    .col-ranking-3 {
        max-width: 28%;
    }

    .offset-ranking-1 {
        margin-left: 2%;
    }
}

.col-materials-btn-1, .col-materials-btn-2, .col-materials-btn-3 {
    padding-right: 0;
    padding-left: 0;
}

@media (max-width: 575px) {
    .col-materials-btn-1 {
        padding-right: 50px;
    }

    .col-materials-btn-2 {
        padding-right: 50px;
    }
}

@media (max-width: 991px) and (min-width: 576px) {
    .col-materials-btn-1 img {
        width: 90%;
    }

    .col-materials-btn-2 {
        padding-right: 50px;
    }

    .col-materials-btn-2 img {
        width: 90%;
    }

    .col-materials-btn-3 img {
        width: 90%;
    }
}

.mobile-typography .span-inline-margin-left {
    margin-left: 0 !important;
}

@media (max-width: 991px) {
    .mobile-typography .span-inline-margin-left {
        margin-left: 5px !important;
    }
}

@media (max-width: 991px) {
    .mobile-typography {
        line-height: 28px !important;
        font-size: 17px !important;
        text-align: left !important;
        padding: 0 24px !important;
    }

    .mobile-typography-element {
        line-height: 28px !important;
        font-size: 17px !important;
        text-align: left !important;
    }

    .mobile-typography span {
        margin: 0;
    }
}

.about-publications a {
    color: #6db672;
    text-decoration: none;
}

.about-publications a:hover {
    text-decoration: underline;
}

/* SCROLLBAR TECHNICAL SHEET TOPIC */

/* width */
::-webkit-scrollbar {
    width: 10px;
}

/* Handle */
::-webkit-scrollbar-thumb {
    background: #6db672;
}

/* Handle on hover */
::-webkit-scrollbar-thumb:hover {
    background: #549759;
}
/*
::-webkit-scrollbar-button {
    display: block;
    background-color: #0099FE;
    background-repeat: no-repeat;
    background-size: 50%;
}

::-webkit-scrollbar-button:horizontal:start:decrement {
    width: 22px;
    background-position: center;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='100' height='100' fill='rgb(256, 256, 256)'><polygon points='0,50 50,100 50,0'/></svg>");
}

::-webkit-scrollbar-button:horizontal:start:increment {
    display: none;
}

::-webkit-scrollbar-button:horizontal:end:decrement {
    display: none;
}

::-webkit-scrollbar-button:horizontal:end:increment {
    width: 22px;
    background-position:center right;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='100' height='100' fill='rgb(256, 256, 256)'><polygon points='0,0 0,100 50,50'/></svg>");
}
*/
/* QUILL JS */
.ql-align-center {
    text-align: center;
}

.ql-video.ql-align-center {
    display: block;
    margin: 0 auto;
}

.ql-align-left {
    text-align: left;
}

.ql-align-right {
    text-align: right;
}

.ql-size-small {
    font-size: .75em;
}

.ql-size-large {
    font-size: 1.5em;
}

.ql-size-huge {
    font-size: 2.5em;
}

span.ql-size-small, span.ql-size-large, span.ql-size-huge {
    margin: 0;
}

/* CKEDITOR 5 */

span.text-tiny, span.text-small, span.text-big, span.text-huge {
    margin: 0;
}

.text-tiny {
    font-size: .7em;
}

.text-small {
    font-size: .85em;
}

.text-big {
    font-size: 1.4em;
}

.text-huge {
    font-size: 1.8em;
}

.table table p {
    margin-bottom: 0;
}

/* SCUOLA PRIMARIA MATEMATICA ELEMENTARI */

.btn-outline-white {
    background-color: white;
}

.btn-outline-white:hover {
    background-color: #85C189;
}

.btn-outline-void {
    padding-top: 26px;
    background-color: white;
    color: #87cbd0;
    margin-top: 0 !important;
}

.btn-outline-void:hover, .btn-check:checked+.btn-outline-void {
    background-color: #87cbd0;
    color: white;
}

.btn-outline-peano {
    padding-top: 26px;
    background-color: white;
    color: #ffc933;
    margin-top: 0 !important;
}

.btn-outline-peano:hover, .btn-check:checked+.btn-outline-peano {
    background-color: #ffc933;
    color: white;
}

.btn-outline-kamil {
    padding-top: 26px;
    background-color: white;
    color: #cf8eed;
    margin-top: 0 !important;
}

.btn-outline-kamil:hover, .btn-check:checked+.btn-outline-kamil {
    background-color: #cf8eed;
    color: white;
}

.btn-outline-tarski {
    padding-top: 26px;
    text-transform: none;
    background-color: white;
    color: #ff7984;
    margin-top: 0 !important;
}

.btn-outline-tarski:hover, .btn-check:checked+.btn-outline-tarski {
    background-color: #ff7984;
    color: white;
}

@media(max-width: 480px) {
    .btn-group-container-primary {
        display: none;
    }
}

@media(min-width: 481px) {
    .btn-group-container-primary-mobile {
        display: none;
    }
}

.btn-outline-elementari-logica {
    background-color: white;
    color: #87cbd0;
    margin-top: 0 !important;
}

.btn-outline-elementari-logica:hover, .btn-check:checked+.btn-outline-elementari-logica {
    background-color: #87cbd0;
    color: white;
}

.btn-outline-elementari-numeri {
    background-color: white;
    color: #ffc933;
    margin-top: 0 !important;
}

.btn-outline-elementari-numeri:hover, .btn-check:checked+.btn-outline-elementari-numeri {
    background-color: #ffc933;
    color: white;
}

.btn-outline-elementari-relazioni {
    padding-top: 26px;
    background-color: white;
    color: #cf8eed;
    margin-top: 0 !important;
}

.btn-outline-elementari-relazioni:hover, .btn-check:checked+.btn-outline-elementari-relazioni {
    background-color: #cf8eed;
    color: white;
}

.btn-outline-elementari-figure {
    text-transform: none;
    background-color: white;
    color: #ff7984;
    margin-top: 0 !important;
}

.btn-outline-elementari-figure:hover, .btn-check:checked+.btn-outline-elementari-figure {
    background-color: #ff7984;
    color: white;
}

.btn-outline-elementari-giochi {
    text-transform: none;
    background-color: white;
    color: #6db672;
    margin-top: 0 !important;
}

.btn-outline-elementari-giochi:hover, .btn-check:checked+.btn-outline-elementari-giochi {
    background-color: #6db672;
    color: white;
}

@media (min-width: 481px) {
    .btn-outline-elementari-logica,
    .btn-outline-elementari-numeri {
        padding-top: 50px !important;
    }
    
    .btn-outline-elementari-figure,
    .btn-outline-elementari-giochi {
        padding-top: 32px !important;
    }
}

.d-flex {
    display: flex !important;
}

.w-100 {
    width: 100% !important;
}

.btn-lg {
    padding: .5rem 1rem;
    font-size: 1.25rem;
    border-radius: .3rem;
}

.btn-check{
    position:absolute;
    clip:rect(0,0,0,0);
    pointer-events:none
}
.btn-check:disabled+.btn,.btn-check[disabled]+.btn{
    pointer-events:none;
    filter:none;
    opacity:.65
}

.btn-group,.btn-group-vertical{
    position:relative;
    display:inline-flex;
    vertical-align:middle
}
.btn-group-vertical>.btn,.btn-group>.btn{
    position:relative;
    flex:1 1 auto
}
.btn-group-vertical>.btn-check:checked+.btn,.btn-group-vertical>.btn-check:focus+.btn,.btn-group-vertical>.btn.active,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn:focus,.btn-group-vertical>.btn:hover,.btn-group>.btn-check:checked+.btn,.btn-group>.btn-check:focus+.btn,.btn-group>.btn.active,.btn-group>.btn:active,.btn-group>.btn:focus,.btn-group>.btn:hover{
    z-index:1
}
.btn-toolbar{
    display:flex;
    flex-wrap:wrap;
    justify-content:flex-start
}
.btn-toolbar .input-group{
    width:auto
}
.btn-group>.btn-group:not(:first-child),.btn-group>.btn:not(:first-child){
    margin-left:-1px
}
.btn-group>.btn-group:not(:last-child)>.btn,.btn-group>.btn:not(:last-child):not(.dropdown-toggle){
    border-top-right-radius:0;
    border-bottom-right-radius:0
}
.btn-group>.btn-group:not(:first-child)>.btn,.btn-group>.btn:nth-child(n+3),.btn-group>:not(.btn-check)+.btn{
    border-top-left-radius:0;
    border-bottom-left-radius:0
}
.dropdown-toggle-split{
    padding-right:.5625rem;
    padding-left:.5625rem
}
.dropdown-toggle-split::after,.dropend .dropdown-toggle-split::after,.dropup .dropdown-toggle-split::after{
    margin-left:0
}
.dropstart .dropdown-toggle-split::before{
    margin-right:0
}
.btn-group-sm>.btn+.dropdown-toggle-split,.btn-sm+.dropdown-toggle-split{
    padding-right:.375rem;
    padding-left:.375rem
}
.btn-group-lg>.btn+.dropdown-toggle-split,.btn-lg+.dropdown-toggle-split{
    padding-right:.75rem;
    padding-left:.75rem
}
.btn-group-vertical{
    flex-direction:column;
    align-items:flex-start;
    justify-content:center
}
.btn-group-vertical>.btn,.btn-group-vertical>.btn-group{
    width:100%
}
.btn-group-vertical>.btn-group:not(:first-child),.btn-group-vertical>.btn:not(:first-child){
    margin-top:-1px
}
.btn-group-vertical>.btn-group:not(:last-child)>.btn,.btn-group-vertical>.btn:not(:last-child):not(.dropdown-toggle){
    border-bottom-right-radius:0;
    border-bottom-left-radius:0
}
.btn-group-vertical>.btn-group:not(:first-child)>.btn,.btn-group-vertical>.btn~.btn{
    border-top-left-radius:0;
    border-top-right-radius:0
}
#btn-group-theories .btn, #btn-group-theories-mobile .btn {
    font-size: 1.2rem;
    width: 25%;
    padding-top: 16px;
    padding-bottom: 10px;
    text-transform: uppercase;
}

@media (max-width: 480px) {
    #btn-group-theories .btn, #btn-group-theories-mobile .btn {
        width: 90%;
    }
}

/* MATEMATICA ELEMENTARI */

.btn-clickable, .btn-clickable-mobile {
    cursor: pointer;
}

.hide {
    display: none;
}

.math-primary-list {
    list-style-type: none;
    padding: 0;
    margin: 0;
}

.math-primary-list li {
    cursor: pointer;
}

.math-primary-list li:hover {
    filter: brightness(95%);
}

.math-primary-descr-container .title:hover {
    text-decoration: none;
    opacity: 1;
}

.math-primary-img-container {
    overflow: hidden;
    padding: 0;
    display: flex;
    justify-content: center;
    align-items: center;
}

.math-primary-img-container img {
    width: 120px;
    max-height: 120px;
    transform: scale(1.6);
}

@media (max-width: 480px) {
    .math-primary-img-container img {
        width: 80%;
        max-height: 100%;
    }
}

.math-primary-descr-container {
    text-align: left;
    padding-top: 5px;
}

.math-primary-descr-container p {
    font-size: .9rem;
}

#spazio-figure-container, #logica-container, #numeri-container, #relazioni-dati-previsioni-container {
    padding-right: 0;
}

@media (max-width: 1030px) and (min-width: 576px) {
    #spazio-figure-container, #logica-container, #numeri-container, #relazioni-dati-previsioni-container {
        padding-right: 30px;
    }
}

@media (max-width: 575px) {
    #spazio-figure-container, #logica-container, #numeri-container, #relazioni-dati-previsioni-container {
        padding: 5px;
    }
}

@media (max-width: 1030px) and (min-width: 576px) {
    .btn-group-school-primary {
        padding-right: 25px;
    }
}

@media (max-width: 575px) {
    .btn-group-school-primary {
        padding-right: 25px;
    }
}

.primaria-elementari-text {
    font-weight: 500;
    margin: 0;
}

.spazio-figure-text {
    color: #ff7984;
}

.logica-text {
    color: #87cbd0;
}

.numeri-text {
    color: #ffc933;
}

.relazioni-dati-previsioni-text {
    color: #cf8eed;
}

.primaria-generic-text {
    color: #6db672;
}

/* SPECIAL SYMBOLS */

.pi {
    margin: 0 !important;
    font-family: "Arial", "Times New Roman", "Segoe UI", "Noto Sans", sans-serif !important;
}

/* MATH PRIMARY BUTTONS */

/* ---------- Palette ---------- */
:root{
    --green-main:#6db672;
    --grad-top:#7ccf85;          /* +8 % luminosità */
    --grad-bottom:#5fa965;       /* −6 % luminosità */
    --hover-top:#67b06e;         /* versione hover */
    --hover-bottom:#4d9357;
    --text-light:#ffffff;
    --focus-ring:#94d6a0;        /* per accessibilità */
  }
  
  /* Contenitore orizzontale */
  .classi-wrapper{
    display:flex;
    gap:0.8rem;
    flex-wrap:wrap;
    justify-content:center;
    margin-bottom:16px;
  }
  
  /* ---------- Pulsante ---------- */
  .btn-classe{
    flex:0 1 auto;
    width:150px;
    padding:0.6rem 0.9rem;
    font-family:"gotham-pro", sans-serif;
    font-weight:500;
    font-size:0.85rem;
    color:var(--text-light);
    background:linear-gradient(var(--grad-top), var(--grad-bottom));
    border:1px solid rgba(255,255,255,0.18);   /* highlight quasi invisibile */
    border-radius:0.75rem;
    text-decoration:none;
    box-shadow:0 0.5px 1.5px rgba(0,0,0,0.08);
    transition:background .25s, box-shadow .25s;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    line-height:1.1;
  }
  
  /* Hover + focus */
  .btn-classe:hover,
  .btn-classe:focus-visible{
    background:linear-gradient(var(--hover-top), var(--hover-bottom));
    box-shadow:0 4px 8px rgba(0,0,0,0.14);
  }
  
  /* Focus ring (accessibilità tastiera) */
  .btn-classe:focus-visible{
    outline:3px solid var(--focus-ring);
    outline-offset:2px;
  }
  
  /* Active (clic) */
  .btn-classe:active{
    box-shadow:0 2px 4px rgba(0,0,0,0.15) inset;
  }

  /* MATH PRIMARY INTRO COLLAPSIBLE */

  /* =========== Intro collassabile =========== */
  .intro-collapsible{
    position:relative;
    max-height:230px;              /* altezza chiusa */
    overflow:hidden;
    cursor:pointer;                /* indica che è cliccabile */
    transition:max-height .5s ease;

    /* ----- fade diretto sul testo (modern browsers) ----- */
    -webkit-mask-image:linear-gradient(#000 0%, #000 calc(100% - 120px), transparent 100%);
    mask-image:linear-gradient(#000 0%, #000 calc(100% - 120px), transparent 100%);
  }

  @media (max-width: 480px) {
    .intro-collapsible {
        max-height: 300px;
    }
  }
  
  /* overlay + tre puntini */
  .intro-collapsible::after{
    content:'•••';
    position:absolute;
    inset-inline:0;
    bottom:0;
    height:120px;                     /* sfumatura più alta */
    text-align:center;
    font:600 24px/120px "Montserrat",sans-serif;
    color:#6db672;
    background:linear-gradient(to bottom, rgba(255,255,255,0) 0%, #ffffff 70%, #ffffff 100%);
    letter-spacing:4px;
    pointer-events:none;
    animation:pulse 1.6s ease-in-out infinite;
  }
  
  /* stato aperto */
  .intro-collapsible.open{
    max-height:none;               /* si espande completamente */
    cursor:auto;

    /* rimuove la maschera – testo pieno */
    -webkit-mask-image:none;
    mask-image:none;
  }
  .intro-collapsible.open::after{  /* spariscono fade + puntini */
    display:none;
  }

  .scuola-primaria-classi-bottom-text {
    font-weight: 500;
    margin-left: 0;
  }

  @media (max-width: 480px) {
    .scuola-primaria-classi-bottom-text {
        margin-left: 5px !important;
      }
  }

  /* HOME */

  .cards-home {
    padding-top: 1.25rem;
    margin:0;
    align-items:center;
    justify-content:center;
    text-align: left;
    display:grid;
    gap:1.8rem;
  }

  .card-home {
    position:relative;
    display:flex;
    align-items:center;
    line-height:1rem;
    background:linear-gradient(120deg, #6db672 0%, #7ed27a 100%);
    color:#fff;
    padding:1.5rem 2rem;
    border-radius:999px;
    text-decoration:none;
    overflow:hidden;
    max-width:440px;
    box-shadow:0 6px 14px rgba(0,0,0,.15);
    transition:transform .2s cubic-bezier(.4,.2,.2,1),box-shadow .2s;
  }

  .card-home::before {
    content:"";
    position:absolute;
    inset:-150%;
    background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.4) 0%,rgba(255,255,255,0) 60%);
    transform:rotate(45deg);
    transition:opacity .4s;
    pointer-events:none;
  }
  .card-home:hover,
  .card-home:focus-visible {
    transform:translateY(-4px) scale(1.02);
    box-shadow:0 12px 28px rgba(0,0,0,.25);
  }
  .card-home:hover::before {opacity:.75;}

  .icon-home-wrapper {
    width:60px;
    height:60px;
    border-radius:50%;
    overflow:hidden;
    flex-shrink:0;
    margin-right:1.5rem;
    margin-left:0;
    background:rgba(255,255,255,.15);
  }
  .icon-home-wrapper img {
    width:100%;
    height:100%;
    object-fit:cover;
  }

  .text-home {
    flex:1;
    margin:0;
    padding:0;
  }

  .title-home {
    margin:0;
    font-size:1.1rem;
    font-weight:500;
    letter-spacing:.4px;
    line-height:1.1;
    text-transform:uppercase;
  }
  .tagline-home {
    margin:0;
    font-size:.8rem;
    font-weight:500;
    margin-top:.35rem;
    display:block;
  }
  .desc-home {
    margin:0;
    font-size:.75rem;
    opacity:.87;
    margin-top:.15rem;
    line-height:1.3;
    display:block;
  }

  .cta-home {
    margin-left:1.3rem;
    margin-right:0;
    display:flex;
    align-items:center;
    font-size:1.2rem;
    font-weight:700;
    transition:transform .2s;
  }
  .cta-home svg {
    width:20px;
    height:20px;
    fill:currentColor;
    transition:transform .2s;}
  .card-home:hover .cta-home svg {transform:translateX(4px);}    

  /* ====== Responsive tweaks ====== */
  @media(max-width:480px){
    .cards-home {padding: 1.25rem;}
    .card-home {padding:1rem 1.25rem;}
    .icon-wrapper-home {width:50px;height:50px;margin-right:1rem;}
    .title-home {font-size:1.125rem;}
    .tagline-home {font-size:.8rem;}
    .desc-home {font-size:.75rem;}
  }

  /* SCUOLA MATERIALI */

  .cards-materials {
    display:flex;
    flex-direction:column;
    text-align:left;
    margin:0;
    padding:1.8rem;
    gap:1.8rem;
    max-width:630px;
    margin:0 auto;
  }

  /* Card larga */
  .card-materials {
    position:relative;
    display:flex;
    align-items:center;
    background:linear-gradient(120deg,#6db672 0%,#7ed27a 100%);
    color:#fff;
    padding:1.52rem 1.96rem;
    border-radius:30px;
    text-decoration:none;
    overflow:hidden;
    box-shadow:0 8px 20px rgba(0,0,0,.14);
    transition:transform .25s cubic-bezier(.4,.2,.2,1),box-shadow .25s;
  }
  .card-materials::before {
    content:"";
    position:absolute;
    inset:-160%;
    background:radial-gradient(circle at 25% 25%,rgba(255,255,255,.45) 0%,rgba(255,255,255,0) 60%);
    transform:rotate(40deg);
    transition:opacity .5s;
    pointer-events:none;
  }
  .card-materials:hover,.card-materials:focus-visible {
    transform:translateY(-5px) scale(1.03);
    box-shadow:0 14px 32px rgba(0,0,0,.25);
  }
  .card-materials:hover::before {opacity:.75;}

  /* Icona */
  .icon-materials-wrapper {
    width:70px;
    height:70px;
    border-radius:50%;
    overflow:hidden;
    flex-shrink:0;
    margin-right:1.52rem;
    margin-left:0;
    box-shadow:0 0 0 4px rgba(255,255,255,.25);
    background:rgba(255,255,255,.18);
  }
  .icon-materials-wrapper img {width:100%;height:100%;object-fit:cover;}

  /* Testo */
  .text-materials {
    flex:1;
    margin:0;
    padding:0;
  }
  .title-materials {
    display:block;
    margin: 0;
    font-size:1.2rem;
    font-weight:500;
    letter-spacing:.4px;
    line-height:1.1;
    text-transform:uppercase;
  }
  .desc-materials {
    display:block;
    font-size:.8rem;
    opacity:.9;
    margin-top:.3rem;
    margin-left:0;
    line-height:1.35;
    max-width:420px;
  }

  /* CTA */
  .cta-materials {
    margin-left:1.52rem;
    margin-right:0;
    font-size:1.35rem;
    font-weight:700;
    display:flex;
    align-items:center;
    transition:transform .25s;
  }
  .cta-materials svg {
    width:22px;
    height:22px;
    fill:currentColor;
    transition:transform .25s;
  }
  .card-materials:hover .cta-materials svg {transform:translateX(6px);}  

  /* Mobile */
  @media(max-width:480px) {
    .card-materials {padding:1.25rem 1.5rem;flex-direction:row;}
    .icon-materials-wrapper {width:58px;height:58px;margin-right:1.25rem;}
    .title-materials {font-size:1.15rem;}
    .desc-materials {font-size:.8rem;}
    .cta-materials {margin-left:1rem;font-size:1.2rem;}
  }

  /* PRIMARIA SEZIONI */

  .cat-primaria-selector {
    display:grid;
    grid-template-columns:repeat(5,1fr);
    gap:.45rem;
    max-width:900px;
    margin:30px auto 0 auto;
  }
  @media(max-width: 992px) {
    .cat-primaria-selector {
        margin:30px 20px 20px 20px;
        grid-template-columns:repeat(3,1fr);
    }
  }
  @media(max-width: 640px) {
    .cat-primaria-selector {
        margin:30px 20px 20px 20px;
        grid-template-columns:repeat(2,1fr);
    }
  }
  @media(max-width: 480px) {
    .cat-primaria-selector {
        margin:30px 20px 20px 20px;
        grid-template-columns:1fr;
        padding: 0 70px;
    }
  }

  .cat-primaria-selector input[type=radio]{display:none;}

  .cat-primaria {
    position:relative;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    padding:.6rem .35rem;
    border-radius:14px;
    font-weight:600;
    font-size:.88rem;
    text-transform:uppercase;
    color:#fff;
    cursor:pointer;
    overflow:hidden;
    line-height:1.25;
    transition:transform .25s,box-shadow .25s;
  }
  .cat-primaria::before {
    content:"";
    position:absolute;
    inset:0;
    background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.2) 0%,rgba(255,255,255,0) 70%);
    opacity:.12;
    transition:opacity .3s;
    pointer-events:none;
  }
  .cat-primaria:hover {
    transform:translateY(-3px) scale(1.04);
    box-shadow:0 10px 20px rgba(0,0,0,.15);
  }
  .cat-primaria:hover::before {opacity:.33;}

  .btn-figure{background:linear-gradient(135deg,#ff6f7d,#ff8b99);}  
  .btn-logica{background:linear-gradient(135deg,#45c2d1,#6fd4e0);}   
  .btn-numeri{background:linear-gradient(135deg,#f4b41a,#f7c64c);}   
  .btn-relazioni{background:linear-gradient(135deg,#c696f9,#dcb0ff);}  
  .btn-giochi{background:linear-gradient(135deg,#6db672,#82d88c);}   

  /* highlight invertito */
  input#cat-spazio-figure:checked + label.btn-figure {
    background:#fff;
    color:#ff6f7d;
    box-shadow:0 0 0 3px #ff6f7d,0 6px 16px rgba(0,0,0,.17);
  }
  input#cat-logica:checked + label.btn-logica {
    background:#fff;
    color:#45c2d1;
    box-shadow:0 0 0 3px #45c2d1,0 6px 16px rgba(0,0,0,.17);
  }
  input#cat-numeri:checked + label.btn-numeri {
    background:#fff;
    color:#f4b41a;
    box-shadow:0 0 0 3px #f4b41a,0 6px 16px rgba(0,0,0,.17);
  }
  input#cat-relazioni-dati-previsioni:checked + label.btn-relazioni {
    background:#fff;
    color:#c696f9;
    box-shadow:0 0 0 3px #c696f9,0 6px 16px rgba(0,0,0,.17);
  }
  input#cat-giochi-online:checked + label.btn-giochi {
    background:#fff;
    color:#6db672;
    box-shadow:0 0 0 3px #6db672,0 6px 16px rgba(0,0,0,.17);
  }

  /* YouTube video responsive */
  .youtube-video-responsive {
    height: 365px;
  }

  @media (max-width: 767px) {
    .youtube-video-responsive {
      height: 220px;
      width: 100%;
      max-width: 100%;
    }
  }

  .special-char {
    font-family: "Segoe UI Symbol", "Arial Unicode MS", sans-serif;
  }

  .container-about{max-width:1100px; margin-inline:auto; padding:0 18px 60px;margin:0; font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
    color:#111; line-height:1.55; text-align: left; font-size: .9rem;}
  .container-about *{box-sizing:border-box}
  .section-about{margin-top:.6rem}
  .section-about .bar{display:inline-block; padding:.28rem .55rem; border:1px solid #6db672; border-radius:999px; font-weight:700; font-size:.8rem; color:#6db672; background:#fff}
  .section-about h1,h2,h3{margin:0 0 .6rem}
  .section-about h2{font-size:clamp(1.15rem,2vw,1.3rem); font-weight:800; color:#6db672; margin-top:0;}
  .section-about p{margin:.35rem 0; font-weight: 400;}
  .team-grid{
    display:grid; gap:18px;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    margin-top:1rem;
  }
  .team-grid .card{
    background:#f7f7f7; border-radius:14px; padding:16px; display:grid; grid-template-columns:110px 1fr; gap:14px;
    border:1px solid #eaeaea;
  }
  @media (max-width:520px){ .team-grid.card{grid-template-columns:1fr} }
  .team-grid .card .avatar{
    width:110px; aspect-ratio:1/1; object-fit:cover; border-radius:12px; background:#fff;
    border:2px solid #6db672;
  }
  .team-grid .card .name{font-size:.95rem; font-weight:800; line-height:1.25; color: #000;}
  .team-grid .card .who{color:#555; font-style:italic}
  .team-grid .card .cv{
    font-weight:700; text-decoration:none; border-bottom:2px solid #6db672; padding-bottom:1px; margin-left:.4rem; color:#111;
  }
  .team-grid .card .cv:hover{color:#6db672}

  .contributors{margin-top:1rem; display:grid; gap:10px}
  .contrib{
    background:#fff; border:1px solid #eaeaea; border-left:4px solid #6db672;
    border-radius:10px; padding:12px 14px;
  }
  .contrib .name{font-size:0.9rem; color:#000; font-weight: 700;}