section#formdev-archive-product{
	padding: 50px 0;
	.backlink{
		display: block;
		padding: 15px 0;
	}
	.fd-head{
		text-align: center;
	}
	h1{
		text-align: center;
		font-weight: bold;
		font-size: 32px;
		position: relative;
		display: inline-block;
		line-height: normal;
  		padding: 0;
  		margin-bottom: 15px;
		&:after{
			position: absolute;
			content:'';
			height: 6px;
			background: #000;
			opacity: 0.2;
			width: 100%;
			bottom: 4px;
			left: 0;
		}
	}
	.intro{
		text-align: center;
		max-width: 700px;
		margin: auto;
		padding: 10px 0 30px 0;
	}
	.categories, .products{
		margin: 25px 0;
		.category, .product{
			width:31%;
			margin: 0 1%;
			float: left;
			background: #f3f3f3;
			position: relative;
			padding: 30px 1% 55px 1%;
        	display: flex;
			justify-content: center;
			flex-direction: column;
			align-items: flex-start;
			border-radius: 20px;
			cursor: pointer;
			margin-bottom: 16px;
			.wrapper{
				text-align: center;
				width: 100%;
				h2{
					font-weight: bold;
					font-size: 22px;
					line-height: normal;
					text-transform: uppercase;
				}
			}
			a{
				display: block;
				position: absolute;
				width: 100%;
				bottom: 28px;
				left: 0;
				text-align: center;
			}
			&.two{
				width:48%;
			}
			&.one{
				width:98%;
			}
		}
		.category{
			.img{
				width: 100%;
				height: 140px;
				background-size: contain;
				background-repeat: no-repeat;
				background-position: center center;
				margin-bottom: 30px;
			}
		}
	}
	.clearfix{
		clear: both;
	}
	.products{
		margin-top: 0;
		&.dataTable{
			td{
				padding: 0 !important;
				width: 100%;
				display: block;
				text-align: left;
				border: none !important;
			}
			th{
				visibility: hidden !important;
			}
			tr{    
				display: block;
				width: 50%;
				float: left;
			}
		}
		.product{
			width:100%;
			float: none;
			padding: 20px;
			height: 130px;
			overflow: hidden;
			.wrapper{
				text-align: left;
				/* padding-left: 80px; */
				position: relative;
				.img{
					position: absolute;
					left: 0;
					top: -2px;
					width: 60px;
					height: 60px;
					background-position: center center;
					background-size: cover;
					border-radius: 40px;
					display: none;
				}
				h2{
					font-size: 16px;
				}
			}
			a{
				position: relative;
				bottom: auto;
				text-align: left;
			}
		}
	}
	.dataTables_wrapper .dataTables_filter{
		float: none;
		text-align: center;
		font-weight: bold;
		input{
			margin: auto;
			border-radius: 5px;
			width: 50%;
			display: block;
			padding: 10px;
		}
	}
	#products-fd{
		border: none !important;
	}
	#products-fd_info, #products-fd_paginate, .dt-paging{
		display: none !important;
	}
	div.dt-container div.dt-layout-row{
		display: block;
		margin: 0;
	}
	div.dt-container div.dt-layout-row div.dt-layout-cell.dt-layout-end{
		display: block;
		.dt-search{
			text-align: center;
			font-weight: bold;
			input{
				margin: auto;
				border-radius: 5px;
				width: 50%;
				display: block;
				padding: 10px;
			}
		}
	}
}

