.te-event-full__excerpt,
.te-event-list__excerpt {
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical
}

.te-calendar__event-title,
.te-calendar__list-event-title,
.te-event-compact__location,
.te-event-compact__title,
.te-event-elegant__meta,
.te-event-gradient__location,
.te-event-magazine__location,
.te-event-modern__location {
    white-space: nowrap;
    text-overflow: ellipsis
}

:root {
    --te-primary-50: #eff6ff;
    --te-primary-100: #dbeafe;
    --te-primary-200: #bfdbfe;
    --te-primary-400: #60a5fa;
    --te-primary-500: #3b82f6;
    --te-primary-600: #2563eb;
    --te-primary-700: #1d4ed8;
    --te-primary-800: #1e40af;
    --te-primary-900: #1e3a8a;
    --te-gray-50: #f9fafb;
    --te-gray-100: #f3f4f6;
    --te-gray-200: #e5e7eb;
    --te-gray-300: #d1d5db;
    --te-gray-400: #9ca3af;
    --te-gray-500: #6b7280;
    --te-gray-600: #4b5563;
    --te-gray-700: #374151;
    --te-gray-800: #1f2937;
    --te-gray-900: #111827;
    --te-red-100: #fee2e2;
    --te-red-300: #fca5a5;
    --te-red-400: #f87171;
    --te-red-500: #ef4444;
    --te-red-600: #dc2626;
    --te-red-700: #b91c1c;
    --te-red-800: #991b1b;
    --te-red-900: #7f1d1d;
    --te-green-100: #dcfce7;
    --te-green-300: #86efac;
    --te-green-400: #4ade80;
    --te-green-600: #16a34a;
    --te-green-700: #15803d;
    --te-yellow-100: #fef9c3;
    --te-yellow-300: #fde047;
    --te-yellow-400: #facc15;
    --te-yellow-600: #ca8a04;
    --te-yellow-700: #a16207;
    --te-purple-400: #c084fc;
    --te-purple-500: #a855f7;
    --te-purple-600: #9333ea;
    --te-purple-800: #6b21a8;
    --te-blue-400: #60a5fa;
    --te-blue-500: #3b82f6;
    --te-blue-600: #2563eb;
    --te-blue-800: #1e40af;
    --te-shadow-sm: 0 1px 2px 0 #0000000d;
    --te-shadow: 0 1px 3px 0 #0000001a 0 1px 2px -1px #0000001a;
    --te-shadow-lg: 0 10px 15px -3px #0000001a 0 4px 6px -4px #0000001a;
    --te-shadow-xl: 0 20px 25px -5px #0000001a 0 8px 10px -6px #0000001a;
    --border-radius-md: 0.325rem;
    --border-radius-lg: 0.5rem;
    --border-radius-xl: 0.75rem;
    --border-radius-md-full: 9999px;
    --te-transition: .3s ease
}

.dark,
[data-theme=dark] {
    --te-bg: var(--te-gray-900);
    --te-bg-card: var(--te-gray-800);
    --te-bg-subtle: var(--te-gray-700);
    --te-text: #fff;
    --te-text-muted: var(--te-gray-400);
    --te-border: var(--te-gray-700)
}

.te-event-container--narrow {
    max-width: 72rem
}

.te-archive-header {
    margin-bottom: 2rem;
    text-align: center
}

.te-archive-header__text {
    margin-bottom: 2rem
}

.te-archive-title {
    font-size: 2.25rem;
    line-height: 1.2;
    font-weight: 700;
    color: var(--te-primary-700)
}

.dark .te-archive-title {
    color: var(--te-primary-400)
}

.te-archive-description {
    color: var(--te-gray-600);
    margin-top: 1rem
}

.dark .te-archive-description,
.dark .te-empty-text {
    color: var(--te-gray-400)
}

.te-filters {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-items: center;
    justify-content: center
}

@media (min-width:768px) {
    .te-filters {
        flex-direction: row;
        justify-content: center;
        gap: 1.5rem
    }
}

.te-filter-group {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
    justify-content: center
}

.te-filter-btn {
    display: inline-block;
    padding: .5rem 1rem;
    transition: all var(--te-transition);
    text-decoration: none
}

.te-filter-btn {
    border-radius: var(--border-radius-md-full);
    font-size: .875rem;
    font-weight: 500;
    background: var(--te-gray-100);
    color: var(--te-gray-700);
    border: none;
    cursor: pointer
}

.dark .te-filter-btn {
    background: var(--te-gray-800);
    color: var(--te-gray-300)
}

.te-filter-btn:hover{
    background: var(--te-gray-200)
}

.dark .te-filter-btn:hover {
    background: var(--te-gray-700)
}

.te-filter-btn--active {
    background: var(--te-primary-600);
    color: #fff
}

.te-filter-btn--active:hover {
    background: var(--te-primary-700)
}

.te-filter-count {
    font-size: .75rem;
    opacity: .75;
    margin-inline-start: .25rem
}

.te-filters--pills .te-filter-btn {
    border-radius: var(--border-radius-md-full)
}

.te-filters--tabs {
    border-bottom: 2px solid var(--te-gray-200);
    padding-bottom: 0;
    gap: 0
}

.dark .te-filters--tabs {
    border-bottom-color: var(--te-gray-700)
}

.te-filters--tabs .te-filter-group {
    gap: 0
}

.te-filters--tabs .te-filter-btn {
    border-radius: 0;
    background: 0 0;
    color: var(--te-gray-600);
    padding: .75rem 1.25rem;
    margin-bottom: -2px;
    border-bottom: 2px solid transparent
}

.dark .te-filters--tabs .te-filter-btn {
    background: 0 0;
    color: var(--te-gray-400)
}

.te-filters--tabs .te-filter-btn:hover {
    background: var(--te-gray-50);
    color: var(--te-gray-900)
}

.dark .te-filters--tabs .te-filter-btn:hover {
    background: var(--te-gray-800);
    color: var(--te-gray-200)
}

.te-filters--tabs .te-filter-btn--active {
    background: 0 0;
    color: var(--te-primary-600);
    border-bottom-color: var(--te-primary-600)
}

.dark .te-filters--tabs .te-filter-btn--active {
    color: var(--te-primary-400);
    border-bottom-color: var(--te-primary-400)
}

.te-filters--tabs .te-filter-btn--active:hover {
    background: var(--te-gray-50)
}

.dark .te-filters--tabs .te-filter-btn--active:hover {
    background: var(--te-gray-800)
}

.te-filters--underline .te-filter-btn {
    background: 0 0;
    color: var(--te-gray-600);
    padding: .5rem .75rem;
    border-radius: 0;
    position: relative
}

.dark .te-filters--underline .te-filter-btn {
    background: 0 0;
    color: var(--te-gray-400)
}

.te-filters--underline .te-filter-btn::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 2px;
    background: var(--te-primary-600);
    transition: width var(--te-transition)
}

.te-filters--underline .te-filter-btn--active::after,
.te-filters--underline .te-filter-btn:hover::after {
    width: 100%
}

.te-filters--underline .te-filter-btn:hover {
    background: 0 0;
    color: var(--te-gray-900)
}

.dark .te-filters--underline .te-filter-btn:hover {
    background: 0 0;
    color: var(--te-gray-200)
}

.te-filters--underline .te-filter-btn--active {
    background: 0 0;
    color: var(--te-primary-600)
}

.dark .te-filters--underline .te-filter-btn--active {
    color: var(--te-primary-400)
}

.te-filters--underline .te-filter-btn--active:hover {
    background: 0 0
}

.te-filters--buttons .te-filter-btn {
    border-radius: var(--border-radius-md-md);
    background: var(--te-gray-100);
    color: var(--te-gray-700);
    padding: .625rem 1.25rem;
    border: 1px solid var(--te-gray-200);
    box-shadow: 0 1px 2px rgba(0, 0, 0, .05)
}

.dark .te-filters--buttons .te-filter-btn {
    background: var(--te-gray-800);
    color: var(--te-gray-300);
    border-color: var(--te-gray-700)
}

.te-filters--buttons .te-filter-btn:hover {
    background: var(--te-gray-50);
    border-color: var(--te-gray-300);
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(0, 0, 0, .1)
}

.dark .te-filters--buttons .te-filter-btn:hover {
    background: var(--te-gray-700);
    border-color: var(--te-gray-600)
}

.te-filters--buttons .te-filter-btn--active {
    background: var(--te-primary-600);
    color: #fff;
    border-color: var(--te-primary-600);
}

.te-filters--buttons .te-filter-btn--active:hover {
    background: var(--te-primary-700);
    border-color: var(--te-primary-700);
    transform: translateY(-1px)
}

.te-filters--minimal .te-filter-group {
    gap: 1rem
}

.te-filters--minimal .te-filter-btn {
    background: 0 0;
    color: var(--te-gray-500);
    padding: .25rem .5rem;
    border-radius: 0;
    font-weight: 400
}

.dark .te-filters--minimal .te-filter-btn {
    background: 0 0;
    color: var(--te-gray-500)
}

.te-filters--minimal .te-filter-btn:hover {
    background: 0 0;
    color: var(--te-gray-900)
}

.dark .te-filters--minimal .te-filter-btn:hover {
    background: 0 0;
    color: var(--te-gray-200)
}

.te-filters--minimal .te-filter-btn--active {
    background: 0 0;
    color: var(--te-primary-600);
    font-weight: 600
}

.dark .te-filters--minimal .te-filter-btn--active {
    color: var(--te-primary-400)
}

.te-filters--minimal .te-filter-btn--active:hover {
    background: 0 0
}

.te-events-grid {
    --te-columns: 3;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem
}

@media (min-width:768px) {
    .te-events-grid {
        grid-template-columns: repeat(min(var(--te-columns, 3), 2), 1fr)
    }
}

.te-empty-state {
    grid-column: 1/-1;
    text-align: center;
    padding: 4rem 1rem
}

.te-empty-icon {
    width: 4rem;
    height: 4rem;
    margin: 0 auto 1rem;
    color: var(--te-gray-400)
}

.te-empty-text {
    font-size: 1.125rem;
    color: var(--te-gray-500)
}

.te-table-pagination {
    margin-top: 2rem;
}

.te-event-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    background: #fff;
    border-radius: var(--border-radius-xl);
    overflow: hidden;
    box-shadow: var(--te-shadow-sm);
    border: 1px solid var(--te-gray-100);
    transition: all var(--te-transition)
}

.te-event-card__date-badge,
.te-single-event__date-badge {
    top: 1rem;
    left: 1rem;
    box-shadow: var(--te-shadow-lg);
    min-width: 70px;
    overflow: hidden;
    text-align: center
}

.dark .te-add-to-calendar,
.dark .te-event-card,
.dark .te-event-details,
.dark .te-event-map {
    background: var(--te-gray-800);
    border-color: var(--te-gray-700)
}

.te-event-card:hover {
    box-shadow: var(--te-shadow-xl);
    border-color: var(--te-primary-200);
    transform: translateY(-4px)
}

[dir=rtl] .te-calendar__list-arrow,
[dir=rtl] .te-calendar__nav-btn svg,
[dir=rtl] .te-event-card__btn svg,
[dir=rtl] .te-event-list__btn svg {
    transform: rotate(180deg)
}

