﻿:root {
    /* رنگ‌های اصلی - مقادیر RGB برای استفاده در rgb() */
    --color-primary-rgb: 109 47 138;
    --color-primary: rgb(109 47 138);
    --color-primary-hex: #6d2f8a;
    --color-secondary-rgb: 236 72 153;
    --color-secondary: rgb(236 72 153);
    --color-secondary-hex: #ec4899;
    --color-accent-rgb: 245 158 11;
    --color-accent: rgb(245 158 11);
    --color-success-rgb: 16 185 129;
    --color-success: rgb(16 185 129);
    --color-dark-rgb: 31 41 55;
    --color-dark: rgb(31 41 55);
    --color-white-rgb: 255 255 255;
    --color-white: rgb(255 255 255);

    /* رنگ‌های خاکستری */
    --color-gray-50-rgb: 249 250 251;
    --color-gray-50: rgb(249 250 251);
    --color-gray-100-rgb: 243 244 246;
    --color-gray-100: rgb(243 244 246);
    --color-gray-200-rgb: 229 231 235;
    --color-gray-200: rgb(229 231 235);
    --color-gray-300-rgb: 209 213 219;
    --color-gray-300: rgb(209 213 219);
    --color-gray-400-rgb: 156 163 175;
    --color-gray-400: rgb(156 163 175);
    --color-gray-500-rgb: 107 114 128;
    --color-gray-500: rgb(107 114 128);
    --color-gray-600-rgb: 75 85 99;
    --color-gray-600: rgb(75 85 99);
    --color-gray-700-rgb: 55 65 81;
    --color-gray-700: rgb(55 65 81);
    --color-gray-800-rgb: 31 41 55;
    --color-gray-800: rgb(31 41 55);

    /* رنگ‌های دیگر */
    --color-red-500-rgb: 239 68 68;
    --color-red-500: rgb(239 68 68);
    --color-green-500-rgb: 34 197 94;
    --color-green-500: rgb(34 197 94);
    --color-blue-500-rgb: 59 130 246;
    --color-blue-500: rgb(59 130 246);
    --color-blue-600-rgb: 100 134 255;

    /* سطوح رنگی پرکاربرد */
    --color-primary-50: #eef2ff;
    --color-primary-200: #c7d2fe;
    --color-primary-600: #4f46e5;
    --color-secondary-50: #fdf2f8;
    --color-secondary-200: #fbcfe8;
    --color-secondary-600: #db2777;
    --color-accent-50: #fffbeb;
    --color-accent-200: #fde68a;
    --color-accent-600: #d97706;
    --color-success-50: #f0fdf4;
    --color-success-200: #bbf7d0;
    --color-success-600: #16a34a;
    --color-blue-50: #eff6ff;
    --color-blue-200: #bfdbfe;
    --color-blue-600: #2563eb;
    --color-purple-50: #faf5ff;
    --color-purple-200: #e9d5ff;
    --color-purple-600: #9333ea;
    --color-orange-50: #fff7ed;
    --color-orange-200: #fed7aa;
    --color-orange-600: #ea580c;
    --color-yellow-50: #fefce8;
    --color-yellow-200: #fef08a;
    --color-yellow-600: #ca8a04;
    --color-navy: #0f172a;
}

* {
    box-sizing: border-box;
    font-family: 'Vazirmatn', sans-serif;
}

body {
    margin: 0;
}

::-webkit-scrollbar {
    display: none;
}

/* Show scrollbars for dropdowns */
#headerLocationModal .header-location-body::-webkit-scrollbar,
#headerLocationModal .ad-search-location-body::-webkit-scrollbar,
.location-dropdown::-webkit-scrollbar,
.location-list::-webkit-scrollbar {
    display: block;
    width: 8px;
}

#headerLocationModal .header-location-body::-webkit-scrollbar-track,
#headerLocationModal .ad-search-location-body::-webkit-scrollbar-track,
.location-dropdown::-webkit-scrollbar-track,
.location-list::-webkit-scrollbar-track {
    background: transparent;
}

#headerLocationModal .header-location-body::-webkit-scrollbar-thumb,
#headerLocationModal .ad-search-location-body::-webkit-scrollbar-thumb,
.location-dropdown::-webkit-scrollbar-thumb,
.location-list::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.7);
    border-radius: 999px;
}


#headerLocationModal .header-location-body::-webkit-scrollbar-thumb:hover,
#headerLocationModal .ad-search-location-body::-webkit-scrollbar-thumb:hover,
.location-dropdown::-webkit-scrollbar-thumb:hover,
.location-list::-webkit-scrollbar-thumb:hover {
    background: rgba(148, 163, 184, 0.9);
}

/* Location Modal Styles */
.ad-search-location-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ad-search-location-modal-content {
    background: white;
    border-radius: 12px;
    max-width: 500px;
    width: 90%;
    max-height: 80vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.ad-search-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    border-bottom: 1px solid #e5e7eb;
}

.ad-search-modal-header-left {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.ad-search-modal-title {
    margin: 0;
    font-size: 1.125rem;
    font-weight: 600;
}

.ad-search-close-modal {
    background: none;
    border: none;
    font-size: 1.25rem;
    cursor: pointer;
    color: #6b7280;
}

.ad-search-back-btn {
    background: none;
    border: none;
    color: #6b7280;
    cursor: pointer;
    padding: 0.25rem;
}

.ad-search-location-body {
    flex: 1;
    overflow-y: auto;
    padding: 1rem;
}

.ad-search-location-grid {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.ad-search-location-item {
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    overflow: hidden;
}

.ad-search-location-item-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem;
}

.ad-search-location-item-header-main {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex: 1;
}

.ad-search-location-checkbox {
    margin: 0;
    width: 18px;
    height: 18px;
    accent-color: #3b82f6;
    cursor: pointer;
    border-radius: 4px;
    appearance: none;
    border: 2px solid #d1d5db;
    background: white;
    position: relative;
    transition: all 0.2s ease;
}

.ad-search-location-checkbox:checked {
    background: #3b82f6;
    border-color: #3b82f6;
}

.ad-search-location-checkbox:checked::after {
    content: '✓';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: white;
    font-size: 12px;
    font-weight: bold;
}

.ad-search-location-checkbox:indeterminate {
    background: #e5e7eb;
    border-color: #9ca3af;
}

.ad-search-location-checkbox:indeterminate::after {
    content: '−';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #6b7280;
    font-size: 14px;
    font-weight: bold;
}

.ad-search-location-checkbox:hover {
    border-color: #3b82f6;
}

.ad-search-location-checkbox:focus {
    outline: 2px solid #3b82f6;
    outline-offset: 2px;
}

.ad-search-location-item label {
    cursor: pointer;
    user-select: none;
    margin-right: 8px;
}

.ad-search-location-item-all {
    background: #f9fafb;
    border-color: #d1d5db;
}

.province-select-btn {
    background: none;
    border: none;
    color: #6b7280;
    cursor: pointer;
    padding: 0.25rem;
    border-radius: 4px;
    transition: background-color 0.2s;
}

.province-select-btn:hover {
    background: #f3f4f6;
}

.province-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

.province-city-count {
    font-size: 0.75rem;
    color: #6b7280;
    font-weight: 500;
    background: #f3f4f6;
    padding: 2px 6px;
    border-radius: 4px;
    white-space: nowrap;
}

.selected-cities-box {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    padding: 0.75rem;
}

.selected-cities-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: #374151;
}

.selected-cities-header i {
    color: #3b82f6;
}

.selected-cities-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.selected-cities-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    flex: 1;
    max-height: 60px;
    overflow: hidden;
}

.city-tag {
    background: #e0f2fe;
    color: #0277bd;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    font-size: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.city-tag .remove-city {
    background: none;
    border: none;
    color: #0277bd;
    cursor: pointer;
    padding: 0;
    font-size: 0.875rem;
    line-height: 1;
}

.city-tag .remove-city:hover {
    color: #01579b;
}

.show-more-cities {
    background: #f1f5f9;
    color: #475569;
    border: 1px solid #cbd5e1;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    font-size: 0.75rem;
    cursor: pointer;
    transition: all 0.2s;
}

.show-more-cities:hover {
    background: #e2e8f0;
    color: #334155;
}

.ad-search-location-actions {
    display: flex;
    gap: 0.75rem;
    padding: 1rem;
    border-top: 1px solid #e5e7eb;
}

.ad-search-location-btn {
    flex: 1;
    padding: 0.75rem;
    border-radius: 8px;
    border: none;
    font-weight: 500;
    cursor: pointer;
    transition: background-color 0.2s;
}

.ad-search-location-btn-primary {
    background: #3b82f6;
    color: white;
}

.ad-search-location-btn-primary:hover {
    background: #2563eb;
}

.ad-search-location-btn-secondary {
    background: #f3f4f6;
    color: #374151;
}

.ad-search-location-btn-secondary:hover {
    background: #e5e7eb;
}

/* Header Location Modal Styles - Unique classes to avoid conflicts */
.header-location-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
}

.header-location-modal-content {
    background: white;
    border-radius: 12px;
    max-width: 500px;
    width: 90%;
    max-height: 80vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.header-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    border-bottom: 1px solid #e5e7eb;
}

.header-modal-header-left {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.header-modal-title {
    margin: 0;
    font-size: 1.125rem;
    font-weight: 600;
}

.header-close-modal {
    background: none;
    border: none;
    font-size: 1.25rem;
    cursor: pointer;
    color: #6b7280;
}

.header-back-btn {
    background: none;
    border: none;
    color: #6b7280;
    cursor: pointer;
    padding: 0.25rem;
}

.header-location-body {
    flex: 1;
    overflow-y: auto;
    padding: 1rem;
}

.header-location-grid {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.header-location-item {
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
}

.header-location-item-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem;
}

.header-location-item-header-main {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex: 1;
}

.header-location-checkbox {
    margin: 0;
    width: 18px;
    height: 18px;
    accent-color: #3b82f6;
    cursor: pointer;
    border-radius: 4px;
    appearance: none;
    border: 2px solid #d1d5db;
    background: white;
    position: relative;
    transition: all 0.2s ease;
}

.header-location-checkbox:checked {
    background: #3b82f6;
    border-color: #3b82f6;
}

.header-location-checkbox:checked::after {
    content: '✓';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: white;
    font-size: 12px;
    font-weight: bold;
}

.header-location-checkbox:indeterminate {
    background: #e5e7eb;
    border-color: #9ca3af;
}

.header-location-checkbox:indeterminate::after {
    content: '−';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #6b7280;
    font-size: 14px;
    font-weight: bold;
}

.header-location-checkbox:hover {
    border-color: #3b82f6;
}

.header-location-checkbox:focus {
    outline: 2px solid #3b82f6;
    outline-offset: 2px;
}

.header-location-item label {
    cursor: pointer;
    user-select: none;
    margin-right: 8px;
}

.header-location-item-all {
    background: #f9fafb;
    border-color: #d1d5db;
}

.header-province-select-btn {
    background: none;
    border: none;
    color: #6b7280;
    cursor: pointer;
    padding: 0.25rem;
    border-radius: 4px;
    transition: background-color 0.2s;
}

.header-location-item:hover {
    background: #f3f4f6;
}

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

.header-province-city-count {
    font-size: 0.75rem;
    color: #6b7280;
    font-weight: 500;
    background: #f3f4f6;
    padding: 2px 6px;
    border-radius: 4px;
    white-space: nowrap;
}

.header-selected-cities-box {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    padding: 0.75rem;
}

.header-selected-cities-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: #374151;
}

.header-selected-cities-header i {
    color: #3b82f6;
}

.header-selected-cities-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.header-selected-cities-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    flex: 1;
    max-height: 60px;
    overflow: hidden;
}

.header-city-tag {
    background: #e0f2fe;
    color: #0277bd;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    font-size: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.header-city-tag .header-remove-city {
    background: none;
    border: none;
    color: #0277bd;
    cursor: pointer;
    padding: 0;
    font-size: 0.875rem;
    line-height: 1;
}

.header-city-tag .header-remove-city:hover {
    color: #01579b;
}

.header-show-more-cities {
    background: #f1f5f9;
    color: #475569;
    border: 1px solid #cbd5e1;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    font-size: 0.75rem;
    cursor: pointer;
    transition: all 0.2s;
}

.header-show-more-cities:hover {
    background: #e2e8f0;
    color: #334155;
}

.header-location-actions {
    display: flex;
    gap: 0.75rem;
    padding: 1rem;
    border-top: 1px solid #e5e7eb;
}

.header-location-btn {
    flex: 1;
    padding: 0.75rem;
    border-radius: 8px;
    border: none;
    font-weight: 500;
    cursor: pointer;
    transition: background-color 0.2s;
}

.header-location-btn-primary {
    background: #3b82f6;
    color: white;
}

.header-location-btn-primary:hover {
    background: #2563eb;
}

.header-location-btn-secondary {
    background: #f3f4f6;
    color: #374151;
}

.header-location-btn-secondary:hover {
    background: #e5e7eb;
}

.header-cities-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

/* Scrollbar styles for header modal */
#headerLocationModal .header-location-body::-webkit-scrollbar {
    display: block;
    width: 8px;
}

#headerLocationModal .header-location-body::-webkit-scrollbar-track {
    background: transparent;
}

#headerLocationModal .header-location-body::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.7);
    border-radius: 999px;
}

#headerLocationModal .header-location-body::-webkit-scrollbar-thumb:hover {
    background: rgba(148, 163, 184, 0.9);
}

:host,
:root {
    --fa-font-solid: normal 900 1em/1 "Font Awesome 6 Solid";
    --fa-font-regular: normal 400 1em/1 "Font Awesome 6 Regular";
    --fa-font-light: normal 300 1em/1 "Font Awesome 6 Light";
    --fa-font-thin: normal 100 1em/1 "Font Awesome 6 Thin";
    --fa-font-duotone: normal 900 1em/1 "Font Awesome 6 Duotone";
    --fa-font-sharp-solid: normal 900 1em/1 "Font Awesome 6 Sharp";
    --fa-font-sharp-regular: normal 400 1em/1 "Font Awesome 6 Sharp";
    --fa-font-sharp-light: normal 300 1em/1 "Font Awesome 6 Sharp";
    --fa-font-brands: normal 400 1em/1 "Font Awesome 6 Brands";
}

/* Background colors */
root {
    --fa-font-solid: normal 900 1em/1 "Font Awesome 6 Solid";
    --fa-font-regular: normal 400 1em/1 "Font Awesome 6 Regular";
    --fa-font-light: normal 300 1em/1 "Font Awesome 6 Light";
    --fa-font-thin: normal 100 1em/1 "Font Awesome 6 Thin";
    --fa-font-duotone: normal 900 1em/1 "Font Awesome 6 Duotone";
    --fa-font-sharp-solid: normal 900 1em/1 "Font Awesome 6 Sharp";
    --fa-font-sharp-regular: normal 400 1em/1 "Font Awesome 6 Sharp";
    --fa-font-sharp-light: normal 300 1em/1 "Font Awesome 6 Sharp";
    --fa-font-brands: normal 400 1em/1 "Font Awesome 6 Brands"
}