section#formdev-single-product{
	.clearfix{
		clear: both;
	}
	.fd-head{
		background: #f3f3f3;
		padding: 30px 30px 30px 150px;
		position: relative;
		.img{
			position: absolute;
			left: 30px;
			top: 30px;
			width: 90px;
			height: 90px;
			background-position: center center;
			background-size: cover;
			border-radius: 40px;
		}
		h1{
			font-weight: bold;
			font-size: 36px;
			line-height: 40px;
			position: relative;
			display: inline-block;
	  		padding: 0;
	  		margin-bottom: 15px;;
			&:after{
				position: absolute;
				content:'';
				height: 10px;
				background: #000;
				opacity: 0.2;
				width: 100%;
				bottom: 2px;
				left: 0;
			}
		}
		a{
			font-size: 20px;
		}
	}
	p, li{
		font-size: 13px;
  		line-height: 20px;
	}
	p{
		margin-top: 10px;
		margin-bottom: 5px;
		padding: 0;
	}
	ul{
		padding-bottom: 0;
	}
	li{
		margin-left: 0px;
		padding-left: 5px;
		background-size: 15px;
		background-repeat: no-repeat;
  		background-position: top 5px left;
	}
	h2{
		margin-top: 15px;
	}
	img{
		max-width: 100%;
		height: auto;
	}
	section.main-info{
		div.price,
		div.duree,
		div.effectifs{
			width: 33%;
			float: left;
			padding: 60px 0;
			.wrapper{
				width: 250px;
				margin: auto;
				text-align: center;
				position: relative;
				.picto{
					height: 130px;
					width: 130px;
					border-radius: 100px;
					background: #f3f3f3;
					margin: auto;
				}
				.title{
					font-size: 18px;
					line-height: 22px;
					text-transform: uppercase;
					font-weight: bold;
					padding-top: 20px;
				}
				.info{
					font-size: 14px;
					padding-bottom: 4px;
				}
				&:after{
					position: absolute;
					content:'';
					height: 3px;
					background: #000;
					opacity: 0.2;
					width: 140px;
					bottom: -10px;
					left: 0;
					right: 0;
					margin: auto;
				}
			}
		}
		div.price .wrapper{
			float: left;
		}
		div.effectifs .wrapper{
			float: right;
		}
		div.picto svg{
			max-width: 86%;
			height: auto;
			margin: 7%;
		}
	}
	section.programme,
	section.devis{
		width: 50%;
		float: left;
		background: #f3f3f3;
		border-radius: 12px;
		padding: 2%;
		margin-bottom: 15px;
		div.picto{
			width: 72px;
			height: 72px;
			border-radius: 50px;
			float: left;
			svg{
				width: 60%;
				margin: 20%;
				height: auto;
			}
		}
		div.title, a.title{
			float: right;
			padding: 4px 15px;
			border-radius: 8px;
			color: #fff;
			background: #333333;
		}
		h2{
			margin-top: 25px;
			&:after{
				display: none;
			}
		}
	}
	a.btn{
		font-size: 14px;
		color: #000;
		display: inline-block;
		border:1px solid #000;
		line-height: 20px;
		padding: 4px 15px;
		border-radius: 8px;
		margin-right: 10px;
		text-transform: uppercase;
	}
	section.infos{
		width: 50%;
		float: right;
		padding: 2% 0 2% 3%;
	}
	section.infos_bis{
		width: 60%;
		float: left;
		padding-top: 20px;
		margin-bottom: 50px;
		.left{
			width: 35%;
			float: left;
		}
		.right{
			width: 65%;
			float: left;
			padding-left: 3%;
			padding-right: 3%;
		}
	}
	section.stats{
		width: 40%;
		float: left;
		background: #f3f3f3;
		padding: 2%;
		border-radius: 12px;
	}
	section.sessions{
		width: 40%;
		float: left;
		background: #f3f3f3;
		padding: 2%;
		border-radius: 12px;
	}
	h2{
		font-size: 15px;
		line-height: 18px;
		text-transform: uppercase;
		font-weight: bold;
		padding-bottom: 15px;
		position: relative;
		display: inline-block;
		&:after{
			position: absolute;
			content:'';
			height: 6px;
			background: #000;
			opacity: 0.2;
			width: 100%;
			bottom: 14px;
			left: 0;
		}
	}
	section.sessions{
		margin-top: 0px;
		width: 100%;
		float: none;
		background: #f3f3f3;
		padding: 3%;
		border-radius: 12px;
		margin-bottom: 50px;
		.fd-head{
			text-align: center;
			padding: 0;
		}
		h2{
			text-align: center;
			font-size: 18px;
			&:after{
				bottom: 13px;
			}
		}
		div.session{
			border-radius: 10px;
			margin: 1%;
			padding: 2%;
			width: 48%;
			float: left;
			background: #fff;
			.date h3{
				text-transform: uppercase;
				font-size: 14px;
  				padding: 0;
			}
			.lieu{
				font-size: 12px;
			}
			.ctas{
				padding-top: 5px;
			}
			a.programme{
				font-size: 12px;
				color: #000;
				display: inline-block;
				border:1px solid #000;
				line-height: 16px;
				padding: 0 6px;
				border-radius: 4px;
				margin-right: 10px;
			}
			a.inscription{
				font-size: 12px;
				color: #fff;
				background: #000;
				display: inline-block;
				border:1px solid #000;
				line-height: 16px;
				padding: 0 6px;
				border-radius: 4px;
			}
		}
	}
}
section#formdev-cart{
	.clearfix{
		clear: both;
	}
	margin-bottom: 50px;
	.fd-head{
		background: #f3f3f3;
		padding: 30px;
		position: relative;
		margin-top: 50px;
	  	text-align: center;
		h1{
			font-weight: bold;
			font-size: 36px;
			line-height: 40px;
			position: relative;
			display: inline-block;
	  		padding: 0;
	  		margin-bottom: 15px;
	  		text-align: center;
			&:after{
				position: absolute;
				content:'';
				height: 10px;
				background: #000;
				opacity: 0.2;
				width: 100%;
				bottom: 2px;
				left: 0;
			}
		}
		a{
		}
	}
	.woocommerce-cart-form{
		max-width: 800px;
		margin: auto;
	}
	table.shop_table{
		width: 100%;
	}
	table.login{
		margin: 30px 0;
		width: 100%;
		border-width: 0;
		tr{
			td{
				padding: 10px 10px 0 10px;
				width: 50%;
				vertical-align: top;
				border-width: 0;
				label:not(.ch){
					display: block;
				}
				input:not(.ch), textarea{
					width: 100%;
				}
				small{
					font-size: 11px;
					line-height: 16px;
					display: block;
					padding-top: 3px;
					opacity: 0.7;
				}
			}
		}
	}
	input:not(.ch):read-only {
	    background-color: #f0f0f0;
	    color: #555;
	    cursor: not-allowed;
	}
	div.error{
		padding: 10px;
		color: red;
	}
	input.text, input.title, input[type="email"], input[type="password"], input[type="tel"], input[type="text"], select, textarea{
		font-size: 14px;
		padding: 10px;
		border-radius: 6px;
	}
	button.quote-request-submit{
		display: none !important;
	}
	a.learner-request-submit{
		border:1px solid #666;
		color: #fff;
		background:#666;
		padding:4px 15px;
		border-radius:8px;
		margin-right: 10px;
		text-transform: uppercase;
		font-size: 14px;
		cursor: pointer;
		font-weight: 500;
		line-height: 1.7em !important;
	}
	ul.participants{
		input{
			padding: 10px;
			border-radius: 5px;
			margin-bottom: 5px;
			margin-left: 5px;
			width: 18%;
			font-size: 13px;
		}
	}
	.product-name a{
		text-transform: uppercase;
		padding-top: 0px;
		padding-bottom: 8px;
		display: block;
	}
	tr.cart_item{
		border-bottom: 1px solid #f3f3f3;
	}
}
.woocommerce-cart section#formdev-cart table.cart td{
	vertical-align: top !important;
	&.product-price{
		padding-top: 20px !important;
	}
	&.product-subtotal{
		padding-top: 20px !important;
	}
}
.woocommerce-page section#formdev-cart button.button{
	border: 1px solid;
	line-height: 20px;
	padding: 4px 15px;
	border-radius: 8px;
	margin-right: 10px;
	text-transform: uppercase;
	font-size: 14px;
	cursor: pointer;
	&:after{
		display: none;
	}
}

