/*===== FONTS =====*/
@font-face {
    font-family: 'Caviar';
    src: url('fonts/caviar.woff') format('woff');
}
@font-face {
    font-family: 'Euro';
    src: url('fonts/euro.woff') format('woff');
}
@font-face {
    font-family: 'EuroB';
    src: url('fonts/euroB.woff') format('woff');
}
@font-face {
    font-family: 'EuroH';
    src: url('fonts/euroH.woff') format('woff');
}
@font-face {
    font-family: 'EuroEH';
    src: url('fonts/euroEH.woff') format('woff');
}
@font-face {
    font-family: '3017';
    src: url('fonts/3017.woff') format('woff');
}
@font-face {
    font-family: 'DFGothic';
    src: url('fonts/DFGothic.woff') format('woff');
}
@font-face {
    font-family: 'Hiro';
    src: url('fonts/HIROMISAKE.woff') format('woff');
}

/*===== VALEURS GLOABLES =====*/
html, body {
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	font-size: 1em;
	color: black;
	background-color: rgb(231,225,203);
	font-family: 'Caviar';
}

/*===== SKIN =====*/
#back1, #back2, #back3 {
	position: fixed;
	width: 100%;
	height: 100vh;
}
#back1 {
	display: none;
	z-index: 1;
	background: radial-gradient(circle, rgba(68,173,192,1) 0%, rgba(101,130,165,1) 100%);
}
#back2 {
	z-index: 2;
	background: url('img/back.png') repeat-x;
	background-size: contain;
}
#back3 {
	z-index: 3;
	box-shadow:0px 0px 0px 15px rgb(112,100,52) inset;
}
#admin {
	position: fixed;
	z-index: 2000;
	bottom: 0;
	right: 0;
	width: 15px;
	height: 15px;
}

