/*
 Theme Name: iransite
 Theme URI: https://iransite.com/
 Author: IRANSITE
 Author URI: mailto:info@iransite.com
 Description: Powered by IRANSITE company
 Version: 1.0
 License: Free
 Text Domain: iransite
*/
@font-face {
	font-family: 'Visby';
	src: url('fonts/VisbyCF-ExtraBold.woff2') format('woff2'), url('fonts/VisbyCF-ExtraBold.woff') format('woff');
	font-weight: bolder;
	font-style: normal;
	font-stretch: normal;
	font-display: swap;
}
@font-face {
	font-family: 'Peyda';
	src: url('fonts/Peyda-ExtraBold.woff2') format('woff2'), url('fonts/Peyda-ExtraBold.woff') format('woff');
	font-weight: bolder;
	font-style: normal;
	font-stretch: normal;
	font-display: swap;
}
@font-face {
	font-family: 'Peyda';
	src: url('fonts/Peyda-Medium.woff2') format('woff2'), url('fonts/Peyda-Medium.woff') format('woff');
	font-weight: 400;
	font-style: normal;
	font-stretch: normal;
	font-display: swap;
}
:root {
	--bs-primary: #f26522;
	--bs-primary-rgb: 242, 101, 34;
	--bs-secondary: rgb(32, 76, 160);
	--bs-secondary-rgb: 32, 76, 160;
	--bs-body-color: #1e1e1e;
	--bs-body-color-rgb: 30, 30, 30;
	--bs-light: #f9f9f9;
	--bs-light-rgb: 249, 249, 249;
	--bs-dark: #1E1E1E;
	--bs-dark-rgb: 30, 30, 30;
	--bs-link-color: #10B798;
	--bs-link-color-rgb: 16, 183, 152;
	--bs-link-hover-color: #2b5986;
    --bs-link-hover-color-rgb: 43, 89, 134;
	--bs-body-font-family: Peyda, Arial, tahoma;
	--bs-box-shadow: 0 3px 8px rgba(0,0,0,0.1);
	--bs-border-radius: 8px;
	--bs-success: #06c270;
	--bs-success-rgb: 6, 194, 112;
	--bs-danger: rgb(255, 59, 59);
	--bs-danger-rgb: 255, 59, 59;
	--bs-body-font-size: 14px;
	font-size: 14px;

	--bs-primary-darker: #BD430B;
	--bs-primary-lighter: #F68E5E;
	--bs-primary-subtle: #FBD5C3;

	--bs-secondary-darker: #112A58;
	--bs-secondary-lighter: #5786DE;
	--bs-secondary-subtle: #CFDCF6;

	--bs-body-color-1: #313131;
	--bs-body-color-2: #444444;
	--bs-body-color-3: #606060;
	--bs-body-color-4: #6F6F6F;
}

.bg-primary-darker {
	background: var(--bs-primary-darker);
}
.bg-primary-lighter {
	background: var(--bs-primary-lighter);
}
.bg-primary-subtle {
	background: var(--bs-primary-subtle);
}
.bg-secondary-darker {
	background: var(--bs-secondary-darker);
}
.bg-secondary-lighter {
	background: var(--bs-secondary-lighter);
}
.bg-secondary-subtle {
	background: var(--bs-secondary-subtle);
}

.border-primary-darker {
	border-color: var(--bs-primary-darker)
}
.border-primary-lighter {
	border-color: var(--bs-primary-lighter)
}
.border-primary-subtle {
	border-color: var(--bs-primary-subtle)
}
.border-secondary-darker {
	border-color: var(--bs-secondary-darker)
}
.border-secondary-lighter {
	border-color: var(--bs-secondary-lighter)
}
.border-secondary-subtle {
	border-color: var(--bs-secondary-subtle)
}

.text-body-2 {
	color: var(--bs-body-color-2) !important;
}
.text-body-3 {
	color: var(--bs-body-color-3) !important;
}
.text-body-4 {
	color: var(--bs-body-color-4) !important;
}

.rounded-12 {
	border-radius: 12px;
}
.rounded-16 {
	border-radius: 16px;
}
.rounded-24 {
	border-radius: 24px;
}
.rounded-38 {
	border-radius: 38px;
}

