/**
 * Theme Name: Blocksy Child
 * Description: Blocksy Child theme
 * Author: Creative Themes
 * Template: blocksy
 * Text Domain: blocksy
 */

/** _________________ GLOBAL _________________  */

:root{
	--black:#3C3C3B; 
	--orange:#EF774C; 
	--blanc:#FCFCFC; 
}


@font-face {
	font-family: 'Satochi';
	src: url('/wp-content/uploads/2025/12/Satoshi-Regular.woff2') format('woff2'),
		url('/wp-content/uploads/2025/12/Satoshi-Regular.woff') format('woff');
	font-weight: 300; 
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: 'Satochi';
	src: url('/wp-content/uploads/2025/12/Satoshi-Bold.woff2') format('woff2'),
		url('/wp-content/uploads/2025/12/Satoshi-Bold.woff') format('woff');
	font-weight: 700; 
	font-style: normal;
	font-display: swap;
}

h2 em {
	display: block!important;
	font-style: normal!important;
}

@media (max-width: 768px){
	h2 em {
		   display: inline!important;
	}
}

#main {
	margin-top: -90px!important;
}

/** _________________ MENU  _________________  */

.menu .ct-menu-link {
	font-family : 'Satochi'!important;
	font-weight: 700!important;
}

.btn-menu {
	background: var(--black)!important;
	border-radius: 8px!important;
}

.btn-menu a {
		color: var(--blanc)!important;
		padding-left: 15px!important;
	padding-right: 15px!important;
	box-shadow: 0 20px 6px 0 rgba(0, 0, 0, 0.00), 0 13px 5px 0 rgba(0, 0, 0, 0.01), 0 7px 4px 0 rgba(0, 0, 0, 0.05), 0 3px 3px 0 rgba(0, 0, 0, 0.09), 0 1px 2px 0 rgba(0, 0, 0, 0.10)!important;
	

}

#menu-menu-principal.menu {
	height: 40px!important;
}

#header .ct-sticky-container > DIV {
	backdrop-filter: blur(6px)!important;
	margin: 20px!important;
	border-radius: 20px!important;
}

#header .ct-sticky-container > DIV > DIV {
	border-radius: 20px!important;
}

#offcanvas {
	height: fit-content!important;
	background: linear-gradient(269deg, rgba(252, 252, 252, 0.50) 20.27%, rgba(252, 252, 252, 0.80) 48.37%)!important;
	backdrop-filter: blur(6px)!important;

}
@media screen and (max-width:999px){
	[data-header*="type-1"] #offcanvas .ct-panel-content{
		height: auto!important;
		flex: unset!important;
		justify-content: start!important;
	}
	.btn-menu {
		width: fit-content!important;
		margin: 0 auto!important;
	}
}
/** _________________ HOME _________________  */

.informations {
	gap: 20px;
	display: flex;
    flex-direction: column;
}

@media screen and (min-width: 601px) and (max-width: 768px) {
	.informations {
		flex-direction: row;
	}
}

.brz-accordion .brz-columns, .toggle-height {
	height: fit-content!important;
}

.informations-case {
	border-radius: 16px;
	background: var(--blanc);
	padding: 20px;
	font-family : 'Satochi'!important;
	width: fit-content!important;
}

.informations-case p {
	margin: 0px!important;
	line-height: 0px!important
}

.informations-case strong {
	color: var(--black);
	font-size:  30px;
	font-style: normal;
	font-weight: 700;
	line-height: 30px; /* 32px */
	text-transform: uppercase;
}
.case-1 p {
	margin: 9px 0px !important;
}

.case-2 p {
	margin: 14px 0px !important;
}

@media screen and (min-width: 769px) and (max-width: 1000px) {
	.informations-case strong {
		font-size:  25px;
	}
}

@media (max-width: 768px){
	.informations-case strong  {
		font-size:  20px;
	}
}

@media (max-width: 600px){
	.informations-case {
		text-align: center;
		width: 100%!important;
	}
}