.dark .te-event-card:hover,
.dark .te-event-compact:hover,
.dark .te-event-full:hover,
.dark .te-event-list:hover {
    border-color: var(--te-primary-800)
}

.te-event-card__image {
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden
}

.te-event-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s
}

.te-event-card:hover .te-event-card__image img {
    transform: scale(1.1)
}

.te-event-full:hover .te-event-full__bg img,
.te-event-list:hover .te-event-list__image img,
.te-event-timeline__card:hover .te-event-timeline__image img {
    transform: scale(1.05)
}

.te-event-card__image-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--te-primary-50), var(--te-primary-100))
}

.dark .te-event-card__image-placeholder {
    background: linear-gradient(135deg, var(--te-gray-700), var(--te-gray-800))
}

.te-event-card__image-placeholder svg {
    width: 5rem;
    height: 5rem;
    color: var(--te-primary-200)
}

.dark .te-event-card__image-placeholder svg {
    color: var(--te-gray-600)
}

.te-event-card__date-badge {
    position: absolute;
    z-index: 10;
    background: linear-gradient(135deg, var(--te-primary-600), var(--te-primary-800));
    color: #fff;
    border-radius: var(--border-radius-lg);
    padding: .5rem .75rem
}

[dir=rtl] .te-event-card__date-badge {
    right: auto;
    left: 1rem
}

.te-event-card__date-day {
    font-size: 1.875rem;
    font-weight: 700;
    line-height: 1;
    margin-bottom: .25rem
}

.te-event-card__date-month {
    font-size: .75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    line-height: 1.2;
    opacity: .9
}

.te-event-card__date-year,
.te-single-event__date-year {
    font-size: .625rem;
    font-weight: 500;
    opacity: .75;
    margin-top: .125rem;
    line-height: 1.2;
    letter-spacing: .05em
}

.te-event-card__body,
.te-event-modern__body {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: 1.5rem
}

.te-event-card__title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--te-gray-900);
    margin-bottom: .75rem;
    line-height: 1.3
}

.dark .te-event-card__title {
    color: #fff
}

.dark .te-event-card__excerpt,
.dark .te-event-card__meta-item {
    color: var(--te-gray-400)
}

.te-event-card__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--te-transition)
}

.te-event-card__title a:hover {
    color: var(--te-primary-600)
}

.dark .te-event-card__meta-icon svg,
.dark .te-event-card__title a:hover {
    color: var(--te-primary-400)
}

.te-event-card__excerpt {
    flex: 1;
    font-size: .875rem;
    color: var(--te-gray-600);
    line-height: 1.6;
    margin-bottom: 1.4rem
}

.te-event-card__btn,
.te-event-card__meta-item {
    font-size: .875rem;
    align-items: center;
    gap: .5rem
}

.te-event-card__meta {
    margin-bottom: 1.25rem
}

.te-event-card__meta-item {
    display: flex;
    color: var(--te-gray-600)
}

.te-event-card__meta-icon {
    flex-shrink: 0;
    width: 2rem;
    height: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #2563eb1a;
    border-radius: var(--border-radius-lg)
}

.dark .te-event-card__meta-icon {
    background: #2563eb33
}

.te-event-card__meta-icon svg {
    width: 1rem;
    height: 1rem;
    color: var(--te-primary-600)
}

.te-event-card__footer,
.te-event-magazine__main {
    margin-top: auto
}

.te-event-card__btn {
    display: inline-flex;
    justify-content: center;
    padding: .5rem 1rem;
    background: var(--te-primary-600);
    color: #fff;
    border-radius: var(--border-radius-md);
    text-decoration: none;
    font-weight: 500;
    transition: background var(--te-transition)
}

.te-event-card__btn:hover {
    background: var(--te-primary-700)
}

.te-event-card__btn svg {
    width: 1rem;
    height: 1rem
}

.te-single-event__featured {
    position: relative;
    aspect-ratio: 16/9;
    margin-bottom: 2rem;
    overflow: hidden;
    border-radius: var(--border-radius-xl)
}

.te-single-event__featured img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.te-single-event__featured-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--te-gray-200);
    border-radius: var(--border-radius-md);
    color: var(--te-gray-400)
}

.dark .te-single-event__featured-placeholder {
    background: var(--te-gray-800)
}

.te-single-event__featured-placeholder svg {
    width: 3rem;
    height: 3rem
}

.te-single-event__date-badge {
    position: absolute;
    background: linear-gradient(135deg, var(--te-primary-600), var(--te-primary-800));
    color: #fff;
    border-radius: var(--border-radius-lg);
    padding: .5rem .75rem
}

[dir=rtl] .te-single-event__date-badge {
    left: auto;
    right: 1rem
}

.te-single-event__date-day {
    font-size: 1.875rem;
    font-weight: 700;
    line-height: 1;
    margin-bottom: .25rem;
    color: #fff
}

.te-single-event__date-month {
    font-size: .75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    opacity: .9;
    color: #fff
}

.te-single-event__date-time {
    font-size: .75rem;
    font-weight: 500;
    color: #fff;
    opacity: .85;
    line-height: 1.2;
    margin-top: .375rem;
    padding-top: .375rem;
    border-top: 1px solid #fff3
}

.te-single-event__title {
    font-size: 1.875rem;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 1rem;
    color: var(--te-gray-900)
}

.dark .te-single-event__title {
    color: #fff
}

.te-calendar__header,
.te-single-event__content {
    margin-bottom: 2rem
}

.te-single-event--sidebar .te-single-event__inner,
.te-single-event__content .prose {
    max-width: none
}

.te-event-details {
    margin-top: 3rem;
    padding: 1.5rem;
    background: var(--te-gray-50);
    border-radius: var(--border-radius-xl);
    border: 1px solid var(--te-gray-200)
}

.te-event-details__title {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--te-gray-800);
    margin-bottom: 1.25rem
}

.dark .te-event-details__title {
    color: #fff;
    border-color: var(--te-gray-700)
}

.te-event-details__grid {
    display: grid;
    gap: 1rem
}

.te-event-details__item {
    display: flex;
    align-items: flex-start;
    gap: .875rem;
    padding: .875rem;
    background: #fff;
    border-radius: var(--border-radius-md);
    border: 1px solid var(--te-gray-100);
    transition: all var(--te-transition)
}

.te-event-details__item:hover {
    border-color: var(--te-gray-200);
    box-shadow: var(--te-shadow-sm)
}

.dark .te-event-details__item,
.dark .te-event-map__container {
    border-color: var(--te-gray-700)
}

.dark .te-event-details__item {
    background: var(--te-gray-900)
}

.dark .te-event-details__item:hover {
    border-color: var(--te-gray-600)
}

.te-event-details__icon {
    flex-shrink: 0;
    padding: .75rem;
    border-radius: var(--border-radius-lg)
}

.te-event-details__icon--date {
    background: #2563eb1a !important;
    color: #2563eb !important
}

.dark .te-event-details__icon--date {
    background: #2563eb33 !important;
    color: var(--te-primary-400) !important
}

.te-event-details__icon--time {
    background: #a855f71a !important;
    color: var(--te-purple-600) !important
}

.dark .te-event-details__icon--time {
    background: #a855f733 !important;
    color: var(--te-purple-400) !important
}

.te-event-details__icon--location {
    background: #ef44441a !important;
    color: var(--te-red-600) !important
}

.dark .te-event-details__icon--location {
    background: #ef444433 !important;
    color: var(--te-red-400) !important
}

.te-event-details__icon--organizer {
    background: #14b8a61a !important;
    color: #0d9488 !important
}

.dark .te-event-details__icon--organizer {
    background: #14b8a633 !important;
    color: #2dd4bf !important
}

.te-event-details__icon--type {
    background: #10b9811a !important;
    color: #059669 !important
}

.dark .te-event-details__icon--type {
    background: #10b98133 !important;
    color: #34d399 !important
}

.te-event-details__icon--price {
    background: #f59e0b1a !important;
    color: #d97706 !important
}

.dark .te-event-details__icon--price {
    background: #f59e0b33 !important;
    color: #fbbf24 !important
}

.te-event-details__icon--website {
    background: #6366f11a !important;
    color: #4f46e5 !important
}

.dark .te-event-details__icon--website {
    background: #6366f133 !important;
    color: #818cf8 !important
}

.te-event-details__icon--contact {
    background: #ec48991a !important;
    color: #db2777 !important
}

.dark .te-event-details__icon--contact {
    background: #ec489933 !important;
    color: #f472b6 !important
}

.te-event-details__icon svg {
    width: 1.25rem;
    height: 1.25rem
}

.te-event-details__content {
    flex: 1;
    display: flex;
    flex-direction: column
}

.te-event-details__label {
    font-size: .75rem;
    color: var(--te-gray-500);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .025em
}

.dark .te-event-details__label {
    color: var(--te-gray-400)
}

.te-event-details__value {
    font-weight: 600;
    font-size: .9375rem;
    color: var(--te-gray-800);
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap
}

.dark .te-event-details__value {
    color: var(--te-gray-100)
}

.te-status-badge {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    font-size: .6875rem;
    font-weight: 600;
    padding: .25rem .5rem;
    border-radius: 9999px;
    margin-inline-start: .5rem;
    vertical-align: middle;
    white-space: nowrap
}

.te-status-badge svg {
    width: .875rem;
    height: .875rem;
    flex-shrink: 0
}

.te-status-badge--upcoming {
    color: var(--te-green-700);
    background-color: var(--te-green-100)
}

.dark .te-status-badge--upcoming {
    color: var(--te-green-300);
    background-color: #22c55e26
}

.te-status-badge--today {
    color: var(--te-yellow-700);
    background-color: var(--te-yellow-100)
}

.dark .te-status-badge--today {
    color: var(--te-yellow-300);
    background-color: #eab30826
}

.te-status-badge--past {
    color: var(--te-red-700);
    background-color: var(--te-red-100)
}

.dark .te-status-badge--past {
    color: var(--te-red-300);
    background-color: #ef444426
}

.dark .te-calendar__title,
.dark .te-event-map__title {
    color: #fff
}

.te-add-to-calendar,
.te-event-map {
    margin-top: 2rem;
    padding: 1.5rem;
    background: var(--te-gray-50);
    border-radius: var(--border-radius-xl);
    border: 1px solid var(--te-gray-200)
}

.te-event-map__title {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--te-gray-800);
    margin: 0 0 1rem;
    display: flex;
    align-items: center;
    gap: .5rem
}

.te-event-map__container {
    overflow: hidden;
    border-radius: var(--border-radius-lg);
    box-shadow: var(--te-shadow);
    border: 1px solid var(--te-gray-200)
}

.te-event-map__container iframe {
    width: 100%;
    height: 350px;
    border: 0;
    display: block
}

.te-calendar {
    padding: 2rem 0
}

.te-calendar__header-inner,
.te-event-search,
.te-events-grid--list {
    display: flex;
    flex-direction: column;
    gap: 1rem
}

.te-calendar__title {
    font-size: 1.875rem;
    font-weight: 700;
    color: var(--te-gray-900)
}

.te-calendar__subtitle {
    color: var(--te-gray-600);
    margin-top: .25rem
}

.te-calendar__nav-btn,
.te-calendar__select {
    border-radius: var(--border-radius-lg);
    color: var(--te-gray-700)
}

.dark .te-calendar__subtitle {
    color: var(--te-gray-400)
}