/*===== CORPS =====*/
#corps {
	position: relative;
	z-index: 10;
	top: 0;
	left: 0;
	width: 90vw;
	min-height: 110vh;
	margin: 0 auto;
	padding: 20px;
	text-align: center;
}
	#logo {
		clear: both;
		overflow: hidden;
	}
	#logo img {
		display: inline-block;
		float: left;
		width: 30%;
		max-height: 20%;
		margin-right: 30px;
		transition: width 0.5s;
	}
	#logo h1 {
		font-family: 'Hiro';
		color: rgb(112,100,52);
		text-shadow: 3px 3px rgb(255,237,164), -3px 3px rgb(255,237,164), 3px -3px rgb(255,237,164), -3px -3px rgb(255,237,164), 0 3px rgb(255,237,164), 3px 0 rgb(255,237,164), 0 -3px rgb(255,237,164), -3px 0 rgb(255,237,164);
		font-size: 4em;
		text-align: left;
		padding: 40px 0 15px;
		margin: 0;
	}
	#logo h2, #logo h4 {
		font-family: 'euroH';
		color: white;
		font-size: 3em;
		padding: 0;
		text-align: left;
		margin: 0;
		text-transform: uppercase;
	}
		#logo h4 {
			color: rgb(229,57,53);
			text-shadow: 1px 1px rgb(255,164,183), 1px -1px rgb(255,164,183), -1px 1px rgb(255,164,183), -1px -1px rgb(255,164,183);
		}
	#logo h3 {
		font-family: 'euroH';
		color: white;
		font-size: 2em;
		font-style: italic;
		padding: 0;
		text-align: left;
		margin: 0;
		text-indent: 50px;
	}
		#logo h2 strong, #logo h3 strong { color: black; }
	#logo h2, #logo h3, #logo h4 {
		transition: width 0.5s;
	}
	
	/*--- Menu réduit ---*/
	#logo.reduit {
		position: sticky !important;
		top: 20px;
	}
	#logo.reduit img {
		width: 10% !important;
	}
	#logo.reduit h2, #logo.reduit h3, #logo.reduit h4 {
		display: none;
	}
	/*--- Corps ---*/
	#corps h3.titre {
		font-family: 'Hiro';
		font-size: 3em;
		color: black;
		letter-spacing: 4px;
		font-weight: normal;
		text-align: left;
		padding: 5px 20px 5px 35px;
		margin-top: 20px;
		margin-bottom: 20px;
	}
	#menu {
		font-family: 'DFGothic';
		color: rgb(49,58,65);
		font-size: 2.3em;
		text-shadow: 3px 3px 5px pink;
		margin: 15px 0 0 0;
	}
		#menu a span {
			display: inline-block;
			height: 70px;
			border: 4px solid rgb(49,58,65);
			background-color: rgb(219,230,234);
			line-height: 68px;
			padding-right: 8px;
			margin: 10px;
		}
			#menu a.menu_back1 span { 
				outline: 10px solid rgb(253,199,197);
				box-shadow: inset 0 2px rgb(137,54,72);
			}
				#menu a.menu_back1:hover span {
					background-color: rgb(216,18,33);
					border: 4px solid black;
					outline: 10px solid rgb(251,108,3);
				}
			#menu a.menu_back2 span { 
				outline: 10px solid rgb(200,227,244);
				box-shadow: inset 0 2px rgb(38,88,139);
			}
				#menu a.menu_back2:hover span {
					background-color: rgb(1,41,235);
					border: 4px solid black;
					outline: 10px solid rgb(7,177,236);
				}
			#menu a.menu_back3 span { 
				outline: 10px solid rgb(254,213,161);
				box-shadow: inset 0 2px rgb(198,149,117);
			}
				#menu a.menu_back3:hover span {
					background-color: rgb(249,113,1);
					border: 4px solid black;
					outline: 10px solid rgb(255,227,19);
				}
			#menu a.menu_back4 span { 
				outline: 10px solid rgb(211,254,133);
				box-shadow: inset 0 2px rgb(4,104,2);
			}
				#menu a.menu_back4:hover span {
					background-color: rgb(0,164,82);
					border: 4px solid black;
					outline: 10px solid rgb(149,227,2);
				}
			#menu span img {
				vertical-align: top;
			}
				#menu a.menu_back1 span img:first-child { background-color: rgb(253,108,121); }
				#menu a.menu_back2 span img:first-child { background-color: rgb(89,146,215); }
				#menu a.menu_back3 span img:first-child { background-color: rgb(242,178,78); }
				#menu a.menu_back4 span img:first-child { background-color: rgb(4,210,77); }
					#menu a:hover span img:first-child { background-color: white; }
			#menu a {
				text-decoration: none;
				color: rgb(49,58,65);
				text-shadow: 2px 2px rgba(0,0,0,0), -2px 2px rgba(0,0,0,0), 2px -2px rgba(0,0,0,0), -2px -2px rgba(0,0,0,0);
				letter-spacing: 2px;
				transition: all 0.1s linear;
			}
				#menu a:hover {
					color: white;
					text-shadow: 2px 2px black, -2px 2px black, 2px -2px black, -2px -2px black;
					transition: all 0.05s linear;
				}
				
	/*--- Classement ---*/
	#classement {
	font-size: 1.2em;
	}
	#classement table {
		text-align: left;
		margin: 10px auto;
		border-collapse: collapse;
		padding: 0;
		font-size: 1.1em;
		background-image: linear-gradient( 64.3deg,  rgba(254,122,152,0.81) 17.7%, rgba(255,206,134,1) 64.7%, rgba(172,253,163,0.64) 112.1% );
		font-weight: bold;
		
	}
		#classement table tr.iko {
			font-size: 1.85em;
			font-weight: bold;
			color: white;
			text-shadow: 1px 1px rgb(0,168,240), -1px 1px rgb(0,168,240), 1px -1px rgb(0,168,240), -1px -1px rgb(0,168,240), 1px 0 rgb(0,168,240), -1px 0 rgb(0,168,240), 0 1px rgb(0,168,240), 0 -1px rgb(0,168,240);
			background-image: radial-gradient( circle 300.1px at 10% 20%,  rgba(231,255,19,1) 0%, rgba(255,185,22,1) 100.3% );
		}
			#classement table tr.iko td:first-child { text-align: center; }
			#classement table tr.iko td:first-child sup { font-size: 0.6em; }
		#classement table tr.premier {
			font-size: 1.5em;
			font-weight: bold;
			text-shadow: 2px 2px white, -2px 2px white, 2px -2px white, -2px -2px white, 2px 0 white, -2px 0 white, 0 2px white, 0 -2px white;
		}
		#classement table tr.second {
			font-size: 1.3em;
			text-shadow: 1px 1px white, -1px 1px white, 1px -1px white, -1px -1px white;
		}
		#classement table tr.troisieme {
			font-size: 1.1em;
			text-shadow: 1px 1px white;
		}
			#classement table tr th {
				font-size: 0.8em;
				font-weight: normal;
				text-align: center;
				background-image: radial-gradient( circle 860px at 11.8% 33.5%,  rgba(240,30,92,1) 0%, rgba(244,49,74,1) 30.5%, rgba(249,75,37,1) 56.1%, rgba(250,88,19,1) 75.6%, rgba(253,102,2,1) 100.2% );
				padding: 10px;
				border-radius: 10px 10px 0 0;
			}
			#classement table tr td {
				border-bottom : 1px solid black;
				padding: 3px 15px;
			}
				#classement table tr td:first-child {
					text-align: right;
				}
					#classement table tr td.cacher {
						visibility: hidden;
					}
	#classement #bushido_suivi {
		display: flex;
		justify-content: space-evenly;
		align-items: flex-start;
		margin: 20px 0 10px;
	}
	#classement table.white {
		background-image: none;
		font-size: 0.8em;
		display: inline-block;
		margin: 0;
	}
		#classement table.white tr:first-child {
			border: none;
			font-size: 1.2em;
			font-family: 'EuroB';
		}
		#classement table.white tr {
			border: 1px solid black;
			background-color: white;
		}
	.bushido_icon {
		width: 32px;
	}
	/*--- Inscription ---*/
	fieldset {
		width: 60%;
		border: 4px solid rgb(49,58,65);
		background-color: rgb(219,230,234);
		outline: 10px solid rgb(254,213,161);
		box-shadow: inset 0 2px rgb(198,149,117);
		text-align: justify;
		margin: 30px auto;
		font-size: 1.2em;
	}
		fieldset label {
			font-family: 'DFGothic';
			font-size: 1.2em;
		}
		fieldset input[type=text] {
			width: 50%;
			height: 30px;
			border: 2px solid rgb(49,58,65);
			font-family: 'Caviar';
			border-radius: 0;
			font-size: 1.2em;
		}
		fieldset input[type=submit] {
			height: 50px;
			border: 3px solid rgb(49,58,65);
			background-color: rgb(254,153,71);
			outline: 6px solid rgb(254,213,161);
			box-shadow: inset 0 1px rgb(198,149,117);
			font-family: 'DFGothic';
			border-radius: 0;
			font-size: 1.4em;
			margin: 0 auto;
			display: block;
			padding: 5px 10px;
			text-transform: uppercase;
			color: rgb(49,58,65);
			text-shadow: 2px 2px rgba(0,0,0,0), -2px 2px rgba(0,0,0,0), 2px -2px rgba(0,0,0,0), -2px -2px rgba(0,0,0,0);
		}
			fieldset input[type=submit]:hover {
				cursor: pointer;
				background-color: rgb(249,113,1);
				border: 3px solid black;
				outline: 6px solid rgb(255,227,19);
				color: white;
				text-shadow: 2px 2px black, -2px 2px black, 2px -2px black, -2px -2px black;
			}
	#insc_yes {
		font-weight: bold;
		font-size: 1.2em;
	}
	
