/*
Theme Name: lafirm
Description: This theme for lafirm Theme
Version: 1.0.0
*/

/*@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800;900&display=swap');
*/
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}

body {
	font-family: 'AvertaDemo-Regular';
	font-weight: 400;
	color: #6d6e71;
	line-height: 21px;
	font-size: 16px;
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}

nav ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
	content: '';
	content: none;
}

a {
	margin: 0;
	padding: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
	transition: all 0.3s ease;
	text-decoration: none !important;
}

/* change colours to suit your needs */
ins {
	background-color: #ff9;
	color: #000;
	text-decoration: none;
}

/* change colours to suit your needs */
mark {
	background-color: #ff9;
	color: #000;
	font-style: italic;
	font-weight: bold;
}

del {
	text-decoration: line-through;
}

abbr[title], dfn[title] {
	border-bottom: 1px dotted;
	cursor: help;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
	border: 0 !important;
	border-bottom: 4px solid #f3c64a !important;
	width: 100px;
	margin: 10px 0 !important;
	display: inline-block;
}

input, select {
	vertical-align: middle;
}

li {
	list-style: none;
}

@font-face {
  font-family: 'MagnelDisplay-Black';
  src:  url('assets/fonts/MagnelDisplay-Black.otf')  format('opentype'),
	     url('assets/fonts/MagnelDisplay-Black.woff') format('woff'), 
	     url('assets/fonts/MagnelDisplay-Black.ttf')  format('truetype'), 
	     url('assets/fonts/MagnelDisplay-Black.svg#MagnelDisplay-Black') format('svg');
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'AvertaDemo-Regular';
  src:  url('assets/fonts/AvertaDemo-Regular.otf')  format('opentype'),
	     url('assets/fonts/AvertaDemo-Regular.woff') format('woff'), 
	     url('assets/fonts/AvertaDemo-Regular.ttf')  format('truetype'), 
	     url('assets/fonts/AvertaDemo-Regular.svg#AvertaDemo-Regular') format('svg');
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'Averta-Bold';
  src:  url('assets/fonts/Averta-Bold.otf')  format('opentype'),
	     url('assets/fonts/Averta-Bold.woff') format('woff'), 
	     url('assets/fonts/Averta-Bold.ttf')  format('truetype'), 
	     url('assets/fonts/Averta-Bold.svg#Averta-Bold') format('svg');
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'Averta-ExtraBold';
  src:  url('assets/fonts/Averta-ExtraBold.otf')  format('opentype'),
	     url('assets/fonts/Averta-ExtraBold.woff') format('woff'), 
	     url('assets/fonts/Averta-ExtraBold.ttf')  format('truetype'), 
	     url('assets/fonts/Averta-ExtraBold.svg#Averta-ExtraBold') format('svg');
  font-weight: normal;
  font-style: normal;
}
p:empty{
	display: none;
}
::-webkit-input-placeholder { 
  color: #b8b8b8;
}
::-moz-placeholder { 
  color: #b8b8b8;
}
:-ms-input-placeholder { 
  color: #b8b8b8;
}
:-moz-placeholder { 
  color: #b8b8b8;
}
/*-- Header --*/
.container-custom {
    max-width: 90%;
    margin: 0 auto;
}
header#la-site-header {
    position: absolute;
    width: 100%;
    z-index: 9999;
}
.meanmenu-reveal{
	cursor: pointer;
}
.meanmenu-reveal img {
    transition: all 0.5s ease;
    -ms-transform: rotate(90deg);
    transform: rotate(90deg);
}
.meanmenu-reveal.toggle img {
    -ms-transform: rotate(0deg);
    transform: rotate(0deg);
}
#site-navigation {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}
#site-navigation ul a {
    color: #fff;
    text-transform: uppercase;
    font-size: 16px;
    line-height: 24px;
    letter-spacing: 5px;
}
#site-navigation ul li {
    margin: 0 0 0 35px;
}
.meanmenu-reveal {
    cursor: pointer;
    margin-left: 30px;
}