.dark .te-calendar__nav-btn,
.dark .te-calendar__select {
    background: var(--te-gray-800);
    color: var(--te-gray-300)
}

.te-calendar__controls {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    align-items: center
}

.te-calendar__select {
    padding: .5rem 1rem;
    border: 1px solid var(--te-gray-300);
    background: #fff;
    font-size: .875rem
}

.dark .te-calendar__select {
    border-color: var(--te-gray-600)
}

.te-calendar__nav {
    display: flex;
    align-items: center;
    gap: .5rem
}

.te-calendar__nav-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: .5rem;
    background: var(--te-gray-100);
    text-decoration: none;
    transition: all var(--te-transition);
    border: none;
    cursor: pointer
}

.te-calendar__nav-btn:hover {
    background: var(--te-gray-200)
}

.dark .te-calendar__nav-btn:hover {
    background: var(--te-gray-700)
}

.te-calendar__nav-btn svg {
    width: 1.25rem;
    height: 1.25rem
}

.te-calendar__today-btn {
    padding: .5rem 1rem;
    border-radius: var(--border-radius-lg);
    background: var(--te-primary-600);
    color: #fff;
    font-size: .875rem;
    font-weight: 500;
    text-decoration: none;
    transition: background var(--te-transition)
}

.te-calendar__today-btn:hover {
    background: var(--te-primary-700)
}

.te-calendar__body {
    background: #fff;
    border-radius: var(--border-radius-xl);
    overflow: hidden;
    padding: 1.4rem
}

.te-calendar__day--empty,
.te-calendar__weekdays {
    background: var(--te-gray-50)
}

.dark .te-calendar__body {
    background: var(--te-gray-800)
}

.te-calendar__empty {
    text-align: center;
    padding: 4rem 1rem;
    color: var(--te-gray-500)
}

.dark .te-calendar__empty {
    color: var(--te-gray-400)
}

.te-calendar__empty-icon {
    width: 4rem;
    height: 4rem;
    margin: 0 auto 1rem;
    opacity: .5
}

.te-event-compact__date-month,
.te-event-full__date-month,
.te-event-timeline__month {
    opacity: .9;
    letter-spacing: .05em;
    text-transform: uppercase
}

.te-calendar__grid {
    display: none
}

.te-calendar__days,
.te-calendar__weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr)
}

.dark .te-calendar__weekdays {
    background: var(--te-gray-900)
}

.te-calendar__weekday {
    padding: .75rem;
    text-align: center;
    font-size: .875rem;
    font-weight: 600;
    color: var(--te-gray-600);
    border-bottom: 1px solid var(--te-gray-200)
}

.dark .te-calendar__weekday {
    color: var(--te-gray-400);
    border-color: var(--te-gray-700)
}

.te-calendar__day {
    min-height: 120px;
    padding: .5rem;
    border-bottom: 1px solid var(--te-gray-200);
    border-right: 1px solid var(--te-gray-200)
}

[dir=rtl] .te-calendar__day {
    border-right: none;
    border-left: 1px solid var(--te-gray-200)
}

.dark .te-calendar__day {
    border-color: var(--te-gray-700)
}

.dark .te-calendar__day--empty {
    background: #11182780
}

.te-calendar__day--today {
    background: var(--te-primary-50)
}

.dark .te-calendar__day--today {
    background: #2563eb1a
}

.te-calendar__day-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: .5rem
}

.te-calendar__day-number {
    font-size: .875rem;
    color: var(--te-gray-700)
}

.te-calendar__day-count,
.te-calendar__event {
    background: var(--te-primary-100);
    font-size: .75rem
}

.dark .te-calendar__day-number {
    color: var(--te-gray-300)
}

.te-calendar__day--today .te-calendar__day-number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    background: var(--te-primary-600);
    color: #fff;
    border-radius: var(--border-radius-md-full);
    font-size: .875rem;
    font-weight: 700
}

.te-calendar__day-count {
    color: var(--te-primary-600);
    font-weight: 700;
    padding: .125rem .5rem;
    border-radius: var(--border-radius-md-full)
}

.dark .te-calendar__day-count {
    background: var(--te-primary-900);
    color: var(--te-primary-400)
}

.te-calendar__event {
    display: block;
    margin-bottom: .25rem;
    padding: .375rem;
    border-radius: var(--border-radius-md);
    text-decoration: none;
    transition: background var(--te-transition)
}

.te-calendar__list-item,
.te-calendar__mobile-item {
    padding: 1rem;
    transition: background var(--te-transition);
    text-decoration: none
}

.dark .te-calendar__event {
    background: #2563eb4d
}

.te-calendar__event:hover {
    background: var(--te-primary-200)
}

.dark .te-calendar__event:hover {
    background: var(--te-primary-800)
}

.dark .te-calendar__list-item:hover,
.dark .te-calendar__mobile-item:hover {
    background: var(--te-gray-700)
}

.te-calendar__event-time,
.te-event-timeline__weekday {
    color: var(--te-primary-600);
    font-weight: 600
}

.dark .te-calendar__event-time {
    color: var(--te-primary-400)
}

.te-calendar__event-title {
    color: var(--te-gray-700);
    display: block;
    overflow: hidden
}

.dark .te-calendar__event-title {
    color: var(--te-gray-300)
}

.te-calendar__mobile {
    display: block
}

@media (min-width:1024px) {
    .te-events-grid {
        grid-template-columns: repeat(var(--te-columns, 3), 1fr)
    }

    .te-calendar__header-inner {
        flex-direction: row;
        align-items: center;
        justify-content: space-between
    }

    .te-calendar__grid {
        display: block
    }

    .te-calendar__mobile {
        display: none
    }
}

.te-calendar__mobile-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid var(--te-gray-200)
}

.dark .te-calendar__mobile-item {
    border-color: var(--te-gray-700)
}

.te-calendar__mobile-item:hover {
    background: var(--te-gray-50)
}

.te-calendar__mobile-title {
    font-weight: 600;
    color: var(--te-gray-900)
}

.dark .te-calendar__mobile-title {
    color: #fff
}

.te-calendar__mobile-time {
    font-size: .875rem;
    color: var(--te-gray-500);
    margin-top: .25rem
}

.dark .te-calendar__mobile-time {
    color: var(--te-gray-400)
}

.te-calendar__mobile-date {
    color: var(--te-primary-600);
    font-weight: 700
}

.dark .te-calendar__mobile-date {
    color: var(--te-primary-400)
}

.te-calendar__list {
    margin-top: 2rem
}

.te-calendar__list-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--te-gray-900);
    margin-bottom: 1rem
}

.te-add-to-calendar__title svg,
.te-event-registration__title svg {
    color: var(--te-primary-600)
}

.dark .te-calendar__list-title {
    color: #fff
}

.dark .te-add-to-calendar__title svg,
.dark .te-calendar__list-day-number,
.dark .te-event-registration__title svg {
    color: var(--te-primary-400)
}

.te-calendar__list-container {
    background: #fff;
    border-radius: var(--border-radius-xl);
    overflow: hidden
}

.dark .te-calendar__list-container,
.dark .te-closed-stats {
    background: var(--te-gray-800)
}

.te-calendar__list-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    border-bottom: 1px solid var(--te-gray-200)
}

.dark .te-calendar__list-item {
    border-color: var(--te-gray-700)
}

.te-calendar__list-item:last-child {
    border-bottom: none
}

.te-calendar__list-item:hover {
    background: var(--te-gray-50)
}

.te-calendar__list-day {
    flex-shrink: 0;
    width: 3.5rem;
    height: 3.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--te-primary-100);
    border-radius: var(--border-radius-lg)
}

.dark .te-calendar__list-day {
    background: var(--te-primary-900)
}

.te-calendar__list-day-number {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--te-primary-600)
}

.te-calendar__list-content,
.te-event-compact__body,
.te-event-full__main,
.te-event-minimal__center,
.te-single-event__main {
    flex: 1;
    min-width: 0
}

.te-calendar__list-event-title {
    font-weight: 600;
    color: var(--te-gray-900);
    overflow: hidden
}

.dark .te-calendar__list-event-title {
    color: #fff
}

.te-calendar__list-meta {
    font-size: .875rem;
    color: var(--te-gray-500);
    margin-top: .25rem
}

.dark .te-calendar__list-meta,
.te-calendar__list-arrow {
    color: var(--te-gray-400)
}

.te-calendar__list-arrow {
    flex-shrink: 0;
    width: 1.25rem;
    height: 1.25rem
}

.te-admin-wrap {
    max-width: 800px
}

.te-admin-card {
    background: #fff;
    border: 1px solid #c3c4c7;
    border-radius: 4px;
    margin-bottom: 20px;
    padding: 20px
}

.te-admin-card h2 {
    margin-top: 0;
    padding-bottom: 10px;
    border-bottom: 1px solid #eee
}

.te-admin-shortcode {
    display: flex;
    gap: 10px;
    align-items: center;
    margin: 15px 0
}

.te-admin-shortcode code {
    flex: 1;
    padding: 10px 15px;
    background: #f0f0f1;
    border-radius: 4px;
    font-size: 14px
}

.te-admin-shortcode .button {
    flex-shrink: 0
}

.te-admin-table {
    width: 100%;
    border-collapse: collapse
}

.te-admin-table td,
.te-admin-table th {
    padding: 10px;
    text-align: left;
    border-bottom: 1px solid #eee
}

.te-admin-table th {
    font-weight: 600;
    width: 200px
}

.te-admin-notice {
    padding: 10px 15px;
    background: #d1e7dd;
    border: 1px solid #badbcc;
    border-radius: 4px;
    color: #0f5132;
    margin-bottom: 15px
}

.te-add-to-calendar__title {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: 1rem;
    font-weight: 600;
    color: var(--te-gray-800);
    margin-bottom: 1rem
}

.dark .te-add-to-calendar__title {
    color: var(--te-gray-100)
}

.te-event-search--boxed-dark .te-event-search__label,
.te-event-search--dark .te-event-search__label {
    color: var(--te-gray-300)
}

.te-add-to-calendar__buttons {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem
}

.te-calendar-btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .625rem 1.25rem;
    font-size: .875rem;
    font-weight: 500;
    text-decoration: none;
    border-radius: var(--border-radius-md-full);
    transition: all var(--te-transition);
    border: none
}

.te-calendar-btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--te-shadow-lg);
    filter: brightness(1.1)
}

