/* =============================================
   فونت‌ها
   ============================================= */
@font-face {
    font-family: 'IRANSansX';
    font-style: normal;
    font-weight: 300;
    src: url('../fonts/IRANSansX-Light.woff2') format('woff2'),
        url('../fonts/IRANSansX-Light.woff') format('woff');
}

@font-face {
    font-family: 'IRANSansX';
    font-style: normal;
    font-weight: 400;
    src: url('../fonts/IRANSansX-Regular.woff2') format('woff2'),
        url('../fonts/IRANSansX-Regular.woff') format('woff');
}

@font-face {
    font-family: 'IRANSansX';
    font-style: normal;
    font-weight: 500;
    src: url('../fonts/IRANSansX-Medium.woff2') format('woff2'),
        url('../fonts/IRANSansX-Medium.woff') format('woff');
}

@font-face {
    font-family: 'IRANSansX';
    font-style: normal;
    font-weight: 600;
    src: url('../fonts/IRANSansX-DemiBold.woff2') format('woff2'),
        url('../fonts/IRANSansX-DemiBold.woff') format('woff');
}

@font-face {
    font-family: 'IRANSansX';
    font-style: normal;
    font-weight: 700;
    src: url('../fonts/IRANSansX-Bold.woff2') format('woff2'),
        url('../fonts/IRANSansX-Bold.woff') format('woff');
}

@font-face {
    font-family: 'PeydaWeb';
    font-style: normal;
    font-weight: 400;
    src: url('../fonts/PeydaWeb-Regular.woff2') format('woff2'),
        url('../fonts/PeydaWeb-Regular.woff') format('woff');
}

@font-face {
    font-family: 'PeydaWeb';
    font-style: normal;
    font-weight: 700;
    src: url('../fonts/PeydaWeb-Bold.woff2') format('woff2'),
        url('../fonts/PeydaWeb-Bold.woff') format('woff');
}

@font-face {
    font-family: 'PeydaWeb';
    font-style: normal;
    font-weight: 900;
    src: url('../fonts/PeydaWeb-Black.woff2') format('woff2'),
        url('../fonts/PeydaWeb-Black.woff') format('woff');
}

/* =============================================
   متغیرهای رنگ و تم
   ============================================= */
:root {
    --color-primary: #0EA9ED;
    --color-secondary: #EE6C4D;
    --color-accent: #f59e0b;

    --bg-body: #f5f7fa;
    --bg-card: #ffffff;
    --text-primary: #1e293b;
    --text-secondary: #64748b;
    --border-color: #e2e8f0;

    --header-bg: #ffffff;
    --header-shadow: 0 4px 12px rgba(0, 0, 0, 0.04);
}

body.dark {
    --bg-body: #0f172a;
    --bg-card: #1e293b;
    --text-primary: #f1f5f9;
    --text-secondary: #94a3b8;
    --border-color: #334155;
    --header-bg: #1e293b;
    --header-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

/* =============================================
   استایل‌های پایه
   ============================================= */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'IRANSansX', sans-serif;
    font-weight: 400;
    background-color: var(--bg-body);
    color: var(--text-primary);
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    direction: rtl;
    transition: background-color 0.3s, color 0.3s;
    overflow-x: hidden;
}

.app-container {
    width: 100%;
    max-width: 720px;
    min-height: 100vh;
    background-color: var(--bg-card);
    box-shadow: 0 0 30px rgba(0, 0, 0, 0.05);
    display: flex;
    flex-direction: column;
    position: relative;
    /*overflow-x: hidden;*/
}

/* تایپوگرافی */
h1,
h2,
h3,
h4,
h5,
h6,
.section-title,
.card-title,
.event-title,
.auth-title,
.tab-btn,
.btn {
    font-family: 'PeydaWeb', 'IRANSansX', sans-serif;
}

.font-light {
    font-weight: 300;
}

.font-regular {
    font-weight: 400;
}

.font-medium {
    font-weight: 500;
}

.font-demibold {
    font-weight: 600;
}

.font-bold {
    font-weight: 700;
}

.font-black {
    font-weight: 900;
}

/* =============================================
   هدر (دو سطری)
   ============================================= */
.app-header {
    background-color: var(--header-bg);
    box-shadow: var(--header-shadow);
    position: fixed;
    top: 0;
    z-index: 1000;
    padding: 12px 20px 8px;
    transition: background-color 0.3s;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 720px;
}

/* سطر اول: لوگو وسط */
.header-top {
    display: flex;
    justify-content: center;
    margin-bottom: 10px;
}

.header-logo img {
    height: 36px;
    width: auto;
    display: block;
}

/* سطر دوم: کاربر و دکمه‌ها */
.header-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.header-user {
    display: flex;
    align-items: center;
    gap: 10px;
}

.header-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid var(--color-primary);
}

.header-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.header-user-info {
    display: flex;
    flex-direction: column;
}

.header-user-name {
    font-family: 'PeydaWeb', sans-serif;
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--text-primary);
    line-height: 1.2;
}

.header-user-role {
    font-size: 0.7rem;
    color: var(--text-secondary);
}

/* دکمه‌های سمت چپ */
.header-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

.header-btn {
    background: none;
    border: 1px solid var(--border-color);
    padding: 8px;
    border-radius: 12px;
    cursor: pointer;
    transition: background-color 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
}

.header-btn:hover {
    background-color: var(--border-color);
}

.header-btn img {
    width: 20px;
    height: 20px;
    display: block;
}

/* پاسخگو برای دسکتاپ */
@media (min-width: 720px) {
    .app-header {
        padding: 14px 24px 10px;
    }

    .header-logo img {
        height: 48px;
    }
}

/* =============================================
   فوتر (Bottom Navigation)
   ============================================= */
.bottom-nav {
    background-color: var(--header-bg);
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.06);
    position: fixed;
    /* همیشه ثابت پایین صفحه */
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 720px;
    /* هم‌عرض کانتینر اصلی */
    z-index: 1000;
    padding: 8px 8px env(safe-area-inset-bottom, 10px) 8px;
    transition: background-color 0.3s, box-shadow 0.3s;
    border-radius: 20px 20px 0 0;
    /* ظاهر کارتی */
}

.nav-items {
    display: flex;
    justify-content: space-around;
    align-items: center;
}

.nav-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-decoration: none;
    color: var(--text-secondary);
    font-size: 0.7rem;
    padding: 6px 0;
    transition: color 0.2s;
    flex: 1;
    gap: 6px;
    position: relative;
}

/* متن فعال */
.nav-item.active {
    color: var(--color-primary);
    /* آبی */
    font-weight: 600;
}

/* آیکون غیرفعال */
.nav-icon {
    width: 24px;
    height: 24px;
    opacity: 0.55;
    transition: opacity 0.2s, filter 0.2s;
}

/* حالت فعال: باکس آبی دور آیکون + آیکون سفید */
.nav-item.active .nav-icon-wrap {
    background: var(--color-primary);
    border-radius: 16px;
    padding: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 2px;
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.35);
}

.nav-item.active .nav-icon {
    opacity: 1;
    filter: brightness(0) invert(1);
}

.nav-icon-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}

.nav-item:active {
    opacity: 0.7;
}

/* فضای خالی پایین صفحه (به‌اندازهٔ ارتفاع فوتر) تا محتوا زیرش نرود */
.app-main {
    flex: 1;
    overflow-y: auto;
    padding: 130px 0 100px 0;

}

/* آیکون غیرفعال */
.nav-icon {
    width: 24px;
    height: 24px;
    opacity: 0.7;
    /* برای تم لایت مناسب است */
    transition: opacity 0.2s, filter 0.2s;
}

/* تم دارک: آیکون غیرفعال را سفید می‌کنیم */
body.dark .nav-icon {
    filter: brightness(0) invert(1);
    opacity: 0.8;
}

/* حالت فعال: آیکون همیشه سفید (چون باکس آبی دارد) */
.nav-item.active .nav-icon {
    opacity: 1;
    filter: brightness(0) invert(1);
}

/* =============================================
   سایدبار (Offcanvas منو)
   ============================================= */
.sidebar-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.45);
    z-index: 2000;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s, visibility 0.3s;
}

.sidebar-overlay.active {
    opacity: 1;
    visibility: visible;
}

.sidebar {
    position: fixed;
    top: 0;
    right: -300px;
    width: 280px;
    height: 100%;
    background-color: var(--bg-card);
    box-shadow: -4px 0 20px rgba(0, 0, 0, 0.1);
    z-index: 2001;
    transition: right 0.3s ease;
    padding: 20px;
    overflow-y: auto;
}

.sidebar.active {
    right: 0;
}

.sidebar-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--border-color);
}

.sidebar-title {
    font-family: 'PeydaWeb', sans-serif;
    font-weight: 700;
    font-size: 1.1rem;
    color: var(--color-primary);
}

.sidebar-close {
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
}

.sidebar-close img {
    width: 20px;
    height: 20px;
}

.sidebar-menu {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.sidebar-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    border-radius: 14px;
    color: var(--text-primary);
    text-decoration: none;
    transition: background-color 0.2s;
    cursor: pointer;
    background: none;
    border: none;
    width: 100%;
    font-size: 0.9rem;
}

.sidebar-item:hover {
    background-color: var(--border-color);
}

.sidebar-item img {
    width: 22px;
    height: 22px;
    flex-shrink: 0;
}

/* آیتم تغییر تم */
.theme-toggle-item {
    justify-content: space-between;
    gap: 12px;
    cursor: default;
}

.theme-toggle-item .switch {
    position: relative;
    display: inline-block;
    width: 44px;
    height: 24px;
}

.theme-toggle-item .switch input {
    display: none;
}

.theme-toggle-item .slider {
    position: absolute;
    cursor: pointer;
    background-color: #ccc;
    border-radius: 24px;
    width: 100%;
    height: 100%;
    transition: 0.2s;
}

.theme-toggle-item .slider::before {
    content: "";
    position: absolute;
    height: 18px;
    width: 18px;
    left: 3px;
    bottom: 3px;
    background-color: #fff;
    border-radius: 50%;
    transition: 0.2s;
}

