/*
	Theme Name: KILLA
	Theme URI: 
	Description: 
	Version: 1.0
	Author: WD
	Author URI: https://www.workdivision.paris/

*/
@import url("https://use.typekit.net/dwj4pmh.css");

@font-face {
  font-family: 'df';
  src:  url('fonts/df.eot?gbbfy');
  src:  url('fonts/df.eot?gbbfy#iefix') format('embedded-opentype'),
    url('fonts/df.woff?gbbfy') format('woff');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

[class^="icon-"], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'df' !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;

  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-dl:before {
  content: "\e900";
  color: #0c4e6a;
}
.icon-go-top:before {
  content: "\e901";
  color: #b1b3b4;
}

/*------------------------------------*\
    MAIN
\*------------------------------------*/

/* global box-sizing */
*,
*:after,
*:before {
	-moz-box-sizing:border-box;
	box-sizing:border-box;
	-webkit-font-smoothing:antialiased;
	font-smoothing:antialiased;
	text-rendering:optimizeLegibility;
}
/* html element 62.5% font-size for REM use 
font-family: 'Open Sans', sans-serif;
*/
html {
	font-size:62.5%;
	scroll-behavior: smooth;
}
body {
    overflow-x: hidden;
    font-family: futura-pt, sans-serif;
    font-size: 1.9rem;
    line-height: 2.6rem;
    font-style: normal;
    font-weight: 300;
    background-color: #FFF;
	color: #000;
}
body > main{
	position: relative;
	min-height: 80vh;
}
/* clear */
.clear:before,
.clear:after {
    content:' ';
    display:table;
}

.clear:after {
    clear:both;
}
.clear {
    *zoom:1;
}
p{
	margin-bottom: 0.5rem;
}
p + ul{
	margin-top: -0.5rem;
}
img {
	max-width:100%;
	vertical-align:bottom;
	height: auto;
}
a {
	color:#000;
	text-decoration:none;
}

a:hover,
a:active {
	text-decoration: none;
	outline:0;
}
input:hover,
a:hover {
	transition: all 200ms ease-in-out!important;
	opacity: 0.8;
	color: inherit;
}
a.nohover{
	opacity: 1;
	transition: none;
}
a.retour{
    position: absolute;
	/*display:flex;
	align-content: center;
	align-items: center;*/
	text-transform: uppercase;
	font-size: 1.1rem;
    line-height: 1.4rem;
    color: #8D959C;
    border-bottom: 1px solid #8D959C;
}
input:focus {
	outline:0;
	border:1px solid #04A4CC;
}
.txt-xxl, h1, h2{
    font-size: clamp(3.2rem, 4.3vw + 1.3rem, 4rem);
    line-height: clamp(3.8rem, 4.3vw + 1.3rem, 4.5rem);
    margin-bottom: 4rem;
	font-weight: 300;
}
.txt-l{
	font-size: clamp(2.2rem, 7.5vw - 1.1rem, 3.6rem);
	line-height: clamp(2.8rem, 7.5vw - 1.1rem, 4rem);
	font-weight: 300;
}
h3, h4{
	margin-bottom: 0;
	font-weight: 300;
}

.txt-s{
	font-size: 1.5rem;
	line-height: 1.8rem;
}
.txt-bold{
	font-weight: 600;
}
.txt-up{
	text-transform: uppercase;
}
sup{
    text-transform: lowercase!important;
}
ul{
	margin-left: 0;
	padding-left: 15px;
}
cite{
	display: block;
	padding-top: 5px;
	text-align: center;
	font-size: 1.2rem;
	font-weight:400;
	color: #58A2C3;
	font-style: normal;
}
strong{
	font-weight: 500!important;
}
.text-center{
	text-align: center;
}
.fadeIn {
    animation-name: fadeIn;
}
.animated {
    animation-duration: 800ms !important;
}
@-webkit-keyframes fadeIn {
 0% {
    opacity:0
 }
 100% {
    opacity:1
 }
}
@keyframes fadeIn {
 0% {
    opacity:0
 }
 100% {
    opacity:1
 }
}
.fadeIn {
    -webkit-animation-name:fadeIn;
    animation-name:fadeIn
}
.pt15{
    padding-top: 0.5em;
}
.pt30{
    padding-top: 1.5em;
}
.pt50{
    padding-top: 2.7em;
}
.pt100{
    padding-top: 5em;
}
.pb15{
    padding-bottom: 0.5em;
}
.pb30{
    padding-bottom: 1.5em;
}
.pb50{
    padding-bottom: 3em;
}
.pb100{
    padding-bottom: 5em;
}
.mt30{
    margin-top: 1.5em;
}
.mt50{
    margin-top: 3em;
}
.mb15{
    margin-bottom: 1em;
}
.mb30{
    margin-bottom: 1.5em;
}
.mb50{
    margin-bottom: 3em;
}

.btn {
	display: inline-block;
	padding: 0.5rem 2rem 0.6rem 2rem;
	border: 2px solid #000;
	font-size: 1.4rem;
	line-height: 2rem;
	text-transform: uppercase;
	font-weight: 300;
	letter-spacing: 0.05em;
}
.btn:hover {
	background-color: #000;
	color: #FFF;
}

/*------------------------------------*\
    STRUCTURE
\*------------------------------------*/
section{
	scroll-margin-top: 100px;
}

.embed-container { 
    position: relative; 
    padding-bottom: 56.25%;
    overflow: hidden;
    max-width: 100%;
    height: auto;
} 

.embed-container iframe,
.embed-container object,
.embed-container embed { 
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/*------------------------------------*\
    BLOC IMAGE GRILLE 1
\*------------------------------------*/
.img-grid-2,
.img-grid-1 {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-template-rows: repeat(2, 1fr);
	grid-column-gap: 20px;
	grid-row-gap: 20px;
	margin: 20px 0;
}
.img-grid-3 {
	display: grid;
	grid-template-columns: repeat(9, 1fr);
	grid-template-rows: repeat(2, 1fr);
	grid-column-gap: 20px;
	grid-row-gap: 20px;
}

.img-grid-3 .grid-img1 { grid-area: 1 / 5 / 3 / 10; }
.img-grid-3 .grid-img2 { grid-area: 1 / 1 / 2 / 5; }
.img-grid-3 .grid-img3 { grid-area: 2 / 1 / 3 / 5; } 

.img-grid-4 {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-template-rows: 1fr;
	grid-column-gap: 20px;
	grid-row-gap: 0px;
}
.img-grid-2-2 {
	display: grid;
	grid-template-columns: repeat(2, 1fr); 
	grid-template-rows: 1fr;
	grid-column-gap: 20px;
	grid-row-gap: 20px;
}
.grid-img1 img, .grid-img2 img, .grid-img3 img { 
	width: 100%;
	height: 100%;
	/*object-fit: cover;*/
}
.img-grid-1 .grid-img1 img, .img-grid-1 .grid-img2 img, .img-grid-1 .grid-img3 img,
.img-grid-2 .grid-img1 img, .img-grid-2 .grid-img2 img, .img-grid-2 .grid-img3 img { 
	/*aspect-ratio: 13/18;*/
}
.single-img{
	margin-bottom: 20px;
}
/* grille 3 image left */
.img-grid-2 .grid-img1 { grid-area: 1 / 1 / 3 / 3; }
.img-grid-2 .grid-img2 { grid-area: 1 / 3 / 2 / 4; }
.img-grid-2 .grid-img3 { grid-area: 2 / 3 / 3 / 4; }

/* grille 3 image right */
.img-grid-1 .grid-img1 { grid-area: 1 / 2 / 3 / 4; }
.img-grid-1 .grid-img2 { grid-area: 1 / 1 / 2 / 2; }
.img-grid-1 .grid-img3 { grid-area: 2 / 1 / 3 / 2; } 

/* grille 4 images */
.img-grid-4 .grid-img1 { grid-area: 1 / 1 / 2 / 2; }
.img-grid-4 .grid-img2 { grid-area: 1 / 2 / 2 / 3; }
.img-grid-4 .grid-img3 { grid-area: 1 / 3 / 2 / 4; }
.img-grid-4 .grid-img4 { grid-area: 1 / 4 / 2 / 5; } 

/* grille 2 images */
.img-grid-2-2 .grid-img1 { grid-area: 1 / 1 / 2 / 2; }
.img-grid-2-2 .grid-img2 { grid-area: 1 / 2 / 2 / 3; } 

/*------------------------------------*\
    BLOC CITATION
\*------------------------------------*/
.text-citation-auteur{
	position: relative;
}
.text-citation-auteur::before{
	position: absolute;
	display: inline-block;
	left: 45%;
	top: 0;
	content: "";
	width: 30px;
	height: 2px;
	background-color: #000;
}
.text-citation.txt-l{
	font-size: clamp(2.1rem, 7.5vw - 1.1rem, 3.2rem);
}
/*------------------------------------*\
    BLOC TEXTE
\*------------------------------------*/
.item-text{
	/*padding: 0 3%;*/
}

/*------------------------------------*\
    FOOTER
\*------------------------------------*/
.footer ul{
	list-style: none;
	display: flex;
	flex-direction: row;
	justify-content: center;
}
.footer ul li{
	position: relative;
	padding: 5px;
	font-size: 1rem;
	line-height: 1.5rem;
	font-weight: 400;
}
.footer ul li a:hover{
	text-decoration: underline;
}

@media only screen and (min-width:769px) {
	body {
		font-size: 2rem;
	}
	.footer ul li{
		padding: 5px 15px;
	}
	.footer ul li::before{
		content: "~";
		position: absolute;
		left: 0;
	}
	.footer ul li:first-child::before{
		content: "";
	}
	.text-citation-auteur::before{
		left: 48%;
	}
}
/*------------------------------------*\
   FORMS
\*------------------------------------*/
::placeholder{
	opacity: 1!important;
	font-weight: 200;
	color: #fff;
}
.contact-form textarea,
input[type="password"],
input[type="email"],
input[type="url"],
input[type="tel"],
input[type="text"],
input[type="email"]{
    width: 100%;
	margin: 7.5px 0;
    padding: 10px 15px;
    border: none;
    font-size: 1.8rem;
    line-height: 2.2rem;
	font-weight: 300;
	color: #F5F5F5;
    border-radius: 0;
	background-color: rgba( 245, 245, 245, .2);
}
.contact-form textarea{
	height: 150px;
	resize: none;
}
.wpcf7 input[type="submit"] {
	padding: 2px 45px;
	margin-top: 15px;
	border: 1px solid #F5F5F5;
	background:none;
	color:#F5F5F5;
	font-size: 1.2rem;
    text-transform: uppercase;
}
.wpcf7 input[type="submit"]:hover {
	border: 1px solid #0C4E6A;
	background-color: #0C4E6A;
	opacity: 1;
}
.contact-form .wpcf7 form .wpcf7-response-output{
    margin: 0;
    padding: 0;
    border: none;
}
span.wpcf7-list-item {
	display: block;
	font-size: 1.4rem;
	line-height: 1.6rem;
	color: #616457;
    margin: 7.5px 0 0 0;
}
.wpcf7-not-valid-tip {
    /*position: absolute;*/
    color: #F5F5F5;
    font-size: 1.2rem;
}
.wpcf7-not-valid{
	margin-bottom: 0!important;
}
div.wpcf7 .ajax-loader {
    display: none!important;
}
input:required {
    box-shadow:none;
}
input:invalid {
    box-shadow:0 0 3px #FFF;
}

form.is-invalid > .acf-error-message{
	visibility: visible;
	display: block;
	position: relative;
	padding: 10px 0;
}


/*------------------------------------*\
    CONTACT
\*------------------------------------*/
#contact{
	position: relative;
	overflow: hidden
}
#contact .row{
	overflow-y: hidden;
}
.contact-left{
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	font-size: 1.2rem;
	line-height: 1.8rem;
	font-weight: 200;
}
.contact-left ul{
	margin-bottom: 0;
}
.contact-left ul li{
	margin-bottom: 1rem;
}
.contact-left a{
	color: #fff;
	font-weight: 400;
}
.contact-info{
	font-size: 2.4rem;
	line-height: 3.2rem;
}
.contact-form > span{
	display: inline-block;
	padding-bottom: 15px;
	font-weight: 500;
	font-size: 2.6rem;
}
.modal{
	display: none;
}
.modal-close{
	position: absolute;
	right:25px;
}