.ff-visby {
	font-family: Visby, Peyda, Arial;
}

body {
	line-height: 2;
}
img {
	max-width: 100%;
}
a {
	text-decoration: none;
}
.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
	line-height: 2;
}
.h1, h1 {
	font-size: 32px;
}
.h2, h2 {
	font-size: 28px;
	font-weight: bold;
}
.h3, h3 {
	font-size: 24px;
	font-weight: normal;
}
.fs-20 {
	font-size: 20px;
}
.fs-18 {
	font-size: 18px;
}
.fs-16 {
	font-size: 16px;
}
.fs-15 {
	font-size: 15px;
}
.fs-13 {
	font-size: 13px;
}
.fs-12 {
	font-size: 12px;
}
input[type=text], input[type=tel], input[type=number], input[type=email], input[type=password], select, textarea {
	border-radius: 0 !important;
	border: none !important;
	border-bottom: 1px solid #E0E0E0 !important;
	background: transparent;
	padding: 0 !important;
	line-height: 50px !important;
	height: 50px !important;
	font-family: Peyda !important;
}
textarea {
	display: block;
	height: auto !important;
	min-height: 150px !important;
	line-height: 2em !important;
}
[type=email], [type=number], [type=tel], [type=url] {
	direction: rtl;
}
video {
	max-width: 100%;
	height: auto;
}
iframe {
	display: block;
	max-width: 100%;
	width: 100%;
}
.text-justify {
	text-align: justify;
}
.btn-primary {
	--bs-btn-color: #fff;
	--bs-btn-bg: var(--bs-primary);
    --bs-btn-border-color: var(--bs-primary);
    --bs-btn-hover-bg: var(--bs-secondary);
    --bs-btn-hover-border-color: transparent;
    --bs-btn-active-bg: var(--bs-secondary);
    --bs-btn-active-border-color: transparent;
    --bs-btn-active-shadow: none;
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #999;
    --bs-btn-disabled-border-color: #666;
}
.btn-secondary {
	--bs-btn-color: #fff;
	--bs-btn-bg: var(--bs-secondary);
    --bs-btn-border-color: var(--bs-secondary);
    --bs-btn-hover-bg: var(--bs-primary);
    --bs-btn-hover-border-color: transparent;
    --bs-btn-active-bg: var(--bs-primary);
    --bs-btn-active-border-color: transparent;
    --bs-btn-active-shadow: none;
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #999;
    --bs-btn-disabled-border-color: #666;
}
.btn-success {
    --bs-btn-color: #fff;
    --bs-btn-bg: #06c270;
    --bs-btn-border-color: #06c270;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #157347;
    --bs-btn-hover-border-color: #146c43;
    --bs-btn-focus-shadow-rgb: 60, 153, 110;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #146c43;
    --bs-btn-active-border-color: #13653f;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #999;
    --bs-btn-disabled-border-color: #999;
}
.btn-primary.btn-arrow:after {
	content: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10 8L6 12M6 12L10 16M6 12L18 12' stroke='white' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A");
	height: 24px;
}
.btn, button {
	padding: 0 30px;
	height: 45px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: calc(var(--bs-border-radius) * 2);
}

.icon-16 {
	width: 16px;
	height: 16px;
}
.icon-24 {
	width: 24px;
	height: 24px;
}
.icon-50 {
	width: 50px;
	height: 50px;
}

.fs-12 {
	font-size: 12px;
}
.fs-15 {
	font-size: 15px;
}

a.text-body:hover {
	color: var(--bs-primary) !important;
}

.main ::-webkit-scrollbar {
    width: 5px;
	height: 5px
}
.main ::-webkit-scrollbar-track {
    background: #D9D9D9;
	border-radius: 5px;
}
.main ::-webkit-scrollbar-thumb {
    background: var(--bs-primary);
	border-radius: 5px;
}

.title-bg {
	position: relative;
}
.title-bg:before {
	content: '';
	width: 110%;
	height: 21px;
	background: var(--bs-secondary-subtle);
	position: absolute;
	right: 50%;
	top: 50%;
	transform: translate(50%, -50%);
	z-index: -1;
	padding: 0 0.5rem;
}
.about-us .num-holder {
	font-size: 96px;
	font-weight: 900;
	line-height: 1;
}