.te-calendar-btn--google {
    background: linear-gradient(135deg, #4285f4 0, #1a73e8 100%);
    color: #fff
}

.dark .te-calendar-btn--google {
    background: linear-gradient(135deg, #5a95f5 0, #4285f4 100%)
}

.te-calendar-btn--outlook {
    background: linear-gradient(135deg, #0078d4 0, #005a9e 100%);
    color: #fff
}

.dark .te-calendar-btn--outlook {
    background: linear-gradient(135deg, #2899e8 0, #0078d4 100%)
}

.te-calendar-btn--ical {
    background: linear-gradient(135deg, #374151 0, #1f2937 100%);
    color: #fff
}

.dark .te-calendar-btn--ical {
    background: linear-gradient(135deg, #4b5563 0, #374151 100%)
}

.te-event-search--boxed {
    padding: 1.5rem;
    background: var(--te-gray-50);
    border-radius: var(--border-radius-xl);
    border: 1px solid var(--te-gray-200)
}

.te-event-search--boxed-dark {
    padding: 1.5rem;
    background: var(--te-gray-800);
    border-radius: var(--border-radius-xl);
    border: 1px solid var(--te-gray-700)
}

.te-event-registration__field,
.te-event-search__field {
    display: flex;
    flex-direction: column;
    gap: .5rem
}

.te-event-search__label {
    font-size: .875rem;
    font-weight: 600;
    color: var(--te-gray-700)
}

.te-event-search__input-wrap {
    position: relative;
    display: flex;
    align-items: center
}

.te-event-search__icon {
    position: absolute;
    left: .75rem;
    color: var(--te-gray-400);
    pointer-events: none
}

[dir=rtl] .te-event-search__icon {
    left: auto;
    right: .75rem
}

.te-event-search__input,
.te-event-search__select {
    width: 100%;
    padding: .75rem .75rem .75rem 2.5rem;
    border: 1px solid var(--te-gray-300);
    border-radius: var(--border-radius-lg);
    font-size: .875rem;
    background: #fff;
    color: var(--te-gray-900);
    transition: all var(--te-transition)
}

[dir=rtl] .te-event-search__input,
[dir=rtl] .te-event-search__select {
    padding-left: .75rem;
    padding-right: 2.5rem
}

.te-event-search--boxed-dark .te-event-search__input,
.te-event-search--boxed-dark .te-event-search__select,
.te-event-search--dark .te-event-search__input,
.te-event-search--dark .te-event-search__select {
    background: var(--te-gray-700);
    border-color: var(--te-gray-600);
    color: var(--te-gray-100)
}

.te-event-search__input:focus,
.te-event-search__select:focus {
    outline: 0;
    border-color: var(--te-primary-500);
    box-shadow: 0 0 0 3px #2563eb1a
}

.te-event-search__input--date {
    cursor: pointer
}

.te-event-search__input--date::-webkit-calendar-picker-indicator {
    display: none !important;
    -webkit-appearance: none !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important
}

.te-event-search__input--date::-webkit-clear-button,
.te-event-search__input--date::-webkit-inner-spin-button {
    display: none !important
}

.te-event-search__input--date[type=date] {
    -moz-appearance: textfield
}

.te-event-search__submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: .75rem 1.5rem;
    background: var(--te-primary-600);
    color: #fff;
    border: none;
    border-radius: var(--border-radius-lg);
    font-size: .875rem;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--te-transition)
}

.te-event-search__submit:hover {
    background: var(--te-primary-700);
    transform: translateY(-2px);
    box-shadow: var(--te-shadow)
}

.te-event-registration {
    margin-top: 2rem;
    padding: 1.5rem;
    background: linear-gradient(135deg, var(--te-primary-50), var(--te-gray-50));
    border-radius: var(--border-radius-xl);
    border: 1px solid var(--te-primary-100)
}

@media (max-width:1024px) {

    .te-add-to-calendar,
    .te-event-details,
    .te-event-map {
        padding: 0;
        background: 0 0;
        border: none
    }

    .te-event-registration {
        padding: 1.5rem 1rem
    }
}

.dark .te-event-registration {
    background: linear-gradient(135deg, #2563eb1a, var(--te-gray-800));
    border-color: var(--te-gray-700)
}

.te-event-registration__title {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--te-gray-800);
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--te-gray-200)
}

.dark .te-event-registration__title {
    color: var(--te-gray-100);
    border-color: var(--te-gray-700)
}

.te-event-registration__form {
    display: flex;
    flex-direction: column;
    gap: 1.6rem
}

.te-event-registration__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem
}

.te-event-details--sidebar .te-event-details__grid,
.te-events-grid--overlay {
    grid-template-columns: 1fr
}

@media (max-width:640px) {
    .te-event-registration__row {
        grid-template-columns: 1fr
    }
}

.te-event-full__weekday,
.te-event-registration__field label {
    font-size: .875rem;
    font-weight: 600;
    color: var(--te-gray-700)
}

.dark .te-closed-message span,
.dark .te-event-registration__field label {
    color: var(--te-gray-300)
}

.te-event-registration__field label .required {
    color: var(--te-red-500)
}

.te-event-registration__field input {
    width: 100%;
    padding: .75rem 1rem;
    border: 1px solid var(--te-gray-300);
    border-radius: var(--border-radius-lg);
    font-size: .875rem;
    background: #fff;
    color: var(--te-gray-900);
    transition: all var(--te-transition)
}

.dark .te-event-registration__field input {
    background: var(--te-gray-700);
    border-color: var(--te-gray-600);
    color: var(--te-gray-100)
}

.te-event-registration__field input:focus {
    outline: 0;
    border-color: var(--te-primary-500);
    box-shadow: 0 0 0 3px #2563eb1a
}

.te-event-registration__field input::placeholder {
    color: var(--te-gray-400)
}

.te-event-registration__message {
    padding: .75rem 1rem;
    border-radius: var(--border-radius-lg);
    font-size: .875rem;
    font-weight: 500
}

.te-event-registration__message--success {
    background: #16a34a1a;
    color: var(--te-green-600);
    border: 1px solid #16a34a33
}

.te-event-registration__message--error {
    background: #ef44441a;
    color: var(--te-red-600);
    border: 1px solid #ef444433
}

.te-event-registration__submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: .875rem 1.5rem;
    background: linear-gradient(135deg, var(--te-primary-600), var(--te-primary-700));
    color: #fff;
    border: none;
    border-radius: var(--border-radius-lg);
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--te-transition)
}

.te-event-registration__submit:hover:not(:disabled) {
    background: linear-gradient(135deg, var(--te-primary-700), var(--te-primary-800));
    transform: translateY(-2px)
}

.te-event-registration__submit:disabled {
    opacity: .7;
    cursor: not-allowed
}

.te-event-registration__submit-loading {
    display: inline-flex;
    align-items: center;
    gap: .5rem
}

.te-spinner {
    animation: 1s linear infinite te-spin
}

@keyframes te-spin {
    from {
        transform: rotate(0)
    }

    to {
        transform: rotate(360deg)
    }
}

.te-event-registration__privacy {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .75rem;
    color: var(--te-gray-500)
}

.dark .te-event-registration__privacy {
    color: var(--te-gray-400)
}

.te-event-registration--closed {
    border-color: var(--te-gray-200);
    background: linear-gradient(135deg, var(--te-gray-50) 0, #fff 100%)
}

.dark .te-event-registration--closed {
    border-color: var(--te-gray-700);
    background: linear-gradient(135deg, var(--te-gray-800) 0, var(--te-gray-900) 100%)
}

.te-event-registration__closed {
    padding: 1.5rem
}

.te-closed-header {
    text-align: center;
    margin-bottom: 1.5rem
}

.te-closed-header__icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 1rem;
    background: linear-gradient(135deg, var(--te-red-500) 0, var(--te-red-600) 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 24px #ef44444d
}

.dark .te-closed-header__icon {
    background: linear-gradient(135deg, var(--te-red-600) 0, var(--te-red-700) 100%);
    box-shadow: 0 8px 24px #ef444433
}

.te-closed-header__icon svg {
    color: #fff
}

.te-closed-header__title {
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--te-gray-900);
    margin: 0 0 .5rem
}

.dark .te-closed-header__title {
    color: var(--te-gray-100)
}

.te-closed-header__subtitle {
    font-size: .9rem;
    color: var(--te-gray-500);
    margin: 0
}

.dark .te-closed-header__subtitle {
    color: var(--te-gray-400)
}

.te-closed-stats {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
    margin-bottom: 1.25rem;
    padding: 1.25rem;
    background: var(--te-gray-100);
    border-radius: var(--border-radius-xl)
}

.te-closed-stats__card {
    text-align: center;
    min-width: 80px
}

.te-closed-stats__number {
    font-size: 2rem;
    font-weight: 800;
    color: var(--te-gray-900);
    line-height: 1;
    margin-bottom: .25rem
}

.dark .te-closed-stats__number {
    color: var(--te-gray-100)
}

.te-closed-stats__label {
    font-size: .75rem;
    font-weight: 600;
    color: var(--te-gray-500);
    text-transform: uppercase;
    letter-spacing: .05em
}

.dark .te-closed-stats__label {
    color: var(--te-gray-400)
}

.dark .te-event-list__date,
.dark .te-event-list__title a:hover {
    color: var(--te-primary-400)
}

.te-closed-stats__divider {
    width: 1px;
    height: 40px;
    background: var(--te-gray-300)
}

.dark .te-closed-stats__divider {
    background: var(--te-gray-600)
}

.te-closed-progress {
    display: flex;
    align-items: center;
    gap: .75rem;
    margin-bottom: 1rem
}

.te-closed-progress__bar {
    flex: 1;
    height: 10px;
    background: var(--te-gray-200);
    border-radius: var(--border-radius-md-full);
    overflow: hidden
}

.dark .te-closed-progress__bar {
    background: var(--te-gray-700)
}

.te-closed-progress__fill {
    height: 100%;
    background: linear-gradient(90deg, var(--te-red-500) 0, var(--te-red-600) 100%);
    border-radius: var(--border-radius-md-full);
    transition: width .5s
}

.dark .te-closed-progress__fill {
    background: linear-gradient(90deg, var(--te-red-500) 0, var(--te-red-400) 100%)
}

.te-closed-progress__badge {
    flex-shrink: 0;
    background: var(--te-red-600);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    padding: .35rem .75rem;
    border-radius: var(--border-radius-md-full)
}

.dark .te-closed-progress__badge {
    background: var(--te-red-500)
}

.te-closed-message {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: .875rem 1rem;
    background: #ef444414;
    border-radius: var(--border-radius-lg);
    border: 1px solid #ef444426
}

.dark .te-closed-message {
    background: #ef44441a;
    border-color: #ef444433
}

.te-closed-message svg {
    flex-shrink: 0;
    color: var(--te-red-500)
}

.dark .te-closed-message svg {
    color: var(--te-red-400)
}

.te-closed-message span {
    font-size: .875rem;
    color: var(--te-gray-700);
    line-height: 1.4
}

.te-single-event__layout {
    display: flex;
    flex-direction: column;
    gap: 2rem
}

@media (min-width:1024px) {
    .te-single-event__layout {
        flex-direction: row;
        gap: 2.5rem
    }

    .te-single-event__sidebar {
        width: 320px;
        flex-shrink: 0
    }
}

@media (min-width:1280px) {
    .te-single-event__sidebar {
        width: 360px
    }
}

.te-single-event__sidebar-inner {
    position: sticky;
    top: 2rem
}

.te-event-full,
.te-event-full__bg {
    position: relative;
    overflow: hidden
}

.te-event-details--sidebar {
    margin-top: 0;
    background: #fff;
    border: 1px solid var(--te-gray-200)
}

.dark .te-event-compact,
.dark .te-event-details--sidebar,
.dark .te-event-full,
.dark .te-event-list {
    background: var(--te-gray-800);
    border-color: var(--te-gray-700)
}

.te-event-details--sidebar .te-event-details__item {
    padding: .75rem
}

.te-event-details--sidebar .te-event-details__icon {
    padding: .625rem
}

.te-event-details--sidebar .te-event-details__icon svg {
    width: 1.125rem;
    height: 1.125rem
}