.theme-toggle-item input:checked+.slider {
    background-color: var(--color-primary);
}

.theme-toggle-item input:checked+.slider::before {
    transform: translateX(20px);
}

/* اصلاح فاصله آیتم تغییر تم */
.theme-toggle-item {
    display: flex;
    align-items: center;
    gap: 12px;
    /* دقیقاً برابر با gap سایر sidebar-item ها */
    padding: 12px 16px;
    /* برابر با بقیه */
    color: var(--text-primary);
    cursor: pointer;
    background: none;
    border: none;
    width: 100%;
    font-size: 0.9rem;
    border-radius: 14px;
    transition: background-color 0.2s;
}

.theme-toggle-item:hover {
    background-color: var(--border-color);
}

/* سوییچ را خودکار به سمت چپ ببرد (مانند فلش در بقیه آیتم‌ها) */
.theme-toggle-item .switch {
    margin-right: auto;
    /* سوییچ را به منتها علیه سمت چپ می‌برد */
}

/* آیتم خروج */
.logout-item {
    color: #ef4444;
}

/* جداکننده */
.sidebar-divider {
    height: 1px;
    background-color: var(--border-color);
    margin: 8px 0;
}

/* =============================================
   اسلایدر بنر (ارتفاع بیشتر + دکمه‌های درست)
   ============================================= */
.hero-slider-section {
    margin: 20px 16px 24px;
    border-radius: 28px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.06);
}

#heroSlider .carousel-inner {
    border-radius: 28px;
}

.banner-slide {
    height: 300px;
    /* افزایش ارتفاع */
    background-size: cover;
    background-position: center;
    position: relative;
    display: flex;
    align-items: flex-end;
}

.banner-overlay {
    background: linear-gradient(to top, rgba(0, 0, 0, 0.7), transparent);
    width: 100%;
    padding: 40px 24px 20px;
    color: #fff;
}

.banner-overlay h3 {
    font-family: 'PeydaWeb', sans-serif;
    font-size: 1.6rem;
    font-weight: 700;
    margin-bottom: 4px;
}

.banner-overlay p {
    font-size: 0.9rem;
    opacity: 0.9;
    margin: 0;
}

/* دکمه‌های قبلی/بعدی */
.carousel-control-prev,
.carousel-control-next {
    width: 48px;
    height: 48px;
    background: rgba(255, 255, 255, 0.85);
    border-radius: 50%;
    top: 50%;
    transform: translateY(-50%);
    margin: 0 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
    opacity: 0.9;
}

.carousel-control-prev:hover,
.carousel-control-next:hover {
    opacity: 1;
}

.carousel-icon {
    display: block;
}

/* نشانگرها */
.carousel-indicators button {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #fff;
    opacity: 0.6;
    border: none;
}

.carousel-indicators .active {
    opacity: 1;
    background-color: var(--color-primary);
}

/* =============================================
   کارت یادآوری رویداد (همون طراحی جدید)
   ============================================= */
.reminder-section {
    padding: 0 20px 24px;
}

.reminder-card {
    display: flex;
    align-items: center;
    gap: 16px;
    background-color: var(--bg-card);
    border-radius: 24px;
    padding: 18px 20px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.04);
    position: relative;
    overflow: hidden;
    transition: box-shadow 0.2s;
}

.reminder-card:hover {
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08);
}

.reminder-accent {
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    width: 6px;
    background: linear-gradient(to bottom, var(--color-primary), #2dd4bf);
    border-radius: 0 4px 4px 0;
}

.reminder-img {
    width: 68px;
    height: 68px;
    border-radius: 18px;
    object-fit: cover;
    flex-shrink: 0;
    border: 2px solid var(--border-color);
}

.reminder-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.reminder-badge {
    background-color: rgba(14, 165, 233, 0.1);
    color: var(--color-primary);
    padding: 2px 12px;
    border-radius: 30px;
    font-size: 0.7rem;
    font-weight: 600;
    width: fit-content;
}

.reminder-info h4 {
    font-family: 'PeydaWeb', sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0;
}

.reminder-meta {
    font-size: 0.75rem;
    color: var(--text-secondary);
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.reminder-link {
    color: var(--color-primary);
    opacity: 0.7;
    transition: opacity 0.2s;
    flex-shrink: 0;
}

.reminder-link:hover {
    opacity: 1;
}

/* =============================================
   کارت رویداد (پالت رنگی متعادل)
   ============================================= */
.event-card {
    background-color: var(--bg-card);
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.04);
    margin-bottom: 20px;
    cursor: pointer;
    transition: transform 0.2s, box-shadow 0.2s;
}

.event-card:active {
    transform: scale(0.98);
}

.event-card-img {
    position: relative;
    height: 180px;
    overflow: hidden;
}

.event-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.event-card-type {
    position: absolute;
    top: 12px;
    right: 12px;
    background: rgba(255, 255, 255, 0.9);
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--color-primary);
    backdrop-filter: blur(6px);
}

.event-card-discount-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    background: #ef4444;
    color: #fff;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 0.7rem;
    font-weight: 700;
}

.event-card-body {
    padding: 16px;
}

.event-card-title {
    font-family: 'PeydaWeb', sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 6px;
}

.event-card-desc {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin-bottom: 12px;
}

/* اطلاعات جانبی */
.event-card-meta {
    margin-bottom: 14px;
}

.meta-speaker {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 6px;
}

.meta-speaker img {
    width: 16px;
    height: 16px;
    opacity: 0.7;
}

.meta-speaker span {
    font-family: 'IRANSansX', sans-serif;
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--text-primary);
}

.meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.meta-item {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 0.7rem;
    color: var(--text-secondary);
}

.meta-item img {
    width: 14px;
    height: 14px;
    opacity: 0.7;
}

/* ظرفیت (قرمز جیگری) */
.event-card-capacity {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
}

.capacity-bar {
    flex: 1;
    height: 6px;
    background: var(--border-color);
    border-radius: 4px;
    overflow: hidden;
}

.capacity-fill {
    height: 100%;
    background: var(--color-secondary);
    /* جیگری */
    border-radius: 4px;
    transition: width 0.4s;
}

.event-card-capacity span {
    font-size: 0.7rem;
    color: var(--text-secondary);
}

/* قیمت‌ها */
.event-card-prices {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
    margin-bottom: 14px;
}

.old-price {
    font-size: 0.75rem;
    color: #94a3b8;
    text-decoration: line-through;
}

.old-price.empty {
    visibility: hidden;
    height: 1.2em;
}

.current-price {
    font-family: 'PeydaWeb', sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: #98C1D9;
    /* سبز تیره برای ارزش */
}

/* دکمه گرادینت (آبی آسمانی -> آبی نفتی) */
.event-card-btn {
    width: 100%;
    padding: 10px;
    border: none;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--color-primary), #3D5A80);
    /* آبی پررنگ */
    color: #fff;
    font-family: 'PeydaWeb', sans-serif;
    font-weight: 700;
    font-size: 0.85rem;
    cursor: pointer;
    transition: opacity 0.2s, box-shadow 0.2s;
    /*box-shadow: 0 4px 12px rgba(14, 165, 233, 0.3);*/
}

.event-card-btn:hover {
    opacity: 0.95;
    box-shadow: 0 6px 16px rgba(30, 64, 175, 0.4);
}

/* =============================================
   صفحه جستجو (فقط ساختار)
   ============================================= */
.search-section {
    padding: 20px 20px 0;
}

.search-input-wrap {
    position: relative;
    margin-bottom: 16px;
}

.search-page-input {
    width: 100%;
    padding: 12px 46px 12px 14px;
    border: 1px solid var(--border-color);
    border-radius: 18px;
    font-size: 0.9rem;
    background: var(--bg-card);
    color: var(--text-primary);
    outline: none;
}

.search-page-icon {
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-secondary);
}

.search-filters-row {
    display: flex;
    gap: 8px;
    margin-bottom: 20px;
}

.search-filter-select {
    flex: 1;
    padding: 8px 6px;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    font-size: 0.8rem;
    background: var(--bg-card);
    color: var(--text-primary);
    outline: none;
}

/* برای لیست نتایج (فعلاً خالی) */
.events-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* فوکوس آبی روی ورودی جستجو */
.search-page-input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.15);
    outline: none;
}

/* کادر خلاصه فیلترها */
.filter-summary {
    display: none;
    /* پیش‌فرض مخفی */
    align-items: center;
    justify-content: space-between;
    background-color: var(--color-primary);
    color: #fff;
    padding: 10px 16px;
    border-radius: 14px;
    margin-bottom: 16px;
    font-size: 0.85rem;
    gap: 12px;
}

.filter-summary.active {
    display: flex;
}

.filter-summary-text {
    flex: 1;
}

.btn-search-go {
    background: #fff;
    color: var(--color-primary);
    border: none;
    padding: 6px 16px;
    border-radius: 10px;
    font-weight: 600;
    font-size: 0.8rem;
    cursor: pointer;
    transition: background 0.2s;
}

.btn-search-go:hover {
    background: #f0f9ff;
}

/* =============================================
   سبد خرید
   ============================================= */
.cart-header-section {
    padding: 20px 20px 0;
}

.cart-items-list {
    padding: 0 20px;
}

/* کارت آیتم سبد خرید */
.cart-item {
    display: flex;
    align-items: center;
    gap: 12px;
    background-color: var(--bg-card);
    border-radius: 16px;
    padding: 12px;
    margin-bottom: 12px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.03);
}

.cart-item-img {
    width: 64px;
    height: 64px;
    border-radius: 12px;
    object-fit: cover;
    flex-shrink: 0;
}

.cart-item-info {
    flex: 1;
    min-width: 0;
}

.cart-item-info h4 {
    font-family: 'PeydaWeb', sans-serif;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.cart-item-date {
    font-size: 0.7rem;
    color: var(--text-secondary);
}

.cart-item-price {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
    flex-shrink: 0;
}

.cart-old-price {
    font-size: 0.7rem;
    color: #94a3b8;
    text-decoration: line-through;
}

.cart-old-price.empty {
    visibility: hidden;
    height: 1.1em;
}

.cart-current-price {
    font-family: 'PeydaWeb', sans-serif;
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--text-primary);
}

