
.aic {
    align-items: center;
}
.jcc {
    justify-content: center;
}
.fd-row {
    flex-direction: row;
}
.fd-column {
    flex-direction: column;
}
.jcar {
    justify-content: space-around;
}
.flexwrap {
    flex-wrap: wrap;
}
.img-desk {
    background-image: url("../images/main/intro_desktop.jpg");
    background-position: right center;
    background-size: cover;
    min-height: 70vh;
}
.display-flex {
    display: flex !important;
}
.display-flex2 {
    display: flex !important;
}
.col-12 {
    width: 99.96000000000001% !important;
    max-width: 99.96000000000001% !important;
}
.col-6 {
    flex: 0 0 49.980000000000004% !important;
    width: 49.980000000000004% !important;
    max-width: 49.980000000000004% !important;
}
.col-3 {
    flex: 0 0 24.990000000000002% !important;
    width: 24.990000000000002% !important;
    max-width: 24.990000000000002% !important;
}
.edge-padding-lg-right, .edge-padding-lg-x {
    padding-right: 10% !important;
}
.paddingleft-xl {
    padding-left: 24px !important;
}
.paddingy-xxl {
    padding-top: 32px !important;
    padding-bottom: 32px !important;
}
.paddingy-lg {
    padding-top: 16px !important;
    padding-bottom: 16px !important;
}
.backgroundcolor-primary {
    background-color: #301934 !important;
}
.textcolor-background {
    color: #fff !important;
}
.textalign-right {
    text-align: right !important;
}
.marginbottom-lg {
    margin-bottom: 16px !important;
}
.hero-text {
    font-size: 36px;
    line-height: 52px;
    font-weight: 700;
}
.textsize-xl {
    font-size: 20.3px !important;
}
.edge-padding-lg-x {
    padding-right: 10% !important;
}
.marginx-md {
    margin-left: 8px !important;
    margin-right: 8px !important;
}
.acsp {
    align-content: space-evenly;
}
.backgroud-lightBlue {
    background: #f2f5f8;
}
.paddingbottom-xxxl {
    padding-bottom: 40px !important;
}
.marginbottom-xxxl {
    margin-bottom: 40px !important;
}
.paddingy-xxxl {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
}
.textalign-center {
    text-align: center !important;
}
.radius-xl {
    border-radius: 18px !important;
}
.margin-lg {
    margin: 16px !important;
}
.paddingy-md {
    padding-top: 8px !important;
    padding-bottom: 8px !important;
}
.color-background {
    color: #3f3f3f !important;
    background: #fff !important;
    border-color: #e5e5e5 !important;
}
.ventures_cardWidth__2-Vjb {
    width: 29%;
    max-width: 321px;
}
.marginy-sm {
    margin-top: 4px !important;
    margin-bottom: 4px !important;
}
.textsize-md {
    font-size: 16px !important;
}
.textcolor-gray {
    color: #a3a3a3 !important;
}
.margintop-md {
    margin-top: 8px !important;
}
.mr3a_threeElements__9Urk2 {
    display: flex;
    bottom: 0;
    justify-content: center;
    margin: auto;
    margin-top: auto;
}
.marginx-xl {
    margin-left: 24px !important;
    margin-right: 24px !important;
}
.margintop-lg {
    margin-top: 20%;
}
pre {
    font-size: 100%;
    font-family: inherit;
    vertical-align: baseline;
    white-space: pre-wrap!important;
    background: transparent;
    border: 0;
    padding: 0;
}
.positionrelative {
    position: relative;
}
.arrows {
    width: 60px;
    height: 72px;
    position: absolute;
    margin-right: 5%;

}

.arrows path {
    stroke: #301934;
    fill: transparent;
    stroke-width: 2px;
    animation: arrow 2s infinite;
    -webkit-animation: arrow 2s infinite;
}

@keyframes arrow
{
    0% {opacity:0}
    40% {opacity:1}
    80% {opacity:0}
    100% {opacity:0}
}

@-webkit-keyframes arrow /*Safari and Chrome*/
{
    0% {opacity:0}
    40% {opacity:1}
    80% {opacity:0}
    100% {opacity:0}
}

.arrows path.a1 {
    animation-delay:-1s;
    -webkit-animation-delay:-1s; /* Safari 和 Chrome */
}

.arrows path.a2 {
    animation-delay:-0.5s;
    -webkit-animation-delay:-0.5s; /* Safari 和 Chrome */
}