svg:not(:host).svg-inline--fa,
svg:not(:root).svg-inline--fa {
    overflow: visible;
    box-sizing: content-box
}

.svg-inline--fa {
    display: var(--fa-display, inline-block);
    height: 1em;
    overflow: visible;
    vertical-align: -.125em
}

.svg-inline--fa.fa-2xs {
    vertical-align: .1em
}

.svg-inline--fa.fa-xs {
    vertical-align: 0
}

.svg-inline--fa.fa-sm {
    vertical-align: -.0714285705em
}

.svg-inline--fa.fa-lg {
    vertical-align: -.2em
}

.svg-inline--fa.fa-xl {
    vertical-align: -.25em
}

.svg-inline--fa.fa-2xl {
    vertical-align: -.3125em
}

.svg-inline--fa.fa-pull-left {
    margin-right: var(--fa-pull-margin, .3em);
    width: auto
}

.svg-inline--fa.fa-pull-right {
    margin-left: var(--fa-pull-margin, .3em);
    width: auto
}

.svg-inline--fa.fa-li {
    width: var(--fa-li-width, 2em);
    top: .25em
}

.svg-inline--fa.fa-fw {
    width: var(--fa-fw-width, 1.25em)
}

.fa-layers svg.svg-inline--fa {
    bottom: 0;
    left: 0;
    margin: auto;
    position: absolute;
    right: 0;
    top: 0
}

.fa-layers-counter,
.fa-layers-text {
    display: inline-block;
    position: absolute;
    text-align: center
}

.fa-layers {
    display: inline-block;
    height: 1em;
    position: relative;
    text-align: center;
    vertical-align: -.125em;
    width: 1em
}

.fa-layers svg.svg-inline--fa {
    -webkit-transform-origin: center center;
    transform-origin: center center
}

.fa-layers-text {
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    -webkit-transform-origin: center center;
    transform-origin: center center
}

.fa-layers-counter {
    background-color: var(--fa-counter-background-color, #ff253a);
    border-radius: var(--fa-counter-border-radius, 1em);
    box-sizing: border-box;
    color: var(--fa-inverse, #fff);
    line-height: var(--fa-counter-line-height, 1);
    max-width: var(--fa-counter-max-width, 5em);
    min-width: var(--fa-counter-min-width, 1.5em);
    overflow: hidden;
    padding: var(--fa-counter-padding, .25em .5em);
    right: var(--fa-right, 0);
    text-overflow: ellipsis;
    top: var(--fa-top, 0);
    -webkit-transform: scale(var(--fa-counter-scale, .25));
    transform: scale(var(--fa-counter-scale, .25));
    -webkit-transform-origin: top right;
    transform-origin: top right
}

.fa-layers-bottom-right {
    bottom: var(--fa-bottom, 0);
    right: var(--fa-right, 0);
    top: auto;
    -webkit-transform: scale(var(--fa-layers-scale, .25));
    transform: scale(var(--fa-layers-scale, .25));
    -webkit-transform-origin: bottom right;
    transform-origin: bottom right
}

.fa-layers-bottom-left {
    bottom: var(--fa-bottom, 0);
    left: var(--fa-left, 0);
    right: auto;
    top: auto;
    -webkit-transform: scale(var(--fa-layers-scale, .25));
    transform: scale(var(--fa-layers-scale, .25));
    -webkit-transform-origin: bottom left;
    transform-origin: bottom left
}

.fa-layers-top-right {
    top: var(--fa-top, 0);
    right: var(--fa-right, 0);
    -webkit-transform: scale(var(--fa-layers-scale, .25));
    transform: scale(var(--fa-layers-scale, .25));
    -webkit-transform-origin: top right;
    transform-origin: top right
}

.fa-layers-top-left {
    left: var(--fa-left, 0);
    right: auto;
    top: var(--fa-top, 0);
    -webkit-transform: scale(var(--fa-layers-scale, .25));
    transform: scale(var(--fa-layers-scale, .25));
    -webkit-transform-origin: top left;
    transform-origin: top left
}

.fa-1x {
    font-size: 1em
}

.fa-2x {
    font-size: 2em
}

.fa-3x {
    font-size: 3em
}

.fa-4x {
    font-size: 4em
}

.fa-5x {
    font-size: 5em
}

.fa-6x {
    font-size: 6em
}

.fa-7x {
    font-size: 7em
}

.fa-8x {
    font-size: 8em
}

.fa-9x {
    font-size: 9em
}

.fa-10x {
    font-size: 10em
}

.fa-2xs {
    font-size: .625em;
    line-height: .1em;
    vertical-align: .225em
}

.fa-xs {
    font-size: .75em;
    line-height: .0833333337em;
    vertical-align: .125em
}

.fa-sm {
    font-size: .875em;
    line-height: .0714285718em;
    vertical-align: .0535714295em
}

.fa-lg {
    font-size: 1.25em;
    line-height: .05em;
    vertical-align: -.075em
}

.fa-xl {
    font-size: 1.5em;
    line-height: .0416666682em;
    vertical-align: -.125em
}

.fa-2xl {
    font-size: 2em;
    line-height: .03125em;
    vertical-align: -.1875em
}

.fa-fw {
    text-align: center;
    width: 1.25em
}

.fa-ul {
    list-style-type: none;
    margin-left: var(--fa-li-margin, 2.5em);
    padding-left: 0
}

.fa-ul>li {
    position: relative
}

.fa-li {
    left: calc(var(--fa-li-width, 2em) * -1);
    position: absolute;
    text-align: center;
    width: var(--fa-li-width, 2em);
    line-height: inherit
}

.fa-border {
    border-color: var(--fa-border-color, #eee);
    border-radius: var(--fa-border-radius, .1em);
    border-style: var(--fa-border-style, solid);
    border-width: var(--fa-border-width, .08em);
    padding: var(--fa-border-padding, .2em .25em .15em)
}

.fa-pull-left {
    float: left;
    margin-right: var(--fa-pull-margin, .3em)
}

.fa-pull-right {
    float: right;
    margin-left: var(--fa-pull-margin, .3em)
}

.fa-beat {
    -webkit-animation-name: fa-beat;
    animation-name: fa-beat;
    -webkit-animation-delay: var(--fa-animation-delay, 0s);
    animation-delay: var(--fa-animation-delay, 0s);
    -webkit-animation-direction: var(--fa-animation-direction, normal);
    animation-direction: var(--fa-animation-direction, normal);
    -webkit-animation-duration: var(--fa-animation-duration, 1s);
    animation-duration: var(--fa-animation-duration, 1s);
    -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    -webkit-animation-timing-function: var(--fa-animation-timing, ease-in-out);
    animation-timing-function: var(--fa-animation-timing, ease-in-out)
}

.fa-bounce {
    -webkit-animation-name: fa-bounce;
    animation-name: fa-bounce;
    -webkit-animation-delay: var(--fa-animation-delay, 0s);
    animation-delay: var(--fa-animation-delay, 0s);
    -webkit-animation-direction: var(--fa-animation-direction, normal);
    animation-direction: var(--fa-animation-direction, normal);
    -webkit-animation-duration: var(--fa-animation-duration, 1s);
    animation-duration: var(--fa-animation-duration, 1s);
    -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    -webkit-animation-timing-function: var(--fa-animation-timing, cubic-bezier(.28, .84, .42, 1));
    animation-timing-function: var(--fa-animation-timing, cubic-bezier(.28, .84, .42, 1))
}

.fa-fade {
    -webkit-animation-name: fa-fade;
    animation-name: fa-fade;
    -webkit-animation-delay: var(--fa-animation-delay, 0s);
    animation-delay: var(--fa-animation-delay, 0s);
    -webkit-animation-direction: var(--fa-animation-direction, normal);
    animation-direction: var(--fa-animation-direction, normal);
    -webkit-animation-duration: var(--fa-animation-duration, 1s);
    animation-duration: var(--fa-animation-duration, 1s);
    -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    -webkit-animation-timing-function: var(--fa-animation-timing, cubic-bezier(.4, 0, .6, 1));
    animation-timing-function: var(--fa-animation-timing, cubic-bezier(.4, 0, .6, 1))
}

.fa-beat-fade {
    -webkit-animation-name: fa-beat-fade;
    animation-name: fa-beat-fade;
    -webkit-animation-delay: var(--fa-animation-delay, 0s);
    animation-delay: var(--fa-animation-delay, 0s);
    -webkit-animation-direction: var(--fa-animation-direction, normal);
    animation-direction: var(--fa-animation-direction, normal);
    -webkit-animation-duration: var(--fa-animation-duration, 1s);
    animation-duration: var(--fa-animation-duration, 1s);
    -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    -webkit-animation-timing-function: var(--fa-animation-timing, cubic-bezier(.4, 0, .6, 1));
    animation-timing-function: var(--fa-animation-timing, cubic-bezier(.4, 0, .6, 1))
}

.fa-flip {
    -webkit-animation-name: fa-flip;
    animation-name: fa-flip;
    -webkit-animation-delay: var(--fa-animation-delay, 0s);
    animation-delay: var(--fa-animation-delay, 0s);
    -webkit-animation-direction: var(--fa-animation-direction, normal);
    animation-direction: var(--fa-animation-direction, normal);
    -webkit-animation-duration: var(--fa-animation-duration, 1s);
    animation-duration: var(--fa-animation-duration, 1s);
    -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    -webkit-animation-timing-function: var(--fa-animation-timing, ease-in-out);
    animation-timing-function: var(--fa-animation-timing, ease-in-out)
}

.fa-shake {
    -webkit-animation-name: fa-shake;
    animation-name: fa-shake;
    -webkit-animation-delay: var(--fa-animation-delay, 0s);
    animation-delay: var(--fa-animation-delay, 0s);
    -webkit-animation-direction: var(--fa-animation-direction, normal);
    animation-direction: var(--fa-animation-direction, normal);
    -webkit-animation-duration: var(--fa-animation-duration, 1s);
    animation-duration: var(--fa-animation-duration, 1s);
    -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    -webkit-animation-timing-function: var(--fa-animation-timing, linear);
    animation-timing-function: var(--fa-animation-timing, linear)
}

.fa-spin {
    -webkit-animation-name: fa-spin;
    animation-name: fa-spin;
    -webkit-animation-delay: var(--fa-animation-delay, 0s);
    animation-delay: var(--fa-animation-delay, 0s);
    -webkit-animation-direction: var(--fa-animation-direction, normal);
    animation-direction: var(--fa-animation-direction, normal);
    -webkit-animation-duration: var(--fa-animation-duration, 2s);
    animation-duration: var(--fa-animation-duration, 2s);
    -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    -webkit-animation-timing-function: var(--fa-animation-timing, linear);
    animation-timing-function: var(--fa-animation-timing, linear)
}

.fa-spin-reverse {
    --fa-animation-direction: reverse
}

.fa-pulse,
.fa-spin-pulse {
    -webkit-animation-name: fa-spin;
    animation-name: fa-spin;
    -webkit-animation-direction: var(--fa-animation-direction, normal);
    animation-direction: var(--fa-animation-direction, normal);
    -webkit-animation-duration: var(--fa-animation-duration, 1s);
    animation-duration: var(--fa-animation-duration, 1s);
    -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    animation-iteration-count: var(--fa-animation-iteration-count, infinite);
    -webkit-animation-timing-function: var(--fa-animation-timing, steps(8));
    animation-timing-function: var(--fa-animation-timing, steps(8))
}

@media (prefers-reduced-motion:reduce) {

    .fa-beat,
    .fa-beat-fade,
    .fa-bounce,
    .fa-fade,
    .fa-flip,
    .fa-pulse,
    .fa-shake,
    .fa-spin,
    .fa-spin-pulse {
        -webkit-animation-delay: -1ms;
        animation-delay: -1ms;
        -webkit-animation-duration: 1ms;
        animation-duration: 1ms;
        -webkit-animation-iteration-count: 1;
        animation-iteration-count: 1;
        -webkit-transition-delay: 0s;
        transition-delay: 0s;
        -webkit-transition-duration: 0s;
        transition-duration: 0s
    }
}

@-webkit-keyframes fa-beat {

    0%,
    90% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }

    45% {
        -webkit-transform: scale(var(--fa-beat-scale, 1.25));
        transform: scale(var(--fa-beat-scale, 1.25))
    }
}

@keyframes fa-beat {

    0%,
    90% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }

    45% {
        -webkit-transform: scale(var(--fa-beat-scale, 1.25));
        transform: scale(var(--fa-beat-scale, 1.25))
    }
}

@-webkit-keyframes fa-bounce {
    0% {
        -webkit-transform: scale(1, 1) translateY(0);
        transform: scale(1, 1) translateY(0)
    }

    10% {
        -webkit-transform: scale(var(--fa-bounce-start-scale-x, 1.1), var(--fa-bounce-start-scale-y, .9)) translateY(0);
        transform: scale(var(--fa-bounce-start-scale-x, 1.1), var(--fa-bounce-start-scale-y, .9)) translateY(0)
    }

    30% {
        -webkit-transform: scale(var(--fa-bounce-jump-scale-x, .9), var(--fa-bounce-jump-scale-y, 1.1)) translateY(var(--fa-bounce-height, -.5em));
        transform: scale(var(--fa-bounce-jump-scale-x, .9), var(--fa-bounce-jump-scale-y, 1.1)) translateY(var(--fa-bounce-height, -.5em))
    }

    50% {
        -webkit-transform: scale(var(--fa-bounce-land-scale-x, 1.05), var(--fa-bounce-land-scale-y, .95)) translateY(0);
        transform: scale(var(--fa-bounce-land-scale-x, 1.05), var(--fa-bounce-land-scale-y, .95)) translateY(0)
    }

    57% {
        -webkit-transform: scale(1, 1) translateY(var(--fa-bounce-rebound, -.125em));
        transform: scale(1, 1) translateY(var(--fa-bounce-rebound, -.125em))
    }

    64% {
        -webkit-transform: scale(1, 1) translateY(0);
        transform: scale(1, 1) translateY(0)
    }

    100% {
        -webkit-transform: scale(1, 1) translateY(0);
        transform: scale(1, 1) translateY(0)
    }
}

@keyframes fa-bounce {
    0% {
        -webkit-transform: scale(1, 1) translateY(0);
        transform: scale(1, 1) translateY(0)
    }

    10% {
        -webkit-transform: scale(var(--fa-bounce-start-scale-x, 1.1), var(--fa-bounce-start-scale-y, .9)) translateY(0);
        transform: scale(var(--fa-bounce-start-scale-x, 1.1), var(--fa-bounce-start-scale-y, .9)) translateY(0)
    }

    30% {
        -webkit-transform: scale(var(--fa-bounce-jump-scale-x, .9), var(--fa-bounce-jump-scale-y, 1.1)) translateY(var(--fa-bounce-height, -.5em));
        transform: scale(var(--fa-bounce-jump-scale-x, .9), var(--fa-bounce-jump-scale-y, 1.1)) translateY(var(--fa-bounce-height, -.5em))
    }

    50% {
        -webkit-transform: scale(var(--fa-bounce-land-scale-x, 1.05), var(--fa-bounce-land-scale-y, .95)) translateY(0);
        transform: scale(var(--fa-bounce-land-scale-x, 1.05), var(--fa-bounce-land-scale-y, .95)) translateY(0)
    }

    57% {
        -webkit-transform: scale(1, 1) translateY(var(--fa-bounce-rebound, -.125em));
        transform: scale(1, 1) translateY(var(--fa-bounce-rebound, -.125em))
    }

    64% {
        -webkit-transform: scale(1, 1) translateY(0);
        transform: scale(1, 1) translateY(0)
    }

    100% {
        -webkit-transform: scale(1, 1) translateY(0);
        transform: scale(1, 1) translateY(0)
    }
}

@-webkit-keyframes fa-fade {
    50% {
        opacity: var(--fa-fade-opacity, .4)
    }
}

@keyframes fa-fade {
    50% {
        opacity: var(--fa-fade-opacity, .4)
    }
}

@-webkit-keyframes fa-beat-fade {

    0%,
    100% {
        opacity: var(--fa-beat-fade-opacity, .4);
        -webkit-transform: scale(1);
        transform: scale(1)
    }

    50% {
        opacity: 1;
        -webkit-transform: scale(var(--fa-beat-fade-scale, 1.125));
        transform: scale(var(--fa-beat-fade-scale, 1.125))
    }
}

@keyframes fa-beat-fade {

    0%,
    100% {
        opacity: var(--fa-beat-fade-opacity, .4);
        -webkit-transform: scale(1);
        transform: scale(1)
    }

    50% {
        opacity: 1;
        -webkit-transform: scale(var(--fa-beat-fade-scale, 1.125));
        transform: scale(var(--fa-beat-fade-scale, 1.125))
    }
}

@-webkit-keyframes fa-flip {
    50% {
        -webkit-transform: rotate3d(var(--fa-flip-x, 0), var(--fa-flip-y, 1), var(--fa-flip-z, 0), var(--fa-flip-angle, -180deg));
        transform: rotate3d(var(--fa-flip-x, 0), var(--fa-flip-y, 1), var(--fa-flip-z, 0), var(--fa-flip-angle, -180deg))
    }
}

@keyframes fa-flip {
    50% {
        -webkit-transform: rotate3d(var(--fa-flip-x, 0), var(--fa-flip-y, 1), var(--fa-flip-z, 0), var(--fa-flip-angle, -180deg));
        transform: rotate3d(var(--fa-flip-x, 0), var(--fa-flip-y, 1), var(--fa-flip-z, 0), var(--fa-flip-angle, -180deg))
    }
}

@-webkit-keyframes fa-shake {
    0% {
        -webkit-transform: rotate(-15deg);
        transform: rotate(-15deg)
    }

    4% {
        -webkit-transform: rotate(15deg);
        transform: rotate(15deg)
    }

    24%,
    8% {
        -webkit-transform: rotate(-18deg);
        transform: rotate(-18deg)
    }

    12%,
    28% {
        -webkit-transform: rotate(18deg);
        transform: rotate(18deg)
    }

    16% {
        -webkit-transform: rotate(-22deg);
        transform: rotate(-22deg)
    }

    20% {
        -webkit-transform: rotate(22deg);
        transform: rotate(22deg)
    }

    32% {
        -webkit-transform: rotate(-12deg);
        transform: rotate(-12deg)
    }

    36% {
        -webkit-transform: rotate(12deg);
        transform: rotate(12deg)
    }

    100%,
    40% {
        -webkit-transform: rotate(0);
        transform: rotate(0)
    }
}

@keyframes fa-shake {
    0% {
        -webkit-transform: rotate(-15deg);
        transform: rotate(-15deg)
    }

    4% {
        -webkit-transform: rotate(15deg);
        transform: rotate(15deg)
    }

    24%,
    8% {
        -webkit-transform: rotate(-18deg);
        transform: rotate(-18deg)
    }

    12%,
    28% {
        -webkit-transform: rotate(18deg);
        transform: rotate(18deg)
    }

    16% {
        -webkit-transform: rotate(-22deg);
        transform: rotate(-22deg)
    }

    20% {
        -webkit-transform: rotate(22deg);
        transform: rotate(22deg)
    }

    32% {
        -webkit-transform: rotate(-12deg);
        transform: rotate(-12deg)
    }

    36% {
        -webkit-transform: rotate(12deg);
        transform: rotate(12deg)
    }

    100%,
    40% {
        -webkit-transform: rotate(0);
        transform: rotate(0)
    }
}

@-webkit-keyframes fa-spin {
    0% {
        -webkit-transform: rotate(0);
        transform: rotate(0)
    }

    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg)
    }
}