.cart-remove-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    flex-shrink: 0;
}

.cart-remove-btn img {
    width: 18px;
    height: 18px;
    opacity: 0.6;
    transition: opacity 0.2s;
}

.cart-remove-btn:hover img {
    opacity: 1;
}

/* حالت خالی سبد */
.cart-empty-state {
    padding: 40px 20px;
    text-align: center;
    color: var(--text-secondary);
    font-size: 0.9rem;
}

/* دکمه دعوت از دوستان */
.invite-toggle-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 20px 12px;
    padding: 12px 16px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    cursor: pointer;
    font-size: 0.85rem;
    color: var(--text-primary);
    font-weight: 500;
    width: calc(100% - 40px);
}

.invite-toggle-btn img {
    width: 20px;
    height: 20px;
}

/* پنل دعوت */
.invite-panel {
    display: none;
    margin: 0 20px 16px;
    padding: 16px;
    background: var(--bg-card);
    border-radius: 16px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.03);
}

.invite-field {
    margin-bottom: 10px;
}

.invite-input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    font-size: 0.85rem;
    background: var(--bg-body);
    color: var(--text-primary);
    outline: none;
}

.invite-add-btn {
    width: 100%;
    padding: 10px;
    border: none;
    border-radius: 12px;
    background: var(--color-primary);
    color: #fff;
    font-weight: 600;
    cursor: pointer;
    margin-bottom: 10px;
}

.invite-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.invite-tag {
    background: var(--bg-body);
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 0.8rem;
    display: flex;
    align-items: center;
    gap: 6px;
}

.remove-invite {
    background: none;
    border: none;
    color: #ef4444;
    cursor: pointer;
    font-size: 1rem;
}

/* کد تخفیف */
.coupon-section {
    display: flex;
    gap: 8px;
    padding: 0 20px 16px;
}

.coupon-input {
    flex: 1;
    padding: 10px 14px;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    font-size: 0.85rem;
    background: var(--bg-card);
    color: var(--text-primary);
    outline: none;
}

.coupon-apply-btn {
    padding: 10px 20px;
    border: none;
    border-radius: 12px;
    background: var(--color-primary);
    color: #fff;
    font-weight: 600;
    cursor: pointer;
}

/* خلاصه خرید */
.cart-summary {
    margin: 0 20px;
    padding: 20px;
    background: var(--bg-card);
    border-radius: 20px;
    box-shadow: 0 -4px 16px rgba(0, 0, 0, 0.03);
}

.summary-row {
    display: flex;
    justify-content: space-between;
    font-size: 0.85rem;
    margin-bottom: 8px;
    color: var(--text-secondary);
}

.summary-row.total {
    font-weight: 700;
    font-size: 1rem;
    color: var(--text-primary);
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px solid var(--border-color);
}

.checkout-btn {
    width: 100%;
    padding: 14px;
    border: none;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--color-primary), #054461);
    color: #fff;
    font-family: 'PeydaWeb', sans-serif;
    font-weight: 700;
    font-size: 1rem;
    cursor: pointer;
    margin-top: 16px;
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.3);
}

.secure-note {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 0.7rem;
    color: var(--text-secondary);
    margin-top: 8px;
}

.secure-note img {
    width: 14px;
    height: 14px;
}

/* فوکوس آبی برای فیلد کد تخفیف */
.coupon-input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.15);
    outline: none;
}

/* فوکوس آبی برای فیلدهای دعوت (نام و شماره) */
.invite-input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.15);
    outline: none;
}

/* راست‌چین شدن شماره تماس و نمایش صحیح اعداد */
.invite-input[type="tel"] {
    direction: rtl;
    text-align: right;
}

/* فوکوس آبی برای دکمه‌های دعوت، اعمال کد تخفیف و افزودن همراه */
.invite-toggle-btn:focus,
.invite-add-btn:focus,
.coupon-apply-btn:focus {
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.4);
    outline: none;
}

/* =============================================
   صفحات احراز هویت
   ============================================= */
.centered-page {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-body);
    min-height: 100vh;
}

.centered-page .app-container {
    background: transparent;
    box-shadow: none;
    max-width: 720px;
    width: 100%;
    padding: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.auth-card {
    background: var(--bg-card);
    border-radius: 28px;
    padding: 32px 24px;
    text-align: center;
    width: 100%;
    max-width: 400px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
}

.auth-logo img {
    width: 80px;
    margin-bottom: 20px;
}

.auth-card h2 {
    font-size: 1.5rem;
    margin-bottom: 8px;
    color: var(--text-primary);
}

.auth-card p {
    font-size: 0.9rem;
    color: var(--text-secondary);
    margin-bottom: 24px;
}

.auth-buttons {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.btn-primary-wide,
.btn-outline-wide,
.btn-specialist-wide {
    display: block;
    width: 100%;
    padding: 14px;
    border-radius: 14px;
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none;
    text-align: center;
    transition: 0.2s;
}

.btn-primary-wide {
    background: linear-gradient(135deg, var(--color-primary), #054461);
    color: #fff;
    border: none;
}

.btn-outline-wide {
    background: transparent;
    border: 2px solid var(--color-primary);
    color: var(--color-primary);
}

.btn-specialist-wide {
    background: linear-gradient(135deg, var(--color-secondary), var(--color-accent));
    color: #fff;
    border: none;
}

.auth-switch {
    margin-top: 20px;
    font-size: 0.85rem;
}

.auth-switch a {
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 500;
}

/* فرم‌ها */
.auth-card input,
.auth-card select {
    width: 100%;
    padding: 12px 14px;
    margin-bottom: 12px;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    font-size: 0.9rem;
    background: var(--bg-card);
    color: var(--text-primary);
    outline: none;
    transition: 0.2s;
}

.auth-card input:focus,
.auth-card select:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.15);
}

.upload-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 14px;
    background: var(--bg-body);
    border-radius: 12px;
    margin-bottom: 12px;
    cursor: pointer;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.upload-label input[type="file"] {
    display: none;
}

.form-options {
    text-align: left;
    margin-bottom: 16px;
}

.forgot-link {
    font-size: 0.8rem;
    color: var(--color-primary);
    text-decoration: none;
}

/* مودال عمومی */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2000;
}



.modal-icon {
    font-size: 3rem;
    margin-bottom: 16px;
}



/* =============================================
   جستجوهای اخیر
   ============================================= */
.recent-search-section {
    margin: 0 20px 20px;
}

.recent-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.recent-title {
    font-family: 'PeydaWeb', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-primary);
}

.clear-recent-btn {
    background: none;
    border: none;
    color: var(--color-primary);
    font-size: 0.8rem;
    cursor: pointer;
}

.recent-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.recent-list li {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 0.8rem;
    color: var(--text-secondary);
    cursor: pointer;
    transition: 0.2s;
}

.recent-list li:hover {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary);
}

/* =============================================
   دسته‌بندی رویدادها
   ============================================= */
.category-section {
    margin: 0 20px 24px;
}

.category-title {
    font-family: 'PeydaWeb', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 12px;
}

.category-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}

.category-card {
    position: relative;
    aspect-ratio: 1 / 1;
    /* مربع کامل */
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
    cursor: pointer;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.category-card:hover {
    transform: translateY(-4px) scale(1.03);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
}

.category-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.category-card span {
    position: absolute;
    bottom: 0;
    right: 0;
    left: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.7), transparent);
    color: #fff;
    padding: 20px 8px 8px;
    font-size: 0.75rem;
    font-weight: 600;
    text-align: center;
}

/* =============================================
   رویدادهای من (متخصص)
   ============================================= */
.my-events-section {
    padding: 20px 20px 0;
}

.my-events-tabs {
    display: flex;
    gap: 12px;
    margin-bottom: 20px;
}

.my-events-tab {
    flex: 1;
    padding: 12px;
    border-radius: 14px;
    border: 1px solid var(--border-color);
    background: var(--bg-card);
    color: var(--text-secondary);
    font-weight: 600;
    font-size: 0.9rem;
    cursor: pointer;
    transition: 0.2s;
}

.my-events-tab.active {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary);
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.3);
}

/* کارت ویجتی my-event-card */
.my-event-card {
    display: flex;
    gap: 12px;
    background: var(--bg-card);
    border-radius: 18px;
    padding: 14px;
    margin-bottom: 12px;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.04);
    border: 1px solid var(--border-color);
    flex-wrap: wrap;
    /* ← این خط را اضافه کنید */
}

.my-event-img {
    width: 80px;
    height: 80px;
    border-radius: 14px;
    object-fit: cover;
    flex-shrink: 0;
}

.my-event-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.my-event-title {
    font-family: 'PeydaWeb', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    margin: 0;
    color: var(--text-primary);
}

.my-event-desc {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin: 0;
}

.my-event-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    font-size: 0.7rem;
    color: var(--text-secondary);
}

.my-event-meta span::after {
    content: '•';
    margin-right: 8px;
}

.my-event-meta span:last-child::after {
    content: '';
}

.my-event-reg-count {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--color-primary);
}

/* فوتر کارت پیش‌رو */
.upcoming-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--border-color);
}

.days-left {
    font-size: 0.8rem;
    color: var(--color-secondary);
    font-weight: 600;
}

.btn-note-session {
    background: var(--color-primary);
    border: none;
    padding: 6px 14px;
    border-radius: 10px;
    color: #fff;
    font-size: 0.8rem;
    cursor: pointer;
}

/* فوتر کارت گذشته 
.past-footer {
    display: flex;
    gap: 10px;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--border-color);
}*/

.btn-past-notes,
.btn-past-gallery {
    flex: 1;
    padding: 8px;
    border-radius: 10px;
    border: 1px solid var(--border-color);
    background: var(--bg-card);
    color: var(--text-primary);
    font-size: 0.8rem;
    cursor: pointer;
    transition: 0.2s;
}

.btn-past-notes:hover,
.btn-past-gallery:hover {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary);
}





.gallery-grid {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 20px;
}



.upcoming-action-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 6px;
}