.main-slider {
	height: 960px;
	overflow: hidden;
}
.main-slider > img {
	mix-blend-mode: lighten;
}

.why-us-text-carousel {
	position: relative;
    padding: 15rem 0 10rem;
}
.why-us-title {
	font-weight: bold;
	font-size: 4.5rem;
	text-align: center;
}
.shape-3d-1 {
	position: absolute;
	right: 50%;
	top: 60%;
	transform: translate(50%, -50%);
	width: 494px;
	height: 499px;
	background: url(images/3d-shape-1.png) no-repeat center center / cover;
	z-index: 2;
}
.shape-3d-2 {
	position: absolute;
	right: 50%;
	top: 60%;
	transform: translate(50%, -50%);
	width: 494px;
	height: 499px;
	background: url(images/3d-shape-2.png) no-repeat center center / cover;
	z-index: 4;
}
.years-30 {
	position: absolute;
	right: 50%;
	top: 20%;
	transform: translateX(50%);
	background: rgba(0, 0, 0, 0.20);
	backdrop-filter: blur(5px);
	color: #fff;
	direction: ltr;
	z-index: 10;
}

.m-scroll {
	display: flex;
	position: relative;
	width: 100%;
	height: 6rem;
	margin: auto;
	overflow: hidden;
	z-index: 3;
  
	  .m-scroll__title {
	  display: flex;
	  position: absolute;
	  top: 0;
	  left: 0;
	  align-items: center;
	  justify-content: flex-start;
	  width: 100%;
	  height: 100%;
	  white-space: nowrap;
	  transition: all 1s ease;
	  & > div {
		display: flex;
		gap: 2rem;
		animation: scrollText 240s infinite linear;
	  }
	  .scroll-item {
		margin: 0;
		font-size: 1.2rem !important;
		transition: all 2s ease;
		font-weight: bold;
		display: flex;
		gap: 2rem;

		> span {
			display: flex;
			gap: 0.5rem;
			align-items: center;
			font-size: 32px;
			font-weight: bold;
		}
		.why-us-item:before {
			content: '';
			border-radius: 8px;
			width: 70px;
			height: 70px;
			display: block;
		}
		.why-us-item-1:before {
			background: url(images/why-us/why-us-1-min.jpg) no-repeat center center;
		}
		.why-us-item-2:before {
			background: url(images/why-us/why-us-2-min.jpg) no-repeat center center;
		}
		.why-us-item-3:before {
			background: url(images/why-us/why-us-3-min.jpg) no-repeat center center;
		}
		.why-us-item-4:before {
			background: url(images/why-us/why-us-4-min.jpg) no-repeat center center;
		}
		.why-us-item-5:before {
			background: url(images/why-us/why-us-5-min.jpg) no-repeat center center;
		}
		.why-us-item-6:before {
			background: url(images/why-us/why-us-6-min.jpg) no-repeat center center;
		}
		.why-us-item-7:before {
			background: url(images/why-us/why-us-7-min.jpg) no-repeat center center;
		}
		.why-us-item-8:before {
			background: url(images/why-us/why-us-8-min.jpg) no-repeat center center;
		}
		.why-us-item-9:before {
			background: url(images/why-us/why-us-9-min.jpg) no-repeat center center;
		}
	  }
	}
  }
  @keyframes scrollText {
	from   { transform: translateX(0%); }
	to { transform: translateX(50%); }
  }

.clients {
	padding: 3rem 0;
}
.clients-inner {
	width: calc(calc(18 * 80px) + 17px + calc(17 * 1rem));
}
.black-star {
	position: relative;
	top: 3px;
}
.client-img {
	mix-blend-mode: multiply;
	width: 80px;
	height: 80px;
}
.client-separator {
	width: 1px;
	height: 46px;
	background: #A4A4A4;
	display: flex;
}
.border-gradient {
	position: relative;
}
.border-gradient:before {
	content: '';
	width: 100%;
	height: 1px;
	position: absolute;
	bottom: 0;
	right: 0;
	background: #919191;
	background: linear-gradient(90deg, rgba(145, 145, 145, 0) 0%, rgba(145, 145, 145, 1) 50%, rgba(145, 145, 145, 0) 100%);
}