@keyframes fa-spin {
    0% {
        -webkit-transform: rotate(0);
        transform: rotate(0)
    }

    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg)
    }
}

.fa-rotate-90 {
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg)
}

.fa-rotate-180 {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg)
}

.fa-rotate-270 {
    -webkit-transform: rotate(270deg);
    transform: rotate(270deg)
}

.fa-flip-horizontal {
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1)
}

.fa-flip-vertical {
    -webkit-transform: scale(1, -1);
    transform: scale(1, -1)
}

.fa-flip-both,
.fa-flip-horizontal.fa-flip-vertical {
    -webkit-transform: scale(-1, -1);
    transform: scale(-1, -1)
}

.fa-rotate-by {
    -webkit-transform: rotate(var(--fa-rotate-angle, none));
    transform: rotate(var(--fa-rotate-angle, none))
}

.fa-stack {
    display: inline-block;
    vertical-align: middle;
    height: 2em;
    position: relative;
    width: 2.5em
}

.fa-stack-1x,
.fa-stack-2x {
    bottom: 0;
    left: 0;
    margin: auto;
    position: absolute;
    right: 0;
    top: 0;
    z-index: var(--fa-stack-z-index, auto)
}

.svg-inline--fa.fa-stack-1x {
    height: 1em;
    width: 1.25em
}

.svg-inline--fa.fa-stack-2x {
    height: 2em;
    width: 2.5em
}

.fa-inverse {
    color: var(--fa-inverse, #fff)
}

.fa-sr-only,
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0
}

.fa-sr-only-focusable:not(:focus),
.sr-only-focusable:not(:focus) {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0
}

.svg-inline--fa .fa-primary {
    fill: var(--fa-primary-color, currentColor);
    opacity: var(--fa-primary-opacity, 1)
}

.svg-inline--fa .fa-secondary {
    fill: var(--fa-secondary-color, currentColor);
    opacity: var(--fa-secondary-opacity, .4)
}

.svg-inline--fa.fa-swap-opacity .fa-primary {
    opacity: var(--fa-secondary-opacity, .4)
}

.svg-inline--fa.fa-swap-opacity .fa-secondary {
    opacity: var(--fa-primary-opacity, 1)
}

.svg-inline--fa mask .fa-primary,
.svg-inline--fa mask .fa-secondary {
    fill: #000
}

.fa-duotone.fa-inverse,
.fad.fa-inverse {
    color: var(--fa-inverse, #fff)
}

*,
::before,
::after {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-pan-x: ;
    --tw-pan-y: ;
    --tw-pinch-zoom: ;
    --tw-scroll-snap-strictness: proximity;
    --tw-gradient-from-position: ;
    --tw-gradient-via-position: ;
    --tw-gradient-to-position: ;
    --tw-ordinal: ;
    --tw-slashed-zero: ;
    --tw-numeric-figure: ;
    --tw-numeric-spacing: ;
    --tw-numeric-fraction: ;
    --tw-ring-inset: ;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgb(59 130 246 / 0.5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur: ;
    --tw-brightness: ;
    --tw-contrast: ;
    --tw-grayscale: ;
    --tw-hue-rotate: ;
    --tw-invert: ;
    --tw-saturate: ;
    --tw-sepia: ;
    --tw-drop-shadow: ;
    --tw-backdrop-blur: ;
    --tw-backdrop-brightness: ;
    --tw-backdrop-contrast: ;
    --tw-backdrop-grayscale: ;
    --tw-backdrop-hue-rotate: ;
    --tw-backdrop-invert: ;
    --tw-backdrop-opacity: ;
    --tw-backdrop-saturate: ;
    --tw-backdrop-sepia: ;
    --tw-contain-size: ;
    --tw-contain-layout: ;
    --tw-contain-paint: ;
    --tw-contain-style:
}

::backdrop {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-pan-x: ;
    --tw-pan-y: ;
    --tw-pinch-zoom: ;
    --tw-scroll-snap-strictness: proximity;
    --tw-gradient-from-position: ;
    --tw-gradient-via-position: ;
    --tw-gradient-to-position: ;
    --tw-ordinal: ;
    --tw-slashed-zero: ;
    --tw-numeric-figure: ;
    --tw-numeric-spacing: ;
    --tw-numeric-fraction: ;
    --tw-ring-inset: ;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgb(59 130 246 / 0.5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur: ;
    --tw-brightness: ;
    --tw-contrast: ;
    --tw-grayscale: ;
    --tw-hue-rotate: ;
    --tw-invert: ;
    --tw-saturate: ;
    --tw-sepia: ;
    --tw-drop-shadow: ;
    --tw-backdrop-blur: ;
    --tw-backdrop-brightness: ;
    --tw-backdrop-contrast: ;
    --tw-backdrop-grayscale: ;
    --tw-backdrop-hue-rotate: ;
    --tw-backdrop-invert: ;
    --tw-backdrop-opacity: ;
    --tw-backdrop-saturate: ;
    --tw-backdrop-sepia: ;
    --tw-contain-size: ;
    --tw-contain-layout: ;
    --tw-contain-paint: ;
    --tw-contain-style:
}

/* ! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com */
*,
::after,
::before {
    box-sizing: border-box;
    border-width: 0;
    border-style: solid;
    border-color: #e5e7eb
}

::after,
::before {
    --tw-content: ''
}

:host,
html {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    -moz-tab-size: 4;
    tab-size: 4;
    font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    font-feature-settings: normal;
    font-variation-settings: normal;
    -webkit-tap-highlight-color: transparent
}

body {
    margin: 0;
    line-height: inherit
}

hr {
    height: 0;
    color: inherit;
    border-top-width: 1px
}

abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-size: inherit;
    font-weight: inherit
}

a {
    color: inherit;
    text-decoration: inherit
}

b,
strong {
    font-weight: bolder
}

code,
kbd,
pre,
samp {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-feature-settings: normal;
    font-variation-settings: normal;
    font-size: 1em
}

small {
    font-size: 80%
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse
}

button,
input,
optgroup,
select,
textarea {
    font-family: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    font-size: 100%;
    font-weight: inherit;
    line-height: inherit;
    letter-spacing: inherit;
    color: inherit;
    margin: 0;
    padding: 0
}

button,
select {
    text-transform: none
}

button,
input:where([type=button]),
input:where([type=reset]),
input:where([type=submit]) {
    -webkit-appearance: button;
    appearance: button;
    background-color: transparent;
    background-image: none
}

:-moz-focusring {
    outline: auto
}

:-moz-ui-invalid {
    box-shadow: none
}

progress {
    vertical-align: baseline
}

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    appearance: textfield;
    outline-offset: -2px
}

::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

summary {
    display: list-item
}

blockquote,
dd,
dl,
figure,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
p,
pre {
    margin: 0
}

fieldset {
    margin: 0;
    padding: 0
}

legend {
    padding: 0
}

menu,
ol,
ul {
    list-style: none;
    margin: 0;
    padding: 0
}

dialog {
    padding: 0
}

textarea {
    resize: vertical
}

input::placeholder,
textarea::placeholder {
    opacity: 1;
    color: #9ca3af
}

[role=button],
button {
    cursor: pointer
}

:disabled {
    cursor: default
}

audio,
canvas,
embed,
iframe,
img,
object,
svg,
video {
    display: block;
    vertical-align: middle
}

img,
video {
    max-width: 100%;
    height: auto
}

[hidden]:where(:not([hidden=until-found])) {
    display: none
}

.container {
    width: 100%
}

@media (min-width: 640px) {
    .container {
        max-width: 640px
    }
}

@media (min-width: 768px) {
    .container {
        max-width: 768px
    }
}

@media (min-width: 1024px) {
    .container {
        max-width: 1024px
    }
}

@media (min-width: 1280px) {
    .container {
        max-width: 1280px
    }
}

@media (min-width: 1536px) {
    .container {
        max-width: 1536px !important
    }
}

.absolute {
    position: absolute
}

.relative {
    position: relative
}

.sticky {
    position: sticky
}

.inset-0 {
    inset: 0px
}

.-bottom-4 {
    bottom: -1rem
}

.-bottom-8 {
    bottom: -2rem
}

.-left-4 {
    left: -1rem
}

.-left-8 {
    left: -2rem
}

.-right-2 {
    right: -0.5rem
}

.-right-8 {
    right: -2rem
}

.-top-2 {
    top: -0.5rem
}

.-top-8 {
    top: -2rem
}

.bottom-0 {
    bottom: 0px
}

.left-0 {
    left: 0px
}

.left-3 {
    left: 0.75rem
}

.left-4 {
    left: 1rem
}

.right-0 {
    right: 0px
}

.right-3 {
    right: 0.75rem
}

.right-4 {
    right: 1rem
}

.right-5 {
    right: 1.25rem
}

.top-0 {
    top: 0px
}

.top-1\/2 {
    top: 50%
}

.top-12 {
    top: 3rem
}

.top-3 {
    top: 0.75rem
}

.-z-10 {
    z-index: -10
}

.z-10 {
    z-index: 10
}

.z-50 {
    z-index: 50
}

.order-1 {
    order: 1
}

.order-2 {
    order: 2
}

.mx-auto {
    margin-left: auto;
    margin-right: auto
}

.-mt-6 {
    margin-top: -1.5rem
}

.mb-1 {
    margin-bottom: 0.25rem
}

.mb-10 {
    margin-bottom: 2.5rem
}

.mb-12 {
    margin-bottom: 3rem
}

.mb-16 {
    margin-bottom: 4rem
}

.mb-2 {
    margin-bottom: 0.5rem
}

.mb-3 {
    margin-bottom: 0.75rem
}

.mb-4 {
    margin-bottom: 1rem
}

.mb-6 {
    margin-bottom: 1.5rem
}

.mb-8 {
    margin-bottom: 2rem
}

.ml-2 {
    margin-left: 0.5rem
}

.mr-1 {
    margin-right: 0.25rem
}

.mr-2 {
    margin-right: 0.5rem
}

.mt-10 {
    margin-top: 2.5rem
}

.mt-12 {
    margin-top: 3rem
}

.mt-4 {
    margin-top: 1rem
}

.mt-6 {
    margin-top: 1.5rem
}

.mt-8 {
    margin-top: 2rem
}

.line-clamp-2 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
}