.days-left {
    font-size: 0.8rem;
    color: var(--color-secondary);
    font-weight: 600;
}

.btn-note-session {
    background: var(--color-primary);
    border: none;
    padding: 6px 14px;
    border-radius: 10px;
    color: #fff;
    font-size: 0.8rem;
    cursor: pointer;
    transition: background 0.2s;
}

.btn-note-session:hover {
    background: #0284c7;
}

/* مودال یادداشت (بزرگ‌تر) */
.note-modal-card {
    max-width: 500px;
    width: 90%;
}



/* استایل پایه دکمه‌های مودال (اگر قبلاً ندارید) */
.modal-btn {
    flex: 1;
    padding: 12px;
    border-radius: 12px;
    border: none;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s, opacity 0.2s;
}

.cancel-btn {
    background: #f1f5f9;
    color: #334155;
}

.cancel-btn:hover {
    background: #e2e8f0;
}

.confirm-btn {
    background: #ef4444;
    color: #fff;
}

.confirm-btn:hover {
    background: #dc2626;
}

/* فوتر کارت‌های گذشته (با دکمه‌های استاندارد) 
.past-footer {
    display: flex;
    gap: 10px;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--border-color);
}*/

.btn-past-notes,
.btn-past-gallery {
    flex: 1;
    padding: 8px 12px;
    border-radius: 10px;
    border: 1px solid var(--border-color);
    background: var(--bg-card);
    color: var(--text-primary);
    font-size: 0.8rem;
    cursor: pointer;
    transition: 0.2s;
}

.btn-past-notes:hover,
.btn-past-gallery:hover {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary);
}

.modal-card {
    background: var(--bg-card);
    color: var(--text-primary);
    border-radius: 20px;
    padding: 32px 24px;
    text-align: center;
    max-width: 500px;
    width: 90%;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.2);
}

.modal-card h3 {
    color: var(--text-primary);
    margin-bottom: 12px;
}

.modal-card p {
    color: var(--text-secondary);
}

.modal-card textarea {
    background: var(--bg-body);
    color: var(--text-primary);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    width: 100%;
    height: 120px;
    padding: 10px;
    font-size: 0.9rem;
    resize: vertical;
    margin-bottom: 16px;
}

.gallery-modal-card {
    max-width: 600px;
    width: 95%;
}

.gallery-row {
    display: flex;
    gap: 10px;
    margin-bottom: 10px;
}

.gallery-row img {
    flex: 1;
    max-width: calc(50% - 5px);
    /* هر تصویر نهایتاً نصف عرض */
    aspect-ratio: 1/1;
    object-fit: cover;
    border-radius: 12px;
    cursor: pointer;
}

.events-section {
    padding: 24px 20px 0;
    /* بالا 24px، چپ و راست 20px، پایین 0 */
}

/* =============================================
   صفحه افزودن رویداد
   ============================================= */
.add-event-section {
    padding: 20px 20px 0;
}

.section-subtitle {
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin-bottom: 20px;
    display: block;
}

.add-event-form .form-group {
    margin-bottom: 16px;
}

.add-event-form label, .form-group label{
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 6px;
    text-align: right;
}

.add-event-form input,
.add-event-form select,
.add-event-form textarea {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    font-size: 0.9rem;
    background: var(--bg-card);
    color: var(--text-primary);
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.add-event-form input:focus,
.add-event-form select:focus,
.add-event-form textarea:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.1);
}

.form-row {
    display: flex;
    gap: 12px;
}

.half {
    flex: 1;
}

/* آپلود تصویر */
.image-upload-box {
    border: 2px dashed var(--border-color);
    border-radius: 16px;
    padding: 20px;
    text-align: center;
    cursor: pointer;
    transition: border-color 0.2s;
}

.image-upload-box:hover {
    border-color: var(--color-primary);
}

.upload-placeholder img {
    width: 36px;
    margin-bottom: 8px;
    opacity: 0.6;
}

.upload-placeholder span {
    display: block;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.upload-preview {
    max-height: 200px;
    width: auto;
    margin: 0 auto;
    border-radius: 12px;
}

/* چک‌باکس‌ها */
.checkbox-group {
    display: flex;
    gap: 20px;
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 4px;
}

.checkbox-group label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    font-weight: 400;
    color: var(--text-primary);
    white-space: nowrap;
}

/* دکمه ارسال */
.btn-submit-event {
    width: 100%;
    padding: 14px;
    border: none;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
    color: #fff;
    font-weight: 600;
    font-size: 1rem;
    cursor: pointer;
    margin-top: 10px;
    transition: opacity 0.2s;
}

.btn-submit-event:hover {
    opacity: 0.95;
}

/* آپلود فایل گواهی */
.cert-upload-box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 10px 14px;
    background: var(--bg-card);
}

.cert-upload-box span {
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.btn-upload-cert {
    background: var(--color-primary);
    border: none;
    color: #fff;
    padding: 6px 14px;
    border-radius: 8px;
    font-size: 0.8rem;
    cursor: pointer;
}

/* مودال موفقیت */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2000;
}

.modal-card {
    background: var(--bg-card);
    border-radius: 24px;
    padding: 32px 24px;
    text-align: center;
    max-width: 400px;
    width: 90%;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
}

.modal-card h3 {
    color: var(--text-primary);
    margin-bottom: 8px;
}

.modal-card p {
    color: var(--text-secondary);
    font-size: 0.9rem;
    margin-bottom: 24px;
}

.modal-btn.confirm-btn {
    background: var(--color-primary);
    color: #fff;
    padding: 12px 24px;
    border: none;
    border-radius: 12px;
    font-weight: 600;
    cursor: pointer;
}

/* استایل عمومی مودال */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2000;
}

.modal-card {
    background: var(--bg-card);
    border-radius: 24px;
    padding: 32px 24px;
    text-align: center;
    max-width: 400px;
    width: 90%;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
    color: var(--text-primary);
}

.modal-icon {
    margin-bottom: 12px;
}

.modal-actions {
    display: flex;
    gap: 10px;
    margin-top: 24px;
}

.modal-btn {
    flex: 1;
    padding: 12px;
    border-radius: 12px;
    border: none;
    font-weight: 600;
    cursor: pointer;
    transition: opacity 0.2s;
}

.cancel-btn {
    background: var(--border-color);
    color: var(--text-primary);
}

.cancel-btn:hover {
    opacity: 0.8;
}

.confirm-btn {
    background: #ef4444;
    color: #fff;
}

.confirm-btn:hover {
    background: #dc2626;
}

/* مطمئن شو مودال خروج بالاتر از سایدبار قرار گیرد */
#logoutModal {
    z-index: 9999 !important;
    /* بالاتر از سایدبار (که 2001 است) */
}

/* اگر overlay جداگانه داخل #logoutModal نداری، پس‌زمینه خودش این نقش را دارد */
#logoutModal .modal-card {
    position: relative;
    z-index: 10000;
}

/* =============================================
   داشبورد متخصص
   ============================================= */
.dashboard-welcome {
    padding: 20px 20px 0;
}

.dashboard-welcome h2 {
    font-size: 1.3rem;
    margin-bottom: 4px;
    color: var(--text-primary);
}

.dashboard-welcome p {
    color: var(--text-secondary);
    font-size: 0.85rem;
}

/* کارت‌های KPI */
.kpi-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    padding: 16px 20px;
}

.kpi-card {
    background: #ffffff;
    border-radius: 20px;
    padding: 20px 16px;
    text-align: center;
    color: #fff;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.05);
}

.kpi-card .kpi-icon {
    width: 32px;
    height: 32px;
    opacity: 0.9;
}

.kpi-label {
    font-size: 0.75rem;
    opacity: 0.9;
}

.kpi-value {
    font-family: 'PeydaWeb', sans-serif;
    font-size: 1.2rem;
    font-weight: 700;
}

.gradient-blue {
    background: linear-gradient(135deg, var(--color-primary), #2dd4bf);
}

.gradient-pink {
    background: linear-gradient(135deg, #ec4899, var(--color-accent));
}

.gradient-yellow {
    background: linear-gradient(135deg, var(--color-accent), #fcd34d);
}

.gradient-green {
    background: linear-gradient(135deg, #10b981, #34d399);
}

/* رویدادهای داشبورد */
.dashboard-events {
    padding: 20px 20px 0;
}

/* برچسب وضعیت */
.my-event-title-row {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.status-badge {
    font-size: 0.7rem;
    padding: 2px 8px;
    border-radius: 10px;
    font-weight: 600;
}

.status-badge.approved {
    background: #d1fae5;
    color: #065f46;
}

.status-badge.pending {
    background: #fef3c7;
    color: #92400e;
}

.status-badge.rejected {
    background: #fee2e2;
    color: #991b1b;
}

/* فعالیت‌های اخیر */
.recent-activity {
    padding: 20px 20px 0;
}

.activity-list {
    background: var(--bg-card);
    border-radius: 16px;
    padding: 12px 16px;
    margin-top: 12px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.02);
}

.activity-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid var(--border-color);
}

.activity-item:last-child {
    border-bottom: none;
}

.activity-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-top: 5px;
    flex-shrink: 0;
}

.activity-dot.blue {
    background: var(--color-primary);
}

.activity-dot.green {
    background: #10b981;
}

.activity-dot.orange {
    background: var(--color-accent);
}

.activity-content p {
    margin: 0;
    font-size: 0.85rem;
    color: var(--text-primary);
}

.activity-content span {
    font-size: 0.7rem;
    color: var(--text-secondary);
}

/* =============================================
   کارت مینی رویداد (مربعی)
   ============================================= */
.suggested-section {
    padding: 24px 20px 0;
}

.mini-events-scroll {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding-bottom: 8px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.mini-events-scroll::-webkit-scrollbar {
    display: none;
}

.mini-event-card {
    flex: 0 0 200px;
    /* عرض ثابت مربعی */
    background: var(--bg-card);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.04);
    border: 1px solid var(--border-color);
    transition: transform 0.2s, box-shadow 0.2s;
}

.mini-event-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
}

.mini-event-img {
    height: 130px;
    overflow: hidden;
}

.mini-event-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mini-event-body {
    padding: 10px 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.mini-event-title {
    font-family: 'PeydaWeb', sans-serif;
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0;
    line-height: 1.3;
}

.mini-event-speaker {
    font-size: 0.7rem;
    color: var(--color-primary);
}

.mini-event-meta {
    font-size: 0.7rem;
    color: var(--text-secondary);
}

/* =============================================
   صفحه جزئیات رویداد
   ============================================= */

/* تصویر اصلی */
.detail-hero {
    position: relative;
    height: 240px;
    overflow: hidden;
}

.detail-hero img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.detail-category-badge,
.detail-discount-badge {
    position: absolute;
    top: 16px;
    background: rgba(255, 255, 255, 0.9);
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.7rem;
    font-weight: 600;
    backdrop-filter: blur(6px);
}

.detail-category-badge {
    right: 16px;
    color: var(--color-primary);
}

.detail-discount-badge {
    left: 16px;
    background: var(--color-accent);
    color: #fff;
}

/* نوار عملیات */
.detail-actions-bar {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding: 12px 20px;
}

.detail-icon-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 8px 14px;
    cursor: pointer;
    color: var(--text-secondary);
    font-size: 0.8rem;
    transition: 0.2s;
}

.detail-icon-btn:hover {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary);
}