.point-after:before {
	content: "";
    display: block;
    width: 430px;
    height: 500px;
    margin-top: 30px;
    background-image: radial-gradient(circle, #797979 1px, transparent 1px);
    background-size: 12px 12px;
    background-repeat: repeat;
	opacity: 0.5;
}

.top.point-after:before {
	position: absolute;
	top: 0;
	left: 0;
    background-image:
        linear-gradient(
            to top,
            var(--blanc) 0%,
            var(--blanc) 20%,
            rgba(255,255,255,0) 100%
        ),
        radial-gradient(circle, #797979 1px, transparent 1px);

    background-size: 100% 100%, 12px 12px;
    background-repeat: no-repeat, repeat;
}

.bottom.point-after:before {
	position: absolute;
	bottom: 0;
	right: 0;
	z-index: 1;
}
@media (max-width: 768px){
	.point-after:before {
		    width: 250px;
    		height: 250px;
			top: -3%;
	}
}


.img-responsive .brz-bg {
	display: block!important;
    margin-left: auto!important;
    margin-right: calc(-60vw + 50%)!important;
}

@media screen and (min-width: 577px) and (max-width: 1000px) {
	.img-responsive .brz-bg-image {
		background-position: 90% 50%!important;
	}
}

@media (min-width: 1000px){
	.size-title  {
		max-width: 80%!important;
	}
}

.brz-accordion__item {
	background: transparent!important;
}

.toggle .brz-bg-color {
	backdrop-filter: blur(10px)!important;
}

.brz-accordion__nav {
	padding: 0px!important;
}

.orange-arrow {
	transform: scale(3)!important;
    z-index: 1!important;
}

.gform-body, .gform_footer, .gchoice label, ::placeholder {
	font-family: 'Satochi'!important;
}

.gfield input, .gfield textarea {
	border-radius: 10px!important;
}

input:is([type=url],[type=tel],[type=text],[type=time],[type=date],[type=datetime],[type=datetime-local],[type=email],[type=number],[type=search],[type=password]):focus {
	border-color: var(--blanc)!important;
}

.gform_footer {
	justify-content: center!important;
	padding-bottom: 0px!important;
}

#gform_submit_button_1 {
	margin-bottom: 0px!important;
	border-radius: 8px!important;
	background: var(--blanc)!important;
	box-shadow: 0 20px 6px 0 rgba(0, 0, 0, 0.00), 0 13px 5px 0 rgba(0, 0, 0, 0.01), 0 7px 4px 0 rgba(0, 0, 0, 0.05), 0 3px 3px 0 rgba(0, 0, 0, 0.09), 0 1px 2px 0 rgba(0, 0, 0, 0.10)!important;
	color: var(--noir)!important;
}

::placeholder {
	opacity: 1!important;
}

.contact .brz-bg {
	box-shadow: -111px 107px 43px 0 rgba(0, 0, 0, 0.00), -71px 68px 39px 0 rgba(0, 0, 0, 0.01), -40px 39px 33px 0 rgba(0, 0, 0, 0.05), -18px 17px 25px 0 rgba(0, 0, 0, 0.09), -4px 4px 14px 0 rgba(0, 0, 0, 0.10)!important;

}

#input_1_8 {
	display: flex!important;
    align-items: center!important;
    justify-content: center!important;
    gap: 20px!important;
	flex-wrap: wrap!important;
}


#input_1_8 label {
	color: var(--blanc)!important;
    font-family: 'Satochi'!important;
    font-size: 24px!important;
    font-style: normal!important;
    font-weight: 400!important;
}

@media (max-width: 600px){
 #input_1_8 label {
	 font-size: 18px!important;
}
}
@media (min-width: 769px){
.arrow-section:before {
	content: url('/wp-content/uploads/2025/12/arrow-before.png');
    position: absolute;
    top: 0;
    right: 0;
    transform-origin: top right; 

}
}
.custom-picto .brz-bg {
	    box-shadow: -111px 107px 43px 0 rgba(0, 0, 0, 0.00), -71px 68px 39px 0 rgba(0, 0, 0, 0.01), -40px 39px 33px 0 rgba(0, 0, 0, 0.05), -18px 17px 25px 0 rgba(0, 0, 0, 0.09), -4px 4px 14px 0 rgba(0, 0, 0, 0.10)!important;
}
.custom-picto h3 span {
	margin-bottom: 10px!important;
	    display: block !important;
}

.custom-picto .brz-icon__container img {
	width: 120px!important;
}


@media (max-width: 600px){
.custom-picto .brz-icon-text  {
	    flex-direction: column!important;
}
	.custom-picto .brz-icon__container {
		margin-left: 0px!important;
		margin-right: 0px!important;
		margin-bottom: 10px!important;
	}
	.custom-picto .brz-icon__container img {
		width: 80px!important;
	}
}