.flex {
    display: flex
}

.inline-flex {
    display: inline-flex
}

.grid {
    display: grid
}

.hidden {
    display: none
}

.h-0\.5 {
    height: 0.125rem
}

.h-10 {
    height: 2.5rem
}

.h-12 {
    height: 3rem
}

.h-16 {
    height: 4rem
}

.h-20 {
    height: 5rem
}

.h-24 {
    height: 6rem
}

.h-48 {
    height: 12rem
}

.h-5 {
    height: 1.25rem
}

.h-56 {
    height: 14rem
}

.h-72 {
    height: 18rem
}

.h-8 {
    height: 2rem
}

.h-96 {
    height: 24rem
}

.h-\[680px\] {
    height: 680px
}

.h-full {
    height: 100%
}

.w-10 {
    width: 2.5rem
}

.w-12 {
    width: 3rem
}

.w-16 {
    width: 4rem
}

.w-20 {
    width: 5rem
}

.w-24 {
    width: 6rem
}

.w-5 {
    width: 1.25rem
}

.w-72 {
    width: 18rem
}

.w-8 {
    width: 2rem
}

.w-96 {
    width: 24rem
}

.w-full {
    width: 100%
}

.max-w-4xl {
    max-width: 56rem
}

.max-w-xs {
    max-width: 20rem
}

.flex-1 {
    flex: 1 1 0%
}

.flex-shrink-0 {
    flex-shrink: 0
}

.-translate-x-1\/2 {
    --tw-translate-x: -50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.-translate-y-1\/2 {
    --tw-translate-y: -50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.translate-x-1\/2 {
    --tw-translate-x: 50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.translate-y-1\/2 {
    --tw-translate-y: 50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.cursor-pointer {
    cursor: pointer
}

.appearance-none {
    -webkit-appearance: none;
    appearance: none
}

.grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr))
}

.md\:grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr))
}

.grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr))
}

.flex-col {
    flex-direction: column
}

.items-start {
    align-items: flex-start
}

.items-center {
    align-items: center
}

.justify-end {
    justify-content: flex-end
}

.justify-center {
    justify-content: center
}

.justify-between {
    justify-content: space-between
}

.gap-1 {
    gap: 0.25rem
}

.gap-12 {
    gap: 3rem
}

.gap-2 {
    gap: 0.5rem
}

.gap-3 {
    gap: 0.75rem
}

.gap-4 {
    gap: 1rem
}

.gap-6 {
    gap: 1.5rem
}

.gap-8 {
    gap: 2rem
}

.space-y-2> :not([hidden])~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(0.5rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(0.5rem * var(--tw-space-y-reverse))
}

.space-y-3> :not([hidden])~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(0.75rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(0.75rem * var(--tw-space-y-reverse))
}

.space-y-4> :not([hidden])~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(1rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1rem * var(--tw-space-y-reverse))
}

.space-y-6> :not([hidden])~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1.5rem * var(--tw-space-y-reverse))
}

.space-y-8> :not([hidden])~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(2rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(2rem * var(--tw-space-y-reverse))
}

.overflow-hidden {
    overflow: hidden
}

.rounded-2xl {
    border-radius: 1rem
}

.rounded-3xl {
    border-radius: 1.5rem
}

.rounded-full {
    border-radius: 9999px
}

.rounded-lg {
    border-radius: 0.5rem
}

.rounded-xl {
    border-radius: 0.75rem
}

.rounded-tl-sm {
    border-top-left-radius: 0.125rem
}

.rounded-tr-sm {
    border-top-right-radius: 0.125rem
}

.border {
    border-width: 1px
}

.border-2 {
    border-width: 2px
}

.border-t {
    border-top-width: 1px
}

.border-accent {
    --tw-border-opacity: 1;
    border-color: rgb(var(--color-accent-rgb) / var(--tw-border-opacity, 1))
}

.border-gray-100 {
    --tw-border-opacity: 1;
    border-color: rgb(var(--color-gray-100-rgb) / var(--tw-border-opacity, 1))
}

.border-gray-200 {
    --tw-border-opacity: 1;
    border-color: rgb(var(--color-gray-200-rgb) / var(--tw-border-opacity, 1))
}

.border-gray-800 {
    --tw-border-opacity: 1;
    border-color: rgb(var(--color-gray-800-rgb) / var(--tw-border-opacity, 1))
}

.border-primary {
    --tw-border-opacity: 1;
    border-color: rgb(var(--color-primary-rgb) / var(--tw-border-opacity, 1))
}

.border-secondary {
    --tw-border-opacity: 1;
    border-color: rgb(var(--color-secondary-rgb) / var(--tw-border-opacity, 1))
}

.border-success {
    --tw-border-opacity: 1;
    border-color: rgb(var(--color-success-rgb) / var(--tw-border-opacity, 1))
}

.border-white\/50 {
    border-color: rgb(255 255 255 / 0.5)
}

.bg-gray-50 {
    --tw-bg-opacity: 1;
    background-color: rgb(var(--color-gray-50-rgb) / var(--tw-bg-opacity, 1))
}

.bg-accent\/20 {
    background-color: rgb(var(--color-accent-rgb) / 0.2)
}

.bg-accent\/5 {
    background-color: rgb(var(--color-accent-rgb) / 0.05)
}

.bg-blue-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(219 234 254 / var(--tw-bg-opacity, 1))
}

.bg-dark {
    --tw-bg-opacity: 1;
    background-color: rgb(var(--color-dark-rgb) / var(--tw-bg-opacity, 1))
}

.bg-gray-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(var(--color-gray-100-rgb) / var(--tw-bg-opacity, 1))
}

.bg-gray-800 {
    --tw-bg-opacity: 1;
    background-color: rgb(var(--color-gray-800-rgb) / var(--tw-bg-opacity, 1))
}

.bg-green-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(220 252 231 / var(--tw-bg-opacity, 1))
}

.bg-green-500 {
    --tw-bg-opacity: 1;
    background-color: rgb(34 197 94 / var(--tw-bg-opacity, 1))
}

.bg-primary {
    --tw-bg-opacity: 1;
    background-color: rgb(var(--color-primary-rgb) / var(--tw-bg-opacity, 1)) !important;
}

.bg-primary\/10 {
    background-color: rgb(var(--color-primary-rgb) / 0.1)
}

.bg-primary\/20 {
    background-color: rgb(var(--color-primary-rgb) / 0.2)
}

.bg-primary\/5 {
    background-color: rgb(var(--color-primary-rgb) / 0.05)
}

.bg-purple-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(243 232 255 / var(--tw-bg-opacity, 1))
}

.bg-red-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(254 226 226 / var(--tw-bg-opacity, 1))
}

.bg-red-500 {
    --tw-bg-opacity: 1;
    background-color: rgb(239 68 68 / var(--tw-bg-opacity, 1))
}

.bg-secondary {
    --tw-bg-opacity: 1;
    background-color: rgb(var(--color-secondary-rgb) / var(--tw-bg-opacity, 1))
}

.bg-secondary\/10 {
    background-color: rgb(var(--color-secondary-rgb) / 0.1)
}

.bg-secondary\/20 {
    background-color: rgb(var(--color-secondary-rgb) / 0.2)
}

.bg-secondary\/5 {
    background-color: rgb(var(--color-secondary-rgb) / 0.05)
}

.bg-success {
    --tw-bg-opacity: 1;
    background-color: rgb(var(--color-success-rgb) / var(--tw-bg-opacity, 1))
}

.bg-success\/10 {
    background-color: rgb(var(--color-success-rgb) / 0.1)
}

.bg-success\/20 {
    background-color: rgb(var(--color-success-rgb) / 0.2)
}

.bg-success\/5 {
    background-color: rgb(var(--color-success-rgb) / 0.05)
}

.bg-white {
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1))
}

.bg-white\/20 {
    background-color: rgb(255 255 255 / 0.2)
}

.bg-white\/90 {
    background-color: rgb(255 255 255 / 0.9)
}

.bg-gradient-to-bl {
    background-image: linear-gradient(to bottom left, var(--tw-gradient-stops))
}

.bg-gradient-to-br {
    background-image: linear-gradient(to bottom right, var(--tw-gradient-stops))
}

.from-blue-50 {
    --tw-gradient-from: #eff6ff var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(239 246 255 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-green-50 {
    --tw-gradient-from: #f0fdf4 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(240 253 244 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-indigo-50 {
    --tw-gradient-from: #eef2ff var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(238 242 255 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-orange-50 {
    --tw-gradient-from: #fff7ed var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(255 247 237 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-pink-50 {
    --tw-gradient-from: #fdf2f8 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(253 242 248 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-primary {
    --tw-gradient-from: #6366f1 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(99 102 241 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-primary\/10 {
    --tw-gradient-from: rgb(99 102 241 / 0.1) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(99 102 241 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-primary\/5 {
    --tw-gradient-from: rgb(99 102 241 / 0.05) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(99 102 241 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-purple-50 {
    --tw-gradient-from: #faf5ff var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(250 245 255 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-red-50 {
    --tw-gradient-from: #fef2f2 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(254 242 242 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-yellow-50 {
    --tw-gradient-from: #fefce8 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(254 252 232 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.via-indigo-600 {
    --tw-gradient-to: rgb(79 70 229 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #4f46e5 var(--tw-gradient-via-position), var(--tw-gradient-to)
}

.via-secondary\/5 {
    --tw-gradient-to: rgb(236 72 153 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), rgb(236 72 153 / 0.05) var(--tw-gradient-via-position), var(--tw-gradient-to)
}

.to-accent\/10 {
    --tw-gradient-to: rgb(245 158 11 / 0.1) var(--tw-gradient-to-position)
}

.to-accent\/5 {
    --tw-gradient-to: rgb(245 158 11 / 0.05) var(--tw-gradient-to-position)
}

.to-blue-100 {
    --tw-gradient-to: #dbeafe var(--tw-gradient-to-position)
}

.to-green-100 {
    --tw-gradient-to: #dcfce7 var(--tw-gradient-to-position)
}

.to-indigo-100 {
    --tw-gradient-to: #e0e7ff var(--tw-gradient-to-position)
}

.to-orange-100 {
    --tw-gradient-to: #ffedd5 var(--tw-gradient-to-position)
}

.to-pink-100 {
    --tw-gradient-to: #fce7f3 var(--tw-gradient-to-position)
}

.to-purple-100 {
    --tw-gradient-to: #f3e8ff var(--tw-gradient-to-position)
}

.to-red-100 {
    --tw-gradient-to: #fee2e2 var(--tw-gradient-to-position)
}

.to-secondary {
    --tw-gradient-to: #ec4899 var(--tw-gradient-to-position)
}

.to-yellow-100 {
    --tw-gradient-to: #fef9c3 var(--tw-gradient-to-position)
}

.object-cover {
    object-fit: cover
}

.p-3 {
    padding: 0.75rem
}

.p-4 {
    padding: 1rem
}

.p-5 {
    padding: 1.25rem
}

.p-6 {
    padding: 1.5rem
}

.p-8 {
    padding: 2rem
}

.px-10 {
    padding-left: 2.5rem;
    padding-right: 2.5rem
}

.px-2 {
    padding-left: 0.5rem;
    padding-right: 0.5rem
}

.px-3 {
    padding-left: 0.75rem;
    padding-right: 0.75rem
}

.px-4 {
    padding-left: 1rem;
    padding-right: 1rem
}

.px-6 {
    padding-left: 1.5rem;
    padding-right: 1.5rem
}

.px-8 {
    padding-left: 2rem;
    padding-right: 2rem
}

.py-1 {
    padding-top: 0.25rem;
    padding-bottom: 0.25rem
}

.py-1\.5 {
    padding-top: 0.375rem;
    padding-bottom: 0.375rem
}

.py-16 {
    padding-top: 4rem;
    padding-bottom: 4rem
}

.py-2 {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem
}

.py-2\.5 {
    padding-top: 0.625rem;
    padding-bottom: 0.625rem
}

.py-20 {
    padding-top: 5rem;
    padding-bottom: 5rem
}

.py-3 {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem
}

.py-4 {
    padding-top: 1rem;
    padding-bottom: 1rem
}

.py-5 {
    padding-top: 1.25rem;
    padding-bottom: 1.25rem
}

.pb-8 {
    padding-bottom: 2rem
}

.pr-11 {
    padding-right: 2.75rem
}

.pr-14 {
    padding-right: 3.5rem
}

.pt-16 {
    padding-top: 4rem
}

.pt-4 {
    padding-top: 1rem
}

.pt-8 {
    padding-top: 2rem
}

.text-center {
    text-align: center
}

.text-2xl {
    font-size: 1.5rem;
    line-height: 2rem
}

.text-3xl {
    font-size: 1.875rem;
    line-height: 2.25rem
}

.text-4xl {
    font-size: 2.25rem;
    line-height: 2.5rem
}

.text-5xl {
    font-size: 3rem;
    line-height: 1
}

.text-lg {
    font-size: 1.125rem;
    line-height: 1.75rem
}

.text-sm {
    font-size: 0.875rem;
    line-height: 1.25rem
}

.text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem
}

.text-xs {
    font-size: 0.75rem;
    line-height: 1rem
}

.font-black {
    font-weight: 900
}

.font-bold {
    font-weight: 700
}

.font-medium {
    font-weight: 500
}

.leading-relaxed {
    line-height: 1.625
}

.leading-tight {
    line-height: 1.25
}

.text-accent {
    --tw-text-opacity: 1;
    color: rgb(var(--color-accent-rgb) / var(--tw-text-opacity, 1))
}

.text-blue-500 {
    --tw-text-opacity: 1;
    color: rgb(var(--color-blue-500-rgb) / var(--tw-text-opacity, 1))
}

.text-blue-700 {
    --tw-text-opacity: 1;
    color: rgb(29 78 216 / var(--tw-text-opacity, 1))
}

.text-dark {
    --tw-text-opacity: 1;
    color: rgb(var(--color-dark-rgb) / var(--tw-text-opacity, 1))
}

.text-gray-300 {
    --tw-text-opacity: 1;
    color: rgb(var(--color-gray-300-rgb) / var(--tw-text-opacity, 1))
}

.text-gray-400 {
    --tw-text-opacity: 1;
    color: rgb(var(--color-gray-400-rgb) / var(--tw-text-opacity, 1))
}

.text-gray-500 {
    --tw-text-opacity: 1;
    color: rgb(var(--color-gray-500-rgb) / var(--tw-text-opacity, 1))
}

.text-gray-600 {
    --tw-text-opacity: 1;
    color: rgb(var(--color-gray-600-rgb) / var(--tw-text-opacity, 1))
}

.text-gray-700 {
    --tw-text-opacity: 1;
    color: rgb(var(--color-gray-700-rgb) / var(--tw-text-opacity, 1))
}

.text-green-500 {
    --tw-text-opacity: 1;
    color: rgb(var(--color-green-500-rgb) / var(--tw-text-opacity, 1))
}

.text-green-700 {
    --tw-text-opacity: 1;
    color: rgb(21 128 61 / var(--tw-text-opacity, 1))
}

.text-indigo-500 {
    --tw-text-opacity: 1;
    color: rgb(var(--color-blue-600-rgb) / var(--tw-text-opacity, 1))
}

.text-orange-500 {
    --tw-text-opacity: 1;
    color: rgb(249 115 22 / var(--tw-text-opacity, 1))
}

.text-pink-500 {
    --tw-text-opacity: 1;
    color: rgb(var(--color-secondary-rgb) / var(--tw-text-opacity, 1))
}

.text-primary {
    --tw-text-opacity: 1;
    color: rgb(var(--color-primary-rgb) / var(--tw-text-opacity, 1))
}

.nida-text-primary {
    --tw-text-opacity: 1;
    color: rgb(var(--color-primary-rgb) / var(--tw-text-opacity, 1)) !important;
}

.hover\:nida-text-primary:hover {
    --tw-text-opacity: 1;
    color: rgb(var(--color-primary-rgb) / var(--tw-text-opacity, 1)) !important;
}

.text-purple-500 {
    --tw-text-opacity: 1;
    color: rgb(168 85 247 / var(--tw-text-opacity, 1))
}

.text-purple-700 {
    --tw-text-opacity: 1;
    color: rgb(126 34 206 / var(--tw-text-opacity, 1))
}

.text-red-500 {
    --tw-text-opacity: 1;
    color: rgb(var(--color-red-500-rgb) / var(--tw-text-opacity, 1))
}

.text-red-700 {
    --tw-text-opacity: 1;
    color: rgb(185 28 28 / var(--tw-text-opacity, 1))
}

.text-secondary {
    --tw-text-opacity: 1;
    color: rgb(var(--color-secondary-rgb) / var(--tw-text-opacity, 1))
}

.text-success {
    --tw-text-opacity: 1;
    color: rgb(var(--color-success-rgb) / var(--tw-text-opacity, 1))
}

.text-white {
    --tw-text-opacity: 1;
    color: rgb(var(--color-white-rgb) / var(--tw-text-opacity, 1))
}

.text-white\/80 {
    color: rgb(var(--color-white-rgb) / 0.8)
}

.text-white\/90 {
    color: rgb(var(--color-white-rgb) / 0.9)
}

.text-yellow-400 {
    --tw-text-opacity: 1;
    color: rgb(250 204 21 / var(--tw-text-opacity, 1))
}


.opacity-10 {
    opacity: 0.1
}

.shadow-2xl {
    --tw-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);
    --tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)
}

.shadow-lg {
    --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)
}

.shadow-sm {
    --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)
}