/*-- Main Banner section --*/
#home-banner-sec {
    position: absolute;
    width: 100%;
    height: 100%;
}
#home-banner-sec img {
    background: 100%;
    width: 100%;
    height: auto;
    display: block;
}
.main-title {
    height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.main-title h2 {
    position: absolute;
    font-size: 200px;
    font-weight: bold;
    font-family: 'MagnelDisplay-Black';
    line-height: 200px;
    mix-blend-mode: difference;
    color: #fff;
    z-index: 3;
    width: auto;
    word-break: break-word;
}
#main-banner-sec ,
#main-banner-sec .one,
#main-banner-sec .two {
    position: absolute;
    height: 100vh;
    width: 100%;
    min-height: 600px;
}
#main-banner-sec {position: relative; }
.whitebg {
    z-index: 2;
    width: 100%;
    background: url(/wp-content/uploads/2020/06/banner-white.jpg);
    transition: 0.5s all ease;
    -webkit-transition: 0.5s all ease;
    -ms-transition: 0.5s all ease;
}
body.loaded .whitebg {width: 50% !important;}
.main-title {opacity: 0;visibility: hidden;transition: 0.2s all ease;-webkit-transition: 0.2s all ease;-ms-transition: 0.2s all ease;}
.main-title.active {opacity: 1;visibility: visible;}
.blackbg {
    background: #000;
    z-index: 1;
    width: 100%; 
}
.main-title small {
    font-size: 30px;
    color: #000;
    line-height: 42px;
    display: block;
    position: relative;
    z-index: 5;
    top: 235px;
}
.social-share {
    position: absolute;
    left: 50px;
    top: 50%;
    z-index: 5;
}
.social-share li {
    margin-bottom: 15px;
}
.social-share a {
    font-size: 14px;
    line-height: 30px;
    background: #000;
    width: 40px;
    display: flex;
    justify-content: center;
    height: 40px;
    border-radius: 50%;
    align-items: center;
    color: #fff;
}

/*--- Service Section ---*/
	
#service-sec {
    background: url(/wp-content/uploads/2020/06/banner-white.jpg);
    padding: 100px 0;
    background-size: cover;
    display: block;
}
.title-box {
    margin-bottom: 30px;
    position: relative;
}
.title-box:before {
    content: "";
    height: 2px;
    width: 230px;
    background: #000;
    display: inline-block;
    position: absolute;
    top: 55%;
    left: -20%;
}
.title-box h3 {
    font-size: 92px;
    font-weight: bold;
    color: #000;
    font-family: 'MagnelDisplay-Black';
}
.title-box p{
	color: #fff;
	font-size: 30px;
	line-height: 42px;
	display: block;
	margin-top: 30px;
}
#service-sec h4 {
    font-size: 36px;
    font-weight: 600;
    color: #000;
   font-family: 'Averta-ExtraBold';
    line-height: 90px;
}
.list-btn-box ul li {
    font-size: 18px;
    line-height: 38px;
    color: #000;
}
.gray-white-bg {
    background: rgba(255,255,255,0.90);
    padding: 60px 80px 90px;
    transition: all 0.2s ease;
}
.gray-white-bg:nth-child(2), .gray-white-bg:nth-child(3) {
    background: rgba(0,0,0,0.8);
}
.gray-white-bg:nth-child(2) .list-btn-box ul li, 
.gray-white-bg:nth-child(3) .list-btn-box ul li,
.gray-white-bg:nth-child(2)  h4, 
.gray-white-bg:nth-child(3)  h4,
.gray-white-bg:nth-child(2)  .read-more, 
.gray-white-bg:nth-child(3)  .read-more{
 	color: #fff !important;
}
.gray-white-bg:nth-child(2)  svg polygon,
.gray-white-bg:nth-child(3)  svg polygon{
	fill: #fff;
}
.read-more {
    color: #000;
    font-size: 20px;
    font-weight: 700;
    margin-top: 20px;
    display: block;
    font-family: 'Averta-Bold';
}
.read-more:hover, 
.gray-white-bg:nth-child(2)  .read-more:hover, 
.gray-white-bg:nth-child(3)  .read-more:hover{
	color: #f15555 !important;
}


.gray-white-bg:hover:nth-child(1) {
    background: #e9937b; 
}
.gray-white-bg:hover:nth-child(1) h4,
.gray-white-bg:hover:nth-child(1) ul li,
.gray-white-bg:hover:nth-child(1) .read-more,
.gray-white-bg:hover:nth-child(3)  svg polygon{
	color: #f0d0ca !important;
	fill: #f0d0ca;
}
.gray-white-bg:hover:nth-child(2) {
    background: #f0d0ca; 
}
.gray-white-bg:hover:nth-child(2) h4,
.gray-white-bg:hover:nth-child(2) ul li,
.gray-white-bg:hover:nth-child(2) .read-more,
.gray-white-bg:hover:nth-child(2)  svg polygon{
	color: #e9937b !important;
	fill: #e9937b;
} 


