/* ===== Base ===== */
.esrm {
    position: relative;
    line-height: 1.8;
}

.esrm__intro {
    margin-bottom: 8px;
}


/* ===== Button ===== */
.esrm .esrm__btn {
    cursor: pointer;
    border: 1px solid transparent;
    transition: all .2s ease;
    font-size: 14px;
    padding: 10px 16px;
    background-color: #6a5acd;
    color: #fff;
    border-radius: 6px;

    /* چینش متن و آیکون */
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-wrap: nowrap !important;
    white-space: nowrap !important;
    gap: 8px !important;
    line-height: 1.2 !important;

    /* برای فاین‌تیون ظریف عمودی آیکون */
    --esrm-icon-nudge-y: 0.02em;
}

/* متن داخل دکمه */
.esrm .esrm__btn-text {
    display: inline-flex;
    align-items: center;
    line-height: 1.2;
}

/* ظرف آیکون‌ها */
.esrm .esrm__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 0;
}

/* حالت باز/بسته آیکون‌ها */
.esrm .esrm__icon--less {
    display: none;
}

.esrm.is-expanded .esrm__icon--more {
    display: none;
}

.esrm.is-expanded .esrm__icon--less {
    display: inline-flex;
}

/* ===== Icon ===== */
.esrm .esrm__icon svg {
    width: 1em;
    height: 1em;
    display: block;
    flex: 0 0 auto;
    vertical-align: middle;
    transform: translateY(-0.10em);
}

.esrm .esrm__icon svg path,
.esrm .esrm__icon svg use,
.esrm .esrm__icon svg g {
    fill: currentColor !important;
    stroke: currentColor !important;
}

.esrm .esrm__icon i {
    color: currentColor !important;
    font-size: 1em;
    line-height: 1;
    vertical-align: middle;
}

/* ===== فاصله متن و دکمه ===== */
.esrm__intro> :last-child {
    margin-bottom: 0 !important;
}

.esrm .esrm__btn {
    margin-top: 4px !important;
}

/* ---- Animated collapse/expand ---- */
/* انیمیشن نرم با CSS فقط */
.esrm__more {
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    transition: max-height .35s ease, opacity .35s ease;
}

/* وقتی باز است */
.esrm.is-expanded .esrm__more {
    /* مقدار بزرگ انتخاب کن؛ با محتوای معمولی جواب می‌دهد */
    max-height: 1200px;
    /* در صورت نیاز بیشترش کن */
    opacity: 1;
}

@media (prefers-reduced-motion: reduce) {
    .esrm__more {
        transition: none !important;
    }
}