.shadow-xl {
    --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)
}

.shadow-primary\/30 {
    --tw-shadow-color: rgb(var(--color-primary-rgb) / 0.3);
    --tw-shadow: var(--tw-shadow-colored)
}

.blur-3xl {
    --tw-blur: blur(64px);
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)
}

.backdrop-blur-sm {
    --tw-backdrop-blur: blur(4px);
    -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)
}

.transition-all {
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms
}

.transition-colors {
    transition-property: color, background-color, border-color, fill, stroke, -webkit-text-decoration-color;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, -webkit-text-decoration-color;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms
}

.transition-transform {
    transition-property: transform;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms
}

.duration-500 {
    transition-duration: 500ms
}

.hover\:border-primary:hover {
    --tw-border-opacity: 1;
    border-color: rgb(var(--color-primary-rgb) / var(--tw-border-opacity, 1))
}

.hover\:bg-accent\/10:hover {
    background-color: rgb(var(--color-accent-rgb) / 0.1)
}

.hover\:bg-gray-100:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(var(--color-gray-100-rgb) / var(--tw-bg-opacity, 1))
}

.hover\:bg-gray-200:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(var(--color-gray-200-rgb) / var(--tw-bg-opacity, 1))
}

.hover\:bg-indigo-700:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(67 56 202 / var(--tw-bg-opacity, 1)) !important;
}

.hover\:bg-primary:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(var(--color-primary-rgb) / var(--tw-bg-opacity, 1))
}

.hover\:bg-primary\/10:hover {
    background-color: rgb(var(--color-primary-rgb) / 0.1)
}

.hover\:bg-secondary\/10:hover {
    background-color: rgb(var(--color-secondary-rgb) / 0.1)
}

.hover\:bg-success\/10:hover {
    background-color: rgb(var(--color-success-rgb) / 0.1)
}

.hover\:bg-white:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(var(--color-white-rgb) / var(--tw-bg-opacity, 1))
}

.hover\:bg-white\/30:hover {
    background-color: rgb(var(--color-white-rgb) / 0.3)
}

.hover\:text-indigo-700:hover {
    --tw-text-opacity: 1;
    color: rgb(67 56 202 / var(--tw-text-opacity, 1))
}

.hover\:text-primary:hover {
    --tw-text-opacity: 1;
    color: rgb(var(--color-primary-rgb) / var(--tw-text-opacity, 1))
}

.hover\:text-white:hover {
    --tw-text-opacity: 1;
    color: rgb(var(--color-white-rgb) / var(--tw-text-opacity, 1))
}

.hover\:shadow-2xl:hover {
    --tw-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);
    --tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)
}

.hover\:shadow-xl:hover {
    --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)
}

.focus\:border-primary:focus {
    --tw-border-opacity: 1;
    border-color: rgb(var(--color-primary-rgb) / var(--tw-border-opacity, 1))
}

.focus\:outline-none:focus {
    outline: 2px solid transparent;
    outline-offset: 2px
}

.group:hover .group-hover\:scale-110 {
    --tw-scale-x: 1.1;
    --tw-scale-y: 1.1;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

@media (min-width: 640px) {
    .sm\:w-auto {
        width: auto
    }

    .sm\:flex-row {
        flex-direction: row
    }
}

@media (min-width: 768px) {
    .md\:block {
        display: block
    }

    .md\:flex {
        display: flex
    }

    .md\:hidden {
        display: none
    }

    .md\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr))
    }

    .md\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr))
    }

    .md\:grid-cols-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr))
    }

    .md\:flex-row {
        flex-direction: row
    }

    #featured-ads-section .h-280px {
        height: 280px !important;
    }

    #featured-ads-section .h-275px {
        height: 275px !important;
    }

    /* Featured Ads Section - Desktop Styles */
    #featured-ads-section .desktop-height {
        height: 550px !important;
    }

    @media (max-width: 768px) {
        #featured-ads-section .mobile-height {
            height: 275px !important;
        }
    }

    #featured-ads-section .p-1\.5 {
        padding: 1.25rem !important;
    }

    #featured-ads-section h3.text-\[11px\] {
        font-size: 1.125rem !important;
    }

    #featured-ads-section .text-xs {
        font-size: 0.875rem !important;
    }

    #featured-ads-section .text-\[9px\] {
        font-size: 0.75rem !important;
    }

    #featured-ads-section .text-sm {
        font-size: 0.875rem !important;
    }

    #featured-ads-section .rounded-lg {
        border-radius: 1rem !important;
    }

    #featured-ads-section .grid {
        gap: 1.5rem !important;
    }
}

@media (min-width: 1024px) {
    .lg\:order-1 {
        order: 1
    }

    .lg\:order-2 {
        order: 2
    }

    .lg\:col-span-2 {
        grid-column: span 2 / span 2
    }

    .lg\:block {
        display: block
    }

    .lg\:flex {
        display: flex
    }

    .lg\:hidden {
        display: none
    }

    .lg\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr))
    }

    .lg\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr))
    }

    .lg\:grid-cols-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr))
    }

    .lg\:grid-cols-5 {
        grid-template-columns: repeat(5, minmax(0, 1fr))
    }

    .lg\:grid-cols-8 {
        grid-template-columns: repeat(8, minmax(0, 1fr))
    }

    .lg\:text-5xl {
        font-size: 3rem;
        line-height: 1
    }

    .lg\:text-6xl {
        font-size: 3.75rem;
        line-height: 1
    }
}

/* --------------------------------------------------------------------------------- */

/* 
.nida-primary-bg {
    background-color: var(--color-primary);
}

.bg-primary {
    background-color: var(--color-primary);
}

.bg-secondary {
    background-color: var(--color-secondary);
}

.bg-accent {
    background-color: var(--color-accent);
}

.bg-primary\/5 {
    background-color: rgb(var(--color-primary-rgb) / 0.05);
}

.bg-primary\/10 {
    background-color: rgb(var(--color-primary-rgb) / 0.1);
}

.bg-primary\/20 {
    background-color: rgb(var(--color-primary-rgb) / 0.2);
}

.bg-secondary\/5 {
    background-color: rgb(var(--color-secondary-rgb) / 0.05);
}

.bg-secondary\/10 {
    background-color: rgb(var(--color-secondary-rgb) / 0.1);
}

.bg-secondary\/20 {
    background-color: rgb(var(--color-secondary-rgb) / 0.2);
}

.bg-accent\/5 {
    background-color: rgb(var(--color-accent-rgb) / 0.05);
}

.bg-accent\/10 {
    background-color: rgb(var(--color-accent-rgb) / 0.1);
}

.bg-accent\/20 {
    background-color: rgb(var(--color-accent-rgb) / 0.2);
}

.bg-success\/10 {
    background-color: rgb(var(--color-success-rgb) / 0.1);
}

.bg-success\/20 {
    background-color: rgb(var(--color-success-rgb) / 0.2);
}

.bg-success\/5 {
    background-color: rgb(var(--color-success-rgb) / 0.05);
}

.text-primary {
    color: var(--color-primary);
}

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

.text-accent {
    color: var(--color-accent);
}

.text-success {
    color: var(--color-success);
}

.text-orange-500 {
    color: rgb(249 115 22);
}

.from-orange-50 {
    background-color: rgb(255 243 224 / 0.5);
}

.text-orange-100 {
    color: rgb(249 115 22 / 1);
}

.border-primary {
    border-color: var(--color-primary);
}

.from-primary\/10 {
    background-color: rgb(var(--color-primary-rgb) / 0.1);
}

.via-secondary\/5 {
    background-color: rgb(var(--color-secondary-rgb) / 0.05);
}

.to-accent\/10 {
    background-color: rgb(var(--color-accent-rgb) / 0.1);
}

.border-secondary {
    border-color: var(--color-secondary);
}

.border-accent {
    border-color: var(--color-accent);
} */

.nida-menu a {
    color: var(--color-white);
    transition: color .2s ease;
}

#header-menu {
    width: 880px;
    display: flex;
    position: relative;
}

.nida-logo-full {
    background: white;
    position: absolute;
    top: 0;
    right: 0;
    padding: 7px 0px 7px 29px;
    border-radius: 50px;
}



.mna4h-nida {
    border-radius: 50px;
    position: absolute;
    left: -84px;
    top: 50%;
    transform: translateY(-50%);
}

.nida-menu #menu-menu a:hover {
    color: rgb(67 56 202 / var(--tw-bg-opacity, 1)) !important;

}

@media(max-width:768px) {
    .top-flex-nav {
        gap: 20px;
    }

}

@media(min-width:768px) {
    .top-flex-nav {
        width: 70%;
    }

    nav.nida-menu {
        background: linear-gradient(180deg, #1E293B 0%, #0f172a 100%);
        width: 100%;
        border-radius: 50px;
        padding: 15px;
        padding-right: 110px;
        margin-right: 20px;
    }
}

.nida-menu #menu-menu a:focus {
    color: rgb(67 56 202 / var(--tw-bg-opacity, 1)) !important;
}

body:has(.nida-menu) #sb_loading {
    display: none;
}

#nida-province-wrapper {
    cursor: pointer;
    font-size: 16px;
    transition: all 0.2s ease;
}

@media (max-width: 768px) {
    #nida-province-wrapper {
        font-size: 14px;
        line-height: 19px !important;
    }

    .sml-hidden {
        display: none;
    }
}

#nida-province-wrapper:hover i.text-primary svg {
    font-size: 17px;
    transition: all 0.2s ease;
}

#nida-province-wrapper:hover i.svg-inline--fa.fa-chevron-down {
    transform: rotate(180deg);
    transition: all 0.2s ease;
}

#nida-province-wrapper:hover i.svg-inline--fa.fa-chevron-up {
    transform: rotate(0deg);
    transition: all 0.2s ease;
}

/* انتخابگر محل بهبود یافته */
.location-selector-wrapper {
    position: relative;
}

.location-selector {
    position: relative;
}

.location-input-wrapper {
    position: relative;
}

.location-input {
    padding-right: 3rem !important;
    cursor: pointer;
}

.location-input-arrow {
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: #94a3b8;
    font-size: 0.875rem;
    pointer-events: none;
    z-index: 1;
    transition: transform 0.3s ease;
}

.location-selector:has(.location-dropdown.active) .location-input-arrow {
    transform: translateY(-50%) rotate(180deg);
    color: var(--color-primary);
}

.location-dropdown {
    position: absolute !important;
    top: calc(100% + 0.5rem);
    left: 0 !important;
    right: -80px !important;
    max-width: 300px !important;
    width: max-content !important;
    max-width: min(500px, calc(100vw - 2rem)) !important;
    background: white;
    border: 2px solid #e2e8f0;
    border-radius: 1rem;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.15), 0 10px 10px -5px rgba(0, 0, 0, 0.1);
    z-index: 9999;
    max-height: 400px;
    overflow: hidden;
    display: none;
    animation: fadeInDown 0.3s ease;

}

.location-dropdown.active {
    display: block;
}

@keyframes fadeInDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.location-search {
    position: sticky;
    top: 0;
    background: white;
    padding: 1rem;
    border-bottom: 2px solid #e2e8f0;
    z-index: 51;
}

.location-search-wrapper {
    position: relative;
}

.location-search-icon {
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: #94a3b8;
    font-size: 0.875rem;
    z-index: 1;
    pointer-events: none;
}

.location-search-input {
    padding-right: 2.75rem !important;
}

.location-list {
    max-height: 300px;
    overflow-y: auto;
    padding: 0.5rem;
}

.location-option,
.category-option {
    padding: 0.875rem 1rem;
    cursor: pointer;
    transition: all 0.2s ease;
    border-radius: 0.75rem;
    margin: 0.25rem 0;
    color: #1e293b;
    font-size: 0.9375rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

#heroProvinceSearch:focus,
#heroCategorySearch:focus {
    outline: none;
}

/* Parent categories and provinces (disabled and grayed out) */
.category-parent,
.location-parent {
    padding: 1rem;
    cursor: default;
    pointer-events: none;
    color: #9ca3af;
    font-size: 1.25rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0.5rem 0 0.25rem 0;
    border-bottom: 1px solid #f3f4f6;
    background: #f9fafb;
}