.te-event-details--sidebar .te-event-details__label {
    font-size: .6875rem
}

.te-event-details--sidebar .te-event-details__value {
    font-size: .875rem
}

.te-event-details--mobile {
    display: block;
    margin-top: 2rem;
    padding: 0;
    border: none;
    background: 0 0
}

.te-event-full__overlay,
.te-event-timeline-wrap:last-child .te-event-timeline__line,
.te-single-event--sidebar .te-event-details:not(.te-event-details--sidebar):not(.te-event-details--mobile),
.te-single-event__sidebar {
    display: none
}

.te-event-compact,
.te-event-list {
    border-radius: var(--border-radius-lg);
    box-shadow: var(--te-shadow-sm);
    transition: all var(--te-transition)
}

.te-event-list {
    display: flex;
    flex-direction: column;
    background: #fff;
    overflow: hidden;
    border: 1px solid var(--te-gray-100)
}

.te-event-list:hover {
    box-shadow: var(--te-shadow-lg);
    border-color: var(--te-primary-200)
}

.te-event-list__image {
    flex-shrink: 0;
    width: 100%;
    height: 180px;
    overflow: hidden;
    margin: .75rem .75rem 0;
    border-radius: var(--border-radius-md);
    width: calc(100% - 1.5rem)
}

.te-event-list__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--te-transition);
    border-radius: var(--border-radius-md)
}

.te-event-list__image-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--te-primary-50), var(--te-primary-100));
    border-radius: var(--border-radius-md)
}

.dark .te-event-list__image-placeholder {
    background: linear-gradient(135deg, var(--te-gray-700), var(--te-gray-800))
}

.te-event-list__image-placeholder svg {
    color: var(--te-primary-200)
}

.dark .te-event-list__image-placeholder svg {
    color: var(--te-gray-600)
}

.te-event-list__date,
.te-event-list__title a:hover,
.te-event-timeline__title a:hover {
    color: var(--te-primary-600)
}

.te-event-list__body {
    flex: 1;
    padding: 1rem 1.25rem;
    min-width: 0
}

.te-event-list__date {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .8125rem;
    font-weight: 600;
    margin-bottom: .5rem
}

.te-event-list__date-day {
    font-weight: 700
}

.te-event-list__date-time {
    color: var(--te-gray-500);
    padding-inline-start: .5rem;
    border-inline-start: 1px solid var(--te-gray-300)
}

.dark .te-event-list__date-time {
    color: var(--te-gray-400);
    border-color: var(--te-gray-600)
}

.te-event-list__title {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--te-gray-900);
    margin: 0 0 .5rem;
    line-height: 1.3
}

.dark .te-event-list__title {
    color: #fff
}

.dark .te-event-list__excerpt,
.dark .te-event-list__meta {
    color: var(--te-gray-400)
}

.te-event-list__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--te-transition)
}

.te-event-list__excerpt {
    font-size: .875rem;
    color: var(--te-gray-600);
    line-height: 1.5;
    margin: 0 0 .75rem;
    display: -webkit-box;
    overflow: hidden
}

.te-event-list__meta {
    display: flex;
    align-items: center;
    gap: .375rem;
    font-size: .8125rem;
    color: var(--te-gray-500)
}

.te-event-full__action,
.te-event-list__meta svg,
.te-event-minimal__left {
    flex-shrink: 0
}

.te-event-list__action {
    flex-shrink: 0;
    padding: 1rem
}

.te-event-list__btn {
    display: inline-flex;
    align-items: center;
    gap: .375rem;
    padding: .5rem 1rem;
    background: var(--te-primary-600);
    color: #fff;
    border-radius: var(--border-radius-md);
    text-decoration: none;
    font-size: .8125rem;
    font-weight: 600;
    transition: all var(--te-transition)
}

.te-event-list__btn:hover {
    background: var(--te-primary-700);
    transform: translateX(2px)
}

[dir=rtl] .te-event-list__btn:hover {
    transform: translateX(-2px)
}

[dir=rtl] .te-event-compact:hover,
[dir=rtl] .te-event-compact:hover .te-event-compact__arrow,
[dir=rtl] .te-event-gradient:hover .te-event-gradient__arrow,
[dir=rtl] .te-event-magazine:hover .te-event-magazine__arrow,
[dir=rtl] .te-event-minimal:hover .te-event-minimal__arrow {
    transform: translateX(-4px)
}

.te-events-grid--compact {
    display: flex;
    flex-direction: column;
    gap: .75rem
}

.te-event-compact {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.25rem;
    background: #fff;
    border: 1px solid var(--te-gray-100);
    text-decoration: none
}

.te-event-compact:hover {
    box-shadow: var(--te-shadow);
    border-color: var(--te-primary-200);
    transform: translateX(4px)
}

[dir=rtl] .te-event-compact__arrow,
[dir=rtl] .te-event-full__btn svg,
[dir=rtl] .te-event-timeline__btn svg {
    transform: rotate(180deg)
}

.te-event-compact__date {
    flex-shrink: 0;
    width: 80px;
    height: 80px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--te-primary-600), var(--te-primary-800));
    color: #fff;
    border-radius: var(--border-radius-lg);
    text-align: center;
}

.te-event-compact__date-day {
    font-size: 1.375rem;
    font-weight: 700;
    line-height: 1;
    margin-bottom: .125rem
}

.te-event-compact__date-month {
    font-size: .6875rem;
    font-weight: 600;
    line-height: 1
}

.te-event-compact__title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--te-gray-900);
    margin: 0 0 .25rem;
    overflow: hidden
}

.dark .te-event-compact__title {
    color: #fff
}

.te-event-compact__meta {
    display: flex;
    align-items: center;
    gap: .75rem;
    font-size: .75rem;
    color: var(--te-gray-500)
}

.dark .te-event-compact__meta,
.te-event-compact__arrow {
    color: var(--te-gray-400)
}

.te-event-compact__location,
.te-event-compact__time,
.te-event-magazine__date,
.te-event-magazine__location,
.te-event-magazine__time,
.te-event-overlay__location,
.te-event-overlay__time {
    display: flex;
    align-items: center;
    gap: .25rem
}

.te-event-compact__location {
    overflow: hidden
}

.te-event-compact__arrow {
    flex-shrink: 0;
    transition: transform var(--te-transition)
}

.te-event-full,
.te-event-full__btn,
.te-event-minimal,
.te-event-modern,
.te-event-modern__btn,
.te-event-timeline__btn,
.te-event-timeline__card {
    transition: all var(--te-transition)
}

.dark .te-event-compact__arrow {
    color: var(--te-gray-500)
}

.te-event-compact:hover .te-event-compact__arrow {
    transform: translateX(4px);
    color: var(--te-primary-600)
}

.te-events-grid--full {
    display: flex;
    flex-direction: column;
    gap: 1.5rem
}

.te-event-full {
    display: flex;
    flex-direction: column;
    min-height: 280px;
    background: #fff;
    border-radius: var(--border-radius-xl);
    box-shadow: var(--te-shadow-sm);
    border: 1px solid var(--te-gray-100)
}

.te-event-full:hover {
    box-shadow: var(--te-shadow-xl);
    border-color: var(--te-primary-200)
}

.te-event-full__bg {
    width: 100%;
    height: 200px
}

.te-event-full__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s
}

.te-event-full__content {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 1.5rem
}

.te-event-full__date {
    display: flex;
    align-items: center;
    gap: 1rem
}

.te-event-full__date-badge {
    width: 64px;
    height: 64px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--te-primary-600), var(--te-primary-800));
    color: #fff;
    border-radius: var(--border-radius-lg);
    text-align: center;
    box-shadow: var(--te-shadow-lg)
}

.te-event-full__date-day {
    font-size: 1.75rem;
    font-weight: 700;
    line-height: 1
}

.te-event-full__date-month {
    font-size: .6875rem;
    font-weight: 600
}

.te-event-elegant__date-info,
.te-event-full__date-info {
    display: flex;
    flex-direction: column;
    gap: .125rem
}

.dark .te-event-full__weekday {
    color: var(--te-gray-300)
}

.te-event-full__time {
    font-size: .8125rem;
    color: var(--te-gray-500)
}

.dark .te-event-full__time {
    color: var(--te-gray-400)
}

.te-event-full__title {
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--te-gray-900);
    margin: 0 0 .5rem;
    line-height: 1.3
}

.dark .te-event-full__title {
    color: #fff
}

.dark .te-event-full__excerpt,
.dark .te-event-full__location {
    color: var(--te-gray-400)
}

.te-event-full__title a {
    color: inherit;
    text-decoration: none;
    transition: opacity var(--te-transition)
}

.te-event-full__title a:hover {
    opacity: .8
}

.te-event-full__excerpt {
    font-size: .9rem;
    color: var(--te-gray-600);
    line-height: 1.5;
    margin: 0 0 .75rem;
    display: -webkit-box;
    overflow: hidden
}

.te-event-full__location {
    display: flex;
    align-items: center;
    gap: .375rem;
    font-size: .875rem;
    color: var(--te-gray-500)
}

.dark .te-event-timeline__title a:hover,
.dark .te-event-timeline__weekday {
    color: var(--te-primary-400)
}

.te-event-full__btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .75rem 1.5rem;
    background: var(--te-primary-600);
    color: #fff;
    border-radius: var(--border-radius-lg);
    text-decoration: none;
    font-size: .9rem;
    font-weight: 600
}

.te-event-full__btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--te-shadow-lg)
}

.te-events-grid--timeline {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding-inline-start: 1rem
}

.te-event-timeline {
    display: flex;
    gap: 1.5rem;
    position: relative
}

.te-event-timeline__marker {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-shrink: 0;
    width: 70px
}

.te-event-timeline__date {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    background: linear-gradient(135deg, var(--te-primary-600), var(--te-primary-800));
    color: #fff;
    border-radius: var(--border-radius-lg);
    text-align: center;
    position: relative;
    z-index: 2
}

.te-event-overlay,
.te-event-timeline__card {
    overflow: hidden;
    box-shadow: var(--te-shadow-sm)
}

.te-event-timeline__day {
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.4
}

.te-event-timeline__month {
    font-size: .625rem;
    font-weight: 600;
    line-height: 1.4
}

.te-event-timeline__year {
    font-size: .5rem;
    line-height: 1.4;
    opacity: .7
}

.te-event-timeline__line {
    flex: 1;
    width: 2px;
    background: var(--te-gray-200);
    margin-top: .5rem
}

.dark .te-event-timeline__line {
    background: var(--te-gray-700)
}

.te-event-timeline__card {
    flex: 1;
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: var(--border-radius-lg);
    border: 1px solid var(--te-gray-100);
    margin-bottom: 1.5rem
}

.dark .te-event-boxed,
.dark .te-event-minimal,
.dark .te-event-timeline__card {
    background: var(--te-gray-800);
    border-color: var(--te-gray-700)
}

.te-event-timeline__card:hover {
    box-shadow: var(--te-shadow-lg);
    border-color: var(--te-primary-200)
}

.dark .te-event-timeline__card:hover {
    border-color: var(--te-primary-800)
}

.te-event-timeline__image {
    flex-shrink: 0;
    width: 100%;
    height: 140px;
    overflow: hidden
}

.te-event-timeline__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--te-transition)
}