.holding {
	margin-top: -2rem;
	padding: 15rem 0;
}
.holding-info {
	position: relative;
}
.holding-info > div {
	opacity: 0;
	transition: all 0.3s ease-in-out;
	position: absolute;
	top: 3rem;
	right: 0;
	width: 100%;
}
.holding-info > div.active {
	opacity: 1;
}
.circle-container {
	position: relative;
	width: 275px;
	height: 275px;
	margin: 0 auto;
	border-radius: 50%;
	background: var(--bs-light);
}
.circle-item {
	--n: 8;
    --angle: calc(360deg / var(--n) * calc(var(--i) - 5));
    position: absolute;
    top: 50%;
    left: 50%;
    width: 80px;
    height: 80px;
    margin: -40px;
    border-radius: 50%;
    background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
    transform: rotate(var(--angle)) translate(215px) rotate(calc(-1 * var(--angle)));
	border-bottom: 2px solid transparent;
	transition: all 0.3s ease-in-out;
}
.circle-item.active {
	border-bottom: 2px solid var(--bs-primary)
}
.circle-center-imgs {
	position: relative;
	border-radius: 50%;
	overflow: hidden;
	width: 275px;
	height: 275px;
}
/* .circle-center-imgs img {
	position: absolute;
	left: 0;
	top: 0;
	opacity: 0;
	transition: all 0.3s ease-in-out;
} */
.circle-center-imgs img.active {
	opacity: 1;
}

.services {
	overflow: hidden;
	padding-top: 5rem;
	background: url(images/back-min.jpg) no-repeat center bottom / cover;
}
.services-about-us {
	position: absolute;
	top: 0;
	font-size: 100px;
	font-weight: lighter;
	opacity: 0.1;
	color: #606060;
	width: 100%;
}
.services .title-bg:before {
	background: var(--bs-secondary);
}
.services-circle-holder {
	transition: all 0.5s ease-in-out;
}
.services-circle {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  margin-top: 20rem;
  border: 2px solid #fff;
  border-radius: 50%;
  transition: all 0.5s ease-in-out;
  margin-bottom: -50%;
}
.service-number {
  --n: 4;
  --angle: calc(360deg / var(--n) * calc(var(--i)) - 90deg);
  position: absolute;
  top: 50%;
  left: 50%;
  width: 48px;
  height: 48px;
  margin: -24px; /* نصف سایز آیتم، برای مرکز کردن */
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: bold;
  border-radius: 50%;
  transition: all 0.5s ease-in-out;
  opacity: 0;
  transform:
    rotate(var(--angle))
    translate(720px)
    rotate(90deg);
}
.service-number.active {
  opacity: 1;
}
.service-number:before {
	content: '';
	width: 30px;
	height: 30px;
	background: #fff;
	position: absolute;
	bottom: -60px;
    border-radius: 50%;
}
.service-title {
	font-size: 40px;
}

.services-info > div {
	--n: 4;
    --angle: calc(360deg / var(--n) * calc(var(--j)) - 90deg);
    position: absolute;
    top: 50%;
    left: 50%;
    width: 66.66%;
    aspect-ratio: 1;
    margin: -33.33%;
    transform: rotate(var(--angle)) translate(400px) rotate(90deg);
	opacity: 0;
	transition: all 0.5s ease-in-out;
}
.services-info > div.active {
	opacity: 1;
}

.testimonials-holder {
	column-gap: 1rem;
	row-gap: 2rem;
}
.testimonial-title {
	font-size: 29px;
}

.img-video-bottom-part {
	margin-top: -150px;
}
.logo-holder {
	background: rgba(255, 255, 255, 0.30);
	border: 1px solid #F59322;
	stroke: #F59322;
	backdrop-filter: blur(10px);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 300px;
	height: 300px;
}
.img-video-bottom-part > div {
    margin: 0 -2.5rem;
}
.together {
	width: 315px;
	height: 248px;
	-webkit-mask-image: url("images/26-years-togheter.svg");
	-webkit-mask-size: cover;
	-webkit-mask-repeat: no-repeat;
	mask-image: url("images/26-years-togheter.svg");
	mask-size: cover;
	mask-repeat: no-repeat;
	overflow: hidden;
	mix-blend-mode: luminosity;
}
.together video {
	position: absolute;
    top: 50%;
    right: 50%;
    transform: translate(50%, -50%);
	mix-blend-mode: luminosity;
}

