@charset "UTF-8";
/* Write your code here */
.c-price {
  font-weight: bold !important;
  font-size: 21px !important;
}

a {
  text-decoration: none;
  font-weight: bold;
  color: #4A5A8D;
}

.c-f-color {
  color: #4A5A8D;
}

.c-b-color {
  background-color: #4A5A8D;
}

.all-filters-box {
  display: none;
}

.filter-labels {
  width: fit-content;
}

.fixed-height {
  min-height: 45px;
}

.f-bolder {
  font-weight: bolder;
}

.thumb-img {
  width: 20px;
}

/*.remodal-is-opened {*/
/*    z-index: 999999;*/
/*}*/
.copy-code-btn::before {
  content: "\ecd4";
  font-family: remixicon;
  margin-left: 5px;
}

/* fixed header */
.page-header--middle.sticky {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background-color: white;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.page-header-r-top {
  padding-top: 10px;
  padding-bottom: 10px;
}

.page-header-r-top.sticky {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background-color: white;
  padding-right: 0.75rem;
  padding-left: 0.75rem;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

/*start circles-----------------*/
.outer-circle {
  width: 84px;
  height: 84px;
  border: 3px #4A5A8D solid;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3px; /* فاصله 1 پیکسلی */
}

.inner-circle {
  background: white;
  width: 100%;
  height: 100%;
  border: 1px rgb(1, 106, 104) solid;
  border-radius: 50%;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.story-image {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
  display: block;
}

/*end of circles---------------------*/
/* Preloader */
/* Hide scrollbar when preloader is active */
/* --- Preloader Styles --- */
#professional-preloader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #ffffff;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  z-index: 99999;
  transition: opacity 0.7s ease, visibility 0.7s ease;
}

#professional-preloader.hidden {
  opacity: 0;
  visibility: hidden;
}

.preloader-icons {
  position: relative;
  width: 80px;
  height: 80px;
  margin-bottom: 20px;
}

.preloader-icons i {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  font-size: 70px;
  /* رنگ جدید برای آیکن‌ها */
  opacity: 0;
  animation: icon-fade-sequence 4s infinite ease-in-out;
}

.preloader-icons i:nth-child(2) {
  animation-delay: 1s;
}

.preloader-icons i:nth-child(3) {
  animation-delay: 2s;
}

.preloader-icons i:nth-child(4) {
  animation-delay: 3s;
}

.preloader-text {
  font-weight: bold;
  /* رنگ جدید برای متن */
  font-size: 16px;
  direction: rtl;
}

@keyframes icon-fade-sequence {
  0% {
    opacity: 0;
    transform: scale(0.9);
  }
  10% {
    opacity: 1;
    transform: scale(1);
  }
  25% {
    opacity: 1;
    transform: scale(1);
  }
  35% {
    opacity: 0;
    transform: scale(0.9);
  }
  100% {
    opacity: 0;
  }
}
/*end of preloader*/
/*credi ipgs*/
.card-input-element:checked + .card-input {
  box-shadow: 0 0 1px 1px #4A5A8D;
}

@media (max-width: 768px) {
  .z-index-max {
    z-index: 99999;
  }
}
.remodal-wrapper.remodal-is-opened {
  background-color: rgba(0, 0, 0, 0.29) !important;
}

a.nav-link.custom-link-active {
  border-bottom: 5px #4A5A8D solid;
}

.custom-mobile-slide {
  height: 30vh !important;
}

.text-primary {
  color: #24b02a !important;
}

a.btn-primary {
  color: #fff !important;
}

.badge {
  background-color: #4A5A8D !important;
}

.main-swiper-slider .main-swiper-slide a {
  background-size: cover !important;
}

.swiper main-swiper-slider {
  max-width: 1920px !important;
}

.c-param-title {
  background-color: rgba(108, 117, 125, 0.0509803922);
  padding-right: 20px;
  border-radius: 8px;
}

@media (max-width: 992px) {
  .c-search-box-responsive {
    width: 100% !important;
  }
}
.fade-in-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.fade-in-up.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* این کلاس را به تگ <a> بدهید */
.category-thumbnail-link {
  display: flex !important; /* با !important اولویت را به این استایل می‌دهیم */
  flex-direction: column;
  justify-content: center; /* محتوا را در مرکز عمودی قرار می‌دهد */
  align-items: center;
  text-decoration: none;
  color: #fff; /* یک رنگ مشخص برای متن که مخفی نشود */
  min-height: 130px; /* یک ارتفاع حداقلی برای جلوگیری از به هم ریختگی */
  text-align: center;
  margin: 0 5px;
  box-sizing: border-box;
  background-color: #f8f8f8;
  border-radius: 8px;
}

/* این کلاس را به تگ <img> بدهید */
.category-thumbnail-image {
  width: 80px; /* کمی اندازه را کوچکتر کردم تا بهتر جا شود */
  height: 80px;
  margin-bottom: 8px;
  object-fit: contain; /* برای اینکه تصویر در کادر فیت شود */
}

/* Common styles for floating icons */
.floating-icon {
  position: fixed;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
  transition: transform 0.3s ease;
}

.floating-icon i {
  color: #fff;
  font-size: 32px;
}

.floating-icon:hover {
  transform: scale(1.1);
  animation-play-state: paused;
}

/* Instagram Icon Specific Styles */
.floating-instagram-icon {
  /* گرادینت بین رنگ سازمانی و رنگ تیره پالت برای عمق دادن */
  background: linear-gradient(45deg, #4A5A8D 0%, #1f427c 100%);
  animation: instagram-pulse 2s infinite;
}

/* WhatsApp Icon Specific Styles */
.floating-whatsapp-icon {
  background-color: #4A5A8D; /* رنگ سازمانی خالص */
  animation: whatsapp-pulse 2s infinite;
  animation-delay: 0.5s;
}

/* Instagram Animation Keyframes */
@keyframes instagram-pulse {
  0% {
    transform: scale(0.95);
    /* سایه بر اساس رنگ تیره #1f427c (R:31, G:66, B:124) */
    box-shadow: 0 0 0 0 rgba(31, 66, 124, 0.7);
  }
  70% {
    transform: scale(1);
    box-shadow: 0 0 0 10px rgba(31, 66, 124, 0);
  }
  100% {
    transform: scale(0.95);
    box-shadow: 0 0 0 0 rgba(31, 66, 124, 0);
  }
}
/* WhatsApp Animation Keyframes */
@keyframes whatsapp-pulse {
  0% {
    transform: scale(0.95);
    /* سایه بر اساس رنگ سازمانی #4A5A8D (R:74, G:90, B:141) */
    box-shadow: 0 0 0 0 rgba(74, 90, 141, 0.7);
  }
  70% {
    transform: scale(1);
    box-shadow: 0 0 0 10px rgba(74, 90, 141, 0);
  }
  100% {
    transform: scale(0.95);
    box-shadow: 0 0 0 0 rgba(74, 90, 141, 0);
  }
}
/* Desktop styles (screens wider than 767px) */
@media (min-width: 768px) {
  .floating-icon {
    left: 30px;
    right: auto;
  }
  .floating-instagram-icon {
    bottom: 110px;
  }
  .floating-whatsapp-icon {
    bottom: 180px;
  }
}
/* Mobile styles (screens 767px and narrower) */
@media (max-width: 767px) {
  .floating-icon {
    left: 12px;
    right: auto;
  }
  .floating-instagram-icon {
    bottom: 140px;
  }
  .floating-whatsapp-icon {
    bottom: 210px;
  }
}
div.mega-menu {
  position: absolute;
  left: 0;
  right: 0;
  width: 100%;
  background: #fff;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  z-index: 100;
  display: none;
  padding: 20px 30px;
  border-top: 1px solid var(--gray-light);
}

li.mega-menu-category:hover div.mega-menu {
  display: block;
  animation: fadeIn 0.3s;
}

.mega-menu-scroll {
  max-height: 550px;
  overflow-y: auto;
  overflow-x: hidden;
}

.masonry-container {
  column-count: 5;
  column-gap: 30px;
  width: 100%;
  direction: rtl;
}

.masonry-item {
  display: inline-block;
  width: 100%;
  break-inside: avoid;
  margin-bottom: 30px;
  vertical-align: top;
}

a.parent-title-link {
  font-weight: bold;
  color: var(--text-dark);
  font-size: 15px;
  display: block;
  margin-bottom: 15px;
  padding-bottom: 8px;
  width: 100%;
  text-decoration: none;
}

.visual-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, 80px);
  gap: 15px 10px;
  justify-content: start;
}