/*------------------------------------*\
    RESPONSIVE
\*------------------------------------*/
@media only screen and (max-width:480px) {
    section{
        padding-left: 20px;
        padding-right: 20px;
    }
    section .container-fluid{
        padding-left: 0;
        padding-right: 0;
    }
}

@media only screen and (max-width:768px) {
    .mt50{
        margin-top: 1.5em;
    }
	.mb30{
		margin-bottom: 1em;
	}
    .mb50{
        margin-bottom: 1.5em;
    }
    .pt50{
        padding-top: 1.5em;
    }
    .pb30{
        padding-bottom: 1em;
    }
    .pb50{
        padding-bottom: 1.5em;
    }
	.pb100{
		padding-bottom: 2em;
	}
    .pt100{
        padding-top: 2em;
    }
	section{
		scroll-margin-top: 50px;
	}
	section ul li::before{
		top: 0.8em;
		left: -2rem;
		width: 15px;
	}
	.text-center h1 br,
	.text-center h2 br,
	.text-center p br{
		display: none;
	}
}
@media only screen and (max-width:1140px) {
}
@media only screen and (min-width:320px) {
}
@media only screen and (min-width:769px) {
}
@media only screen and (min-width:1024px) {
}
@media only screen and (min-width:1140px) {
}
@media only screen and (min-width:1280px) {
}
@media only screen and (-webkit-min-device-pixel-ratio:1.5),
	   only screen and (min-resolution:144dpi) {
}