.detail-icon-btn.saved {
    background: var(--color-accent);
    color: #fff;
    border-color: var(--color-accent);
}

.detail-icon-btn img {
    width: 16px;
    height: 16px;
}

/* اطلاعات اصلی */
.detail-info-section {
    padding: 0 20px;
}

.detail-title {
    font-family: 'PeydaWeb', sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 8px;
    color: var(--text-primary);
}

.detail-meta-primary {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 20px;
}

.detail-meta-primary span {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.detail-meta-primary img {
    width: 18px;
    height: 18px;
    opacity: 0.7;
}

/* گرید اطلاعات جانبی */
.detail-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-bottom: 20px;
}

.detail-grid-item {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 12px;
}

.detail-grid-item img {
    width: 24px;
    height: 24px;
    opacity: 0.8;
}

.grid-label {
    display: block;
    font-size: 0.7rem;
    color: var(--text-secondary);
    margin-bottom: 2px;
}

.grid-value {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-primary);
}

/* نوار پیشرفت */
.detail-progress {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 24px;
}

.detail-progress .progress-bar {
    flex: 1;
    height: 8px;
    background: var(--border-color);
    border-radius: 4px;
    overflow: hidden;
}

.detail-progress .progress-fill {
    height: 100%;
    background: var(--color-secondary);
    border-radius: 4px;
}

.detail-progress span {
    font-size: 0.75rem;
    color: var(--text-secondary);
    white-space: nowrap;
}

/* تب‌های توضیحات */
.detail-tabs {
    display: flex;
    gap: 0;
    background: var(--border-color);
    border-radius: 14px;
    padding: 4px;
    margin-bottom: 16px;
}

.d-tab {
    flex: 1;
    padding: 10px;
    border: none;
    background: transparent;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-secondary);
    border-radius: 12px;
    cursor: pointer;
    transition: 0.2s;
}

.d-tab.active {
    background: var(--bg-card);
    color: var(--color-primary);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.04);
}

.d-tab-content {
    font-size: 0.85rem;
    color: var(--text-primary);
    line-height: 1.7;
    margin-bottom: 20px;
}

.d-tab-content ul {
    padding-right: 16px;
}

.d-tab-content li {
    margin-bottom: 6px;
}

/* نظرات */
.detail-reviews {
    padding: 20px 20px 0;
}

.review-card {
    display: flex;
    gap: 12px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 14px;
    margin-bottom: 10px;
}

.review-avatar {
    width: 40px;
    height: 40px;
    background: var(--color-primary);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    flex-shrink: 0;
}

.review-body strong {
    display: block;
    font-size: 0.85rem;
    margin-bottom: 4px;
}

.review-body p {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin-bottom: 4px;
}

.review-body span {
    font-size: 0.7rem;
    color: #94a3b8;
}

/* دکمه شناور ثبت‌نام */
.sticky-register-bar {
    position: sticky;
    bottom: 85px;
    /* قبلاً 70px بود، افزایش یافت */
    margin: 0 20px;
    background: var(--bg-card);
    border-radius: 18px;
    padding: 14px 18px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.06);
    z-index: 10;
}

.price-block {
    display: flex;
    flex-direction: column;
}

.price-block .old-price {
    font-size: 0.7rem;
    color: #94a3b8;
    text-decoration: line-through;
}

.price-block .final-price {
    font-family: 'PeydaWeb', sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--text-primary);
}

.btn-register-now {
    padding: 12px 24px;
    border: none;
    border-radius: 14px;
    background: #EE6C4D;
    color: #fff;
    font-weight: 600;
    font-size: 0.9rem;
    cursor: pointer;

}

/* =============================================
   پروفایل و صفحات زیرمجموعه
   ============================================= */
.profile-header {
    text-align: center;
    padding: 30px 20px 20px;
}

.profile-avatar-wrapper {
    margin-bottom: 12px;
}

.profile-avatar-img {
    width: 96px;
    height: 96px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--color-primary);
}

.profile-name {
    font-family: 'PeydaWeb', sans-serif;
    font-size: 1.4rem;
    margin-bottom: 4px;
    color: var(--text-primary);
}

.profile-phone {
    font-size: 0.9rem;
    color: var(--text-secondary);
    margin-bottom: 16px;
}

.btn-edit-profile {
    display: inline-block;
    padding: 10px 24px;
    border: 1px solid var(--color-primary);
    border-radius: 12px;
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.9rem;
    transition: 0.2s;
}

.btn-edit-profile:hover {
    background: var(--color-primary);
    color: #fff;
}

/* منوی پروفایل */
.profile-menu {
    padding: 20px 20px 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.profile-menu-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 18px;
    background: var(--bg-card);
    border-radius: 16px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.03);
    text-decoration: none;
    color: var(--text-primary);
    transition: 0.2s;
}

.profile-menu-item:hover {
    background: var(--border-color);
}

.menu-item-left {
    display: flex;
    align-items: center;
    gap: 12px;
}

.menu-item-left img {
    width: 24px;
    height: 24px;
}

/* فرم‌های ویرایش / تغییر رمز */
.edit-profile-section,
.change-password-section,
.saved-events-section {
    padding: 20px 20px 0;
}

.edit-profile-form,
.change-password-form {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-top: 20px;
}

.btn-save-profile {
    width: 100%;
    padding: 14px;
    border: none;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
    color: #fff;
    font-weight: 600;
    cursor: pointer;
}

/* آپلود آواتار */
.avatar-upload-box {
    border: 2px dashed var(--border-color);
    border-radius: 16px;
    padding: 20px;
    text-align: center;
    cursor: pointer;
}

.avatar-preview-img {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
    margin-bottom: 8px;
}

/* دعوت */
.invite-page-section {
    padding: 20px 20px 0;
}

.invite-link-box {
    display: flex;
    gap: 8px;
    margin: 20px 0;
}

.invite-link-box input {
    flex: 1;
    padding: 10px;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    background: var(--bg-card);
    color: var(--text-primary);
}

.btn-copy-link {
    padding: 10px 20px;
    border: none;
    border-radius: 12px;
    background: var(--color-primary);
    color: #fff;
    font-weight: 600;
    cursor: pointer;
}

.share-btn {
    padding: 10px 20px;
    border: none;
    border-radius: 12px;
    margin-right: 8px;
    font-weight: 600;
    cursor: pointer;
}

.share-btn.telegram {
    background: #0088cc;
    color: #fff;
}

.share-btn.whatsapp {
    background: #25D366;
    color: #fff;
}

/* =============================================
   صفحات فرم‌دار (تغییر رمز، دعوت و ...)
   ============================================= */
.form-page-section {
    padding: 24px 20px;
}

.form-card {
    background: var(--bg-card);
    border-radius: 28px;
    padding: 32px 24px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.04);
    border: 1px solid var(--border-color);
    text-align: center;
}

.form-card-icon {
    margin-bottom: 16px;
}

.form-card-icon img {
    width: 48px;
    height: 48px;
    opacity: 0.85;
}

.form-card-title {
    font-family: 'PeydaWeb', sans-serif;
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 8px;
}

.form-card-desc {
    font-size: 0.9rem;
    color: var(--text-secondary);
    margin-bottom: 24px;
    line-height: 1.7;
}

.form-card-note {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-top: 16px;
}

/* فرم‌های داخل کارت */
.styled-form {
    text-align: right;
}

.styled-form .form-group {
    margin-bottom: 16px;
}

.styled-form label {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 6px;
}

.styled-form input {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--border-color);
    border-radius: 14px;
    font-size: 0.9rem;
    background: var(--bg-body);
    color: var(--text-primary);
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.styled-form input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.1);
}

.btn-full-gradient {
    width: 100%;
    padding: 14px;
    border: none;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
    color: #fff;
    font-family: 'PeydaWeb', sans-serif;
    font-weight: 600;
    font-size: 1rem;
    cursor: pointer;
    margin-top: 8px;
    transition: opacity 0.2s;
}

.btn-full-gradient:hover {
    opacity: 0.95;
}

/* باکس دعوت */
.invite-link-wrapper {
    display: flex;
    gap: 10px;
    margin-top: 8px;
}

.invite-link-input {
    flex: 1;
    padding: 12px 14px;
    border: 1px solid var(--border-color);
    border-radius: 14px;
    font-size: 0.85rem;
    background: var(--bg-body);
    color: var(--text-primary);
    outline: none;
}

.btn-copy-invite {
    padding: 12px 20px;
    border: none;
    border-radius: 14px;
    background: var(--color-primary);
    color: #fff;
    font-weight: 600;
    font-size: 0.9rem;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.2s;
}

.btn-copy-invite:hover {
    background: #0284c7;
}

/* کارت‌های آمار پروفایل */
.profile-stats-cards {
    display: flex;
    gap: 10px;
    margin-top: 20px;
}