.gchoice .gfield-choice-input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    pointer-events: none; 
}


.gchoice .gform-field-label {
    position: relative;
    padding-left: 28px; 
    cursor: pointer;
}


.gchoice .gform-field-label::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    border: 2px solid var(--blanc);
    border-radius: 4px; 
    background: transparent;
    box-sizing: border-box;
    transition: all 0.2s ease;
}

.gchoice .gform-field-label::after {
    content: "";
    position: absolute;
    left: 7px;
    top: 50%;
    width: 6px;
    height: 12px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: translateY(-60%) rotate(45deg);
    opacity: 0;
    transition: opacity 0.2s ease;
}


.gchoice .gfield-choice-input[type="checkbox"]:checked + .gform-field-label::before {
    background: transparent;      
    border: 2px solid var(--blanc);
}

.gchoice .gfield-choice-input[type="checkbox"]:checked + .gform-field-label::after {
    opacity: 1;
}

/** _________________ FOOTER _________________  */

.fw-footer {
    background: var(--blanc);
    color: var(--black);
    font-size: 14px;
    padding: 20px 0 30px;
	font-family: 'Satochi'!important;
}

@media (max-width: 768px){
	.fw-footer {
		padding: 40px 0 20px;
	}
}

.ct-container {
    margin: 0 auto;
    padding: 0 16px;
}

.fw-footer-top {
    display: flex;
    justify-content: space-between;
    gap: 40px;
    align-items: flex-start;
    flex-wrap: wrap;
}

.fw-footer-left {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.fw-footer-brand {
    display: flex;
    gap: 16px;
    align-items: flex-start;
}

.fw-footer-logo {
    max-width: 120px;
    height: auto;
}

.fw-footer-logo-2 {
	max-width: 200px;
	margin-top: 5px;
}

.fw-footer-contact p {
    margin: 0;
    line-height: 1.4;
}

.fw-footer-contact a {
    color: var(--black);
    text-decoration: none;
}

.fw-footer-contact a:hover {
    text-decoration: underline;
}

.fw-footer-logos {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 6px;
    align-items: center;
}

.fw-footer-logos img {
    max-height: 40px;
    width: auto;
    object-fit: contain;
}

.fw-footer-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 6px;
    flex: 1;
    min-width: 260px;
}

.fw-footer-tagline {
    margin: 0;
    font-weight: 600;
	color: var(--black);
	text-align: center;
	font-size:  26px;
	font-style: normal;
	font-weight: 700;
	min-width: 590px;
}

.fw-footer-nav {
    width: 100%;
    display: flex;
    justify-content: flex-end;
}

.fw-footer-menu {
	list-style: none;
    margin: 0;
    padding: 15px 20px;
    display: flex;
    gap: 24px;
    border-radius: 15px;
    background: var(--orange);
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.15);
    min-width: 590px;
    justify-content: center;
}

.fw-footer-menu li {
    margin: 0;
}

.fw-footer-menu a {
    color: #ffffff;
    text-decoration: none;
    font-weight: 500;
    white-space: nowrap;
    font-size: 20px;
}

.fw-footer-menu a:hover,
.fw-footer-menu a:focus {
    opacity: 0.8;
	color: var(--blanc)!important;
}

.fw-footer-bottom {
    margin-top: 24px;
    text-align: center;
}

.fw-footer-divider {
    display: block;
    border-top: 1px solid rgba(0,0,0,0.12);
    margin-bottom: 16px;
}

.fw-footer-legal {
    margin: 0;
    line-height: 1.6;
}

.fw-footer-legal a {
    color: var(--black);
    text-decoration: none;
}

.fw-footer-legal a:hover {
    opacity: 0.8;
}
.fw-footer-agency svg {
	position: relative;
    top: 3px;
}
}
.fw-footer-agency {
    font-size: 13px;
}

@media screen and (min-width: 901px) and (max-width: 1100px) {
	.fw-footer-menu, .fw-footer-tagline {
		min-width: auto;
	}
	
	.fw-footer-tagline {
		text-align: right;
		line-height: 30px;
	}
}