.te-event-modern:hover .te-event-modern__image img,
.te-event-overlay:hover .te-event-overlay__bg img {
    transform: scale(1.08)
}

.te-event-timeline__content {
    flex: 1;
    padding: 1rem 1.25rem;
    display: flex;
    flex-direction: column
}

.te-event-timeline__meta-top {
    display: flex;
    align-items: center;
    gap: .75rem;
    font-size: .75rem;
    margin-bottom: .5rem
}

.te-event-timeline__time {
    display: flex;
    align-items: center;
    gap: .25rem;
    color: var(--te-gray-500)
}

.dark .te-event-timeline__time {
    color: var(--te-gray-400)
}

.te-event-timeline__title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--te-gray-900);
    margin: 0 0 .375rem;
    line-height: 1.3
}

.dark .te-event-timeline__title {
    color: #fff
}

.dark .te-event-timeline__excerpt,
.dark .te-event-timeline__location {
    color: var(--te-gray-400)
}

.te-event-timeline__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--te-transition)
}

.te-event-timeline__excerpt {
    font-size: .8125rem;
    color: var(--te-gray-600);
    line-height: 1.5;
    margin: 0 0 .75rem;
    flex: 1
}

.te-event-timeline__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    flex-wrap: wrap
}

.te-event-minimal__location,
.te-event-timeline__location {
    display: flex;
    align-items: center;
    gap: .25rem;
    font-size: .75rem;
    color: var(--te-gray-500)
}

.te-event-timeline__btn {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    font-size: .75rem;
    font-weight: 600;
    color: var(--te-primary-600);
    text-decoration: none
}

.dark .te-event-timeline__btn {
    color: var(--te-primary-400)
}

.te-event-timeline__btn:hover {
    gap: .5rem
}

.te-events-grid--overlay {
    display: grid;
    gap: 1.25rem
}

@media (min-width:640px) {
    .te-event-details__grid {
        grid-template-columns: repeat(2, 1fr)
    }

    .te-event-list {
        flex-direction: row;
        align-items: center
    }

    .te-event-list__image {
        width: 160px;
        height: 100%;
        min-height: 120px;
        margin: .75rem;
        margin-inline-end: 0
    }

    .te-event-list__action {
        padding: 1rem 1.25rem
    }

    .te-event-timeline__card {
        flex-direction: row
    }

    .te-event-timeline__image {
        width: 140px;
        height: auto
    }

    .te-events-grid--overlay {
        grid-template-columns: repeat(min(var(--te-columns, 3), 2), 1fr)
    }
}

@media (min-width:1024px) {
    .te-event-details--mobile {
        display: none
    }

    .te-single-event__sidebar {
        display: block
    }

    .te-events-grid--overlay {
        grid-template-columns: repeat(var(--te-columns, 3), 1fr)
    }
}

.te-event-overlay {
    position: relative;
    display: block;
    aspect-ratio: 4/5;
    border-radius: var(--border-radius-xl);
    text-decoration: none
}

.te-event-magazine__bg,
.te-event-overlay__bg {
    position: absolute;
    inset: 0
}

.te-event-overlay__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s
}

.te-event-overlay__placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--te-gray-700), var(--te-gray-900))
}

.te-event-overlay__placeholder svg {
    color: var(--te-gray-500)
}

.te-event-overlay__gradient {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, .9) 0, rgba(0, 0, 0, .5) 40%, rgba(0, 0, 0, .1) 70%, transparent 100%)
}

.te-event-overlay__badge {
    position: absolute;
    top: 1rem;
    left: 1rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    background: var(--te-primary-600);
    border-radius: var(--border-radius-lg);
    text-align: center;
    box-shadow: 0 4px 12px rgba(0, 0, 0, .15)
}

[dir=rtl] .te-event-overlay__badge {
    left: auto;
    right: 1rem
}

.te-event-overlay__badge-day {
    font-size: 1.25rem;
    font-weight: 700;
    color: #fff;
    line-height: 1
}

.te-event-overlay__badge-month {
    font-size: .625rem;
    font-weight: 600;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: .05em
}

.te-event-overlay__content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 1.25rem;
    color: #fff;
    z-index: 2
}

.te-event-overlay__meta {
    display: flex;
    align-items: center;
    gap: .75rem;
    margin-bottom: .5rem;
    font-size: .6875rem;
    opacity: .85
}

.te-event-overlay__excerpt,
.te-event-overlay__title {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden
}

.te-event-overlay__title {
    font-size: 1.125rem;
    font-weight: 700;
    color: #fff;
    margin: 0 0 .375rem;
    line-height: 1.3
}

.te-event-overlay__excerpt {
    font-size: .8125rem;
    color: rgba(255, 255, 255, .8);
    margin: 0;
    line-height: 1.4
}

.te-events-grid--modern {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem
}

@media (min-width:768px) {
    .te-event-list__image {
        width: 200px;
        min-height: 140px
    }

    .te-event-full {
        flex-direction: row;
        min-height: 220px
    }

    .te-event-full__bg {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%
    }

    .te-event-full__overlay {
        display: block;
        position: absolute;
        inset: 0;
        background: linear-gradient(90deg, rgba(0, 0, 0, .85) 0, rgba(0, 0, 0, .6) 50%, rgba(0, 0, 0, .3) 100%)
    }

    [dir=rtl] .te-event-full__overlay {
        background: linear-gradient(270deg, rgba(0, 0, 0, .85) 0, rgba(0, 0, 0, .6) 50%, rgba(0, 0, 0, .3) 100%)
    }

    .te-event-full__content {
        flex-direction: row;
        align-items: center;
        padding: 2rem;
        color: #fff
    }

    .te-event-full__date {
        flex-shrink: 0
    }

    .te-event-full__date-badge {
        width: 80px;
        height: 80px;
        background: rgba(255, 255, 255, .15);
        backdrop-filter: blur(8px)
    }

    .te-event-full__date-day {
        font-size: 2rem
    }

    .te-event-full__weekday {
        color: rgba(255, 255, 255, .9)
    }

    .te-event-full__location,
    .te-event-full__time {
        color: rgba(255, 255, 255, .7)
    }

    .te-event-full__main {
        padding: 0 1.5rem
    }

    .te-event-full__title {
        font-size: 1.5rem;
        color: #fff
    }

    .te-event-full__excerpt {
        color: rgba(255, 255, 255, .8)
    }

    .te-event-full__action {
        padding-inline-start: 1rem
    }

    .te-event-full__btn {
        background: rgba(255, 255, 255, .15);
        backdrop-filter: blur(8px);
        border: 1px solid rgba(255, 255, 255, .2)
    }

    .te-event-full__btn:hover {
        background: rgba(255, 255, 255, .25)
    }

    .te-events-grid--modern {
        grid-template-columns: repeat(min(var(--te-columns, 3), 2), 1fr)
    }
}

@media (min-width:1024px) {
    .te-events-grid--modern {
        grid-template-columns: repeat(var(--te-columns, 3), 1fr)
    }
}

.te-event-modern {
    display: flex;
    flex-direction: column;
    height: 100%;
    background: #fff;
    border-radius: var(--border-radius-xl);
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0, 0, 0, .08)
}

.dark .te-event-modern {
    background: var(--te-gray-800);
    box-shadow: 0 4px 20px rgba(0, 0, 0, .3)
}

.te-event-modern:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, .15)
}

[dir=rtl] .te-event-boxed__btn svg,
[dir=rtl] .te-event-elegant__link svg,
[dir=rtl] .te-event-gradient__arrow svg,
[dir=rtl] .te-event-magazine__arrow svg,
[dir=rtl] .te-event-minimal__arrow,
[dir=rtl] .te-event-modern__btn svg {
    transform: rotate(180deg)
}

.dark .te-event-modern:hover {
    box-shadow: 0 12px 40px rgba(0, 0, 0, .4)
}

.te-event-modern__image {
    position: relative;
    aspect-ratio: 16/10;
    overflow: hidden
}

.te-event-modern__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .6s
}

.te-event-boxed:hover .te-event-boxed__image img,
.te-event-elegant:hover .te-event-elegant__image img {
    transform: scale(1.05)
}

.te-event-modern__image-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--te-gray-100), var(--te-gray-200))
}

.dark .te-event-modern__image-placeholder {
    background: linear-gradient(135deg, var(--te-gray-700), var(--te-gray-800))
}

.te-event-modern__image-placeholder svg {
    color: var(--te-gray-400)
}

.te-event-modern__type-badge {
    position: absolute;
    top: 1rem;
    right: 1rem;
    padding: .375rem .75rem;
    border-radius: var(--border-radius-md-full);
    font-size: .6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em
}

[dir=rtl] .te-event-modern__type-badge {
    right: auto;
    left: 1rem
}

.te-event-modern__type-badge--in-person {
    background: var(--te-green-100);
    color: var(--te-green-700)
}

.te-event-modern__type-badge--virtual {
    background: #f3e8ff;
    color: var(--te-purple-600)
}

.te-event-modern__type-badge--hybrid {
    background: #dbeafe;
    color: var(--te-blue-600)
}

.te-event-modern__date-row {
    display: flex;
    align-items: center;
    gap: .75rem;
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--te-gray-100)
}

.dark .te-event-modern__date-row {
    border-color: var(--te-gray-700)
}

.te-event-modern__date-icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--te-primary-100);
    border-radius: var(--border-radius-lg);
    color: var(--te-primary-600)
}

.dark .te-event-modern__date-icon {
    background: var(--te-primary-900);
    color: var(--te-primary-400)
}

.te-event-modern__date-text {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .375rem;
    font-size: .875rem;
    color: var(--te-gray-600)
}

.dark .te-event-modern__date-text {
    color: var(--te-gray-400)
}

.te-event-modern__weekday {
    font-weight: 600;
    color: var(--te-gray-800)
}

.dark .te-event-modern__weekday {
    color: var(--te-gray-200)
}

.dark .te-event-modern__time,
.dark .te-event-modern__title a:hover {
    color: var(--te-primary-400)
}

.te-event-minimal__time,
.te-event-modern__time {
    color: var(--te-primary-600);
    font-weight: 500
}

.te-event-modern__title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--te-gray-900);
    margin: 0 0 .75rem;
    line-height: 1.3
}

.dark .te-event-modern__title {
    color: #fff
}

.dark .te-event-modern__excerpt,
.dark .te-event-modern__location {
    color: var(--te-gray-400)
}

.te-event-modern__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--te-transition)
}

.te-event-modern__title a:hover {
    color: var(--te-primary-600)
}

.te-event-elegant__excerpt,
.te-event-modern__excerpt {
    flex: 1;
    font-size: .875rem;
    color: var(--te-gray-600);
    line-height: 1.6;
    margin: 0 0 1.25rem
}

.te-event-modern__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: auto;
    padding-top: 1rem;
    border-top: 1px solid var(--te-gray-100)
}

.dark .te-event-modern__footer {
    border-color: var(--te-gray-700)
}

.te-event-modern__location {
    display: flex;
    align-items: center;
    gap: .375rem;
    font-size: .8125rem;
    color: var(--te-gray-500);
    overflow: hidden
}

.te-event-modern__btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    font-size: .8125rem;
    font-weight: 600;
    color: var(--te-primary-600);
    text-decoration: none
}

.dark .te-event-modern__btn {
    color: var(--te-primary-400)
}