.visual-item a {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  width: 100%;
}

.visual-item .img-box {
  width: 70px;
  height: 70px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--color-border-light);
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: all 0.3s ease;
  margin-bottom: 8px;
}

.visual-item .img-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  padding: 2px;
}

.visual-item:hover .img-box {
  border-color: var(--main-color);
  /* استفاده از متغیر RGB برای سایه */
  box-shadow: 0 4px 10px rgba(var(--main-color-rgb), 0.15);
}

.visual-item .shine-effect {
  position: absolute;
  top: 0;
  left: -100%;
  width: 50%;
  height: 100%;
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.7) 100%);
  transform: skewX(-25deg);
  z-index: 2;
  pointer-events: none;
  transition: none;
}

.visual-item:hover .shine-effect {
  animation: shine 0.7s;
}

@keyframes shine {
  100% {
    left: 200%;
  }
}
.visual-item .item-name {
  font-size: 12px;
  line-height: 1.4;
  color: var(--text-medium);
  text-align: center;
  width: 100%;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 34px;
  transition: color 0.3s;
}

.visual-item:hover .item-name {
  color: var(--main-color);
}

@media (max-width: 1400px) {
  .masonry-container {
    column-count: 4;
  }
}
@media (max-width: 1200px) {
  .masonry-container {
    column-count: 3;
  }
}
/* Scrollbar styles using variables */
.mega-menu-scroll::-webkit-scrollbar {
  width: 5px;
  background-color: transparent;
}