/*===== VALEURS SPECIFIQUES =====*/
.no_pc { display: none; }
.menu_on a { color: black; }
p.ligne_plus, ul.ligne_plus li { line-height: 30px; text-indent: 0; }
.fl_left { float: left; margin-right: 5px; }
.fl_right { float: right; margin-left: 5px; }
ul.tiret { list-style: none; }
	ul.tiret li::before { content: '- '; }
.flex_egal { display: flex; justify-content: center; margin-top: 20px; }
.txt_pt { font-size: 0.8em; }
.citation::before, .citation::after {
	position: absolute;
	font-size: 2.5em;
	color: rgb(230,230,230);
}
.citation::before { top: 5px; margin-left: -20px; content: '“'; }
.citation::after { bottom: 5px; margin-left: 5px; content: '“'; transform: rotate(180deg); }
.fade { opacity: 0.5; }
.no_indent { text-indent: 0; }
.marj_g { padding-left: 20px; }
.marj_d { padding-right: 20px; }
.souligne { text-decoration: underline; }
.gras { font-weight: bold; font-size: 1.1em; }
.petit { font-size: 0.8em; }
.centre { text-align: center; }

.t1, .t2, .t3, .t4, .t5 { font-weight: bold; text-indent: 25px; }
.t1 { font-size: 1.2em; }
.t2 { font-size: 1.4em; }
.t3 { font-size: 1.6em; }
.t4 { font-size: 1.8em; }
.t5 { font-size: 2em; }

/*===== HEADER =====*/

/*===== CORPS =====*/
td a, td a:hover {
	color: black;
	text-decoration: none;
}
/*===== PAGES =====*/

/*===== FOOTER =====*/	
footer {
	position: relative;
	z-index: 5;
	text-align: center;
	padding-bottom: 30px;
}
	footer img {
		max-height: 100px;
		margin: 0 20px;
	}
/*====================================================================================*/
/*=================================== MOBILE =========================================*/
/*====================================================================================*/
@media screen and (max-width: 1200px) {
	
/*=== VALEURS SPECIFIQUES ===*/
.no_mobile { display: none; }
.no_pc { display: initial; }

/*=== HEADER ===*/

/*=== CORPS ===*/

/*=== PAGES ===*/

/*=== FOOTER ===*/

}