.gray-white-bg:hover:nth-child(3) {
    background: #0a4d4d; 
}
.gray-white-bg:hover:nth-child(3) h4,
.gray-white-bg:hover:nth-child(3) ul li,
.gray-white-bg:hover:nth-child(3) .read-more,
.gray-white-bg:hover:nth-child(3)  svg polygon{
	color: #d7d3cd !important;
	fill: #d7d3cd;
}


.gray-white-bg:hover:nth-child(4) {
    background: #d7d3cd; 
}
.gray-white-bg:hover:nth-child(4) h4,
.gray-white-bg:hover:nth-child(4) ul li,
.gray-white-bg:hover:nth-child(4) .read-more,
.gray-white-bg:hover:nth-child(4)  svg polygon{
	color: #0a4d4d !important;
	fill: #0a4d4d
}
.read-more svg {
    width: 24px;
    margin-left: 7px;
}

/*-- Footer --*/

#la-site-footer {
    padding: 100px 0 30px;
    background: #e5e5e5;
}
.foo-contact p, .foo-contact a {
    font-size: 18px;
    color: #000;
    font-weight: 500;
    line-height: 28px;
    position: relative;
    margin-bottom: 10px;
}
.address p:before, .phone a:before, .email a:before {
    position: absolute;
    left: -21px;
    font: normal normal normal 20px/1 FontAwesome;
    top: 4px;
    display: inline-block;
    color: #7a7a7a;
}
.phone a:hover:before, .email a:hover:before{
	color: #f15555;
}
.address p:before{
	content: "\f041";
}
.phone a:before {
    content: "\f095";
    transform: rotate(-100deg);
    top: 0;
    left: -27px;
    font-size: 23px;
}
.email a:before {
    content: "\f003";
    left: -31px;
    top: 0;
}

.foo-contact a:hover{
	color: #f15555;
}

.subscribe-box .text-box {
    height: 50px;
    background: #fff;
    border: 0;
    padding: 15px 20px;
    width: 100%;
}
.subscribe-box {
    position: relative;
}
.mail-box .submit-btn {
    background: #000;
    border: 0;
    height: 50px;
    position: absolute;
    right: 0;
    top: 0;
    background: url(/wp-content/uploads/2020/06/send-arrow.png) center #000 no-repeat;
    font-size: 0;
    width: 50px;
}
div.wpcf7-validation-errors, div.wpcf7-acceptance-missing, div.wpcf7-response-output {
    margin: 10px 0 0;
    text-align: center;
}
span.ajax-loader{
	display: none;
}

.social-links {
    display: flex;
    justify-content: flex-end;
}
.social-links li {
    margin: 0 0 0 20px;
}
.social-links li a{
	color: #000;
	font-size: 18px;
	line-height: 24px;
	display: inline-block;
}
.social-links li a:hover{
	color: #f15555;
}
.bottom-space{
	padding-bottom: 50px;
}
.copy-right p{
    font-size: 14px;
    color: #000;
    font-weight: 500;
}

/** About Section **/

#about-lafirm-sec {
    background: url(/wp-content/uploads/2020/06/about-bg.jpg) center no-repeat;
    display: block;
    position: relative;
    background-size: cover;
    padding: 100px 0 80px;
}
.title-box.white-text h3 {
    color: #fff;
    line-height: 90px;
}
#about-lafirm-sec .title-box:before {
    background: #fff;
    left: -57%;
}
.about-box p {
    font-size: 24px;
    color: #fff;
    font-weight: 400;
    display: block;
    line-height: 34px;
}
.about-box a {
    background: #fff;
    color: #000;
    text-transform: uppercase;
    letter-spacing: 2px;
    padding: 16px 52px;
    display: inline-block;
    margin-top: 88px;
}
.about-box a:hover, .submit-btn .form-btn:hover{
	background:#000;
	color: #fff;
}


/*-- Contact Section --*/
#contact-us-sec{
	 background: url(/wp-content/uploads/2020/06/contact-bg.jpg) center no-repeat;
    display: block;
    position: relative;
    background-size: cover;
    padding: 110px 0;
}
.contact-form {
    margin: 0 auto;
    width: 53%;
    padding-top: 30px;
}
.contact-form .text-field {
    margin-bottom: 30px;
}
.title-box.top-border:before {
    left: auto;
    right: auto;
    width: 2px;
    height: 95px;
    background: #fff;
    top: -68%;
}
.contact-form .text-box {
    width: 100%;
    border: 1px solid #fff;
    padding: 14px 20px;
    font-size: 18px;
    color: #000;
}
.submit-btn .form-btn {
    background: #fff;
    border: 0;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 16px;
    padding: 17px 90px;
}