/* Child categories and cities (indented) */
.category-child,
.location-child {
    padding: 0.75rem 1rem 0.75rem 2rem;
    margin: 0.125rem 0;
}

.location-option:hover,
.category-option:hover {
    background: linear-gradient(135deg, rgba(124, 58, 237, 0.1) 0%, rgba(124, 58, 237, 0.05) 100%);
    color: var(--color-primary);
    transform: translateX(-4px);
}

.location-option::before {
    content: '\f3c5';
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    color: var(--color-primary);
    opacity: 0;
    transition: opacity 0.2s ease;
    font-size: 0.875rem;
}

.category-option::before {
    content: '\f002';
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    color: var(--color-primary);
    opacity: 0;
    transition: opacity 0.2s ease;
    font-size: 0.875rem;
}

.category-option:hover::before,
.location-option:hover::before {
    opacity: 1;
}

/* Fallback styles for services cards (when Tailwind runtime is absent) */
#services {
    background-color: var(--color-navy);
    color: var(--color-white);
    position: relative;
    overflow: hidden;
}

#services.services-background {
    background: linear-gradient(135deg, var(--color-navy) 0%, rgb(15, 23, 42) 100%);
}

/* Background decorations for services section */
#services .services-background-decorations {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none;
    z-index: 0;
    overflow: hidden;
}

#services .services-background-decorations::before {
    content: '';
    position: absolute;
    top: -6rem;
    left: -6rem;
    width: 20rem;
    height: 20rem;
    border-radius: 50%;
    background: rgb(82 199 254 / 89%);
    filter: blur(64px);
    animation: pulse-primary 8s ease-in-out infinite;
}

#services .services-background-decorations::after {
    content: '';
    position: absolute;
    bottom: -8rem;
    right: -5rem;
    width: 24rem;
    height: 24rem;
    border-radius: 50%;
    background: rgb(255 79 137);
    filter: blur(20px);
    animation: pulse-secondary 10s ease-in-out infinite;
}

/* Radial gradient overlay */
#services .services-background-decorations {
    background-image:
        radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.08) 0%, transparent 40%),
        radial-gradient(circle at 80% 0%, rgba(255, 255, 255, 0.06) 0%, transparent 35%),
        radial-gradient(circle at 50% 80%, rgba(255, 255, 255, 0.04) 0%, transparent 35%);
}

/* Grid pattern overlay */
#services.services-background::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image:
        linear-gradient(90deg, rgba(255, 255, 255, 0.12) 1px, transparent 1px),
        linear-gradient(0deg, rgba(255, 255, 255, 0.12) 1px, transparent 1px);
    background-size: 40px 40px;
    opacity: 0.1;
    pointer-events: none;
    z-index: 0;
}

@keyframes pulse-primary {

    0%,
    100% {
        transform: scale(1);
        opacity: 0.4;
    }

    50% {
        transform: scale(1.1);
        opacity: 0.5;
    }
}

@keyframes pulse-secondary {

    0%,
    100% {
        transform: scale(1);
        opacity: 0.4;
    }

    50% {
        transform: scale(1.15);
        opacity: 0.5;
    }
}

#services .container {
    position: relative;
    z-index: 1;
    margin-inline: auto;
    padding-inline: 1rem;
}

/* استایل مستقیم برای کلاس‌های bg-primary/40 و bg-secondary/40 در بخش services */
#services .bg-primary\/40,
#services [class*="bg-primary/40"] {
    background-color: rgba(var(--color-primary-rgb), 0.4) !important;
}

#services .bg-secondary\/40,
#services [class*="bg-secondary/40"] {
    background-color: rgba(var(--color-secondary-rgb), 0.4) !important;
}

/* استایل برای ترکیب blur-3xl با bg-primary/40 و bg-secondary/40 */
#services .bg-primary\/40.blur-3xl,
#services .blur-3xl.bg-primary\/40,
#services [class*="bg-primary/40"][class*="blur-3xl"] {
    background-color: rgba(var(--color-primary-rgb), 0.4) !important;
    filter: blur(64px) !important;
}

#services .bg-secondary\/40.blur-3xl,
#services .blur-3xl.bg-secondary\/40,
#services [class*="bg-secondary/40"][class*="blur-3xl"] {
    background-color: rgba(var(--color-secondary-rgb), 0.4) !important;
    filter: blur(64px) !important;
}

#services .bg-primary-50,
#services-section .bg-primary-50 {
    background-color: var(--color-primary-50);
}

#services .border-primary-200,
#services-section .border-primary-200 {
    border-color: var(--color-primary-200);
}

#services .bg-primary-600,
#services-section .bg-primary-600 {
    background-color: var(--color-primary-600);
    color: var(--color-white);
}

#services .group:hover .group-hover\:text-white,
#services-section .group:hover .group-hover\:text-white {
    color: #fff;
}

#services .text-primary-600,
#services-section .text-primary-600 {
    color: var(--color-primary-600);
}

#services .bg-accent-50,
#services-section .bg-accent-50 {
    background-color: var(--color-accent-50);
}

#services .border-accent-200,
#services-section .border-accent-200 {
    border-color: var(--color-accent-200);
}

#services .bg-accent-600,
#services-section .bg-accent-600 {
    background-color: var(--color-accent-600);
    color: var(--color-white);
}

#services .text-accent-600,
#services-section .text-accent-600 {
    color: var(--color-accent-600);
}

#services .hover\:bg-green-50:hover,
#services-section .hover\:bg-green-50:hover {
    background-color: var(--color-success-50);
}

#services .border-green-200,
#services-section .border-green-200,
#services .hover\:border-green-200:hover,
#services-section .hover\:border-green-200:hover {
    border-color: var(--color-success-200);
}

#services .group:hover .group-hover\:bg-green-600,
#services-section .group:hover .group-hover\:bg-green-600 {
    background-color: var(--color-success-600);
    color: var(--color-white);
}


#services .bg-orange-50,
#services-section .bg-orange-50 {
    background-color: var(--color-orange-50);
}

@media (max-width: 768px) {
    .sm\:hidden {
        display: none !important;
    }
}

#services .border-orange-200,
#services-section .border-orange-200 {
    border-color: var(--color-orange-200);
}

#services .bg-orange-600,
#services-section .bg-orange-600 {
    background-color: var(--color-orange-600);
    color: var(--color-white);
}

#services .text-orange-600,
#services-section .text-orange-600 {
    color: var(--color-orange-600);
}

#services .hover\:bg-blue-50:hover,
#services-section .hover\:bg-blue-50:hover {
    background-color: var(--color-blue-50);
}

#services .hover\:border-blue-200:hover,
#services-section .hover\:border-blue-200:hover {
    border-color: var(--color-blue-200);
}

#services .group:hover .group-hover\:bg-blue-600,
#services-section .group:hover .group-hover\:bg-blue-600 {
    background-color: var(--color-blue-600);
    color: var(--color-white);
}

#services .hover\:bg-purple-50:hover,
#services-section .hover\:bg-purple-50:hover {
    background-color: var(--color-purple-50);
}

#services .hover\:border-purple-200:hover,
#services-section .hover\:border-purple-200:hover {
    border-color: var(--color-purple-200);
}

#services .group:hover .group-hover\:bg-purple-600,
#services-section .group:hover .group-hover\:bg-purple-600 {
    background-color: var(--color-purple-600);
    color: var(--color-white);
}

#services .hover\:bg-pink-50:hover,
#services-section .hover\:bg-pink-50:hover {
    background-color: var(--color-secondary-50);
}

#services .border-pink-200,
#services-section .border-pink-200,
#services .hover\:border-pink-200:hover,
#services-section .hover\:border-pink-200:hover {
    border-color: var(--color-secondary-200);
}

#services .group:hover .group-hover\:bg-pink-600,
#services-section .group:hover .group-hover\:bg-pink-600 {
    background-color: var(--color-secondary-600);
    color: var(--color-white);
}


#services .hover\:bg-yellow-50:hover,
#services-section .hover\:bg-yellow-50:hover {
    background-color: var(--color-yellow-50);
}

#services .hover\:border-yellow-200:hover,
#services-section .hover\:border-yellow-200:hover {
    border-color: var(--color-yellow-200);
}

#services .group:hover .group-hover\:bg-yellow-600,
#services-section .group:hover .group-hover\:bg-yellow-600 {
    background-color: var(--color-yellow-600);
    color: var(--color-white);
}

#services .text-yellow-600,
#services-section .text-yellow-600 {
    color: var(--color-yellow-600);
}

/* قرار دادن لینک مشاهده در پایین باکس */
#services .group,
#services-section .group {
    display: flex;
    flex-direction: column;
    height: 100%;
}

/* ضخیم شدن border در hover بدون تغییر اندازه باکس */
#services .group>div,
#services-section .group>div {
    box-sizing: border-box;
    position: relative;
}

#services .group:hover>div,
#services-section .group:hover>div {
    /* استفاده از box-shadow inset برای border ضخیم‌تر بدون تغییر اندازه باکس */
    box-shadow: inset 0 0 0 2px;
}

/* تنظیم رنگ box-shadow بر اساس رنگ border موجود */
#services .group:hover>div.border-primary-200,
#services-section .group:hover>div.border-primary-200 {
    box-shadow: inset 0 0 0 2px var(--color-primary-200) !important;
}

#services .group:hover>div.border-accent-200,
#services-section .group:hover>div.border-accent-200 {
    box-shadow: inset 0 0 0 2px var(--color-accent-200) !important;
}

#services .group:hover>div.border-green-200,
#services-section .group:hover>div.border-green-200 {
    box-shadow: inset 0 0 0 2px var(--color-success-200) !important;
}

#services .group:hover>div.border-orange-200,
#services-section .group:hover>div.border-orange-200 {
    box-shadow: inset 0 0 0 2px var(--color-orange-200) !important;
}

#services .group:hover>div.border-blue-200,
#services-section .group:hover>div.border-blue-200 {
    box-shadow: inset 0 0 0 2px var(--color-blue-200) !important;
}

#services .group:hover>div.border-purple-200,
#services-section .group:hover>div.border-purple-200 {
    box-shadow: inset 0 0 0 2px var(--color-purple-200) !important;
}

#services .group:hover>div.border-pink-200,
#services-section .group:hover>div.border-pink-200 {
    box-shadow: inset 0 0 0 2px var(--color-secondary-200) !important;
}

#services .group:hover>div.border-yellow-200,
#services-section .group:hover>div.border-yellow-200 {
    box-shadow: inset 0 0 0 2px var(--color-yellow-200) !important;
}

#services .group>div,
#services-section .group>div {
    display: flex;
    flex-direction: column;
    flex: 1;
    height: 100%;
}

#services .group>div>div:last-child,
#services-section .group>div>div:last-child {
    margin-top: auto;
    padding-top: 0.5rem;
}

/* حرکت دکمه مشاهده به سمت چپ در hover */
#services .group:hover>div>div:last-child a,
#services-section .group:hover>div>div:last-child a {
    transform: translateX(-4px);
    transition: transform 0.3s ease;
}

/* استایل آیکون arrow در لینک‌های مشاهده بخش services */
#services a[href*="search-results"] i,
#services-section a[href*="search-results"] i,
#services a.text-primary-600 i,
#services a.text-accent-600 i,
#services a.text-green-600 i,
#services a.text-orange-600 i,
#services a.text-blue-600 i,
#services a.text-purple-600 i,
#services a.text-pink-600 i,
#services a.text-yellow-600 i,
#services-section a.text-primary-600 i,
#services-section a.text-accent-600 i,
#services-section a.text-green-600 i,
#services-section a.text-orange-600 i,
#services-section a.text-blue-600 i,
#services-section a.text-purple-600 i,
#services-section a.text-pink-600 i,
#services-section a.text-yellow-600 i {
    font-size: 14px !important;
    width: 14px !important;
    height: 14px !important;
    display: inline-block !important;
    opacity: 1 !important;
    color: inherit !important;
    visibility: visible !important;
}

#services a[href*="search-results"] svg,
#services-section a[href*="search-results"] svg,
#services a.text-primary-600 svg,
#services a.text-accent-600 svg,
#services a.text-green-600 svg,
#services a.text-orange-600 svg,
#services a.text-blue-600 svg,
#services a.text-purple-600 svg,
#services a.text-pink-600 svg,
#services a.text-yellow-600 svg,
#services-section a.text-primary-600 svg,
#services-section a.text-accent-600 svg,
#services-section a.text-green-600 svg,
#services-section a.text-orange-600 svg,
#services-section a.text-blue-600 svg,
#services-section a.text-purple-600 svg,
#services-section a.text-pink-600 svg,
#services-section a.text-yellow-600 svg {
    width: 14px !important;
    height: 14px !important;
    display: inline-block !important;
    opacity: 1 !important;
    fill: currentColor !important;
    visibility: visible !important;
}

/* Base text utilities (fallback) */
.font-bold {
    font-weight: 700;
}

.text-gray-900 {
    color: #111827;
}

.mb-2 {
    margin-bottom: 0.5rem;
}

/* Base layout/text utilities (fallback) */
.items-center {
    align-items: center;
}

.items_center {
    align-items: center;
}

.justify-between {
    justify-content: space-between;
}

.justify-center {
    justify-content: center;
}

.gap-1 {
    gap: 0.25rem;
}

.hover\:gap-2:hover {
    gap: 0.5rem;
}

.text-sm {
    font-size: 0.875rem;
    line-height: 1.25rem;
}

.bg-white {
    background-color: #ffffff;
}

.w-16 {
    width: 4rem;
}

.h-16 {
    height: 4rem;
}

.rounded-xl {
    border-radius: 0.75rem;
}

.mb-4 {
    margin-bottom: 1rem;
}

.transition {
    transition: all 0.2s ease;
}

.shadow-sm {
    box-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.group:hover .group-hover\:bg-pink-600 {
    background-color: #db2777;
    color: #fff;
}

.text-gray-700 {
    color: #374151;
}

/* Fallback utilities for services background layer */
.relative {
    position: relative;
}

.overflow-hidden {
    overflow: hidden;
}

.pointer-events-none {
    pointer-events: none;
}

.absolute {
    position: absolute;
}

.inset-0 {
    inset: 0;
}

.-top-24 {
    top: -6rem;
}

.-left-24 {
    left: -6rem;
}

.-bottom-32 {
    bottom: -8rem;
}

.-right-20 {
    right: -5rem;
}

.h-80 {
    height: 20rem;
}

.w-80 {
    width: 20rem;
}

.h-96 {
    height: 24rem;
}

.w-96 {
    width: 24rem;
}

.rounded-full {
    border-radius: 9999px;
}

.blur-3xl {
    filter: blur(64px);
}

.opacity-10 {
    opacity: 0.1;
}

.bg-primary\/40 {
    background-color: rgb(var(--color-primary-rgb) / 0.4);
}

.bg-secondary\/40 {
    background-color: rgb(var(--color-secondary-rgb) / 0.4);
}

.bg-\[size\:40px_40px\] {
    background-size: 40px 40px;
}

.bg-\[radial-gradient\(circle_at_20\%_20\%\,rgba\(255\,255\,255\,0\.08\)\,transparent_40\%\)\,radial-gradient\(circle_at_80\%_0\,rgba\(255\,255\,255\,0\.06\)\,transparent_35\%\)\,radial-gradient\(circle_at_50\%_80\%\,rgba\(255\,255\,255\,0\.04\)\,transparent_35\%\)\] {
    background: radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.08), transparent 40%),
        radial-gradient(circle at 80% 0, rgba(255, 255, 255, 0.06), transparent 35%),
        radial-gradient(circle at 50% 80%, rgba(255, 255, 255, 0.04), transparent 35%);
}