.te-event-modern__btn:hover {
    gap: .75rem
}

.te-events-grid--minimal {
    display: flex;
    flex-direction: column;
    gap: 1rem
}

.te-event-minimal {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 1.25rem;
    background: #fff;
    border-radius: var(--border-radius-lg);
    border: 1px solid var(--te-gray-200);
    text-decoration: none
}

.te-event-minimal:hover {
    border-color: var(--te-primary-300);
    box-shadow: 0 4px 12px rgba(37, 99, 235, .1)
}

.dark .te-event-minimal:hover {
    border-color: var(--te-primary-700);
    box-shadow: 0 4px 12px rgba(37, 99, 235, .2)
}

.te-event-minimal__date {
    font-size: 1rem;
    font-weight: 700;
    color: var(--te-gray-900);
    margin-bottom: .25rem
}

.dark .te-event-minimal__date {
    color: #fff
}

.te-event-minimal__meta {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .8125rem;
    color: var(--te-gray-500)
}

.dark .te-event-minimal__meta {
    color: var(--te-gray-400)
}

.te-event-minimal__divider {
    opacity: .5
}

.dark .te-event-minimal__time {
    color: var(--te-primary-400)
}

.te-event-minimal__title {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--te-gray-900);
    margin: 0 0 .375rem;
    line-height: 1.3
}

.dark .te-event-minimal__title {
    color: #fff
}

.dark .te-event-minimal__excerpt,
.dark .te-event-minimal__location {
    color: var(--te-gray-400)
}

.te-event-minimal__excerpt {
    font-size: .875rem;
    color: var(--te-gray-600);
    line-height: 1.5;
    margin: 0 0 .5rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden
}

.te-event-minimal__right {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-shrink: 0
}

.te-event-minimal__status {
    padding: .375rem .75rem;
    border-radius: var(--border-radius-md-full);
    font-size: .6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em
}

.te-event-minimal__status--upcoming {
    background: var(--te-green-100);
    color: var(--te-green-700)
}

.dark .te-event-minimal__status--upcoming {
    background: rgba(34, 197, 94, .15);
    color: var(--te-green-400)
}

.te-event-minimal__status--today {
    background: var(--te-yellow-100);
    color: var(--te-yellow-700)
}

.dark .te-event-minimal__status--today {
    background: rgba(234, 179, 8, .15);
    color: var(--te-yellow-400)
}

.te-event-minimal__status--past {
    background: var(--te-gray-100);
    color: var(--te-gray-600)
}

.dark .te-event-minimal__status--past {
    background: var(--te-gray-700);
    color: var(--te-gray-400)
}

.te-event-minimal__arrow {
    color: var(--te-gray-400);
    transition: transform var(--te-transition)
}

.te-event-boxed__date-day,
.te-event-boxed__title a:hover {
    color: var(--te-primary-600)
}

.te-event-boxed,
.te-event-boxed__btn,
.te-event-elegant,
.te-event-elegant__link,
.te-event-gradient,
.te-event-gradient__arrow {
    transition: all var(--te-transition)
}

.dark .te-event-minimal__arrow {
    color: var(--te-gray-500)
}

.dark .te-event-boxed__date-day,
.dark .te-event-boxed__title a:hover {
    color: var(--te-primary-400)
}

.te-event-minimal:hover .te-event-minimal__arrow {
    transform: translateX(4px);
    color: var(--te-primary-600)
}

.te-events-grid--boxed {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem
}

@media (min-width:768px) {
    .te-event-minimal {
        flex-direction: row;
        align-items: center
    }

    .te-event-minimal__left {
        width: 160px;
        padding-inline-end: 1.25rem;
        border-inline-end: 1px solid var(--te-gray-200)
    }

    .dark .te-event-minimal__left {
        border-color: var(--te-gray-700)
    }

    .te-events-grid--boxed {
        grid-template-columns: repeat(min(var(--te-columns, 3), 2), 1fr)
    }
}

@media (min-width:1024px) {
    .te-events-grid--boxed {
        grid-template-columns: repeat(var(--te-columns, 3), 1fr)
    }
}

.te-event-boxed {
    display: flex;
    flex-direction: column;
    height: 100%;
    background: #fff;
    border: 2px solid var(--te-gray-200);
    border-radius: var(--border-radius-xl);
    overflow: hidden
}

.te-event-boxed__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    background: var(--te-gray-50);
    border-bottom: 1px solid var(--te-gray-200)
}

.dark .te-event-boxed__header {
    background: var(--te-gray-900);
    border-color: var(--te-gray-700)
}

.te-event-boxed__date {
    display: flex;
    align-items: baseline;
    gap: .375rem
}

.te-event-boxed__date-day {
    font-size: 1.5rem;
    font-weight: 800;
    line-height: 1
}

.dark .te-event-boxed__date-month,
.te-event-boxed__image-placeholder svg {
    color: var(--te-gray-400)
}

.te-event-boxed__date-month {
    font-size: .875rem;
    font-weight: 600;
    color: var(--te-gray-600);
    text-transform: uppercase
}

.te-event-boxed__date-year {
    font-size: .75rem;
    color: var(--te-gray-500)
}

.te-event-boxed__time {
    display: flex;
    align-items: center;
    gap: .375rem;
    padding: .375rem .75rem;
    background: var(--te-primary-100);
    border-radius: var(--border-radius-md-full);
    font-size: .75rem;
    font-weight: 600;
    color: var(--te-primary-700)
}

.dark .te-event-boxed__time {
    background: var(--te-primary-900);
    color: var(--te-primary-300)
}

.te-event-boxed__image {
    aspect-ratio: 16/9;
    overflow: hidden
}

.te-event-boxed__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--te-transition)
}

.te-event-boxed__image-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--te-gray-100)
}

.dark .te-event-boxed__image-placeholder {
    background: var(--te-gray-700)
}

.te-event-boxed__body {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: 1.25rem
}

.te-event-boxed__title {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--te-gray-900);
    margin: 0 0 .75rem;
    line-height: 1.3
}

.dark .te-event-boxed__title {
    color: #fff
}

.te-event-boxed__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--te-transition)
}

.dark .te-event-boxed__excerpt,
.dark .te-event-boxed__meta-item {
    color: var(--te-gray-400)
}

.dark .te-event-elegant__placeholder svg,
.te-event-boxed__excerpt {
    color: var(--te-gray-600)
}

.te-event-boxed__excerpt {
    font-size: .875rem;
    line-height: 1.6;
    margin: 0 0 1rem
}

.te-event-boxed__meta {
    display: flex;
    flex-direction: column;
    gap: .5rem;
    margin-top: auto
}

.te-event-boxed__meta-item {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .8125rem;
    color: var(--te-gray-500)
}

.te-event-boxed__meta-item svg {
    flex-shrink: 0;
    color: var(--te-gray-400)
}

.te-event-boxed__footer {
    padding: 1rem 1.25rem;
    background: var(--te-gray-50);
    border-top: 1px solid var(--te-gray-200)
}

.dark .te-event-boxed__footer {
    background: var(--te-gray-900);
    border-color: var(--te-gray-700)
}

.te-event-boxed__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    width: 100%;
    padding: .75rem 1rem;
    background: var(--te-primary-600);
    color: #fff;
    border-radius: var(--border-radius-lg);
    font-size: .875rem;
    font-weight: 600;
    text-decoration: none
}

.te-event-boxed__btn:hover {
    background: var(--te-primary-700);
    transform: translateY(-2px)
}

.te-events-grid--gradient {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem
}

@media (min-width:640px) {
    .te-event-overlay {
        aspect-ratio: 3/4
    }

    .te-events-grid--gradient {
        grid-template-columns: repeat(min(var(--te-columns, 3), 2), 1fr)
    }
}

@media (min-width:1024px) {
    .te-events-grid--gradient {
        grid-template-columns: repeat(var(--te-columns, 3), 1fr)
    }
}

.te-event-gradient {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 280px;
    padding: 1.5rem;
    border-radius: var(--border-radius-xl);
    text-decoration: none;
    overflow: hidden
}

.te-event-gradient:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, .2)
}

.te-event-gradient--blue {
    background: linear-gradient(135deg, #3b82f6 0, #1d4ed8 50%, #1e3a8a 100%)
}

.te-event-gradient--purple {
    background: linear-gradient(135deg, #a855f7 0, #7c3aed 50%, #5b21b6 100%)
}

.te-event-gradient--teal {
    background: linear-gradient(135deg, #14b8a6 0, #0d9488 50%, #115e59 100%)
}

.te-event-gradient--orange {
    background: linear-gradient(135deg, #f97316 0, #ea580c 50%, #c2410c 100%)
}

.te-event-gradient--pink {
    background: linear-gradient(135deg, #ec4899 0, #db2777 50%, #9d174d 100%)
}

.te-event-gradient__pattern {
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle at 20% 80%, rgba(255, 255, 255, .1) 0, transparent 50%), radial-gradient(circle at 80% 20%, rgba(255, 255, 255, .08) 0, transparent 40%);
    pointer-events: none
}

.te-event-gradient__content {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    height: 100%;
    color: #fff
}

.te-event-gradient__top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem
}

.te-event-gradient__date {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    background: rgba(255, 255, 255, .2);
    backdrop-filter: blur(8px);
    border-radius: var(--border-radius-lg);
    text-align: center
}

.te-event-gradient__date-day {
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1
}

.te-event-gradient__badge,
.te-event-gradient__date-month {
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em
}

.te-event-gradient__date-month {
    font-size: .625rem;
    opacity: .9
}

.te-event-gradient__badge {
    padding: .375rem .75rem;
    background: rgba(255, 255, 255, .25);
    backdrop-filter: blur(8px);
    border-radius: var(--border-radius-md-full);
    font-size: .6875rem
}

.te-event-gradient__main {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center
}

.te-event-gradient__excerpt,
.te-event-gradient__title {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden
}

.te-event-gradient__title {
    font-size: 1.375rem;
    font-weight: 700;
    margin: 0 0 .75rem;
    line-height: 1.3
}

.te-event-gradient__excerpt {
    font-size: .875rem;
    opacity: .85;
    line-height: 1.5;
    margin: 0
}

.te-event-gradient__bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(255, 255, 255, .2)
}

.te-event-gradient__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    font-size: .8125rem;
    opacity: .9
}

.te-event-elegant__category,
.te-event-elegant__weekday {
    font-size: .6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em
}

.te-event-gradient__location,
.te-event-gradient__time {
    display: flex;
    align-items: center;
    gap: .375rem
}

.te-event-gradient__location {
    overflow: hidden;
    max-width: 150px
}

.te-event-gradient__arrow {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, .2);
    backdrop-filter: blur(8px);
    border-radius: 50%
}

.te-event-elegant,
.te-event-magazine {
    flex-direction: column;
    overflow: hidden;
    height: 100%
}

.te-event-gradient:hover .te-event-gradient__arrow {
    background: rgba(255, 255, 255, .3);
    transform: translateX(4px)
}

.te-events-grid--elegant {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem
}

@media (min-width:768px) {
    .te-events-grid--elegant {
        grid-template-columns: repeat(min(var(--te-columns, 3), 2), 1fr)
    }
}

@media (min-width:1200px) {
    .te-events-grid--elegant {
        grid-template-columns: repeat(var(--te-columns, 3), 1fr)
    }
}