.stat-card {
    flex: 1;
    padding: 16px 10px;
    border-radius: 18px;
    text-align: center;
    color: #fff;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}

.stat-icon-img {
    width: 28px;
    height: 28px;
    opacity: 0.9;
}

.stat-label {
    font-size: 0.7rem;
    opacity: 0.9;
}

.stat-number {
    font-family: 'PeydaWeb', sans-serif;
    font-size: 1.3rem;
    font-weight: 700;
}

/* تاریخچه خرید */
.purchase-history {
    padding: 20px 20px 0;
}

.subsection-title {
    font-size: 1rem;
    margin-bottom: 12px;
    color: var(--text-primary);
}

.history-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.history-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 12px 14px;
}

.history-info strong {
    display: block;
    font-size: 0.9rem;
    margin-bottom: 2px;
}

.history-info span {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.history-status {
    font-size: 0.7rem;
    padding: 2px 8px;
    border-radius: 8px;
    font-weight: 600;
}

.history-status.success {
    background: #d1fae5;
    color: #065f46;
}

.history-status.refund {
    background: #fee2e2;
    color: #991b1b;
}

/* ویجت منو */
.menu-widget {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 14px 16px;
    text-decoration: none;
    color: var(--text-primary);
    transition: background 0.2s;
    margin-bottom: 8px;
    cursor: pointer;
}

.menu-widget:hover {
    background: var(--border-color);
}

.widget-left {
    display: flex;
    align-items: center;
    gap: 10px;
}

.widget-left img {
    width: 22px;
    height: 22px;
}

/* تاریخچه خرید */
.purchase-history-page {
    padding: 20px 20px 0;
}

.history-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 12px 14px;
    margin-bottom: 8px;
}

.history-info strong {
    display: block;
    font-size: 0.9rem;
    margin-bottom: 2px;
}

.history-info span {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.history-status {
    font-size: 0.7rem;
    padding: 2px 8px;
    border-radius: 8px;
    font-weight: 600;
}

.history-status.success {
    background: #d1fae5;
    color: #065f46;
}

.history-status.refund {
    background: #fee2e2;
    color: #991b1b;
}

/* گواهی‌ها */
.cert-page-section {
    padding: 20px 20px 0;
}

.cert-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 16px;
}

.cert-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 14px 16px;
}

.cert-info h4 {
    font-size: 0.95rem;
    margin-bottom: 4px;
}

.cert-info p {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-top: 4px;
}

.cert-badge {
    display: inline-block;
    background: #fef3c7;
    color: #92400e;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 0.7rem;
    font-weight: 700;
}

.cert-download-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: var(--color-primary);
    color: #fff;
    border-radius: 10px;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.8rem;
}

/* =============================================
   گواهی‌ها درون کارت فرم
   ============================================= */
.cert-list-box {
    margin-top: 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.cert-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--bg-body);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 14px 16px;
    text-align: right;
    transition: background 0.2s;
}

.cert-item:hover {
    background: var(--border-color);
}

.cert-item-info h4 {
    font-size: 0.95rem;
    font-weight: 600;
    margin-bottom: 6px;
    color: var(--text-primary);
}

.cert-item-badge {
    display: inline-block;
    background: #fef3c7;
    color: #92400e;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 0.7rem;
    font-weight: 700;
    margin-bottom: 6px;
}

.cert-item-info p {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin: 0;
}

.cert-download-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 18px;
    background: var(--color-primary);
    color: #fff;
    border-radius: 12px;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.8rem;
    white-space: nowrap;
    transition: background 0.2s;
}

.cert-download-btn:hover {
    background: #0284c7;
}

/* =============================================
   تاریخچه خرید (استایل کارتی)
   ============================================= */
.purchase-list-box {
    margin-top: 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.purchase-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--bg-body);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 14px 16px;
    text-align: right;
    text-decoration: none;
    color: inherit;
    transition: background 0.2s, border-color 0.2s;
}

.purchase-item:hover {
    background: var(--border-color);
    border-color: var(--color-primary);
}

.purchase-item-info h4 {
    font-size: 0.95rem;
    font-weight: 600;
    margin-bottom: 4px;
    color: var(--text-primary);
}

.purchase-item-info span {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.purchase-item-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

.purchase-price {
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--text-primary);
}

.purchase-status {
    font-size: 0.7rem;
    padding: 2px 8px;
    border-radius: 8px;
    font-weight: 600;
}

.purchase-status.success {
    background: #d1fae5;
    color: #065f46;
}

.purchase-status.refund {
    background: #fee2e2;
    color: #991b1b;
}

/* =============================================
   پنل ادمین
   ============================================= */
.admin-header {
    padding: 12px 20px 10px !important;
    background-color: var(--header-bg);
    box-shadow: var(--header-shadow);
    z-index: 1000;
}

.header-admin-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.top-row {
    margin-bottom: 12px;
}

.bottom-row {
    gap: 12px;
    margin-bottom: 16px;
}

.header-admin-user {
    display: flex;
    align-items: center;
    gap: 10px;
}

.search-box {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
}

.search-box input {
    width: 100%;
    padding: 10px 40px 10px 14px;
    border: 1px solid var(--border-color);
    border-radius: 14px;
    background: var(--bg-body);
    color: var(--text-primary);
    font-size: 0.85rem;
    outline: none;
}

.search-icon-btn {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
}

.search-icon-btn img {
    width: 18px;
    height: 18px;
    display: block;
}