/*-- Portfolio --*/
.custom-title-size, .custom-box-size{
	padding: 0;
}
.title-box.full-left-line:before {
    left: -37%;
    top: 27%;
}
#portfolio-sec .title-box {
    margin-top: 60px;
}
#portfolio-sec {
    padding: 120px 0;
}
.portfolio-box li {
    float: left;
    width: 25%;
    overflow: hidden;
    height: 360px;
   transition: all 0.5s ease;
}
.portfolio-box li:hover {
    opacity: 1;
    -webkit-box-shadow: 0px 0px 16px 0px rgba(0,0,0,0.75);
    -moz-box-shadow: 0px 0px 16px 0px rgba(0,0,0,0.75);
    box-shadow: 0px 0px 16px 0px rgba(0,0,0,0.75);
    transform: scale(1);
    z-index: 1;
    position: relative;
}
.portfolio-box figure {
    position: relative;
    height: 100%;
}
.portfolio-box figure img {
    height: 360px;
    width: 100%;
    display: block;
    object-fit: cover;
    object-position: 0 0;
}
.portfolio-box figure figcaption {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    display: flex;
    justify-content: center;
    height: 100%;
    align-items: center;
    padding: 20px;
}
.portfolio-box figure figcaption h4{
	color: #fff;
	opacity: 0;
	text-align: center;
    font-size: 36px;
    transition: all 0.5s ease;
    font-family: 'Averta-ExtraBold';
}
.portfolio-box.latest-portfolio-box li {
    width: 49%;
}
.portfolio-box li:hover figure figcaption h4{
	opacity: 1;
}



/* 29-06-2020 */
.portfolio-box figure { padding-bottom: 100%; height: auto; }
.portfolio-box figure img { position: absolute; height: 100%; }
.portfolio-box li { height: auto; }

.main-title h2 { position: relative; }
.main-title { display: block; height: auto; max-width: 1260px; width: 100%; margin: 0 auto; }
.main-title small { position: relative; top: 0;}
#main-banner-sec .col-lg-12 { height: 100vh; display: flex; align-items: center; }

#site-navigation ul { opacity: 0; visibility: hidden; transition: all 0.3s ease; background: #000; transform: translateX(40px); padding: 30px 0; }
body.menu-open #site-navigation ul { opacity: 1; visibility: visible; transform: translateX(0px); }

.service-box-wrapper { position: relative; overflow: hidden; }
.service-box-wrapper .gray-white-bg { position: relative; }
.service-box-wrapper .inner-box { position: absolute; top: 0; left: 0; height: 100%; width: 200%; z-index: 2; background: #e9937b; display: flex; align-items: center; justify-content: center; color: #000; font-size: 21px; line-height: 1.5; margin-left: -100%; opacity: 0; visibility: hidden; transition: all 0.3s ease; }
.service-box-wrapper .inner-box .inner { width: 80%; }
.service-box-wrapper .inner-box h2 { font-family: 'MagnelDisplay-Black'; font-size: 48px; padding: 0 0 20px; }
.service-box-wrapper .open .inner-box { margin-left: 0; visibility: visible; opacity: 1; }
.service-box-wrapper .gray-white-bg:nth-child(even) { }
.service-box-wrapper .gray-white-bg:nth-child(even) .inner-box { left: -100%; margin-left: 100%; }
.service-box-wrapper .gray-white-bg.open:nth-child(even) .inner-box { margin-left: 0; }
.service-box-wrapper .gray-white-bg:nth-child(2) .inner-box { background: #f0d0ca; }
.service-box-wrapper .gray-white-bg:nth-child(3) .inner-box { background: #0a4d4d; color: #fff; }
.service-box-wrapper .gray-white-bg:nth-child(4) .inner-box { background: #d7d3cd; }
.foo-contact.address {padding-left: 15px;}

.service-box-wrapper .gray-white-bg a.read-more:hover { color: #000 !important; fill: #000 !important; transition: all 0.3s ease; }
.service-box-wrapper .gray-white-bg a.read-more:hover svg polygon { fill: #000 !important; transition: all 0.3s ease; }