@media (max-width: 900px) {
    .fw-footer-top {
        flex-direction: column;
        gap: 24px;
    }

    .fw-footer-right {
        align-items: flex-start;
    }

    .fw-footer-tagline {
        text-align: left;
    }

    .fw-footer-nav {
        justify-content: flex-start;
    }
	
	.fw-footer-menu, .fw-footer-tagline, .fw-footer-right {
		min-width: 100%;
	}
    .fw-footer-menu {
        flex-wrap: wrap;
        gap: 12px 16px;
        justify-content: center;
    }

    .fw-footer-right {
        align-items: center;
        text-align: center;
    }

    .fw-footer-tagline {
        text-align: center;
        font-size: 16px;
    }

    .fw-footer-brand {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .fw-footer-left {
        align-items: center;
		margin: 0 auto;
    }

    .fw-footer-logos {
        justify-content: center;
		margin: 0 auto;
    }
}





/*  JOBS   */

.job_filters{
	background: linear-gradient(61deg, rgba(60, 60, 59, 0.70) 30.4%, rgba(60, 60, 59, 0.40) 85.41%);
	border-radius:20px;
	padding:20px;
}

.search_jobs{
	padding:0;
}

.search_submit input{
	width:fit-content !important;
	background:white;
	color:black;
	margin:20px auto auto;
	display:block;
	border-radius:8px !important;
}

#search_keywords, #search_location{
	background:white;
	color:black;
	border-radius:6px;
}

div.job_listings .load_more_jobs{
	padding:10px 20px;
	background:black !important;
	width:fit-content;
	margin:auto;
	border-radius:8px;
	color:white !important;
}

div.job_listings .load_more_jobs:hover{
	background:black !important;
	color:white !important;
}

.showing_jobs{
	display:none !important;
}

.job_types{
	display:none !important;
	border:none !important;
    justify-content: center;
    display: flex;
	background:none !important;
	color:white;
}

.job_types li{
	border:none !important;
}

/* LIST JOBS */

.job_listings{
	margin-top:40px !important;
}

ul.job_listings li.job_listing {
    width: 100%;
    padding: 30px;
    background: #fff;
    position: relative;
    margin-bottom: 20px;
    transition: .3s ease;
	border-radius: 15px;
}

ul.job_listings li.job_listing a {
    padding: 0;
    color: #000;
}

ul.job_listings li.job_listing div.position {
    padding: 0 !important;
    width: auto !important;
    float: unset !important;
}

ul.job_listings li.job_listing div h3 {
    color: #000;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 24px !important;
    margin-bottom: 15px !important;
}

ul.job_listings li.job_listing .metas-container {
	margin-top:10px;
}

ul.job_listings li.job_listing .metas-container .meta {
    color: #000;
    padding: 0;
    list-style: none;
    float: unset;
    text-align: left;
    width: auto;
    font-size: 16px;
}

ul.job_listings li.job_listing .metas-container .meta .category {
    font-weight: 700;
}

ul.job_listings li.job_listing .metas-container .location {
    color: #000;
    font-weight: 700;
    font-size: 16px;
    width: auto;
    float: unset;
    padding: 0;
    padding-left: 3px;
    text-align: left;
}

ul.job_listings li.job_listing .metas-container .meta .tags, 
ul.job_listings li.job_listing .metas-container .meta .job-type {
    color: #000;
}

ul.job_listings li.job_listing .metas-container .meta li {
    width: 100% !important;
    margin: 0 !important;
}

ul.job_listings li.job_listing .apply-button {
    display: inline-block;
    background: #000;
    color: #fff !important;
    font-size: 18px;
    font-weight: 700;
    padding: 10px 35px;
	margin-top:10px;
	border-radius:8px;
}

@media screen and (min-width: 1200px) {
    ul.job_listings li.job_listing a {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    ul.job_listings li.job_listing div h3 {
        width: 212px;
    }

    ul.job_listings li.job_listing .description {
        max-width: 628px;
    }
}


.type-job_listing{
	margin-top:75px;
}

.type-job_listing *{
	color:black !important;
}

.job_application input{
	color:white !important;
}

.single_job_listing {
	color: white;
}

.single_job_listing .company{
	display:none;
}

.single_job_listing .job-listing-meta .job-type {
	background: transparent;
}

.single_job_listing .job-listing-meta .location::before {
	margin: 0;
}

.single_job_listing .job-listing-meta .location a,
.single_job_listing .job-listing-meta .date-posted time{
	margin-left: 5px;
}

.single-job_listing .entry-header .entry-meta,
.single-job_listing .ct-comments-container {
	display: none;
}

.wpcf7 form.sent .wpcf7-response-output {
	border-color: #C0A86F !important;
}




#gform_confirmation_message_1{
	color:white;
	margin-top:20px;
}