.bg-\[linear-gradient\(90deg\,rgba\(255\,255\,255\,0\.12\)_1px\,transparent_1px\)\,linear-gradient\(0deg\,rgba\(255\,255\,255\,0\.12\)_1px\,transparent_1px\)\] {
    background: linear-gradient(90deg, rgba(255, 255, 255, 0.12) 1px, transparent 1px),
        linear-gradient(0deg, rgba(255, 255, 255, 0.12) 1px, transparent 1px);
}

.h-550px {
    height: 550px;
}

.w-550px {
    width: 550px;
}

.rounded-2xl {
    border-radius: 0.75rem;
}

.p-6 {
    padding: 1.5rem;
}

.text-center {
    text-align: center;
}

/* ==========================================================================
   Scoped header/footer hardening to prevent Bootstrap conflicts
   ========================================================================== */

/* Make sure Bootstrap's generic rules can't break header/footer layout */
#header,
#header * {
    box-sizing: border-box;
}

#footer,
#footer * {
    box-sizing: border-box;
}

/* Override Bootstrap .container inside our header/footer */
#header .container,
#footer .container {

    padding-right: 1rem !important;
    padding-left: 1rem !important;
    width: 100% !important;
}

/* Links inside header/footer: neutralize Bootstrap link styles */
#header a,
#footer a {
    text-decoration: none;
}

#header a:hover,
#header a:focus,
#footer a:hover,
#footer a:focus {
    text-decoration: none;
}


#footer {
    /* Prevent footer contents from causing horizontal scroll */
    overflow-x: hidden;
}

#footer img {
    max-width: 100%;
    height: auto;
}


/* Buttons in header/footer should keep rounded / spacing regardless of Bootstrap */
#header button,
#footer button {
    border-radius: 0.5rem;
    border: none;
    font-family: 'Vazirmatn', sans-serif;
}

/* Ensure our flex layouts in header/footer are not overridden */
#header .flex,
#footer .flex {
    display: flex;
}

/* Responsive refinements for homepage sections */
@media (max-width: 1200px) {
    #header .container>.flex {
        flex-wrap: wrap;
        gap: 12px;
    }

    #header-menu {
        order: 3;
        width: 100%;
    }

    #header .nida-menu {
        width: 100%;
        overflow-x: auto;
    }

    #header .nida-menu nav,
    #header .nida-menu ul {
        min-width: max-content;
    }

    #header .flex.items-center.justify-between>div:last-child {
        flex-wrap: wrap;
        gap: 5px;
        justify-content: flex-end;
    }
}

@media (max-width: 1024px) {
    #header {
        z-index: 1100;
    }

    body.nida-menu-open {
        overflow: hidden;
    }

    /* بک‌دراپ را روی خود هدر قرار می‌دهیم تا بین هدر و منو بایستد */
    #header.menu-open::before {
        content: "";
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.35);
        opacity: 1;
        pointer-events: auto;
        transition: opacity 0.3s ease;
        z-index: 1200;
    }

    #header-menu {
        position: fixed;
        top: 0;
        right: 0;
        left: auto;
        height: 100vh;
        width: 55%;
        max-width: 320px;
        padding: calc(1.1rem + env(safe-area-inset-top)) 1rem 1.5rem 1rem;
        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 60%, #f1f5f9 100%);
        border-left: 1px solid #e2e8f0;
        border-right: none;
        box-shadow: -6px 0 28px rgba(15, 23, 42, 0.14);
        overflow-y: auto;
        transform: translateX(100%);
        opacity: 0;
        pointer-events: none;
        transition: transform 0.3s ease, opacity 0.3s ease;
        z-index: 1300;
    }

    /* فضای داخلی و فاصله‌گذاری بین سکشن‌های منو */
    #header-menu nav {
        display: flex;
        flex-direction: column;
        gap: 0.75rem;
    }

    #header-menu .menu,
    #header-menu ul {
        width: 100%;
    }

    #header-menu .sub-menu {
        margin-top: 0.35rem;
        padding-left: 0.75rem;
        border-left: 2px solid #e2e8f0;
        gap: 0.4rem;
    }

    #header-menu::-webkit-scrollbar {
        width: 8px;
    }

    #header-menu::-webkit-scrollbar-track {
        background: transparent;
    }

    #header-menu::-webkit-scrollbar-thumb {
        background: rgba(148, 163, 184, 0.7);
        border-radius: 999px;
    }

    #nida-menu-overlay {
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.35);
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.25s ease;
        z-index: 1200;
    }

    #header.menu-open #nida-menu-overlay {
        opacity: 1;
        pointer-events: auto;
    }

    #header.menu-open #header-menu {
        transform: translateX(0);
        opacity: 1;
        pointer-events: auto;
    }

    #header .nida-menu {
        width: 100%;
    }

    #header .nida-menu nav,
    #header .nida-menu ul {
        width: 100%;
    }

    #header .flex.items-center.gap-8 {
        gap: 1rem;
    }

    #header.menu-open #header-menu nav,
    #header.menu-open #header-menu ul {
        display: block;
    }

    #header.menu-open #header-menu li {
        display: block;
        width: 100%;
    }

    #header-menu ul {
        display: flex;
        flex-direction: column;
        gap: 0.5rem;
        padding: 0;
        margin: 0;
    }

    #header-menu li {
        list-style: none;
    }

    #header-menu li a {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        padding: 0.85rem 1rem;
        border-radius: 0.9rem;
        background: #f8fafc;
        color: #0f172a;
        font-size: 0.95rem;
        font-weight: 600;
        border: 1px solid #e2e8f0;
        transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
    }

    #header-menu li a:hover,
    #header-menu li a:focus-visible {
        background: #eef2ff;
        border-color: #cbd5e1;
        color: var(--color-primary);
        transform: translateX(4px);
        box-shadow: 0 10px 24px rgba(99, 102, 241, 0.12);
        outline: none;
    }

    #header-menu li a:active {
        transform: translateX(2px) scale(0.99);
    }

    /* حالت آیتم فعال وردپرس (current-menu-item) */
    #header-menu li.current-menu-item>a,
    #header-menu li.current_page_item>a {
        background: #e0e7ff;
        border-color: #c7d2fe;
        color: var(--color-primary);
        box-shadow: 0 10px 24px rgba(99, 102, 241, 0.16);
        transform: none;
    }

    /* فلش راهنما برای آیتم‌های دارای زیرمنو */
    #header-menu li.menu-item-has-children>a::after {
        content: "›";
        font-size: 0.9rem;
        color: inherit;
        transition: transform 0.2s ease;
    }

    #header-menu li.menu-item-has-children:hover>a::after,
    #header-menu li.menu-item-has-children:focus-within>a::after {
        transform: translateX(2px);
    }

    #hero-section h1 {
        font-size: 2.75rem;
        line-height: 1.25;
    }

    #hero-section .text-xl {
        font-size: 1.05rem;
        line-height: 1.6;
    }

    #hero-section .bg-white.rounded-3xl,
    #hero-section .bg-white.rounded-2xl {
        padding: 1.25rem;
    }

    #hero-section .flex.items-center.gap-6 {
        flex-wrap: wrap;
    }

    #hero-section .grid {
        gap: 1.5rem;
    }

    #featured-ads-section .h-550px {
        height: auto;
    }

    #featured-ads-section .h-1\/2 {
        height: auto;
    }

    #featured-ads-section .relative.h-1\/2 {
        min-height: 220px;
    }

    #featured-ads-section .p-5 {
        padding: 1.25rem;
    }

    #featured-ads-section .text-2xl {
        font-size: 1.4rem;
    }

    #location-based-section .flex.items-center.justify-between {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.75rem;
    }
}

@media (max-width: 768px) {
    .container {
        padding-inline: 1rem;
    }

    #hero-section h1 {
        font-size: 2.2rem;
    }

    #hero-section .bg-white.rounded-3xl {
        padding: 1rem;
    }

    #hero-section .space-y-8>*+* {
        margin-top: 1rem;
    }

    #categories-section .grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.75rem;
    }

    #categories-section .bg-gradient-to-br {
        padding: 1rem;
    }

    #featured-ads-section .grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 0.5rem !important;
    }

    #featured-ads-section .bg-white.h-\[320px\] {
        height: 320px !important;
    }

    #featured-ads-section .relative.h-\[200px\] {
        height: 200px !important;
    }

    #featured-ads-section .p-1\.5 {
        padding: 0.375rem !important;
    }

    #featured-ads-section h3.text-\[11px\] {
        font-size: 0.6875rem !important;
    }

    #featured-ads-section .text-xs {
        font-size: 0.75rem !important;
    }

    #featured-ads-section .text-\[9px\] {
        font-size: 0.5625rem !important;
    }

    #featured-ads-section .text-sm {
        font-size: 0.75rem !important;
    }



    #ai-matching-section .bg-white.rounded-3xl {
        padding: 1rem;
    }

    #ai-matching-section .mt-6.flex.gap-2 {
        flex-wrap: wrap;
    }

    #cta-section h2 {
        font-size: 2rem;
        line-height: 1.3;
    }

    #cta-section p {
        font-size: 1.05rem;
    }

    #cta-section .flex.items-center.justify-center.gap-8 {
        flex-direction: column;
        gap: 0.75rem;
    }
}

/* AI matching section: floating badge */
#ai-matching-section .nas-float-badge {
    animation: nas-float-y 2.6s ease-in-out infinite;
    will-change: transform;
    --nas-float-distance: 10px;
}

@keyframes nas-float-y {

    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(calc(-1 * var(--nas-float-distance)));
    }
}

@media (prefers-reduced-motion: reduce) {
    #ai-matching-section .nas-float-badge {
        /* Keep it subtle but still animated */
        animation-duration: 5.5s;
        --nas-float-distance: 4px;
    }
}

/* --------------------------------------------------------------------------------- */

#featured-ads-section,
.ai-matching-container,
.similar-ads-section {
    --ad-search-primary: var(--color-primary, #6d2f8a);
    --ad-search-primary-dark: #5b2774;
    --ad-search-white: #ffffff;
    --ad-search-dark: #111827;
    --ad-search-medium: #e5e7eb;
    --ad-search-danger: #ef4444;
    --ad-search-shadow: 0 8px 20px rgba(0, 0, 0, 0.10);
    --ad-search-transition: all 0.25s ease;
}

#featured-ads-section .ad-search-requirements-grid,
.ai-matching-container .ad-search-requirements-grid,
.similar-ads-section .ad-search-requirements-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 25px;
    margin-bottom: 0;
}

#featured-ads-section .ad-search-requirement-card,
.ai-matching-container .ad-search-requirement-card,
.similar-ads-section .ad-search-requirement-card {
    background-color: var(--ad-search-white);
    border-radius: 15px;
    overflow: hidden;
    box-shadow: var(--ad-search-shadow);
    transition: var(--ad-search-transition);
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    height: 100%;
}

#featured-ads-section .ad-search-requirement-card:hover,
.similar-ads-section .ad-search-requirement-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 25px rgba(0, 0, 0, 0.15);
}

#featured-ads-section .ad-search-card-image,
.ai-matching-container .ad-search-card-image,
.similar-ads-section .ad-search-card-image {
    height: 200px;
    background-size: cover;
    background-position: center;
    position: relative;
    background-repeat: no-repeat;
}

#featured-ads-section .ad-search-card-image-count,
.ai-matching-container .ad-search-card-image-count,
.similar-ads-section .ad-search-card-image-count {
    position: absolute;
    top: 15px;
    left: 15px;
    background-color: rgba(0, 0, 0, 0.6);
    color: var(--ad-search-white);
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    z-index: 2;
}

/* AI matching specific styles to match featured cards */
.ai-matching-container .ai-match-percentage {
    position: absolute;
    top: 15px;
    right: 15px;
    background: var(--color-primary-hex);
    color: var(--color-white);
    padding: 6px 10px;
    border-radius: 50px;
    font-weight: 700;
    z-index: 5;
    box-shadow: 0 6px 16px rgba(16, 24, 40, 0.12);
    width: 44px;
}




#featured-ads-section .ad-search-card-badge,
.ai-matching-container .ad-search-card-badge,
.similar-ads-section .ad-search-card-badge {
    position: absolute;
    top: 15px;
    right: 15px;
    background-color: var(--ad-search-primary);
    color: var(--ad-search-white);
    padding: 6px 15px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    z-index: 2;
}

#featured-ads-section .ad-search-card-content,
.ai-matching-container .ad-search-card-content,
.similar-ads-section .ad-search-card-content {
    background: white;

    padding: 20px;
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
}

#featured-ads-section .ad-search-card-desc,
.ai-matching-container .ad-search-card-desc,
.similar-ads-section .ad-search-card-desc {
    margin: -6px 0 12px 0;
    color: #6b7280;
    font-size: 12px;
    line-height: 1.6;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#featured-ads-section .ad-search-card-header,
.ai-matching-container .ad-search-card-header,
.similar-ads-section .ad-search-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
    position: relative;
    background-color: transparent;
    border-bottom: none;
}

#featured-ads-section .ad-search-card-title-link,
.ai-matching-container .ad-search-card-title-link ,
.similar-ads-section .ad-search-card-title-link {
    flex: 1;
    text-decoration: none;
    color: inherit;
    display: block;
    max-width: 100%;
}

#featured-ads-section .ad-search-card-title-link:hover,
.ai-matching-container .ad-search-card-title-link:hover,
.similar-ads-section .ad-search-card-title-link:hover {
    text-decoration: none;
}

#featured-ads-section .ad-search-card-title,
.ai-matching-container .ad-search-card-title ,
.similar-ads-section .ad-search-card-title {

    font-size: 14px;
    font-weight: 700;
    color: #333;
    font-family: 'Vazirmatn', sans-serif;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    position: relative;
    cursor: pointer;
    margin: 0;
}

#featured-ads-section .ad-search-card-title-link:hover .ad-search-card-title,
.ai-matching-container .ad-search-card-title-link:hover .ad-search-card-title,
.similar-ads-section .ad-search-card-title-link:hover .ad-search-card-title {
    color: var(--ad-search-primary);
}