.mega-menu-scroll::-webkit-scrollbar-track {
  background-color: var(--gray-light);
  border-radius: 10px;
  margin: 5px 0;
}

.mega-menu-scroll::-webkit-scrollbar-thumb {
  background-color: var(--scrollbar-thumb);
  border-radius: 10px;
  transition: background-color 0.3s;
}

.mega-menu-scroll::-webkit-scrollbar-thumb:hover {
  background-color: var(--main-color);
}

.mega-menu-scroll {
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--gray-light);
}

/* ============================================= */
/* == WAVE COMPONENT STYLES (wc-) == */
/* ============================================= */
/* متغیرهای رنگی محلی (در صورت عدم وجود در روت اصلی استفاده می‌شوند) */
.wc-container {
  --wc-wave-color-dark: #21417C;
  --wc-wave-color-light: #4A5A8D;
  position: relative;
  overflow: hidden;
  /* پدینگ مشابه کلاس contact-section-no-bg قبلی برای حفظ ظاهر */
  padding: 0 0 120px 0;
  background-color: transparent;
}

.wc-animated-bg {
  position: relative;
  overflow: hidden;
}

/* ================================================ */
/* == SVG & PARALLAX ANIMATIONS == */
/* ================================================ */
.wc-svg-bottom {
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 100%;
  height: 100px;
  pointer-events: none;
  z-index: 1;
}

.wc-parallax use {
  animation: wc-move-wave 25s cubic-bezier(0.55, 0.5, 0.45, 0.5) infinite;
}

.wc-parallax use:nth-child(1) {
  animation-delay: -2s;
  animation-duration: 7s;
  fill: rgba(74, 90, 141, 0.7); /* یا استفاده از var(--wc-wave-color-light) با opacity */
}

.wc-parallax use:nth-child(2) {
  animation-delay: -3s;
  animation-duration: 10s;
  fill: rgba(74, 90, 141, 0.5);
}

.wc-parallax use:nth-child(3) {
  animation-delay: -4s;
  animation-duration: 13s;
  fill: rgba(74, 90, 141, 0.3);
}

.wc-parallax use:nth-child(4) {
  animation-delay: -5s;
  animation-duration: 20s;
  fill: var(--wc-wave-color-light);
}

@keyframes wc-move-wave {
  0% {
    transform: translate3d(-90px, 0, 0);
  }
  100% {
    transform: translate3d(85px, 0, 0);
  }
}
/* ================================================ */
/* == BUBBLES ANIMATIONS == */
/* ================================================ */
.wc-bubbles {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 0;
  pointer-events: none;
  margin: 0;
  padding: 0;
}

.wc-bubbles li {
  position: absolute;
  display: block;
  list-style: none;
  width: 20px;
  height: 20px;
  animation: wc-animateBubbles 25s linear infinite;
  bottom: -150px;
  border-radius: 50%;
  /* رنگ حباب‌ها */
  background: rgba(33, 65, 124, 0.15);
}

/* اگر نیاز است در سکشن‌های دیگر رنگ حباب فرق کند، اینجا مدیریت می‌شود */
/* .some-other-wrapper .wc-bubbles li { background: rgba(255, 255, 255, 0.2); } */
@keyframes wc-animateBubbles {
  0% {
    transform: translateY(0) rotate(0deg);
    opacity: 1;
    border-radius: 50%;
  }
  100% {
    transform: translateY(-1000px) rotate(720deg);
    opacity: 0;
    border-radius: 50%;
  }
}
.wc-bubbles li:nth-child(1) {
  left: 25%;
  width: 80px;
  height: 80px;
  animation-delay: 0s;
}

.wc-bubbles li:nth-child(2) {
  left: 10%;
  width: 20px;
  height: 20px;
  animation-delay: 2s;
  animation-duration: 12s;
}

.wc-bubbles li:nth-child(3) {
  left: 70%;
  width: 20px;
  height: 20px;
  animation-delay: 4s;
}

.wc-bubbles li:nth-child(4) {
  left: 40%;
  width: 60px;
  height: 60px;
  animation-delay: 0s;
  animation-duration: 18s;
}

.wc-bubbles li:nth-child(5) {
  left: 65%;
  width: 20px;
  height: 20px;
  animation-delay: 0s;
}

.wc-bubbles li:nth-child(6) {
  left: 75%;
  width: 110px;
  height: 110px;
  animation-delay: 3s;
}

.wc-bubbles li:nth-child(7) {
  left: 35%;
  width: 150px;
  height: 150px;
  animation-delay: 7s;
}

.wc-bubbles li:nth-child(8) {
  left: 50%;
  width: 25px;
  height: 25px;
  animation-delay: 15s;
  animation-duration: 45s;
}

.wc-bubbles li:nth-child(9) {
  left: 20%;
  width: 15px;
  height: 15px;
  animation-delay: 2s;
  animation-duration: 35s;
}

.wc-bubbles li:nth-child(10) {
  left: 85%;
  width: 150px;
  height: 150px;
  animation-delay: 0s;
  animation-duration: 11s;
}

/*# sourceMappingURL=custom.css.map */