.social-item {
	width: 44px;
	height: 44px;
	background: rgba(255,255,255,0.1);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}
.contact-text {
	font-size: 18px;
}

.icon-holder {
	aspect-ratio: 1;
    height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.contact-us-absolute {
	font-size: 100px;
	position: absolute;
	left: 0;
	bottom: 0;
	left: -10px;
    bottom: -10px;
    line-height: 0.5;
}
.bottom-contact-inner {
	transition: all 0.3s ease-in-out;
    width: calc(100% + 120px + 1rem);
}
.bottom-contact-inner:hover {
	transform: translateX(calc(120px + 1rem));
}
.icon-phone {
	transition: all 0.3s ease-in-out;
}
.icon-phone:hover {
	background: var(--bs-secondary) !important
}
.icon-phone a {
	display: flex;
    width: 100%;
    height: 100%;
    align-items: center;
    justify-content: center;
}

.contact-item {
	background: var(--bs-primary);
	transition: all 0.3s ease-in-out;
}
.contact-item:hover {
	background: var(--bs-secondary);
}

@media only screen and (max-width: 575px) {
	.h1, h1 {
		font-size: 24px;
	}
	.h2, h2 {
		font-size: 20px;
	}
	.h3, h3 {
		font-size: 18px;
	}
	.fs-20 {
		font-size: 18px;
	}
	.fs-18 {
		font-size: 16px;
	}

	.main-slider {
		height: auto;
	}

	.clients {
		padding: 6rem 0 3rem;
	}
	.clients-inner {
        width: 100%;
        padding: 0 1rem;
    }
	.shape-3d-1, .shape-3d-2 {
		width: calc(494px / 1.5);
		height: calc(499px / 1.5);
	}
	.why-us-text-carousel {
		padding: 10rem 0 5rem;
	}

	.holding {
		padding: 3rem 0 10rem;
	}

	.circle-center-imgs {
		width: 220px;
		height: 220px;
	}
	.circle-center-imgs img {
		width: 220px;
		height: 220px;
	}
	.circle-container {
		width: 220px;
		height: 220px;
		margin-top: 6rem;
	}
	.circle-item {
		width: 60px;
		height: 60px;
		margin: -30px;
		transform: rotate(var(--angle)) translate(160px) rotate(calc(-1 * var(--angle)));
	}

	.services {
		padding-top: 2rem;
	}
	.services .container {
		padding: 0;
	}
	.services-about-us {
		font-size: 45px;
	}
	.services-circle {
		width: 670px;
		margin-top: 10rem;
		right: 50%;
		transform: translateX(50%);
		margin-bottom: -25%;
	}
	.services-info > div {
		width: 50%;
        margin: -25%;
	}
	.service-number {
		transform: rotate(var(--angle))
			translate(405px)
			rotate(90deg)
	}
	.services-info > div {
		transform: rotate(var(--angle)) translate(70px) rotate(90deg)
	}
	.service-title {
		font-size: 25px;
	}
	.services-info .fs-20 {
		font-size: 14px;
	}

	.testimonials-holder > div {
		width: 100%;
		justify-content: space-between !important;
	}
	.testimonial-title {
		font-size: 18px;
		font-weight: bold !important;
	}

	.logo-holder {
		width: 150px;
		height: 150px;
	}
	.logo-holder img {
		width: 120px;
		height: 120px;
	}
	.img-video-bottom-part {
		margin-top: -75px;
	}
	.img-video-bottom-part > div {
		margin: 0 -1rem;
	}
	.together {
		width: calc(315px / 2);
    	height: calc(248px / 2);
	}

	.contact-text {
		font-size: 14px;
	}
	.icon-holder {
		height: 70px;
	}
	.bottom-contact-inner {
		width: calc(100% + 70px + 1rem)
	}
	.bottom-contact-inner:hover {
		transform: translateX(calc(70px + 1rem));
	}
	.contact-us-absolute {
		font-size: 30px;
		left: 0px;
		bottom: -2px;
		line-height: 0.5;
	}
}