#featured-ads-section .ad-search-card-title-tooltip,
.ai-matching-container .ad-search-card-title-tooltip,
.similar-ads-section .ad-search-card-title-tooltip {
    position: absolute;
    bottom: calc(100% + 12px);
    left: 50%;
    transform: translateX(-50%) translateY(5px);
    background-color: rgba(0, 0, 0, 0.95);
    color: #fff;
    padding: 12px 16px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 500;
    white-space: normal;
    max-width: 320px;
    min-width: 200px;
    width: max-content;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease, transform 0.3s ease;
    z-index: 10000;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
    line-height: 1.6;
    text-align: center;
    word-wrap: break-word;
    direction: rtl;
    visibility: hidden;
}

#featured-ads-section .ad-search-card-title-tooltip::after,
.ai-matching-container .ad-search-card-title-tooltip::after,
.similar-ads-section .ad-search-card-title-tooltip::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 7px solid transparent;
    border-top-color: rgba(0, 0, 0, 0.95);
}

#featured-ads-section .ad-search-card-title-link:hover+.ad-search-card-title-tooltip,
#featured-ads-section .ad-search-card-title:hover+.ad-search-card-title-tooltip,
.ai-matching-container .ad-search-card-title-link:hover+.ad-search-card-title-tooltip,
.ai-matching-container .ad-search-card-title:hover+.ad-search-card-title-tooltip ,
.similar-ads-section .ad-search-card-title-link:hover+.ad-search-card-title-tooltip,
.similar-ads-section .ad-search-card-title:hover+.ad-search-card-title-tooltip {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}

#featured-ads-section .ad-search-card-save-btn,
.ai-matching-container .ad-search-card-save-btn,
.similar-ads-section .ad-search-card-save-btn {
    background: none;
    border: none;
    color: var(--ad-search-dark);
    font-size: 18px;
    cursor: pointer;
    transition: var(--ad-search-transition);
    margin-right: 10px;
    padding: 0;
    outline: none;
}

#featured-ads-section .ad-search-card-save-btn:hover,
#featured-ads-section .ad-search-card-save-btn.saved,
.ai-matching-container .ad-search-card-save-btn:hover,
.ai-matching-container .ad-search-card-save-btn.saved,
.similar-ads-section .ad-search-card-save-btn:hover,
.similar-ads-section .ad-search-card-save-btn.saved {
    color: var(--ad-search-primary);
}

#featured-ads-section .ad-search-card-meta,
.ai-matching-container .ad-search-card-meta ,
.similar-ads-section .ad-search-card-meta {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 0;
}

#featured-ads-section .ad-search-meta-top,
.ai-matching-container .ad-search-meta-top ,
.similar-ads-section .ad-search-meta-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

#featured-ads-section .ad-search-meta-left,
.ai-matching-container .ad-search-meta-left ,
.similar-ads-section .ad-search-meta-left {
    display: flex;
    gap: 15px;
}

#featured-ads-section .ad-search-meta-item,
#location-based-section .ad-search-meta-item,
.ai-matching-container .ad-search-meta-item ,
.similar-ads-section .ad-search-meta-item {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--ad-search-dark);
    font-size: 10px;
}

#featured-ads-section .ad-search-meta-item i,
#location-based-section .ad-search-meta-item i,
.ai-matching-container .ad-search-meta-item i,
.similar-ads-section .ad-search-meta-item i {
    color: var(--ad-search-primary, #6d2f8a);
}

#featured-ads-section .ad-search-meta-bottom,
.ai-matching-container .ad-search-meta-bottom,
.similar-ads-section .ad-search-meta-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}

#featured-ads-section .ad-search-meta-location,
#location-based-section .ad-search-meta-location,
.ai-matching-container .ad-search-meta-location,
.similar-ads-section .ad-search-meta-location {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--ad-search-dark);
    font-size: 10px;
    min-width: 0;
}

#featured-ads-section .ad-search-meta-location span,
#location-based-section .ad-search-meta-location span,
.ai-matching-container .ad-search-meta-location span,
.similar-ads-section .ad-search-meta-location span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#featured-ads-section .ad-search-card-price-box,
#location-based-section .ad-search-card-price-box,
.ai-matching-container .ad-search-card-price-box ,
.similar-ads-section .ad-search-card-price-box {
    background-color: var(--color-red-500);
    color: var(--color-white);
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 14px;
    font-weight: bolder;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    white-space: nowrap;
}

#featured-ads-section .ad-search-card-details,
.ai-matching-container .ad-search-card-details,
.similar-ads-section .ad-search-card-details {
    background-color: var(--color-primary);
    color: var(--color-white);
    padding: 12px;
    margin-top: 30px;
    margin-left: -20px;
    margin-right: -20px;
    margin-bottom: -20px;
    border-radius: 0 0 15px 15px;
    text-align: center;
    cursor: pointer;
    transition: var(--ad-search-transition);
    display: block;
    text-decoration: none;
    position: relative;
    z-index: 1;
    font-family: 'Vazirmatn', sans-serif;
    font-size: 16px;
    font-weight: 600;
    outline: none;
    box-sizing: border-box;
    align-self: stretch;
}

#featured-ads-section .ad-search-card-details:hover,
.ai-matching-container .ad-search-card-details:hover,
.similar-ads-section .ad-search-card-details:hover {
    background-color: var(--ad-search-primary-dark);
}

#featured-ads-section .ad-search-card-details-title,
.ai-matching-container .ad-search-card-details-title,
.similar-ads-section .ad-search-card-details-title {
    font-size: 16px;
    font-weight: 600;
}

#featured-ads-section .ad-search-post-type-badge,
.ai-matching-container .ad-search-post-type-badge,
.similar-ads-section .ad-search-post-type-badge {

    padding: 4px 8px;
    border-radius: 20px;
    font-size: 10px;
    font-weight: 600;
    color: white;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    z-index: 3;
}

#featured-ads-section .seller-badge,
.ai-matching-container .seller-badge ,
.similar-ads-section .seller-badge {
    background-color: #4CAF50;
}

#featured-ads-section .buyer-badge,
.ai-matching-container .buyer-badge,
.similar-ads-section .buyer-badge {
    background-color: #2196F3;
}

/* دکمه مشاهده همه */
.hp.featured-ads-view-all-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    color: var(--color-white, #fff);
    background: var(--color-primary);
    border-radius: 50px;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s ease;
    font-family: 'Vazirmatn', sans-serif;
    white-space: nowrap;
}

.hp.featured-ads-view-all-btn:hover {
    color: var(--color-white, #fff);
    text-decoration: none;
}

.hp.featured-ads-view-all-btn i,
.hp.featured-ads-view-all-btn .fa-solid,
.hp.featured-ads-view-all-btn .fas {
    font-size: 12px;
    transition: transform 0.3s ease;
}

.hp.featured-ads-view-all-btn:hover i,
.hp.featured-ads-view-all-btn:hover .fa-solid,
.hp.featured-ads-view-all-btn:hover .fas {
    transform: translateX(-3px);
}

#featured-ads-section .featured-ads-view-all-btn i {
    font-size: 12px;
    transition: transform 0.3s ease;
}

#featured-ads-section .featured-ads-view-all-btn:hover i {
    transform: translateX(-3px);
}

.ad-search-card-image {
    height: 200px!important;
    background-size: cover;
    background-position: center;
    position: relative;
    background-repeat: no-repeat;
}

.ad-search-card-image-count {
    position: absolute;
    top: 15px;
    left: 15px;
    background-color: rgba(0, 0, 0, 0.6);
    color: var(--ad-search-white);
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    z-index: 2;
}

/* Featured Ads Section Styles */
.ad-search-meta-location .location-badge-container {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

.ad-search-meta-location .location-badge-container i,
.ad-search-meta-location .location-badge-container span {
    display: inline-block;
    vertical-align: middle;
}

.ad-search-meta-location .location-badge-container .ad-search-post-type-badge {
    display: inline-block;
    margin-right: 0;
    margin-left: 6px;
    vertical-align: middle;
    white-space: nowrap;
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .ad-search-meta-location .location-badge-container {
        gap: 4px;
    }

    .ad-search-meta-location .location-badge-container .ad-search-post-type-badge {
        margin-left: 4px;
        font-size: 10px;
        padding: 3px 8px;
    }
}

@media (max-width: 480px) {
    .ad-search-meta-location .location-badge-container .ad-search-post-type-badge {
        font-size: 9px;
        padding: 2px 6px;
        margin-left: 3px;
    }
}


@media (max-width: 768px) {


    #featured-ads-section .ad-search-card-content,
    .ai-matching-container .ad-search-card-content {
        padding: 14px;
    }

    #featured-ads-section .ad-search-card-desc,
    .ai-matching-container .ad-search-card-desc {
        margin: -6px 0 10px 0;
        font-size: 11px;
    }

    #featured-ads-section .ad-search-card-details {
        margin-left: -14px;
        margin-right: -14px;
        margin-bottom: -14px;
    }

    #featured-ads-section .featured-ads-view-all-btn {
        padding: 8px 16px;
        font-size: 12px;
        gap: 6px;
    }

    #featured-ads-section .flex.items-center.justify-between {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    #featured-ads-section .featured-ads-view-all-btn {
        align-self: flex-end;
    }

    .hp.featured-ads-view-all-btn {
        padding: 8px 16px;
        font-size: 12px;
        gap: 6px;
    }
}

/* Location-based section styles - matching featured-ads-section */
#location-based-section .ad-search-requirements-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-top: 20px;
}

/* Force single column on mobile devices - using specific class for mobile */
.mobile-single-column {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.mobile-single-column .ad-search-requirement-card,
.ai-matching-container .ad-search-requirement-card {
    width: 100% !important;
    max-width: 100% !important;
}

/* Backup: Force single column on mobile devices */
@media (max-width: 768px) {
    #location-based-section .ad-search-requirements-grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
    }

    #location-based-section .ad-search-requirement-card {
        width: 100% !important;
        max-width: 100% !important;
    }
}

#location-based-section .ad-search-requirement-card {
    background: white;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    cursor: pointer;
}

#location-based-section .ad-search-requirement-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    transform: translateY(-2px);
}

#location-based-section .ad-search-card-image {
    position: relative;
    width: 100%;
    height: 200px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

#location-based-section .ad-search-card-image-count {
    position: absolute;
    top: 15px;
    left: 15px;
    background-color: rgba(0, 0, 0, 0.6);
    color: white;
    padding: 4px 10px;
    border-radius: 15px;
    font-size: 12px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 5px;
    z-index: 2;
}

#location-based-section .ad-search-card-badge {
    position: absolute;
    top: 15px;
    right: 15px;
    background-color: var(--ad-search-primary);
    color: var(--ad-search-white);
    padding: 6px 15px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    z-index: 2;
}

#location-based-section .ad-search-card-distance-badge {
    position: absolute;
    bottom: 15px;
    left: 15px;
    background-color: var(--color-success, #10b981);
    color: white;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    z-index: 2;
    display: flex;
    align-items: center;
    gap: 5px;
}

#location-based-section .ad-search-card-distance-badge i {
    font-size: 10px;
}

#location-based-section .ad-search-post-type-badge {

    padding: 4px 8px;
    border-radius: 20px;
    font-size: 10px;
    font-weight: 600;
    color: white;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    z-index: 3;
}

#location-based-section .seller-badge {
    background-color: #4CAF50;
}

#location-based-section .buyer-badge {
    background-color: #2196F3;
}

#location-based-section .ad-search-card-content {
    padding: 20px;
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
}

#location-based-section .ad-search-card-desc {
    margin: -6px 0 12px 0;
    color: #6b7280;
    font-size: 12px;
    line-height: 1.6;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#location-based-section .ad-search-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
    position: relative;
    background-color: transparent;
    border-bottom: none;
}

#location-based-section .ad-search-card-title-link {
    flex: 1;
    text-decoration: none;
    color: inherit;
}

#location-based-section .ad-search-card-title {
    font-size: 16px;
    font-weight: 700;
    color: #1f2937;
    margin: 0;
    line-height: 1.4;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    position: relative;
}

#location-based-section .ad-search-card-title-tooltip {
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    background-color: #1f2937;
    color: white;
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 13px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s;
    z-index: 10;
    margin-bottom: 5px;
    max-width: 300px;
    overflow: hidden;
    text-overflow: ellipsis;
}

#location-based-section .ad-search-card-title:hover+.ad-search-card-title-tooltip,
#location-based-section .ad-search-card-title-tooltip:hover {
    opacity: 1;
}

#location-based-section .ad-search-card-save-btn {
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 8px;
    color: #9ca3af;
    transition: all 0.2s;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 8px;
}

#location-based-section .ad-search-card-save-btn:hover {
    color: var(--ad-search-primary);
}

#location-based-section .ad-search-card-save-btn.saved {
    color: var(--ad-search-primary);
}

#location-based-section .ad-search-card-meta {
    margin-top: auto;
    padding-top: 12px;
}

#location-based-section .ad-search-meta-top {
    margin-bottom: 10px;
}

#location-based-section .ad-search-meta-left {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
}



#location-based-section .ad-search-meta-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 8px;
}

#location-based-section .ad-search-card-details {
    background-color: var(--color-primary);
    color: var(--color-white);
    margin: 15px -20px -20px -20px;
    padding: 12px 20px;
    text-align: center;
    text-decoration: none;
    font-weight: 600;
    transition: all 0.2s;
    border-top: 1px solid #e5e7eb;
}

#location-based-section .ad-search-card-details:hover {
    background-color: var(--ad-search-primary-dark, #5b2774);
    color: white;
}

#location-based-section .ad-search-card-details-title {
    font-size: 16px;
    font-weight: 600;
}




#location-based-section .ad-search-card-content {
    padding: 14px;
}

#location-based-section .ad-search-card-desc {
    margin: -6px 0 10px 0;
    font-size: 11px;
}

#location-based-section .ad-search-card-details {
    margin-left: -14px;
    margin-right: -14px;
    margin-bottom: -14px;
}

::-webkit-scrollbar {
    display: none;
}

#headerLocationModal .header-location-body::-webkit-scrollbar,
#headerLocationModal .ad-search-location-body::-webkit-scrollbar,
.location-dropdown::-webkit-scrollbar,
.location-list::-webkit-scrollbar {
    display: block;
    width: 8px;
}

#headerLocationModal .header-location-body::-webkit-scrollbar-track,
#headerLocationModal .ad-search-location-body::-webkit-scrollbar-track,
.location-dropdown::-webkit-scrollbar-track,
.location-list::-webkit-scrollbar-track {
    background: transparent;
}

#headerLocationModal .header-location-body::-webkit-scrollbar-thumb,
#headerLocationModal .ad-search-location-body::-webkit-scrollbar-thumb,
.location-dropdown::-webkit-scrollbar-thumb,
.location-list::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.7);
    border-radius: 999px;
}