.te-event-elegant-wrap,
.te-event-magazine-wrap {
    height: 100%
}

.te-event-elegant {
    display: flex;
    background: #fff;
    border-radius: var(--border-radius-xl);
    box-shadow: 0 1px 3px rgba(0, 0, 0, .06);
    border: 1px solid var(--te-gray-100)
}

.dark .te-event-elegant {
    background: var(--te-gray-800);
    border-color: var(--te-gray-700);
    box-shadow: 0 1px 3px rgba(0, 0, 0, .2)
}

.te-event-elegant:hover {
    box-shadow: 0 12px 40px rgba(0, 0, 0, .1);
    border-color: var(--te-gray-200)
}

.dark .te-event-elegant:hover {
    box-shadow: 0 12px 40px rgba(0, 0, 0, .3);
    border-color: var(--te-gray-600)
}

.te-event-elegant__image-section {
    position: relative
}

.te-event-elegant__image {
    aspect-ratio: 16/10;
    overflow: hidden
}

.te-event-elegant__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .6s
}

.te-event-elegant__placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--te-gray-50), var(--te-gray-100))
}

.dark .te-event-elegant__placeholder {
    background: linear-gradient(135deg, var(--te-gray-700), var(--te-gray-800))
}

.te-event-elegant__placeholder svg {
    color: var(--te-gray-300)
}

.te-event-elegant__category {
    position: absolute;
    bottom: .75rem;
    left: .75rem;
    padding: .375rem .875rem;
    background: #fff;
    border-radius: var(--border-radius-md-full);
    color: var(--te-gray-700);
    box-shadow: 0 2px 8px rgba(0, 0, 0, .1)
}

.te-event-elegant__title a:hover,
.te-event-elegant__weekday {
    color: var(--te-primary-600)
}

[dir=rtl] .te-event-elegant__category {
    left: auto;
    right: .75rem
}

.dark .te-event-elegant__category {
    background: var(--te-gray-900);
    color: var(--te-gray-300)
}

.dark .te-event-elegant__title a:hover,
.dark .te-event-elegant__weekday {
    color: var(--te-primary-400)
}

.te-event-elegant__content {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: 1.25rem 1.5rem 1.5rem
}

.te-event-elegant__date-strip {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--te-gray-100)
}

.dark .te-event-elegant__date-strip {
    border-color: var(--te-gray-700)
}

.te-event-elegant__full-date {
    font-size: .9rem;
    font-weight: 500;
    color: var(--te-gray-700)
}

.dark .te-event-elegant__full-date {
    color: var(--te-gray-300)
}

.te-event-elegant__time {
    display: flex;
    align-items: center;
    gap: .375rem;
    padding: .375rem .75rem;
    background: var(--te-gray-50);
    border-radius: var(--border-radius-md-full);
    font-size: .75rem;
    font-weight: 500;
    color: var(--te-gray-600)
}

.dark .te-event-elegant__time {
    background: var(--te-gray-700);
    color: var(--te-gray-300)
}

.te-event-elegant__title {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--te-gray-900);
    margin: 0 0 .75rem;
    line-height: 1.4
}

.dark .te-event-elegant__title {
    color: #fff
}

.dark .te-event-elegant__excerpt,
.dark .te-event-elegant__meta {
    color: var(--te-gray-400)
}

.te-event-elegant__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--te-transition)
}

.te-event-elegant__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: auto
}

.te-event-elegant__meta {
    display: flex;
    align-items: center;
    gap: .375rem;
    font-size: .8125rem;
    color: var(--te-gray-500);
    overflow: hidden;
    max-width: 60%
}

.te-event-elegant__meta svg {
    flex-shrink: 0
}

.te-event-elegant__link {
    display: inline-flex;
    align-items: center;
    gap: .375rem;
    font-size: .8125rem;
    font-weight: 600;
    color: var(--te-primary-600);
    text-decoration: none
}

.dark .te-event-elegant__link {
    color: var(--te-primary-400)
}

-NoNewline .te-filters--chips .te-filter-btn,
.te-filters--chips .te-filter-btn {
    padding: .5rem 1rem;
    font-weight: 500;
    color: var(--te-gray-600);
    font-size: .8125rem
}

.te-event-elegant__link:hover {
    gap: .625rem
}

.te-events-grid--magazine {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem
}

@media (min-width:640px) {
    .te-events-grid--magazine {
        grid-template-columns: repeat(min(var(--te-columns, 3), 2), 1fr)
    }
}

@media (min-width:1024px) {
    .te-events-grid--magazine {
        grid-template-columns: repeat(var(--te-columns, 3), 1fr)
    }
}

.te-event-magazine {
    position: relative;
    display: flex;
    justify-content: flex-end;
    min-height: 380px;
    border-radius: var(--border-radius-xl);
    text-decoration: none
}

.te-event-magazine__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .8s
}

.te-event-magazine:hover .te-event-magazine__bg img {
    transform: scale(1.1)
}

.te-event-magazine__placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, var(--te-gray-700), var(--te-gray-900))
}

.te-event-magazine__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, .95) 0, rgba(0, 0, 0, .7) 30%, rgba(0, 0, 0, .3) 60%, rgba(0, 0, 0, .1) 100%);
    transition: background var(--te-transition)
}

.te-event-magazine:hover .te-event-magazine__overlay {
    background: linear-gradient(to top, rgba(0, 0, 0, .98) 0, rgba(0, 0, 0, .75) 35%, rgba(0, 0, 0, .4) 65%, rgba(0, 0, 0, .15) 100%)
}

.te-event-magazine__content {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    padding: 1.5rem;
    color: #fff
}

.te-event-magazine__top {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .5rem;
    margin-bottom: auto;
    padding-bottom: 1rem
}

.te-event-magazine__excerpt,
.te-event-magazine__title {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden
}

.te-event-magazine__badge,
.te-event-magazine__category {
    padding: .375rem .75rem;
    border-radius: var(--border-radius-md-full);
    font-size: .6875rem;
    text-transform: uppercase;
    letter-spacing: .05em
}

.te-event-magazine__category {
    background: rgba(255, 255, 255, .15);
    backdrop-filter: blur(8px);
    font-weight: 600
}

.te-event-magazine__badge {
    font-weight: 700
}

.te-event-magazine__badge--today {
    background: var(--te-yellow-500);
    color: var(--te-yellow-900)
}

.te-event-magazine__badge--soon {
    background: var(--te-green-500);
    color: #fff
}

.te-event-magazine__title {
    font-size: 1.375rem;
    font-weight: 700;
    margin: 0 0 .625rem;
    line-height: 1.3
}

.te-event-magazine__excerpt {
    font-size: .875rem;
    color: rgba(255, 255, 255, .8);
    line-height: 1.5;
    margin: 0
}

.te-event-magazine__bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(255, 255, 255, .15)
}

.te-event-magazine__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .75rem;
    font-size: .75rem;
    opacity: .85
}

.te-event-magazine__location {
    overflow: hidden;
    max-width: 150px
}

.te-event-magazine__arrow {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, .1);
    backdrop-filter: blur(8px);
    border-radius: 50%;
    transition: all var(--te-transition)
}

.te-event-magazine:hover .te-event-magazine__arrow {
    background: var(--te-primary-600);
    transform: translateX(4px)
}

.te-filters--chips .te-filter-btn {
    background: var(--te-gray-100);
    border: none;
    border-radius: var(--border-radius-md-full);
    transition: all var(--te-transition)
}

.te-filters--floating {
    border-radius: var(--border-radius-lg)
}

.dark .te-filters--floating {
    background: var(--te-gray-800)
}

-NoNewline .te-filters--chips .te-filter-btn {
    background: var(--te-gray-100);
    border: none;
    border-radius: var(--border-radius-md-full);
    transition: all var(--te-transition)
}

.dark .te-filters--chips .te-filter-btn {
    background: var(--te-gray-700);
    color: var(--te-gray-300)
}

.te-filters--chips .te-filter-btn:hover {
    background: var(--te-gray-200);
    color: var(--te-gray-800)
}

.dark .te-filters--chips .te-filter-btn:hover {
    background: var(--te-gray-600);
    color: var(--te-gray-100)
}

.te-filters--chips .te-filter-btn--active {
    background: var(--te-primary-600);
    color: #fff
}

.te-filters--chips .te-filter-btn--active:hover {
    background: var(--te-primary-700)
}

.te-filters--outline .te-filter-btn {
    padding: .5rem 1.25rem;
    background: 0 0;
    border: 2px solid var(--te-gray-300);
    border-radius: var(--border-radius-lg);
    font-size: .8125rem;
    font-weight: 600;
    color: var(--te-gray-600);
    transition: all var(--te-transition)
}

.dark .te-filters--outline .te-filter-btn {
    border-color: var(--te-gray-600);
    color: var(--te-gray-400)
}

.te-filters--outline .te-filter-btn:hover {
    border-color: var(--te-primary-400);
    color: var(--te-primary-600)
}

.dark .te-filters--outline .te-filter-btn:hover {
    border-color: var(--te-primary-500);
    color: var(--te-primary-400)
}

.te-filters--outline .te-filter-btn--active {
    background: var(--te-primary-600);
    border-color: var(--te-primary-600);
    color: #fff
}

.te-filters--outline .te-filter-btn--active:hover {
    background: var(--te-primary-700);
    border-color: var(--te-primary-700)
}

.te-filters--floating {
    background: #fff;
    padding: .75rem;
    border-radius: var(--border-radius-xl);
}

.dark .te-filters--floating {
    background: var(--te-gray-800);
}

.te-filters--floating .te-filter-btn {
    padding: .625rem 1.25rem;
    background: 0 0;
    border: none;
    border-radius: var(--border-radius-lg);
    font-size: .8125rem;
    font-weight: 500;
    color: var(--te-gray-600)
}

.dark .te-filters--floating .te-filter-btn {
    color: var(--te-gray-400)
}

.te-filters--floating .te-filter-btn:hover {
    background: var(--te-gray-100);
    color: var(--te-gray-800)
}

.dark .te-filters--floating .te-filter-btn:hover {
    background: var(--te-gray-700);
    color: var(--te-gray-200)
}

.te-filters--floating .te-filter-btn--active {
    background: var(--te-primary-600);
    color: #fff;
}

.te-filters--floating .te-filter-btn--active:hover {
    background: var(--te-primary-700)
}

.dark .te-filters--floating .te-filter-btn--active:hover {
    background: var(--te-primary-500)
}

.te-filters--split {
    flex-direction: column;
    gap: 1.5rem
}

@media (min-width:768px) {
    .te-archive-header--split {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 2rem;
        text-align: start
    }

    .te-archive-header--split .te-archive-header__text {
        margin-bottom: 0;
        flex-shrink: 0;
        text-align: start
    }

    .te-archive-header:has(.te-filters--split) {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 2rem;
        text-align: start
    }

    .te-archive-header:has(.te-filters--split) .te-archive-header__text {
        margin-bottom: 0;
        flex-shrink: 0;
        text-align: start
    }

    .te-filters--split {
        flex-direction: column;
        align-items: flex-end;
        gap: 1rem;
        flex: 1
    }

    .te-filters--split .te-filter-group {
        justify-content: flex-end
    }
}

.te-filters--split .te-filter-btn {
    border-radius: var(--border-radius-md-full)
}