/*------------------------------------*\
    WORDPRESS CORE
\*------------------------------------*/

.alignnone {
	margin:0 20px 20px 0;
}
.aligncenter,
div.aligncenter {
	display:block;
	margin:5px auto 5px auto;
}
.alignright {
	float:right;
	margin:5px 0 20px 20px;
}
.alignleft {
	float:left;
	margin:5px 20px 20px 0;
}
a img.alignright {
	float:right;
	margin:5px 0 20px 20px;
}
a img.alignnone {
	margin:5px 20px 20px 0;
}
a img.alignleft {
	float:left;
	margin:5px 20px 20px 0;
}
a img.aligncenter {
	display:block;
	margin-left:auto;
	margin-right:auto;
}
.wp-caption {
	background:#FFF;
	border:1px solid #F0F0F0;
	max-width:96%;
	padding:5px 3px 10px;
	text-align:center;
}
.wp-caption.alignnone {
	margin:5px 20px 20px 0;
}
.wp-caption.alignleft {
	margin:5px 20px 20px 0;
}
.wp-caption.alignright {
	margin:5px 0 20px 20px;
}
.wp-caption img {
	border:0 none;
	height:auto;
	margin:0;
	max-width:98.5%;
	padding:0;
	width:auto;
}
.wp-caption .wp-caption-text,
.gallery-caption {
	font-size:11px;
	line-height:17px;
	margin:0;
	padding:0 4px 5px;
}

/*------------------------------------*\
    PRINT
\*------------------------------------*/

@media print {
	* {
		background:transparent !important;
		color:#000 !important;
		box-shadow:none !important;
		text-shadow:none !important;
	}
	a,
	a:visited {
		text-decoration:underline;
	}
	a[href]:after {
		content:" (" attr(href) ")";
	}
	abbr[title]:after {
		content:" (" attr(title) ")";
	}
	.ir a:after,
	a[href^="javascript:"]:after,
	a[href^="#"]:after {
		content:"";
	}
	pre,blockquote {
		border:1px solid #999;
		page-break-inside:avoid;
	}
	thead {
		display:table-header-group;
	}
	tr,img {
		page-break-inside:avoid;
	}
	img {
		max-width:100% !important;
	}
	@page {
		margin:0.5cm;
	}
	p,
	h2,
	h3 {
		orphans:3;
		widows:3;
	}
	h2,
	h3 {
		page-break-after:avoid;
	}
}