.icon-btn {
    background: none;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 10px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.icon-btn img {
    width: 20px;
    height: 20px;
}

/* تب‌ها */
.admin-tabs {
    display: flex;
    gap: 8px;
    padding-bottom: 4px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.admin-tab {
    flex: 1 0 auto;
    padding: 10px 16px;
    border-radius: 14px;
    background: var(--border-color);
    color: var(--text-secondary);
    font-weight: 600;
    font-size: 0.8rem;
    border: none;
    cursor: pointer;
    transition: 0.2s;
    white-space: nowrap;
}

.admin-tab.active {
    background: var(--color-primary);
    color: #fff;
}

/* کارت‌های KPI */
.kpi-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    padding: 0 20px 20px;
}

.kpi-card {
    padding: 20px 14px;
    border-radius: 20px;
    color: #fff;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

.kpi-icon {
    width: 36px;
    height: 36px;
    opacity: 0.9;
    filter: brightness(0) invert(1);
    /* آیکون را سفید می‌کند */
}

.kpi-red {
    background: linear-gradient(135deg, #ef4444, #f87171);
}

.kpi-green {
    background: linear-gradient(135deg, #10b981, #34d399);
}

.kpi-blue {
    background: linear-gradient(135deg, #3b82f6, #60a5fa);
}

.kpi-pink {
    background: linear-gradient(135deg, #ec4899, #f472b6);
}

.kpi-purple {
    background: linear-gradient(135deg, #8b5cf6, #a78bfa);
}

.kpi-yellow {
    background: linear-gradient(135deg, #f59e0b, #fcd34d);
}

/* گزارش اتفاقات */
.reports-section {
    padding: 0 20px 20px;
}

.reports-title {
    font-size: 1.6rem;
    margin-bottom: 14px;
    color: var(--text-primary);
}

.report-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 16px;
    margin-bottom: 12px;
}

.report-card-title {
    font-size: 0.95rem;
    font-weight: 700;
    margin-bottom: 12px;
    color: var(--text-primary);
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 8px;
}

.report-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.report-list li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 0;
    border-bottom: 1px solid var(--border-color);
    font-size: 0.8rem;
    color: var(--text-primary);
}

.report-list li:last-child {
    border-bottom: none;
}

.badge {
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 0.7rem;
    font-weight: 600;
}

.badge.user {
    background: #dbeafe;
    color: #1e40af;
}

.badge.specialist {
    background: #fef3c7;
    color: #92400e;
}

.time,
.count {
    font-size: 0.7rem;
    color: var(--text-secondary);
}

/* در انتظار تأیید و تأیید شده */
.pending-card {
    display: flex;
    gap: 14px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 18px;
    padding: 16px;
    margin: 0 20px 12px;
    align-items: center;
}

.pending-img {
    width: 80px;
    height: 80px;
    border-radius: 14px;
    object-fit: cover;
    flex-shrink: 0;
}

.pending-info {
    flex: 1;
}

.pending-info h4 {
    margin-bottom: 6px;
}

.pending-info p {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin-bottom: 4px;
}

.pending-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.btn-approve,
.btn-reject {
    width: 70px;
    padding: 10px;
    border: none;
    border-radius: 12px;
    font-weight: 600;
    color: #fff;
    cursor: pointer;
    font-size: 0.8rem;
}

.btn-approve {
    background: #10b981;
}

.btn-reject {
    background: #ef4444;
}

.btn-view-attendees {
    display: inline-block;
    margin-top: 8px;
    background: none;
    border: 1px solid var(--color-primary);
    color: var(--color-primary);
    border-radius: 8px;
    padding: 6px 14px;
    font-size: 0.75rem;
    cursor: pointer;
    transition: background 0.2s;
}

.btn-view-attendees:hover {
    background: var(--color-primary);
    color: #fff;
}

.approved-card {
    position: relative;
}

.status-badge.approved {
   /* position: absolute;
    top: 16px;
    left: 16px;*/
    background: #d1fae5;
    color: #065f46;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 0.7rem;
    font-weight: 700;
}

/* تأیید نشده */
.rejected-card {
    display: flex;
    gap: 12px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 12px;
    margin: 0 20px 10px;
    align-items: center;
}

.rejected-img {
    width: 60px;
    height: 60px;
    border-radius: 10px;
    object-fit: cover;
}

.status-badge.rejected {
    background: #fee2e2;
    color: #991b1b;
    padding: 2px 8px;
    border-radius: 8px;
    font-size: 0.7rem;
}

/* مودال‌ها */
.attendees-modal {
    max-width: 400px;
}

.attendees-list {
    list-style: none;
    padding: 0;
    margin: 16px 0;
    text-align: right;
}

.attendees-list li {
    padding: 8px 0;
    border-bottom: 1px solid var(--border-color);
}

/* =============================================
   فاصلهٔ محتوای پنل ادمین از هدر
   ============================================= */
.admin-main {
    padding-top: 200px;
    /* می‌توانید مقدار را بیشتر یا کمتر کنید */
}

.search-box input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.15);
    outline: none;
}

.icon-btn:hover {
    background-color: rgba(14, 165, 233, 0.1);
    border-color: var(--color-primary);
}

.report-list li {
    flex-wrap: nowrap;
    /* جلوگیری از شکستن به خط بعد */
    gap: 12px;
    /* فاصله مناسب بین ستون‌ها */
}

.report-list .badge {
    white-space: nowrap;
    /* متن داخل بج شکسته نشود */
}

.report-list .badge {
    min-width: 80px;
    /* عرض ثابت برای بج‌ها */
    text-align: center;
}

/* =============================================
   رویدادهای ذخیره‌شده
   ============================================= */
.saved-list-box {
    margin-top: 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.saved-item {
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--bg-body);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 12px 14px;
    text-align: right;
    transition: background 0.2s;
}

.saved-item:hover {
    background: var(--border-color);
}

.saved-item-img {
    width: 60px;
    height: 60px;
    border-radius: 12px;
    object-fit: cover;
    flex-shrink: 0;
}

.saved-item-info {
    flex: 1;
}

.saved-item-info h4 {
    font-size: 0.9rem;
    font-weight: 600;
    margin-bottom: 4px;
    color: var(--text-primary);
}

.saved-item-info span {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.saved-remove-btn {
    background: none;
    border: 1px solid var(--border-color);
    border-radius: 10px;
    padding: 8px;
    cursor: pointer;
    flex-shrink: 0;
    transition: background 0.2s, border-color 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
}

.saved-remove-btn:hover {
    background: #fee2e2;
    border-color: #fecaca;
}

.saved-remove-btn img {
    width: 16px;
    height: 16px;
    opacity: 0.7;
}

.saved-remove-btn:hover img {
    opacity: 1;
}

/* ========== خلاصه یادداشت‌ها ========== */
.notes-summary-box {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 14px 16px;
    margin-bottom: 16px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.notes-summary-box h4 {
    margin: 0;
    font-size: 0.95rem;
    color: var(--text-primary);
}

.btn-view-notes-summary {
    background: var(--color-primary);
    border: none;
    padding: 8px 16px;
    border-radius: 10px;
    color: #fff;
    font-weight: 600;
    font-size: 0.8rem;
    cursor: pointer;
}

/* مودال خلاصه یادداشت‌ها */
.summary-modal-card {
    max-width: 500px;
    text-align: right;
}

.summary-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin: 16px 0 20px;
    max-height: 60vh;
    overflow-y: auto;
}

.summary-item {
    background: var(--bg-body);
    border-radius: 12px;
    padding: 12px 14px;
}

.summary-item h5 {
    margin-bottom: 6px;
    color: var(--text-primary);
}

.summary-item p {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin: 0;
}

/* گالری تمام‌صفحه (در مودال) */
.gallery-full-img {
    width: 100%;
    border-radius: 10px;
    object-fit: cover;
    margin-bottom: 6px;
}

/* کارت‌های پیش‌رو */
.upcoming-detail-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--border-color);
}

.days-left {
    font-size: 0.8rem;
    color: var(--color-secondary);
    font-weight: 600;
}

.btn-cancel-reg {
    background: none;
    border: 1px solid #fecaca;
    padding: 6px 14px;
    border-radius: 10px;
    color: #b91c1c;
    font-size: 0.8rem;
    cursor: pointer;
    transition: background 0.2s;
}

.btn-cancel-reg:hover {
    background: #fee2e2;
}

/* بقیه استایل‌ها (extra-tabs، panels، note، gallery و...) مشابه نسخه متخصص در main.css موجود است.
   اگر لازم است بخش‌های زیر را دوباره در main.css اضافه کنید: */

.past-event-extra {
    margin-top: 12px;
    border-top: 1px solid var(--border-color);
}

.extra-tabs {
    display: flex;
    gap: 8px;
    margin: 10px 0;
}

.extra-tab {
    background: var(--border-color);
    border: none;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 0.7rem;
    cursor: pointer;
    color: var(--text-secondary);
}

.extra-tab.active {
    background: var(--color-primary);
    color: #fff;
}

.extra-panel {
    display: none;
}

.extra-panel.active {
    display: block;
}

.note-display {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin: 8px 0;
    background: var(--bg-body);
    padding: 10px;
    border-radius: 8px;
}

.btn-edit-note {
    background: var(--color-primary);
    border: none;
    padding: 6px 12px;
    border-radius: 8px;
    color: #fff;
    font-size: 0.75rem;
    cursor: pointer;
}

.gallery-scroll {
    display: flex;
    gap: 8px;
    overflow-x: auto;
}

.gallery-scroll img {
    height: 70px;
    border-radius: 10px;
    cursor: pointer;
}

.cert-download-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: var(--color-primary);
    color: #fff;
    border-radius: 10px;
    text-decoration: none;
    font-size: 0.8rem;
    font-weight: 600;
}

/* ========== خلاصه یادداشت‌ها (کارت) ========== */
.notes-summary-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 14px 16px;
    margin-bottom: 16px;
    gap: 12px;
}

.notes-summary-content {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
}

.notes-summary-icon {
    width: 40px;
    height: 40px;
    background: rgba(14, 165, 233, 0.1);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.notes-summary-icon img {
    width: 22px;
    height: 22px;
    opacity: 0.8;
}

.notes-summary-info h4 {
    font-size: 0.9rem;
    font-weight: 600;
    margin-bottom: 4px;
    color: var(--text-primary);
}

.notes-summary-info p {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin: 0;
}

.btn-view-summary {
    background: var(--color-primary);
    border: none;
    padding: 8px 16px;
    border-radius: 10px;
    color: #fff;
    font-weight: 600;
    font-size: 0.8rem;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
}

/* ========== فوتر پیش رو ========== */
.upcoming-footer {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--border-color);
}

.days-remaining {
    font-size: 0.8rem;
    color: var(--color-secondary);
    font-weight: 600;
}

.notes-summary-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 14px 16px;
    margin-bottom: 16px;
    gap: 12px;
}

.notes-summary-content {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
}

.notes-summary-icon {
    width: 40px;
    height: 40px;
    background: rgba(14, 165, 233, 0.1);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.notes-summary-icon img {
    width: 22px;
    height: 22px;
}

.notes-summary-info h4 {
    font-size: 0.9rem;
    font-weight: 600;
    margin-bottom: 4px;
    color: var(--text-primary);
}

.notes-summary-info p {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin: 0;
}

.btn-view-summary {
    background: var(--color-primary);
    border: none;
    padding: 8px 16px;
    border-radius: 10px;
    color: #fff;
    font-weight: 600;
    font-size: 0.8rem;
    cursor: pointer;
    white-space: nowrap;
}

/* دکمه‌های پایین کارت گذشته */
/* فوتر کارت‌های گذشته (دکمه‌های معمولی) */
.past-footer {
    width: 100%;
    /* عرض کامل زیر کارت */
    display: flex;
    gap: 8px;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--border-color);
}

.simple-past-btn {
    flex: 1;
    /* هر دو دکمه هم‌عرض */
    padding: 10px;
    border-radius: 8px;
    border: 1px solid var(--color-primary);
    background: var(--bg-card);
    color: var(--color-primary);
    font-size: 0.8rem;
    font-weight: 500;
    cursor: pointer;
    text-align: center;
    white-space: nowrap;
    transition: background 0.2s, color 0.2s;
}
.simple-past-btn.active{
    background: var(--color-primary);
    color: var(--bg-card);
}
.simple-past-btn:hover {
    background: var(--color-primary);
    color: #fff;
}

/* مودال نمایش یادداشت */
.note-modal-card {
    max-width: 450px;
    text-align: right;
}

/* اطمینان از اعمال فونت در صفحات auth */
.auth-card,
.auth-card input,
.auth-card select,
.auth-card textarea,
.auth-card button {
    font-family: 'IRANSansX', sans-serif;
}

.auth-card h2,
.auth-card .auth-title {
    font-family: 'PeydaWeb', sans-serif;
}

@media (max-width: 720px) {
    .app-main {
        padding-bottom: 140px;
    }
}

/* ردیف اطلاعات پیش‌رو (ثبت‌نام‌کننده + روزهای باقی‌مانده) */
.upcoming-info-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 6px;
    font-size: 0.8rem;
}

.reg-count {
    color: var(--color-primary);
    font-weight: 600;
}

.days-left {
    color: var(--color-secondary);
    font-weight: 500;
}

.days-left-inline {
    color: var(--color-secondary);
    font-weight: 500;
    margin-right: 4px;
}

/* =============================================
   صفحه ویرایش پروفایل
   ============================================= */
.edit-profile-section {
    padding: 20px 20px 0;
}

.edit-profile-form {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-top: 24px;
}

.edit-profile-form label {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 6px;
}

.edit-profile-form input {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--border-color);
    border-radius: 14px;
    font-size: 0.9rem;
    background: var(--bg-card);
    color: var(--text-primary);
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.edit-profile-form input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.1);
}

/* آپلود آواتار */
.avatar-upload-box {
    border: 2px dashed var(--border-color);
    border-radius: 16px;
    padding: 20px;
    text-align: center;
    cursor: pointer;
    transition: border-color 0.2s;
}

.avatar-upload-box:hover {
    border-color: var(--color-primary);
}

.avatar-preview-img {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
    margin-bottom: 8px;
    border: 2px solid var(--color-primary);
}

.avatar-upload-box span {
    display: block;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

/* دکمه ذخیره */
.btn-save-profile {
    width: 100%;
    padding: 14px;
    border: none;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--color-primary), #054461);
    color: #fff;
    font-weight: 600;
    font-size: 1rem;
    cursor: pointer;
    margin-top: 12px;
    transition: opacity 0.2s;
}

.btn-save-profile:hover {
    opacity: 0.95;
}

/* =============================================
   بخش ارسال نظر
   ============================================= */
.comment-section {
    padding: 20px 20px 0;
}

.comment-box {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 16px;
    margin-top: 12px;
}