.arrows path.a3 {
    animation-delay:0s;
    -webkit-animation-delay:0s; /* Safari 和 Chrome */
}
.hover-primary {
    color: #676767;
    font-size: 100%;
}
.hover-primary:hover {
    color: #301934;
}
.paddingtop-xxxl {
    padding-top: 40px !important;
}
.textsize-xxl {
    font-size: 25.12px !important;
}
.marginy-xxl {
    margin-top: 32px !important;
    margin-bottom: 32px !important;
}

.col-sm-3 {
    float: right;
}
@media (min-width:768px){ body { padding-top: 100px; } }

/* بخش بک‌گراند */
.hero-calc{
    position: relative;
    padding: 150px 0 150px;
    background-image: url('../images/bg-price-div.jpg'); /* مسیر تصویر خودت */
    background-size: cover;
    background-position: center;
}
.hero-calc:before{
    content:'';
    position:absolute; top:0; right:0; bottom:0; left:0;
    background: linear-gradient(to left, rgba(0,0,0,.15), rgba(0,0,0,.15));
}
.hero-calc .container{ position: relative; z-index: 2; }

/* جعبه فرم */
.calc-wrap{
    background:#fff;
    border-radius:18px;
    padding:18px;
    box-shadow:0 6px 20px rgba(0,0,0,.08);
    max-width:1120px;
    margin:0 auto;
}
.form-title{ margin-bottom:6px; font-size:12px; color:#7a7f85; }
.required::after{ content:" *"; color:#ff4d4f; }

/* ورودی‌ها و دکمه‌ها */
.form-control{ height:42px; border-radius:12px; border:1px solid #e6e8eb; box-shadow:none; }
.pill-btn{
    border-radius:28px; padding:10px 22px; font-weight:600;
    border:2px solid #301934; background:transparent; color:#301934; transition:all .2s;
}
.pill-btn:hover{ background:#fff5e6; }
.pill-btn.primary{ background:#301934; color:#fff; }
.pill-btn.primary:hover{ background:#301934; }

/* فاصله‌ی مناسب در موبایل */
.row.equal [class*="col-"]{ margin-bottom:10px; }
/* پیش‌فرض روی موبایل: راست یا وسط—هرکدوم را می‌خوای انتخاب کن */
.btn-col { text-align: left; }         /* اگر می‌خوای وسط باشد: text-align:center; */

/* از sm به بالا (≥768px) دکمه‌ها سمت چپ باشند */
@media (min-width:768px){
    .btn-col { text-align: left;margin-top: 20px }
    .model-content-custom {
        width: 450px;
    }

}
@media (max-width:768px){
    .btn-col { text-align: right; margin-top: 20px}
    .col-sm-3 {
        float: none;
    }
}

/* کمی فاصله بین دکمه‌ها */
.btn-col .pill-btn { margin: 0 6px; }

#resultModal .modal-dialog,
.custom-modal { min-width: 450px; }

/* برای گوشی‌های خیلی کوچک اجازه‌ی کوچکتر شدن بده تا اسکرول افقی نگیرد */
@media (max-width: 479px){
    #resultModal .modal-dialog,
    .custom-modal { min-width: 0; width: auto; margin: 10px; }
}

/* استایل لطیف‌تر مدال (اختیاری) */
.modal-content{ border-radius:16px; overflow:hidden; }
.modal-header{ background:#301934; border-bottom:0; }
.modal-title{ color:#ffffff; font-weight:700; }
.modal-footer{ border-top:0; }
.list-price-info li {
    font-size: 17px;
}

/* والد برای موقعیت‌دهی مطلق لیست */
.auto-parent { position: relative; }

/* لیست نتایج با اسکرول عمودی */
.dropdown-list{
    position: absolute;
    top: 100%;           /* دقیقا زیر input */
    right: 0;
    left: 0;             /* = عرض کامل والد */
    z-index: 1000;
    display: none;

    max-height: 300px;   /* هر عددی خواستی؛ مثلا 100px/140px */
    overflow-y: auto;    /* اسکرول عمودی */
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch; /* اسکرول نرم روی موبایل */

    background: #fff;
    border: 1px solid #e6e8eb;
    border-top: 0;
    border-radius: 0 0 10px 10px;
    box-shadow: 0 8px 18px rgba(0,0,0,.08);
}

/* متن طولانی توی یه خط بمونه و تهش … بخوره */
.dropdown-list .list-group-item{
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