div#formdev-cart{
	position: fixed;
	bottom: 40px;
	right: 20px;
	z-index: 666;
	background: #fff;
	width: 50px;
	height: 50px;
	border: 1px solid #333;
	border-radius: 50px;
	box-shadow: 0px 0px 6px 3px rgba(0,0,0,0.15);
	a{
		display: block;
		width: 100%;
		height: 100%;
	}
	span{
		position: absolute;
		width: 100%;
		text-align: center;
		font-size: 12px;
	}
	svg{
		width: 26px;
		height: 26px;
		margin: 16px 10px;
	}
}

#admin-formdev{
	color:#1E1E1E;
	min-height: 100vh;
	position: relative;
	.loader{
		position: absolute;
		width: 100%;
		height: 100%;
		background: #f0f0f1;
		text-align: center;
		padding-top: 15%;
		display: none;
		z-index: 666;
	}
	p{
		color:#1E1E1E;
	}
	h1{
		color: #0669B3;
		font-size: 28px;
	}
	h2{
		color: #004778;
	}
	h3{
		margin: 0 0 10px 0;
		color: #0C73B7;
		font-size: 16px;
		text-transform: uppercase;
	}
	.card{
		border: 1px solid #0669B34D;
		border-radius: 10px;
		margin-top: 0;
	}
	.button-primary{
		border-radius: 10px;
		padding: 0 15px;
		&.green{
			border: 1px solid #47AB1C !important;
			background: #47AB1C !important;
			color: #fff !important;
		}
		&.greenBis{
			border: 1px solid #47AB1C !important;
			background: #fff !important;
			color: #47AB1C !important;
		}
	}
	.button-danger{
		border-radius: 10px;
		padding: 0 15px;
	}
	.button-secondary{
		border: 1px solid #F39208 !important;
		background: #F39208 !important;
		color: #fff !important;
		border-radius: 10px;
		padding: 0 15px;
		&.smallUpdate{
			border: 1px solid #F39208 !important;
			background: #fff !important;
			color: #F39208 !important;
		}
	}
	input[type="color"], input[type="date"], input[type="datetime-local"], input[type="datetime"], input[type="email"], input[type="month"], input[type="number"], input[type="password"], input[type="search"], input[type="tel"], input[type="text"], input[type="time"], input[type="url"], input[type="week"], select, textarea{
		border: 1px solid #0C73B780;
	}
	.nav-tab{
		-webkit-border-top-left-radius: 14px;
		-webkit-border-top-right-radius: 14px;
		-moz-border-radius-topleft: 14px;
		-moz-border-radius-topright: 14px;
		border-top-left-radius: 14px;
		border-top-right-radius: 14px;
		border-top: 1px solid #0669B34D;
		border-left: 1px solid #0669B34D;
		border-right: 1px solid #0669B34D;
		padding: 5px 40px;
	}
	.nav-tab-active{
		color: #004778;
	}
	.nav-tab-wrapper{
		border-bottom: 1px solid #0669B34D;
	}
	.form-table th{
		color: #004778;
	}
	table.wp-list-table{
		border-radius: 10px;
		border: 1px solid #0669B34D;
	}
}