.comment-box textarea {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--border-color);
    border-radius: 14px;
    font-size: 0.9rem;
    background: var(--bg-body);
    color: var(--text-primary);
    outline: none;
    resize: vertical;
    margin-bottom: 12px;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.comment-box textarea:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.1);
}

.btn-submit-comment {
    width: 100%;
    padding: 12px;
    border: none;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
    color: #fff;
    font-weight: 600;
    font-size: 0.9rem;
    cursor: pointer;
    transition: opacity 0.2s;
}

.btn-submit-comment:hover {
    opacity: 0.95;
}

/* بک‌گراند صفحات احراز هویت */
body.auth-page {
    position: relative;
    background: none;
    /* بک‌گراند پیش‌فرض برداشته می‌شود */
}

body.auth-page::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url('../images/auth-bg.jpg') center/cover no-repeat;
    opacity: 0.35;
    /* شفافیت تصویر، می‌توانید تغییر دهید */
    z-index: -1;
}

body.auth-page::after {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.45);
    /* لایه تیره نسبتاً تیره */
    z-index: -1;
}

/* اطمینان از اینکه محتوای فرم خوانا باقی بماند */
body.auth-page .app-container {
    background: transparent;
    box-shadow: none;
}

body.auth-page .auth-card {
    background: rgba(255, 255, 255, 0.95);
    /* در تم دارک نیز کمی شفاف */
}

body.dark.auth-page .auth-card {
    background: rgba(30, 41, 59, 0.95);
}

input[type="tel"] {
    direction: rtl;
    text-align: right;
    padding-right: 14px !important;
}

/* سطر اول هدر */
.header-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.header-logo img {
    height: 36px;
    width: auto;
    display: block;
}

/* دکمه بازگشت */
.header-back-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 6px 14px;
    color: var(--text-secondary);
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    transition: background-color 0.2s, border-color 0.2s;
}

.header-back-btn:hover {
    background-color: var(--border-color);
    border-color: var(--color-primary);
    color: var(--color-primary);
}

/* سطر دوم هدر */
.header-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.header-user {
    display: flex;
    align-items: center;
    gap: 10px;
}

.header-avatar {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid var(--color-primary);
}

.header-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.header-user-info {
    display: flex;
    flex-direction: column;
}

.header-user-name {
    font-family: 'PeydaWeb', sans-serif;
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--text-primary);
    line-height: 1.2;
}

.header-user-role {
    font-size: 0.7rem;
    color: var(--text-secondary);
}

.header-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

.header-btn {
    background: none;
    border: 1px solid var(--border-color);
    padding: 8px;
    border-radius: 12px;
    cursor: pointer;
    transition: background-color 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
}

.header-btn:hover {
    background-color: var(--border-color);
}

.header-btn img {
    width: 20px;
    height: 20px;
    display: block;
}

/* لینک پشتیبانی – اندازهٔ عادی (دسکتاپ) */
.header-support-link {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--color-primary);
    font-weight: 600;
    font-size: 0.85rem;
    text-decoration: none;
    padding: 6px 14px;
    border: 1px solid var(--color-primary);
    border-radius: 12px;
    background: rgba(14, 165, 233, 0.05);
    transition: background 0.2s, color 0.2s;
}

.header-support-link:hover {
    background: var(--color-primary);
    color: #fff;
}

.header-support-link svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

/* نسخهٔ موبایل – کوچک‌تر */
@media (max-width: 720px) {
    .header-support-link {
        font-size: 0.75rem;
        padding: 4px 10px;
        gap: 4px;
    }

    .header-support-link svg {
        width: 16px;
        height: 16px;
    }
}

/* =============================================
   صفحات منو (اعلان‌ها، سوالات، درباره، تماس)
   ============================================= */

/* --- اعلان‌ها --- */
.notif-list {
    margin-top: 16px;
}

.notif-item {
    display: flex;
    gap: 12px;
    padding: 14px 0;
    border-bottom: 1px solid var(--border-color);
}

.notif-item:last-child {
    border-bottom: none;
}

.notif-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--border-color);
    margin-top: 5px;
    flex-shrink: 0;
}

.notif-item.unread .notif-dot {
    background: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.15);
}

.notif-content p {
    margin: 0 0 4px;
    font-size: 0.9rem;
    color: var(--text-primary);
}

.notif-content span {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

/* --- سوالات متداول --- */
.faq-list {
    margin-top: 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.faq-item {
    border: 1px solid var(--border-color);
    border-radius: 14px;
    overflow: hidden;
}

.faq-question {
    width: 100%;
    padding: 14px 16px;
    background: var(--bg-body);
    border: none;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text-primary);
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    transition: background 0.2s;
}

.faq-question:hover {
    background: var(--border-color);
}

.faq-arrow {
    display: inline-block;
    width: 12px;
    height: 12px;
    border-left: 2px solid var(--text-secondary);
    border-bottom: 2px solid var(--text-secondary);
    transform: rotate(-45deg);
    transition: transform 0.3s;
}

.faq-question:not(.collapsed) .faq-arrow {
    transform: rotate(135deg);
}

.faq-answer {
    padding: 0 16px 14px;
    font-size: 0.85rem;
    color: var(--text-secondary);
    line-height: 1.7;
}

/* --- درباره ما و تماس با ما (قاب عکس) --- */
.image-frame-rect {
    display: inline-block;
    padding: 4px;
    border-radius: 20px;
    background: linear-gradient(135deg, var(--color-primary), #2dd4bf);
    margin: 0 auto 24px;
}

.image-frame-rect img {
    display: block;
    width: 100%;
    max-width: 300px;
    height: auto;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    border-radius: 17px;
    border: 2px solid var(--bg-card);
}

/* اطلاعات تماس */
.contact-info {
    margin-top: 20px;
    text-align: right;
}

.contact-info p {
    font-size: 0.9rem;
    margin-bottom: 10px;
    color: var(--text-secondary);
}

.contact-info strong {
    color: var(--text-primary);
    margin-left: 6px;
}



/* ========== استایل‌های اسپینر ========== */

/* اسپینر نقطه‌ای */
.spinner-dots {
    display: inline-flex;
    gap: 4px;
    align-items: center;
    margin-left: 8px;
}

.spinner-dots .dot {
    width: 8px;
    height: 8px;
    background: white;
    border-radius: 50%;
    display: inline-block;
    animation: dotPulse 1.4s infinite ease-in-out both;
}

.spinner-dots .dot:nth-child(1) { animation-delay: -0.32s; }
.spinner-dots .dot:nth-child(2) { animation-delay: -0.16s; }
.spinner-dots .dot:nth-child(3) { animation-delay: 0s; }

@keyframes dotPulse {
    0%, 80%, 100% { transform: scale(0); opacity: 0.5; }
    40% { transform: scale(1); opacity: 1; }
}

/* اسپینر دایره‌ای */
.spinner-circle {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255,255,255,0.3);
    border-top-color: white;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin-left: 8px;
    vertical-align: middle;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* اسپینر ضربان‌دار */
.spinner-pulse {
    display: inline-block;
    width: 20px;
    height: 20px;
    background: white;
    border-radius: 50%;
    animation: pulse 1s ease-in-out infinite;
    margin-left: 8px;
    vertical-align: middle;
}

@keyframes pulse {
    0%, 100% { transform: scale(0.5); opacity: 0.5; }
    50% { transform: scale(1); opacity: 1; }
}

/* اسپینر حلقه‌ای */
.spinner-ring {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 3px solid transparent;
    border-top-color: white;
    border-right-color: white;
    border-radius: 50%;
    animation: spin 0.6s linear infinite;
    margin-left: 8px;
    vertical-align: middle;
}

/* ========== استایل‌های دکمه در حال لود ========== */
.btn-loading {
    position: relative;
    transition: all 0.3s ease;
}

.btn-loading:hover {
    transform: none !important;
    box-shadow: none !important;
}

.btn-success {
    animation: successPulse 0.3s ease;
}

.btn-error {
    animation: errorShake 0.5s ease;
}

@keyframes successPulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.05); }
    100% { transform: scale(1); }
}

@keyframes errorShake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-10px); }
    75% { transform: translateX(10px); }
}

/* ========== استایل برای دکمه‌های غیرفعال ========== */
button:disabled {
    cursor: not-allowed !important;
    opacity: 0.7;
}

button:disabled:hover {
    transform: none !important;
    box-shadow: none !important;
}

/* ========== دکمه‌های شناور و sticky ========== */
.sticky-register-bar .btn-register-now.btn-loading {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
}

/* دکمه‌های auth */
.btn-auth.btn-loading {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
}

/* دکمه submit event */
.btn-submit-event.btn-loading {
    background: var(--primary-color, #4a90e2);
}


/* استایل صحیح Toast Container */
.toast-container {
    position: fixed;
    top: 20px;
    left: 0;
    right: 0;
    z-index: 10000;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    pointer-events: none;
    padding: 0 20px;
}

.toast-item {
    padding: 14px 24px;
    border-radius: 12px;
    color: white;
    font-family: 'IRANSans', Tahoma, sans-serif;
    font-size: 14px;
    font-weight: 500;
    box-shadow: 0 8px 25px rgba(0,0,0,0.2);
    animation: toastSlideDown 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    pointer-events: auto;
    display: flex;
    align-items: center;
    gap: 10px;
    max-width: 90%;
    width: auto;
    min-width: 200px;
    text-align: center;
    direction: rtl;
}

.toast-item.removing {
    animation: toastSlideUp 0.3s ease forwards;
}

@keyframes toastSlideDown {
    from {
        transform: translateY(-100%);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes toastSlideUp {
    from {
        transform: translateY(0);
        opacity: 1;
    }
    to {
        transform: translateY(-100%);
        opacity: 0;
    }
}

/* رنگ‌های مختلف */
.toast-success { background: #4caf50; }
.toast-error { background: #f44336; }
.toast-warning { background: #ff9800; }
.toast-info { background: #2196f3; }

.toast-icon {
    font-size: 20px;
    flex-shrink: 0;
}

.toast-message {
    flex: 1;
    line-height: 1.5;
}