.wp-theme-Divi h1{
	margin-top: 70px;
}

@media screen and (max-width: 1023px) {
	section#formdev-cart .fd-head h1,
	section#formdev-single-product .fd-head h1{
		font-size: 18px;
	}
	section#formdev-cart .fd-head h1:after,
	section#formdev-single-product .fd-head h1:after{
		height: 4px;
	}
	section#formdev-single-product .fd-head a{
		font-size: 16px;
	}
	section#formdev-archive-product .categories .category, section#formdev-archive-product .categories .product, section#formdev-archive-product .products .category, section#formdev-archive-product .products .product{
		width: 100%;
		margin: 0;
		float: none;
		height: auto !important;
		margin-bottom: 15px;
	}
	section#formdev-archive-product .products.dataTable tr {
		display: block;
		width: 100%;
		float: none;
	}
	section#formdev-single-product .fd-head{
		padding: 25px;
		position: relative;
		text-align: center;
	}
	section#formdev-single-product .fd-head .img{
		position: relative;
		left: auto;
		top: auto;
		margin: auto;
	}
	section#formdev-single-product section.main-info div.price, section#formdev-single-product section.main-info div.duree, section#formdev-single-product section.main-info div.effectifs{
		width: 100%;
		padding: 30px 0;
	}
	section#formdev-single-product section.main-info div.effectifs .wrapper,
	section#formdev-single-product section.main-info div.price .wrapper{
		float: none;
	}
	section#formdev-single-product section.programme, section#formdev-single-product section.devis, section#formdev-single-product section.stats,
	section#formdev-single-product section.infos_bis .right, section#formdev-single-product section.infos_bis .left,
	section#formdev-single-product section.infos_bis{
		width: 100%;
		float: none;
		padding: 15px;
	}
	section#formdev-single-product section.infos{
		width: 100%;
		float: none;
	}
	section#formdev-single-product section.sessions {
	    margin-top: 15px;
	}
	section#formdev-single-product section.infos_bis{
		margin: 0;
		padding: 0;
	}
}

@media screen and (max-width: 767px) {
	section#formdev-cart ul.participants input{
		width: 100%;
	}
}

.session-action-btn.session-action-inscription{
	font-size: 12px;
	color: #fff;
	background: #000;
	display: inline-block;
	border: 1px solid #000;
	line-height: 16px;
	padding: 0 6px;
	border-radius: 4px;
}

.places-dispo, .session-places-dispo{
	display: block;
	font-size: 12px;
}