/* ===== CSS Variables ===== */
:root {
    --primary-color: #6366f1;
    --primary-hover: #4f46e5;
    --danger-color: #ef4444;
    --danger-hover: #dc2626;
    --success-color: #10b981;
    --warning-color: #f59e0b;
    --bg-color: #f9fafb;
    --surface-color: #ffffff;
    --text-color: #111827;
    --text-primary: #111827;
    --text-secondary: #6b7280;
    --border-color: #e5e7eb;
    --shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
}

[data-theme="dark"] {
    --bg-color: #111827;
    --surface-color: #1f2937;
    --text-color: #f9fafb;
    --text-primary: #f9fafb;
    --text-secondary: #9ca3af;
    --border-color: #374151;
    --shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.3), 0 1px 2px -1px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -2px rgba(0, 0, 0, 0.3);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.3), 0 4px 6px -4px rgba(0, 0, 0, 0.3);
}

/* ===== Loading Overlay ===== */
.loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--bg-color);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999;
    transition: opacity 0.3s ease;
}

.loading-overlay.hidden {
    opacity: 0;
    pointer-events: none;
}

.loading-spinner {
    width: 50px;
    height: 50px;
    border: 4px solid var(--border-color);
    border-top-color: var(--primary-color);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

.spinner-small {
    width: 16px;
    height: 16px;
    border: 2px solid var(--border-color);
    border-top-color: var(--primary-color);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    display: inline-block;
}

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

/* ===== Lazy Loading & Parties Loading ===== */
.lazy-load-trigger {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 3rem 2rem;
    min-height: 100px;
    opacity: 0.5;
}

.lazy-load-trigger .spinner {
    animation: spin 0.6s linear infinite;
}

.loading-parties {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 4rem 2rem;
    gap: 1rem;
    opacity: 0.6;
}

.loading-parties .spinner {
    animation: spin 0.6s linear infinite;
}

.loading-parties p {
    font-size: 0.9rem;
    color: var(--text-secondary);
}

/* ===== Base Styles ===== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    background-color: var(--bg-color);
    color: var(--text-color);
    line-height: 1.6;
    transition: background-color 0.3s, color 0.3s;
}

html[lang="en"] {
    direction: ltr;
}

html[lang="en"] body {
    font-family: 'Lato', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

html[lang="fa"] {
    direction: rtl;
}

html[lang="fa"] body {
    font-family: 'Vazirmatn', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* Ensure all elements inherit Vazirmatn in Farsi mode */
html[lang="fa"] * {
    font-family: 'Vazirmatn', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* ===== Header ===== */
.header {
    background-color: var(--surface-color);
    border-bottom: 1px solid var(--border-color);
    padding: 1rem 0;
    box-shadow: var(--shadow);
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 101;
    direction: ltr;
}

.header-content {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 1rem;
}

.header-left,
.header-right {
    display: flex;
    gap: 0.5rem;
}

.header-left {
    justify-content: flex-end;
    order: 3;
}

.header-right {
    order: 1;
}

.header-center {
    display: flex;
    align-items: center;
    gap: 1rem;
    justify-content: center;
    order: 2;
}

.logo {
    height: 25px;
    width: auto;
    max-width: 100%;
    color: var(--primary-color);
}

.header-title {
    font-size: 1.5rem;
    font-weight: 600;
}

.back-link {
    color: var(--text-color);
    text-decoration: none;
    display: flex;
    align-items: center;
    transition: color 0.2s;
}

.back-link:hover {
    color: var(--primary-color);
}

/* ===== Buttons ===== */
.btn {
    padding: 0.625rem 1.25rem;
    border: none;
    border-radius: 0.5rem;
    font-size: 1rem;
    font-weight: 500;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: all 0.2s;
    font-family: inherit;
}

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

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

.btn-secondary {
    background-color: var(--surface-color);
    color: var(--text-color);
    border: 1px solid var(--border-color);
}

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

.btn-danger {
    background-color: var(--danger-color);
    color: white;
}

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

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

.btn-danger-outline:hover {
    background-color: var(--danger-color);
    color: white;
}

.btn-sm {
    padding: 0.375rem 0.75rem;
    font-size: 0.875rem;
}

.btn-with-icon {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    justify-content: center;
    width: 100%;
}

/* ===== Amount Input Row ===== */
.amount-input-row {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.amount-unit-presets {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.amount-unit-btn {
    flex: 1;
    min-width: fit-content;
}

/* ===== Custom Dropdown with Avatars ===== */
.custom-select-wrapper {
    position: relative;
}

.custom-select-trigger {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    padding: 0.625rem;
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    cursor: pointer;
    transition: all 0.3s;
}

.custom-select-trigger:hover {
    border-color: var(--primary-color);
}

.static-payer-display {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem;
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
}

.static-payer-display .guest-avatar-small {
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    object-fit: cover;
}

.static-payer-name {
    font-size: 0.9375rem;
    color: var(--text-color);
}

.form-group.inline-payer {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.form-group.inline-payer label {
    margin-bottom: 0;
    white-space: nowrap;
}

.custom-select-trigger.open {
    border-color: var(--primary-color);
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.custom-select-trigger .guest-avatar-small {
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    object-fit: cover;
}

.custom-select-trigger .selected-guest-name {
    flex: 1;
    text-align: start;
}

.custom-select-trigger .dropdown-arrow {
    width: 12px;
    height: 12px;
    transition: transform 0.3s;
}

.custom-select-trigger.open .dropdown-arrow {
    transform: rotate(180deg);
}

.custom-select-options {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--bg-color);
    border: 1px solid var(--primary-color);
    border-top: none;
    border-radius: 0 0 0.375rem 0.375rem;
    max-height: 200px;
    overflow-y: auto;
    z-index: 100;
    display: none;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.custom-select-options.open {
    display: block;
}

.custom-select-option {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    padding: 0.625rem;
    cursor: pointer;
    transition: background 0.2s;
}

.custom-select-option:hover {
    background: var(--hover-bg);
}

.custom-select-option .guest-avatar-small {
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    object-fit: cover;
}

.custom-select-option .guest-name {
    flex: 1;
    text-align: start;
}

.expense-paid-by-select {
    display: none;
}

.icon-btn {
    background: transparent;
    border: none;
    color: var(--text-color);
    cursor: pointer;
    padding: 0.5rem;
    border-radius: 0.5rem;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    transition: background-color 0.2s;
    font-family: inherit;
    font-size: 0.875rem;
    min-width: 60px;
    justify-content: center;
}

.icon-btn:hover {
    background-color: var(--bg-color);
}

#langText {
    display: inline-block;
    min-width: 20px;
    text-align: center;
}

[data-theme="light"] .moon-icon {
    display: none;
}

[data-theme="dark"] .sun-icon {
    display: none;
}

/* ===== Tab Navigation ===== */
.tab-navigation {
    background-color: var(--surface-color);
    border-bottom: 2px solid var(--border-color);
    position: fixed;
    top: 5rem;
    left: 0;
    right: 0;
    z-index: 100;
}

.tabs {
    display: flex;
    gap: 0;
}

.tab-btn {
    flex: 1;
    padding: 1rem 2rem;
    background: none;
    border: none;
    border-bottom: 3px solid transparent;
    color: var(--text-secondary);
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    font-family: inherit;
}

/* Hide icons on desktop */
.tab-btn .tab-icon {
    display: none;
}

/* Desktop: show icon inline and position badge beside it */
@media (min-width: 769px) {
    .tab-btn .tab-icon {
        display: inline-block;
        width: 20px;
        height: 20px;
        vertical-align: middle;
        margin-right: 0.5rem;
    }
    
    html[lang="fa"] .tab-btn .tab-icon {
        margin-right: 0;
        margin-left: 0.5rem;
    }
    
    /* Desktop tab icons: black 50% in light, white 50% in dark */
    .tab-btn .tab-icon:not([src*="_color"]) {
        opacity: 0.5;
    }
    
    [data-theme="dark"] .tab-btn .tab-icon:not([src*="_color"]) {
        filter: invert(1);
        opacity: 0.5;
    }
    
    .tab-btn {
        position: relative;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    
    .tab-btn .balances-badge {
        position: relative;
        top: auto;
        right: auto;
        left: auto;
        margin-left: 0.375rem;
        display: inline-block;
    }
    
    html[lang="fa"] .tab-btn .balances-badge {
        margin-left: 0;
        margin-right: 0.375rem;
    }
}

.tab-btn:hover {
    color: var(--text-color);
    background-color: rgba(var(--primary-color-rgb), 0.05);
}

.tab-btn.active {
    color: var(--primary-color);
    border-bottom-color: var(--primary-color);
    background-color: rgba(var(--primary-color-rgb), 0.1);
}

.tab-content {
    display: none;
    opacity: 0;
    animation: fadeOut 0.2s ease-out;
    margin-top: 8.5rem;
}

.tab-content.active {
    display: block;
    animation: fadeIn 0.3s ease-in;
    opacity: 1;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

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

/* Mobile Bottom Navigation */
@media (max-width: 768px) {
    .tab-navigation {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        top: auto;
        border-top: 2px solid var(--border-color);
        border-bottom: none;
        z-index: 1000;
        padding-bottom: env(safe-area-inset-bottom);
        box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.15);
    }
    
    /* Inverted colors for mobile bottom nav */
    [data-theme="light"] .tab-navigation {
        background-color: #1f2937;
        border-top-color: #374151;
    }
    
    [data-theme="dark"] .tab-navigation {
        background-color: #2d3748;
        border-top-color: #4a5568;
    }
    
    .tabs {
        display: flex;
        justify-content: space-around;
    }
    
    .tab-btn {
        padding: 0.75rem 1rem;
        font-size: 0.75rem;
        border-bottom: none;
        border-top: 3px solid transparent;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 0.25rem;
        position: relative;
    }
    
    /* Text colors for mobile navbar */
    [data-theme="light"] .tab-btn {
        color: rgba(255, 255, 255, 0.5);
    }
    
    [data-theme="dark"] .tab-btn {
        color: rgba(255, 255, 255, 0.5);
    }
    
    [data-theme="light"] .tab-btn.active {
        color: rgba(255, 255, 255, 0.9);
        border-top-color: rgba(255, 255, 255, 0.5);
    }
    
    [data-theme="dark"] .tab-btn.active {
        color: rgba(255, 255, 255, 0.9);
        border-top-color: rgba(255, 255, 255, 0.5);
    }
    
    [data-theme="light"] .tab-btn:hover {
        color: rgba(255, 255, 255, 0.7);
        background-color: rgba(55, 65, 81, 0.5);
    }
    
    [data-theme="dark"] .tab-btn:hover {
        color: rgba(255, 255, 255, 0.7);
        background-color: rgba(229, 231, 235, 0.1);
    }
    
    /* Icons for tabs - show on mobile */
    .tab-btn .tab-icon {
        display: block;
        width: 24px;
        height: 24px;
    }
    
    /* Color the icons - white in both modes (skip _color suffixed icons) */
    .tab-btn .tab-icon:not([src*="_color"]) {
        filter: invert(1);
        opacity: 0.5;
    }
    
    .tab-btn.active .tab-icon:not([src*="_color"]) {
        filter: invert(1);
        opacity: 0.75;
    }
    
    /* Color suffixed tab icons - use as is */
    .tab-btn .tab-icon[src*="_color"] {
        filter: none;
        opacity: 1;
    }
    
    /* Text labels on mobile */
    .tab-btn span {
        font-size: 0.6875rem;
    }
    
    /* Mobile: Position balances badge on top-right of icon */
    .tab-btn .balances-badge {
        position: absolute;
        top: 0.5rem;
        right: 50%;
        transform: translateX(12px); /* Half of icon width (24px) + half of badge width */
    }
    
    html[lang="fa"] .tab-btn .balances-badge {
        right: auto;
        left: 50%;
        transform: translateX(-12px);
    }
    
    /* Add padding to bottom of content for mobile bottom nav */
    .tab-content {
        padding-bottom: 80px;
        margin-top: 5rem; /* Only header on mobile, tabs at bottom */
    }
}

/* ===== Statistics Section ===== */
.stats-section {
    padding: 2rem 0;
}

.stats-grid-three {
    grid-template-columns: repeat(3, 1fr) !important;
}

@media (max-width: 768px) {
    .stats-grid-three {
        grid-template-columns: 1fr !important;
    }
}

.stats-grid {
    display: grid;
    grid-template-columns: 3fr 1fr; /* 75% and 25% on desktop */
    gap: 1.5rem;
}

@media (max-width: 768px) {
    .stats-grid {
        grid-template-columns: 1fr; /* Stack on mobile */
        gap: 0.75rem; /* Tighter gap on mobile */
    }
}

.stat-card {
    background-color: var(--surface-color);
    padding: 2rem;
    border-radius: 1rem;
    box-shadow: var(--shadow);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

/* Desktop: Icon at top, then content */
.stat-icon {
    order: -1;
}

.stat-content {
    order: 0;
}

@media (max-width: 768px) {
    .stat-card {
        padding: 1rem;
        flex-direction: row;
        align-items: center;
        gap: 1rem;
    }
    
    .stat-icon {
        margin-bottom: 0;
        order: 0;
    }
    
    .stat-content {
        flex: 1;
        order: 0;
    }
    
    /* RTL support */
    [dir="rtl"] .stat-card {
        text-align: right;
    }
    
    [dir="rtl"] .stat-value,
    [dir="rtl"] .stat-label {
        text-align: right;
    }
    
    [dir="ltr"] .stat-card {
        text-align: left;
    }
    
    [dir="ltr"] .stat-value,
    [dir="ltr"] .stat-label {
        text-align: left;
    }
}

.stat-icon {
    color: var(--primary-color);
    margin-bottom: 1rem;
}

.stat-icon.emoji-icon {
    font-size: 2rem;
}

.stat-icon img {
    width: 32px;
    height: 32px;
}

/* Color the stat icons based on theme (skip _color suffixed icons) */
[data-theme="light"] .stat-icon img:not([src*="_color"]) {
    filter: none;
    opacity: 0.5;
}

[data-theme="dark"] .stat-icon img:not([src*="_color"]) {
    filter: invert(1);
    opacity: 0.5;
}

/* Color suffixed icons - use as is */
.stat-icon img[src*="_color"] {
    filter: none;
    opacity: 1;
}

.stat-value {
    font-size: 2rem;
    font-weight: 700;
    color: var(--text-color);
    margin-bottom: 0.5rem;
}

/* Currency unit styling in stat cards */
.stat-value .currency-unit {
    font-size: 1rem;
    opacity: 0.5;
}

/* Currency unit styling in other contexts */
.amount-value .currency-unit,
.expense-amount .currency-unit,
.ratio-amount .currency-unit,
.record-amount .currency-unit,
.share-amount .currency-unit,
.amount-item .value .currency-unit {
    font-size: 0.5em;
    opacity: 0.5;
}

.stat-label {
    color: var(--text-secondary);
    font-size: 0.875rem;
}

/* ===== Parties Section ===== */
.parties-section,
.expenses-section,
.shares-section {
    padding: 2rem 0;
}

.section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
}

.section-header h2 {
    font-size: 1.5rem;
    font-weight: 600;
}

/* ===== Balances Section ===== */
.balances-section {
    padding: 2rem 0;
}

.balances-section .section-header {
    margin-bottom: 1.5rem;
}

.balances-section .section-header h2 {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--text-color);
}

/* Payment Cards */
.payment-card {
    background-color: var(--surface-color);
    padding: 1.5rem;
    border-radius: 1rem;
    border: 2px solid var(--border-color);
    box-shadow: var(--shadow);
    display: flex;
    align-items: center;
    gap: 1.5rem;
    margin-bottom: 1rem;
}

.payment-avatars {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.payment-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--border-color);
}

.payment-arrow {
    font-size: 1.25rem;
    color: var(--text-secondary);
}

.payment-info {
    flex: 1;
}

.payment-names {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-color);
    margin-bottom: 0.5rem;
}

.payment-arrow-text {
    color: var(--text-secondary);
    font-weight: normal;
    margin: 0 0.5rem;
}

.payment-amount {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--success-color);
    margin-bottom: 0.25rem;
}

.payment-date {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

/* Share Card Enhancements for Balances */
.share-guests {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-top: 0.75rem;
}

.share-guest-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.share-guest-item .guest-avatar {
    width: 32px;
    height: 32px;
}

.share-guest-item .guest-name {
    font-weight: 600;
    color: var(--text-color);
}

/* Expense Card Enhancements for Balances */
.expense-details {
    flex: 1;
}

.expense-top-row {
    display: flex;
    align-items: baseline;
    gap: 1rem;
    margin-bottom: 0.5rem;
}

.expense-party-link {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

@media (max-width: 768px) {
    .payment-card {
        flex-direction: column;
        align-items: stretch;
        gap: 1rem;
    }
    
    .payment-avatars {
        justify-content: center;
    }
    
    .payment-info {
        text-align: center;
    }
}

/* ===== Filters Bar ===== */
.filters-bar {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 2rem;
    margin-bottom: 1rem;
    padding: 1.5rem;
    background-color: var(--surface-color);
    border-radius: 0.75rem;
    box-shadow: var(--shadow);
    align-items: center;
}

/* Debt Filter Toggle */
.debt-filter-container {
    margin: 0 0 1.5rem 0;
}

.debt-filter-container .toggle-container {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
}

.debt-filter-container .toggle-label {
    font-size: 0.9375rem;
    color: var(--text-color);
    user-select: none;
    cursor: pointer;
}

.btn-group {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.btn-group:first-child {
    justify-content: flex-start;
}

.btn-group:last-child {
    justify-content: flex-end;
}

.filter-btn {
    padding: 0.5rem 1rem;
    border: 1px solid var(--border-color);
    background-color: var(--bg-color);
    color: var(--text-color);
    border-radius: 0.5rem;
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    font-family: inherit;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

.filter-btn:hover {
    background-color: var(--surface-color);
    border-color: var(--primary-color);
    color: var(--primary-color);
}

.filter-btn.active {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: white;
}

.filter-btn.active:hover {
    background-color: var(--primary-hover);
    border-color: var(--primary-hover);
}

.filter-btn .expense-arrow {
    transition: transform 0.3s;
    display: inline-flex;
    align-items: center;
}

.filter-btn[data-sort="expense-low"] .expense-arrow {
    transform: rotate(180deg);
}

.parties-list,
.expenses-list,
.shares-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.party-card,
.expense-card,
.share-card {
    background-color: var(--surface-color);
    padding: 1.5rem;
    border-radius: 1rem;
    border: 2px solid var(--border-color);
    box-shadow: var(--shadow);
    cursor: pointer;
    transition: all 0.2s;
}

.party-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
    border-color: var(--primary-color);
}

.party-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.party-meta {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.party-date {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.party-status {
    display: inline-block;
    padding: 0.5rem 1rem;
    border-radius: 9999px;
    font-size: 0.875rem;
    font-weight: 600;
}

.status-happening {
    background-color: rgba(16, 185, 129, 0.1);
    color: var(--success-color);
}

.status-scheduled {
    background-color: rgba(99, 102, 241, 0.1);
    color: var(--primary-color);
}

.status-ended {
    background-color: rgba(107, 114, 128, 0.1);
    color: var(--text-secondary);
}

.status-pending-payment {
    background-color: rgba(245, 158, 11, 0.1);
    color: var(--warning-color);
}

.status-canceled {
    background-color: rgba(239, 68, 68, 0.1);
    color: var(--danger-color);
}

.status-postponed {
    background-color: rgba(245, 158, 11, 0.1);
    color: var(--warning-color);
}

.party-guests {
    font-size: 0.875rem;
    color: var(--text-secondary);
    flex: 1;
}

.party-guests-avatars {
    display: flex;
    gap: 0.375rem;
    flex: 1;
}

.guest-avatar-wrapper {
    position: relative;
    display: inline-block;
}

.guest-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    display: block;
}

.guest-tooltip {
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(-8px);
    background-color: var(--text-color);
    color: var(--surface-color);
    padding: 0.375rem 0.75rem;
    border-radius: 0.375rem;
    font-size: 0.75rem;
    font-weight: 500;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s, transform 0.2s;
    z-index: 1000;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.guest-tooltip::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: var(--text-color);
}

.guest-avatar-wrapper:hover .guest-tooltip {
    opacity: 1;
    transform: translateX(-50%) translateY(-4px);
}

.party-description {
    margin: 1rem 0;
    color: var(--text-color);
    line-height: 1.6;
    display: inline;
}

.party-amounts {
    display: flex;
    gap: 1.5rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}

.amount-item {
    flex: 1;
}

.amount-item label {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-bottom: 0.25rem;
}

.amount-item label svg {
    color: var(--text-secondary);
    flex-shrink: 0;
}

.amount-item label .emoji-icon {
    font-size: 1.125rem;
    flex-shrink: 0;
}

.amount-item label .amount-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

/* Color the amount icons based on theme (skip _color suffixed icons) */
[data-theme="light"] .amount-item label .amount-icon:not([src*="_color"]) {
    filter: none;
    opacity: 0.5;
}

[data-theme="dark"] .amount-item label .amount-icon:not([src*="_color"]) {
    filter: invert(1);
    opacity: 0.5;
}

/* Color suffixed amount icons - use as is */
.amount-item label .amount-icon[src*="_color"] {
    filter: none;
    opacity: 1;
}

.amount-item .value {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--text-color);
}

.party-card-actions {
    display: flex;
    gap: 1rem;
    align-items: center;
    margin-inline-start: 1rem;
}

@keyframes pulse {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.7;
    }
}

.delete-btn {
    background-color: transparent;
    border: none;
    color: var(--danger-color);
    cursor: pointer;
    padding: 0.5rem;
    border-radius: 0.5rem;
    transition: all 0.2s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.delete-btn:hover {
    background-color: rgba(239, 68, 68, 0.1);
}

.edit-btn {
    background-color: transparent;
    border: none;
    color: #9ca3af;
    cursor: pointer;
    padding: 0.5rem;
    border-radius: 0.5rem;
    transition: background-color 0.2s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.edit-btn:hover {
    background-color: rgba(156, 163, 175, 0.1);
}

/* Hide icon+text label by default (desktop/tablet) */
.btn-text {
    display: none;
}

/* ===== Floating Close Button ===== */
.floating-close-btn {
    position: fixed;
    top: 9.5rem;
    left: calc((100vw - 1200px) / 2 + 1200px + 1rem);
    width: 56px;
    height: 56px;
    background-color: var(--surface-color);
    border: 2px solid var(--border-color);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-color);
    text-decoration: none;
    box-shadow: var(--shadow-md);
    transition: all 0.2s;
    z-index: 999;
    cursor: pointer;
}

.floating-close-btn:hover {
    background-color: var(--danger-color);
    border-color: var(--danger-color);
    color: white;
    transform: scale(1.05);
    box-shadow: var(--shadow-lg);
}

/* When screen is smaller than container + button space */
@media (max-width: 1300px) {
    .floating-close-btn {
        left: auto;
        right: 1rem;
    }
}

@media (max-width: 768px) {
    .floating-close-btn {
        top: auto;
        bottom: 2rem;
        left: auto;
        right: 1.5rem;
        width: 48px;
        height: 48px;
    }
}

/* ===== Party Header Section ===== */
/* ===== Party Banner ===== */
.party-banner-section {
    width: 100%;
    background-color: var(--surface-color);
    position: relative;
    margin-top: 8.5rem;
    margin-bottom: -80px; /* Overlap with header */
}

.party-banner-container {
    position: relative;
    width: 100%;
    max-width: 1920px;
    margin: 0 auto;
    aspect-ratio: 5 / 2; /* 1920x768 = 2.5:1 (mobile aspect ratio) */
    overflow: hidden;
    background-color: var(--card-bg);
}

.party-banner-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    background-color: var(--surface-color);
    color: transparent; /* Hide alt text */
    cursor: pointer;
    transition: opacity 0.2s ease;
}

.party-banner-image:hover {
    opacity: 0.9;
}

/* Hide broken image icon */
.party-banner-image::before {
    content: '';
    display: block;
}

.party-banner-edit-btn {
    position: absolute;
    top: 1rem;
    left: 1rem;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background-color: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(8px);
    border: none;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
    z-index: 10;
}

.party-banner-edit-btn:hover {
    background-color: rgba(0, 0, 0, 0.8);
    transform: scale(1.05);
}

.party-banner-edit-btn svg {
    width: 20px;
    height: 20px;
}

.party-banner-upload-progress {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background-color: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(8px);
    padding: 0.75rem 1rem;
    border-radius: 8px;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    z-index: 11;
}

.party-banner-upload-progress .progress-bar {
    width: 150px;
    height: 6px;
    background-color: rgba(255, 255, 255, 0.2);
    border-radius: 3px;
    overflow: hidden;
}

.party-banner-upload-progress .progress-fill {
    height: 100%;
    background-color: var(--primary-color);
    transition: width 0.3s ease;
}

.party-banner-upload-progress .progress-text {
    color: white;
    font-size: 0.875rem;
    font-weight: 500;
    min-width: 40px;
}

.party-header-section {
    padding: 2rem 0;
    position: relative;
    z-index: 1;
}

.party-header-card {
    background-color: var(--surface-color);
    padding: 2rem;
    border-radius: 1rem;
    box-shadow: var(--shadow);
}

.party-header-main {
    margin-bottom: 1.5rem;
}

/* Row 1: Date, Status, Guests */
.party-info-row-1 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-bottom: 1rem;
}

.party-info-item-inline {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.party-info-item-inline label {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-secondary);
    white-space: nowrap;
}

.party-info-inline-value {
    font-size: 0.9375rem;
    color: var(--text-color);
    font-weight: 500;
}

.party-status-badge {
    display: inline-block;
    padding: 0.375rem 0.875rem;
    border-radius: 9999px;
    font-size: 0.8125rem;
    font-weight: 600;
}

.party-guests-list-inline {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
}

.party-guests-list-inline .guest-avatar-wrapper {
    position: relative;
    display: inline-block;
}

.party-guests-list-inline .party-guest-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    display: block;
}

.party-guests-list-inline .guest-tooltip {
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(-8px);
    background-color: var(--text-color);
    color: var(--surface-color);
    padding: 0.375rem 0.75rem;
    border-radius: 0.375rem;
    font-size: 0.75rem;
    font-weight: 500;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s, transform 0.2s;
    z-index: 1000;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.party-guests-list-inline .guest-tooltip::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: var(--text-color);
}

.party-guests-list-inline .guest-avatar-wrapper:hover .guest-tooltip {
    opacity: 1;
    transform: translateX(-50%) translateY(-4px);
}

/* Row 2: Tags + Description */
.party-info-row-2 {
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
    margin-top: 1rem; /* Add spacing above badges/description row */
}

.party-info-row-2 .party-tags-display {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-inline-end: 0.5rem;
}

.party-description-inline {
    color: var(--text-color);
    line-height: 1.6;
    flex: 1;
}

@media (max-width: 768px) {
    .party-info-row-1 {
        grid-template-columns: repeat(2, 1fr);
        gap: 1rem;
    }
    
    /* Guests take full width on second row */
    .party-info-row-1 .party-info-item-inline:nth-child(3) {
        grid-column: 1 / -1;
    }
}

.party-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1.5rem;
}

.party-info-item {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.party-info-item.full-width {
    grid-column: 1 / -1;
}

.party-info-item label {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.party-info-value {
    font-size: 1rem;
    color: var(--text-color);
    font-weight: 500;
}

.party-header-footer {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border-color);
    flex-wrap: wrap;
}

.party-header-amounts {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    flex: 1;
}

.party-header-actions {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    flex-shrink: 0;
}

@media (max-width: 768px) {
    .party-header-footer {
        flex-direction: column;
    }
    
    .party-header-amounts {
        width: 100%;
    }
    
    .party-header-actions {
        width: 100%;
    }
}

.amount-box {
    text-align: center;
    padding: 1rem;
    background-color: var(--bg-color);
    border-radius: 0.5rem;
}

.amount-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.375rem;
}

.amount-label .emoji-icon {
    font-size: 1.125rem;
}

.amount-label .amount-icon {
    width: 20px;
    height: 20px;
}

/* Color the party header amount icons based on theme (skip _color suffixed icons) */
[data-theme="light"] .amount-label .amount-icon:not([src*="_color"]) {
    filter: none;
    opacity: 0.5;
}

[data-theme="dark"] .amount-label .amount-icon:not([src*="_color"]) {
    filter: invert(1);
    opacity: 0.5;
}

/* Color suffixed amount label icons - use as is */
.amount-label .amount-icon[src*="_color"] {
    filter: none;
    opacity: 1;
}

.amount-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--primary-color);
}

/* ===== Expense Card ===== */
.expense-card {
    cursor: default;
}

.expense-card-header {
    display: flex;
    justify-content: space-between;
    align-items: start;
}

.expense-info {
    flex: 1;
}


.expense-paid-by {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 0.25rem;
}

.expense-for {
    margin-top: 0.75rem;
    color: var(--text-color);
}

.expense-actions {
    display: flex;
    gap: 0.5rem;
}

.edit-btn {
    background-color: transparent;
    border: none;
    color: #9ca3af;
    cursor: pointer;
    padding: 0.5rem;
    border-radius: 0.5rem;
    transition: background-color 0.2s;
}

.edit-btn:hover {
    background-color: rgba(156, 163, 175, 0.1);
}

/* ===== Share Card ===== */
.share-card {
    cursor: default;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.share-info {
    flex: 1;
}

.share-text {
    font-size: 1rem;
    color: var(--text-color);
    margin-bottom: 0.5rem;
}

.share-amount {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--primary-color);
}

.share-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.share-status {
    padding: 0.375rem 0.75rem;
    border-radius: 9999px;
    font-size: 0.875rem;
    font-weight: 500;
}

.status-paid {
    background-color: rgba(16, 185, 129, 0.1);
    color: var(--success-color);
}

.status-pending {
    background-color: rgba(245, 158, 11, 0.1);
    color: var(--warning-color);
}

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

.toggle-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.toggle-slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--border-color);
    transition: 0.3s;
    border-radius: 24px;
}

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

.toggle-switch input:checked + .toggle-slider {
    background-color: var(--success-color);
}

.toggle-switch input:checked + .toggle-slider:before {
    transform: translateX(24px);
}

/* ===== Modal ===== */
.modal {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(0, 0, 0, 0.5);
    animation: fadeIn 0.2s;
}

.modal.active {
    display: flex;
    justify-content: center;
    align-items: center;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.modal-content {
    background-color: var(--surface-color);
    margin: 1rem;
    border-radius: 1rem;
    box-shadow: var(--shadow-lg);
    width: 100%;
    max-width: 600px;
    max-height: 90vh;
    overflow: auto;
    animation: slideUp 0.3s;
}

.modal-large {
    max-width: 800px;
}

.modal-small {
    max-width: 400px;
}

@keyframes slideUp {
    from {
        transform: translateY(20px);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.5rem;
    border-bottom: 1px solid var(--border-color);
}

.modal-header h3 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
}

.modal-close {
    background: none;
    border: none;
    font-size: 1.5rem;
    cursor: pointer;
    color: var(--text-secondary);
    padding: 0.25rem;
    line-height: 1;
    transition: color 0.2s;
}

.modal-close:hover {
    color: var(--text-color);
}

.modal-body {
    padding: 1.5rem;
    color: var(--text-primary);
}

.modal-body p,
.modal-description {
    color: var(--text-primary);
    margin-bottom: 1rem;
}

.modal-footer {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 1rem;
    padding: 1.5rem;
    border-top: 1px solid var(--border-color);
}

.modal-footer:has(.toggle-container) {
    justify-content: space-between;
}

.modal-footer-buttons {
    display: flex;
    gap: 1rem;
}

/* ===== Form Elements ===== */
.form-group {
    margin-bottom: 1.5rem;
}

.form-group label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    margin-bottom: 0.5rem;
    color: var(--text-primary);
}

/* Preset Chips */
.preset-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

.preset-chip {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.75rem;
    font-size: 0.8rem;
    color: var(--text-secondary);
    background: transparent;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    cursor: pointer;
    transition: all 0.2s ease;
    user-select: none;
}

.preset-chip:hover {
    background: var(--surface-color);
    color: var(--text-color);
    border-color: var(--primary-color);
}

.preset-chip:active {
    transform: scale(0.95);
}

/* Notification User Selection */
.notification-users-selection {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 0.5rem;
}

.notification-user-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s;
}

.notification-user-item:hover {
    border-color: var(--primary-color);
    background: var(--hover-bg);
}

.notification-user-item input[type="checkbox"] {
    cursor: pointer;
}

.notification-user-item.selected {
    border-color: var(--primary-color);
    background: var(--primary-bg-light);
}

.form-control {
    width: 100%;
    padding: 0.625rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    font-size: 1rem;
    font-family: inherit;
    background-color: var(--surface-color);
    color: var(--text-color);
    transition: border-color 0.2s;
}

.form-control:focus {
    outline: none;
    border-color: var(--primary-color);
}

textarea.form-control {
    resize: vertical;
}

select.form-control {
    cursor: pointer;
}

.guests-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.guest-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.375rem;
    padding: 0.75rem 0.5rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    cursor: pointer;
    transition: all 0.2s;
    background-color: var(--surface-color);
}

.guest-card:hover {
    background-color: var(--bg-color);
    border-color: var(--primary-color);
}

.guest-card.selected {
    border-width: 2px;
    border-color: var(--primary-color);
    background-color: rgba(99, 102, 241, 0.05);
    padding: calc(0.75rem - 1px) calc(0.5rem - 1px);
}

.guest-card-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
}

.guest-card-name {
    font-size: 0.8125rem;
    font-weight: 500;
    text-align: center;
    color: var(--text-color);
    line-height: 1.2;
}

.guest-card input[type="checkbox"] {
    display: none;
}

.custom-guests-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-top: 0.75rem;
    margin-bottom: 0.75rem;
}

.custom-guests-list:empty {
    display: none;
}

/* Remove top margin from form-group when custom-guests-list is empty */
.form-group:has(.custom-guests-list:empty) {
    margin-top: -0.75rem;
}

.custom-guest-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.5rem;
    background-color: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    transition: all 0.2s;
}

.custom-guest-row:hover {
    border-color: var(--primary-color);
    background-color: var(--bg-color);
}

.custom-guest-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.custom-guest-name {
    flex: 1;
    font-size: 0.875rem;
    font-weight: 500;
}

.custom-guest-actions {
    display: flex;
    gap: 0.5rem;
}

.btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: 0.375rem;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s;
}

.btn-icon:hover {
    background-color: var(--bg-color);
    color: var(--text-color);
}

.btn-icon.edit-custom-guest:hover {
    background-color: rgba(99, 102, 241, 0.1);
    color: var(--primary-color);
}

.btn-icon.remove-custom-guest:hover {
    background-color: rgba(239, 68, 68, 0.1);
    color: #ef4444;
}

.toggle-label {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    cursor: pointer;
}

.single-guest-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.toggle-label-inline {
    display: flex;
    align-items: center;
    margin: 0;
}

.toggle-label-inline input[type="checkbox"] {
    position: relative;
    width: 48px;
    height: 28px;
    appearance: none;
    background-color: var(--border-color);
    border-radius: 28px;
    cursor: pointer;
    transition: background-color 0.3s;
}

.toggle-label-inline input[type="checkbox"]:checked {
    background-color: var(--primary-color);
}

.toggle-label-inline input[type="checkbox"]:before {
    content: "";
    position: absolute;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    top: 3px;
    left: 3px;
    background-color: white;
    transition: transform 0.3s;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.toggle-label-inline input[type="checkbox"]:checked:before {
    transform: translateX(20px);
}

.single-guest-text,
.single-guest-text-end {
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--text-color);
    transition: opacity 0.2s;
    white-space: nowrap;
}

.single-guest-row.disabled .single-guest-text,
.single-guest-row.disabled .single-guest-text-end,
.single-guest-row.disabled .single-guest-selector-inline {
    opacity: 0.4;
    pointer-events: none;
}

.single-guest-selector-inline {
    flex-shrink: 0;
}

.custom-select-trigger-compact {
    padding: 0.375rem 0.5rem;
    min-width: 150px;
}

.custom-select-trigger-compact.open {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.custom-select-trigger-compact .guest-avatar-small {
    width: 1.5rem;
    height: 1.5rem;
}

.custom-select-trigger-compact .selected-guest-name {
    font-size: 0.875rem;
}

.custom-select-trigger-compact .dropdown-arrow {
    width: 10px;
    height: 10px;
}

.single-guest-selector-inline .custom-select-options {
    position: fixed;
    z-index: 10000;
    max-height: 250px;
    overflow-y: auto;
    background-color: var(--bg-color);
    border: 1px solid var(--primary-color);
    border-top: none;
    border-radius: 0 0 0.375rem 0.375rem;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.toggle-label input[type="checkbox"] {
    position: relative;
    width: 48px;
    height: 24px;
    appearance: none;
    background-color: var(--border-color);
    border-radius: 24px;
    cursor: pointer;
    transition: background-color 0.3s;
}

.toggle-label input[type="checkbox"]:checked {
    background-color: var(--primary-color);
}

.toggle-label input[type="checkbox"]:before {
    content: "";
    position: absolute;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    top: 3px;
    left: 3px;
    background-color: white;
    transition: transform 0.3s;
}

.toggle-label input[type="checkbox"]:checked:before {
    transform: translateX(24px);
}

/* ===== iPhone-style Toggle Switch ===== */
.toggle-container {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.toggle-switch {
    position: relative;
    display: inline-block;
    width: 48px;
    height: 28px;
    cursor: pointer;
}

.toggle-switch input[type="checkbox"] {
    opacity: 0;
    width: 0;
    height: 0;
}

.toggle-slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #ccc;
    transition: 0.3s;
    border-radius: 28px;
}

[data-theme="dark"] .toggle-slider {
    background-color: #4b5563;
}

.toggle-slider:before {
    position: absolute;
    content: "";
    height: 20px;
    width: 20px;
    left: 4px;
    bottom: 4px;
    background-color: white;
    transition: 0.3s;
    border-radius: 50%;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

[data-theme="dark"] .toggle-slider:before {
    background-color: #e5e7eb;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4);
}

[dir="rtl"] .toggle-slider:before {
    left: auto;
    right: 4px;
}

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

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

[dir="rtl"] .toggle-switch input:checked + .toggle-slider:before {
    transform: translateX(-20px);
}

.toggle-text {
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--text-color);
    cursor: pointer;
    user-select: none;
}

/* ===== Date Picker ===== */
.date-presets {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}

.preset-btn {
    padding: 0.5rem 1rem;
    border: 1px solid var(--border-color);
    background-color: var(--bg-color);
    color: var(--text-color);
    border-radius: 0.5rem;
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    font-family: inherit;
}

.preset-btn:hover {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: white;
}

.preset-btn.active {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: white;
}

.date-fields {
    display: grid;
    grid-template-columns: 1fr 2fr 1.5fr;
    gap: 0.75rem;
}

.date-field-group {
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
}

.date-field-label {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-secondary);
}

.date-input {
    padding: 0.5rem !important;
    font-size: 0.875rem !important;
}

.date-input:disabled {
    background-color: var(--bg-color);
    color: var(--text-secondary);
    cursor: not-allowed;
    opacity: 0.6;
}

.preset-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

/* Custom Select (Typable Dropdown) */
.custom-select-wrapper {
    position: relative;
}

.custom-select-input {
    cursor: text;
    padding-inline-end: 2rem !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: left 0.5rem center;
    background-size: 12px;
}

[dir="ltr"] .custom-select-input {
    background-position: right 0.5rem center;
}

.custom-select-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background-color: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    max-height: 200px;
    overflow-y: auto;
    z-index: 1000;
    display: none;
    margin-top: 0.25rem;
    box-shadow: var(--shadow-md);
}

.custom-select-dropdown.active {
    display: block;
}

.custom-select-option {
    padding: 0.5rem 0.75rem;
    cursor: pointer;
    transition: background-color 0.2s;
}

.custom-select-option:hover {
    background-color: var(--bg-color);
}

.custom-select-option.selected {
    background-color: var(--primary-color);
    color: white;
}

/* ===== Tags ===== */
.tags-container {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.tags-container:not(:empty) {
    margin-bottom: 0.75rem;
}

.tag-input-row {
    display: flex;
    gap: 0.75rem;
    align-items: center;
}

.tag-input-row input {
    flex: 2;
}

.tag-input-row button {
    flex-shrink: 0;
}

.color-picker-wrapper {
    position: relative;
    flex-shrink: 0;
}

.color-picker-button {
    width: 46px;
    height: 46px;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    background-color: var(--surface-color);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: all 0.2s;
}

.color-picker-button:hover {
    border-color: var(--primary-color);
    box-shadow: var(--shadow);
}

.color-preview {
    width: 28px;
    height: 28px;
    border-radius: 0.375rem;
    display: block;
}

.color-picker-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    margin-top: 0.5rem;
    background-color: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    padding: 0.5rem;
    display: none;
    z-index: 1000;
    box-shadow: var(--shadow-md);
    grid-template-columns: repeat(5, 1fr);
    gap: 0.375rem;
}

.color-picker-dropdown.active {
    display: grid;
}

/* Card Color Picker Dropdown - Specific Styling */
#cardColorPickerDropdown {
    background-color: var(--surface-color) !important;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.4) !important;
    backdrop-filter: blur(10px);
}

[data-theme="dark"] #cardColorPickerDropdown {
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.6) !important;
}

/* RTL positioning for card color picker dropdown */
html[lang="fa"] #cardColorPickerDropdown {
    left: 0 !important;
    right: auto !important;
}

/* Card Color Picker Button - ensure background shows */
#cardColorPickerBtn {
    background: #000a38;
}

/* Avatar Position - Left, Middle, Right (absolute positions, not affected by RTL) */
.player-card[data-avatar-position] .card-avatar-container {
    position: absolute !important;
    top: 1rem;
    margin: 0;
}

.player-card[data-avatar-position] .card-content {
    justify-content: flex-end; /* Push content to bottom when avatar is absolutely positioned */
}

.player-card[data-avatar-position="left"] .card-avatar-container {
    left: 1rem !important;
    right: auto !important;
}

.player-card[data-avatar-position="middle"] .card-avatar-container {
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%);
}

.player-card[data-avatar-position="right"] .card-avatar-container {
    right: 1rem !important;
    left: auto !important;
}

/* Custom Hue Slider Styling */
#cardHueSlider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: white;
    cursor: pointer;
    border: 3px solid #333;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

#cardHueSlider::-moz-range-thumb {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: white;
    cursor: pointer;
    border: 3px solid #333;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.color-option {
    width: 32px;
    height: 32px;
    border: none;
    border-radius: 0.375rem;
    cursor: pointer;
    padding: 0;
    transition: all 0.2s;
}

.color-option:hover {
    transform: scale(1.15);
}

.color-option.selected {
    transform: scale(1.25);
}

.party-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem 0.75rem;
    border-radius: 0.5rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: white;
    border: 1px solid transparent;
    transition: all 0.2s;
    cursor: default;
}

.party-tag.tag-color-0,
.party-tag-display.tag-color-0 {
    background-color: #ef4444;
}

.party-tag.tag-color-1,
.party-tag-display.tag-color-1 {
    background-color: #f59e0b;
}

.party-tag.tag-color-2,
.party-tag-display.tag-color-2 {
    background-color: #eab308;
}

.party-tag.tag-color-3,
.party-tag-display.tag-color-3 {
    background-color: #22c55e;
}

.party-tag.tag-color-4,
.party-tag-display.tag-color-4 {
    background-color: #d1d5db;
    color: #374151;
}

.party-tag.tag-color-5,
.party-tag-display.tag-color-5 {
    background-color: #06b6d4;
}

.party-tag.tag-color-6,
.party-tag-display.tag-color-6 {
    background-color: #3b82f6;
}

.party-tag.tag-color-7,
.party-tag-display.tag-color-7 {
    background-color: #6b7280;
}

.party-tag.tag-color-8,
.party-tag-display.tag-color-8 {
    background-color: #a855f7;
}

.party-tag.tag-color-9,
.party-tag-display.tag-color-9 {
    background-color: #ec4899;
}

.party-tag-text {
    flex: 1;
}

.party-tag-edit,
.party-tag-remove {
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    color: white;
    opacity: 0.7;
    transition: opacity 0.2s;
    display: flex;
    align-items: center;
}

.party-tag-edit:hover,
.party-tag-remove:hover {
    opacity: 1;
}

.party-tag-edit svg,
.party-tag-remove svg {
    width: 14px;
    height: 14px;
}

.party-tags-display {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-inline-end: 0.5rem;
}

.party-tag-display {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.625rem;
    border-radius: 0.5rem;
    font-size: 0.75rem;
    font-weight: 500;
    color: white;
}

.new-badge-tag {
    background-color: var(--danger-color);
    font-weight: 700;
    letter-spacing: 0.025em;
    animation: pulse 2s ease-in-out infinite;
}

/* ===== Ratios List ===== */
.ratios-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.ratio-item {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    padding: 0.75rem;
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
}

.ratio-guest-display {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex: 1;
}

.ratio-guest-display .guest-avatar-small {
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    object-fit: cover;
}

.ratio-guest-display .guest-name {
    font-weight: 500;
}

.ratio-amount-display {
    flex: 1;
    text-align: center;
    font-weight: 600;
    color: var(--primary-color);
}

.ratio-actions {
    display: flex;
    gap: 0.25rem;
    flex-shrink: 0;
}

.ratio-edit-btn,
.ratio-remove-btn {
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0.5rem;
    border-radius: 0.5rem;
    transition: background-color 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
}

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

.ratio-edit-btn:hover {
    background-color: rgba(156, 163, 175, 0.1);
    color: var(--text-color);
}

.ratio-remove-btn {
    color: var(--danger-color);
}

.ratio-remove-btn:hover {
    background-color: rgba(239, 68, 68, 0.1);
}

/* Toggle label alignment fix */
.toggle-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
}

.toggle-label input[type="checkbox"] {
    margin: 0;
}

/* ===== Expense Cards Layout ===== */
.expense-single-row {
    display: grid;
    grid-template-columns: 200px 150px 1fr auto;
    gap: 1.5rem;
    align-items: center;
}

.expense-payer {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.payer-avatar {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--border-color);
    flex-shrink: 0;
}

.payer-info {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}

.payer-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    font-weight: 500;
}

.payer-name {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--text-color);
}

.expense-amount-section {
    display: flex;
    align-items: center;
    justify-content: center;
}

.expense-amount-section .expense-amount {
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--primary-color);
}

.expense-description-section {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}

.description-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    font-weight: 500;
}

.expense-description {
    font-size: 0.9375rem;
    color: var(--text-color);
}

.expense-separator {
    height: 1px;
    background: var(--border-color);
    margin: 0.75rem 0;
}

.expense-secondary-info {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
}

.expense-actions-bottom {
    display: none;
}

.payer-only-badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    background: var(--warning-color);
    color: white;
    border-radius: 1rem;
    font-size: 0.75rem;
    font-weight: 500;
}

.expense-ratios-section {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.ratios-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    font-weight: 500;
}

.expense-ratios-boxes {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

@media (max-width: 768px) {
    .expense-single-row {
        grid-template-columns: 1fr auto;
        grid-template-areas: 
            "payer amount"
            "description description"
            "actions actions";
        gap: 0.75rem;
    }

    .expense-actions {
        display: none;
    }

    .expense-payer { grid-area: payer; }
    .expense-amount-section { grid-area: amount; justify-content: flex-end; }
    .expense-description-section { grid-area: description; }

    .edit-btn, .delete-btn {
        min-height: 40px;
        padding: 0.5rem 0.75rem;
        gap: 0.375rem;
    }

    /* Mobile: show bordered icon+text buttons */
    .edit-btn {
        border: 2px solid rgba(156, 163, 175, 0.3);
        color: #6b7280;
        transition: all 0.2s;
    }
    .edit-btn:hover {
        background-color: #6b7280;
        color: white;
    }
    .delete-btn {
        border: 2px solid rgba(239, 68, 68, 0.3);
        color: var(--danger-color);
        transition: all 0.2s;
    }
    .delete-btn:hover {
        background-color: var(--danger-color);
        color: white;
    }

    .btn-text { display: inline; }

    /* Bottom actions row after badges/ratios */
    .expense-actions-bottom {
        display: flex;
        justify-content: flex-end;
        gap: 0.5rem;
        margin-top: 0.5rem;
        padding-top: 0.75rem;
        border-top: 1px solid var(--border-color);
    }

    /* Hide "For/بابت" label on mobile */
    .expense-description-section .description-label {
        display: none;
    }
}

.expense-ratios {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.ratio-box {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    background: var(--bg-color);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    font-size: 0.875rem;
}

.ratio-avatar {
    width: 1.5rem;
    height: 1.5rem;
    border-radius: 50%;
    object-fit: cover;
}

.ratio-name {
    font-weight: 500;
}

.ratio-amount {
    font-weight: 600;
    color: var(--primary-color);
}

/* ===== Shares Statistics ===== */
.shares-statistics {
    margin-bottom: 2rem;
}

.stats-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-color);
    margin-bottom: 1rem;
}

.stats-container {
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 0.75rem;
    overflow: hidden;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
}

.stat-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    border-bottom: 1px solid var(--border-color);
}

html[lang="en"] .stat-item {
    border-right: 1px solid var(--border-color);
}

html[lang="en"] .stat-item:nth-child(2n) {
    border-right: none;
}

html[lang="fa"] .stat-item {
    border-left: 1px solid var(--border-color);
}

html[lang="fa"] .stat-item:nth-child(2n) {
    border-left: none;
}

.stat-item:nth-last-child(-n+2) {
    border-bottom: none;
}


.stat-guest-info {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex: 0 0 200px;
}

.stat-guest-avatar {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.stat-guest-name {
    font-weight: 600;
    color: var(--text-color);
    font-size: 0.95rem;
}

.stat-balance {
    font-weight: 600;
    font-size: 0.9rem;
    flex: 1;
}

.stat-balance.creditor {
    color: var(--success-color);
}

.stat-balance.debtor {
    color: var(--danger-color);
}

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

.guest-exception-controls {
    margin-left: auto;
}

.exception-select {
    padding: 0.375rem 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    background-color: var(--surface-color);
    color: var(--text-color);
    font-size: 0.875rem;
    cursor: pointer;
    outline: none;
    transition: border-color 0.2s;
}

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

.exception-select:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

.exception-badge {
    padding: 0.375rem 0.75rem;
    border-radius: 0.5rem;
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    white-space: nowrap;
    transition: opacity 0.2s;
}

.exception-badge:hover {
    opacity: 0.8;
}

.exception-badge.exception-wontpay {
    background-color: var(--danger-color);
    color: white;
}

.exception-badge.exception-special {
    background-color: var(--warning-color);
    color: white;
}

.exception-badge.exception-admin {
    background-color: #ff9800;
    color: white;
    cursor: default;
}

@media (max-width: 768px) {
    .stats-container {
        grid-template-columns: 1fr;
    }
    
    .stat-item {
        flex-wrap: nowrap;
        gap: 0.5rem;
        border-right: none !important;
        border-bottom: 1px solid var(--border-color) !important;
    }
    
    .stat-item:last-child {
        border-bottom: none !important;
    }
    
    .stat-guest-info {
        flex: 0 0 auto;
        min-width: 0;
        gap: 0.4rem;
    }
    
    .stat-guest-avatar {
        width: 2rem;
        height: 2rem;
    }
    
    .stat-guest-name {
        font-size: 0.85rem;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        max-width: 80px;
    }
    
    .stat-balance {
        flex: 1 1 auto;
        font-size: 0.75rem;
        white-space: nowrap;
    }
    
    .guest-exception-controls {
        flex: 0 0 auto;
        display: flex;
        justify-content: flex-end;
    }
    
    .exception-select {
        font-size: 0.75rem;
        padding: 0.25rem 0.5rem;
    }
    
    .exception-badge {
        font-size: 0.7rem;
        padding: 0.25rem 0.5rem;
    }
}


/* ===== Payment Records & Current Shares ===== */
.payment-records-section,
.current-shares-section {
    margin-top: 2rem;
}

.records-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-color);
    margin-bottom: 1rem;
}

.records-container {
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 0.75rem;
    overflow: hidden;
}

.record-item {
    padding: 1rem;
    border-bottom: 1px solid var(--border-color);
    transition: background-color 0.2s;
}

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

.record-item.record-paid {
    opacity: 0.5;
}

.custom-share-description {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    padding: 0.75rem 0 0 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
    line-height: 1.5;
    width: 100%;
}

.custom-share-description svg {
    margin-top: 0.125rem;
    opacity: 0.5;
    flex-shrink: 0;
}

.custom-share-description span {
    flex: 1;
}

/* Emphasize user-involved shares */
.record-item.user-involved {
    padding: 1.25rem;
}

.record-item.user-involved .participant-avatar {
    width: 2.5rem;
    height: 2.5rem;
}

.record-item.user-involved .participant-name {
    font-size: 1rem;
}

.record-item.user-involved .record-amount {
    font-size: 1.15rem;
}

.record-main {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    width: 100%;
}

/* When there's a description, make record-main vertical */
.record-main:has(.custom-share-description) {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
}

.record-main:has(.custom-share-description) > div:first-child {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    width: 100%;
}


.record-participants {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex: 1;
}

html[lang="fa"] .record-participants {
    justify-content: flex-end;
}

.participant-avatar {
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.participant-name {
    font-weight: 600;
    color: var(--text-color);
    font-size: 0.9rem;
}

.payment-arrow-icon {
    color: var(--text-secondary);
    flex-shrink: 0;
}

.record-date {
    font-size: 0.875rem;
    color: var(--text-secondary);
    min-width: 100px;
    white-space: nowrap;
}

.record-amount {
    font-size: 1rem;
    font-weight: 700;
    color: var(--primary-color);
    min-width: 120px;
    text-align: right;
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}


.payment-toggle-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 2px solid var(--border-color);
    background: transparent;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
    flex-shrink: 0;
}

.payment-toggle-btn:hover {
    border-color: var(--primary-color);
    background: rgba(99, 102, 241, 0.1);
}

.payment-toggle-btn.unpaid {
    color: var(--text-secondary);
}

.payment-toggle-btn.paid {
    background: var(--success-color);
    border-color: var(--success-color);
    color: white;
}

.payment-toggle-btn.paid:hover {
    background: #059669;
    border-color: #059669;
}

/* Payment Action Button (with icon + text) */
.payment-action-btn {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    border: 1px solid var(--primary-color);
    background: var(--primary-color);
    color: white;
    font-weight: 600;
    font-family: 'Lato', sans-serif;
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
}

.payment-action-btn:hover {
    background: var(--primary-hover);
    border-color: var(--primary-hover);
    transform: translateY(-1px);
}

.payment-action-btn svg {
    flex-shrink: 0;
}

/* Variant: "I Paid for Him" button (border-only) */
.payment-action-btn.for-others {
    background: transparent;
    color: var(--primary-color);
    border: 1px solid var(--primary-color);
    opacity: 0.5;
}

.payment-action-btn.for-others:hover {
    opacity: 1;
    border-color: var(--primary-hover);
    color: var(--primary-hover);
}

/* Admin Action Buttons */
.admin-share-actions {
    display: flex;
    gap: 0.5rem;
}

.admin-action-btn {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    border-radius: 0.5rem;
    border: 1px solid;
    font-weight: 600;
    font-family: 'Lato', sans-serif;
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
    font-size: 0.875rem;
}

.admin-action-btn svg {
    flex-shrink: 0;
}

.admin-action-btn.settle {
    background: var(--success-color);
    border-color: var(--success-color);
    color: white;
}

.admin-action-btn.settle:hover {
    background: #059669;
    border-color: #059669;
    transform: translateY(-1px);
}

.admin-action-btn.disable {
    background: transparent;
    border-color: var(--danger-color);
    color: var(--danger-color);
}

.admin-action-btn.disable:hover {
    background: var(--danger-color);
    color: white;
    transform: translateY(-1px);
}

/* Section Header (for button next to title) */
.section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1rem;
}

.section-header .records-title {
    margin-bottom: 0;
}

.btn-small {
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    border: none;
    border-radius: 0.5rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    font-family: inherit;
}

.btn-small svg {
    width: 16px;
    height: 16px;
}

.record-actions-wrapper {
    display: flex;
    flex-direction: row;
    gap: 0.5rem;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.custom-share-actions {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}

.record-description {
    font-style: italic;
    max-width: 60%;
    text-align: right;
}

.record-actions {
    display: flex;
    justify-content: flex-end;
}

.payment-button {
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    font-weight: 600;
    font-size: 0.875rem;
    cursor: pointer;
    transition: all 0.3s;
    border: 2px solid;
}

.payment-button.unpaid {
    background: var(--success-color);
    color: white;
    border-color: var(--success-color);
}

.payment-button.unpaid:hover {
    background: var(--success-hover);
    border-color: var(--success-hover);
}

.payment-button.paid {
    background: transparent;
    color: var(--danger-color);
    border-color: var(--danger-color);
}

.payment-button.paid:hover {
    background: var(--danger-color);
    color: white;
}

/* ===== Payment History (Invoice-like) ===== */
.payment-history-section {
    margin-top: 2rem;
}

.history-container {
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 0.75rem;
    overflow: hidden;
    max-height: 400px;
    overflow-y: auto;
}

.history-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 1rem;
    border-bottom: 1px solid var(--border-color);
    gap: 1rem;
    font-size: 0.875rem;
}

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

.history-info {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex: 1;
}

.history-text {
    color: var(--text-secondary);
    flex: 1;
    min-width: 0;
}

.history-amount {
    font-weight: 600;
    color: var(--primary-color);
    min-width: 100px;
    text-align: right;
}

.history-date {
    color: var(--text-secondary);
    font-size: 0.8rem;
    min-width: 90px;
    text-align: right;
}

.history-remove-btn {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1px solid var(--border-color);
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
    flex-shrink: 0;
}

.history-remove-btn:hover {
    border-color: var(--danger-color);
    background: rgba(239, 68, 68, 0.1);
    color: var(--danger-color);
}

.empty-state-small {
    text-align: center;
    padding: 1.5rem;
    color: var(--text-secondary);
    font-size: 0.9rem;
}

@media (max-width: 768px) {
    .record-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.75rem;
    }
    
    .record-participants {
        width: 100%;
        justify-content: space-between;
    }
    
    .record-details {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.5rem;
    }
    
    .record-description {
        max-width: 100%;
        text-align: left;
    }
    
    /* Mobile layout for shares/payment records */
    .record-main {
        flex-direction: column;
        align-items: stretch;
        gap: 1rem;
    }
    
    .record-participants {
        justify-content: center;
    }
    
    html[lang="fa"] .record-participants {
        justify-content: center;
    }
    
    .record-amount {
        text-align: center;
        font-size: 1.25rem;
        align-items: center;
        justify-content: center;
        width: 100%;
    }
    
    .record-actions-wrapper {
        align-items: center;
        width: 100%;
        gap: 0.75rem;
    }
    
    .custom-share-actions {
        justify-content: center;
        width: 100%;
        gap: 0.75rem;
    }
    
    .custom-share-actions .edit-btn,
    .custom-share-actions .delete-btn,
    .record-actions-wrapper .admin-action-btn {
        flex: 1 1 calc(50% - 0.375rem);
        min-width: 0;
        justify-content: center;
    }
    
    .payment-action-btn {
        width: 100%;
        justify-content: center;
        padding: 0.75rem 1rem;
    }
    
    .admin-share-actions {
        width: 100%;
        flex-direction: column;
    }
    
    .admin-action-btn {
        width: 100%;
        justify-content: center;
        padding: 0.75rem 1rem;
    }
    
    .section-header {
        flex-direction: column;
        align-items: stretch;
        gap: 1rem;
    }
    
    .btn-small {
        width: 100%;
        justify-content: center;
    }
    
    /* History items on mobile */
    .history-item {
        position: relative;
        flex-direction: column;
        align-items: stretch;
        gap: 0.75rem;
        padding-right: 2.5rem; /* Add padding for the absolute button */
    }
    
    html[lang="fa"] .history-item {
        padding-right: 1rem;
        padding-left: 2.5rem; /* Add padding on left for Farsi */
    }
    
    .history-info {
        flex-direction: column;
        gap: 0.5rem;
    }
    
    .history-date,
    .history-amount {
        text-align: left;
    }
    
    html[lang="fa"] .history-date,
    html[lang="fa"] .history-amount {
        text-align: right;
    }
    
    .history-remove-btn {
        position: absolute;
        top: 0.5rem;
        right: 0.5rem;
    }
    
    html[lang="fa"] .history-remove-btn {
        right: auto;
        left: 0.5rem;
    }
}

/* ===== Notifications System ===== */

/* Notification Badge */
.notification-badge,
.notification-badge-floating,
.balances-badge {
    position: absolute;
    top: -2px;
    right: -2px;
    background-color: var(--danger-color);
    color: white;
    font-size: 0.625rem;
    font-weight: 700;
    padding: 0.125rem 0.375rem;
    border-radius: 9999px;
    min-width: 18px;
    text-align: center;
    line-height: 1.2;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

[dir="ltr"] .notification-badge,
[dir="ltr"] .notification-badge-floating,
[dir="ltr"] .balances-badge {
    left: -2px;
    right: auto;
}

/* Floating Notifications Button (Mobile) */
.floating-notifications-btn {
    position: fixed;
    bottom: 2rem;
    left: 1.5rem;
    width: 48px;
    height: 48px;
    background-color: var(--primary-color);
    border: 2px solid var(--border-color);
    border-radius: 50%;
    display: none;
    align-items: center;
    justify-content: center;
    color: white;
    text-decoration: none;
    box-shadow: var(--shadow-lg);
    transition: all 0.2s;
    z-index: 998;
    cursor: pointer;
}

/* Keep floating button on left side in both RTL and LTR */

.floating-notifications-btn:hover {
    background-color: var(--primary-hover);
    transform: scale(1.05);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
}

@media (max-width: 768px) {
    .floating-notifications-btn {
        display: flex;
    }
    
    /* Adjust notification button for mobile bottom nav (homepage and party page) */
    .page-home .floating-notifications-btn,
    .page-party .floating-notifications-btn {
        bottom: 6rem;
    }

    /* Adjust close button for mobile bottom nav (party page only) */
    .page-party .floating-close-btn {
        bottom: 6rem;
    }

    /* Adjust tab content padding for mobile bottom nav */
    .page-party .tab-content {
        padding-bottom: 80px;
    }
    
    /* Hide desktop notification button on mobile */
    .notifications-btn {
        display: none !important;
    }
}

/* Notifications Modal */
.notifications-actions {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.notifications-list {
    max-height: 60vh;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.notification-item {
    background-color: var(--bg-color);
    border: 1px solid var(--border-color);
    border-radius: 0.75rem;
    padding: 1rem;
    transition: all 0.2s;
    cursor: pointer;
}

.notification-item:hover {
    border-color: var(--primary-color);
    box-shadow: var(--shadow);
}

.notification-item.unread {
    background-color: rgba(99, 102, 241, 0.05);
    border-color: var(--primary-color);
    border-width: 2px;
    padding: calc(1rem - 1px);
}

.notification-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
}

.notification-icon {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.notification-icon.type-info {
    background-color: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
}

.notification-icon.type-payment {
    background-color: rgba(16, 185, 129, 0.1);
    color: var(--success-color);
}

.notification-icon.type-gift_payment {
    background-color: rgba(236, 72, 153, 0.1);
    color: #ec4899;
}

.notification-icon.type-warning {
    background-color: rgba(245, 158, 11, 0.1);
    color: var(--warning-color);
}

.notification-icon.type-success {
    background-color: rgba(16, 185, 129, 0.1);
    color: var(--success-color);
}

.notification-icon.type-badge_awarded {
    background-color: rgba(251, 191, 36, 0.1);
    color: #fbbf24;
}

.notification-badge-image {
    width: 48px;
    height: 48px;
    object-fit: contain;
    flex-shrink: 0;
    margin-left: 0.5rem;
    margin-right: 0.5rem;
}

.notification-content {
    flex: 1;
}

/* ===== New Badge Indicator ===== */
.new-badge-indicator {
    text-align: center;
    margin-top: 1rem;
    padding: 0.5rem;
    background: linear-gradient(135deg, rgba(251, 191, 36, 0.1), rgba(245, 158, 11, 0.1));
    border-radius: 0.5rem;
    border: 1px solid rgba(251, 191, 36, 0.3);
}

.new-badge-indicator span {
    color: #fbbf24;
    font-weight: 500;
    font-size: 0.9rem;
}

/* NEW tag for badges in select badge modal */
.badge-new-tag {
    position: absolute;
    top: -0.5rem;
    right: -0.5rem;
    background: linear-gradient(135deg, #f59e0b, #fbbf24);
    color: white;
    font-size: 0.7rem;
    font-weight: bold;
    padding: 0.25rem 0.5rem;
    border-radius: 0.5rem;
    box-shadow: 0 2px 8px rgba(251, 191, 36, 0.4);
    z-index: 10;
    animation: pulse 2s ease-in-out infinite;
}

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

.notification-message {
    font-size: 0.9375rem;
    color: var(--text-color);
    margin-bottom: 0.375rem;
    line-height: 1.5;
}

.notification-time {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.notification-link {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    color: var(--primary-color);
    font-size: 0.875rem;
    font-weight: 500;
    margin-top: 0.5rem;
    text-decoration: none;
    transition: color 0.2s;
}

.notification-link:hover {
    color: var(--primary-hover);
}

.notification-actions-btn {
    display: flex;
    gap: 0.375rem;
    margin-left: auto;
}

[dir="ltr"] .notification-actions-btn {
    margin-left: 0;
    margin-right: auto;
}

.notification-action-icon {
    width: 28px;
    height: 28px;
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s;
    background: transparent;
}

.notification-action-icon:hover {
    background-color: var(--bg-color);
    border-color: var(--primary-color);
    color: var(--primary-color);
}

.notification-action-icon.delete:hover {
    border-color: var(--danger-color);
    background-color: rgba(239, 68, 68, 0.1);
    color: var(--danger-color);
}

@media (max-width: 768px) {
    .notifications-actions {
        flex-direction: column;
    }
    
    .notifications-actions .btn {
        width: 100%;
        justify-content: center;
    }
    
    .notification-item {
        padding: 0.875rem;
    }
}

/* ===== Empty State ===== */
.empty-state {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--text-secondary);
}

.empty-state svg {
    margin-bottom: 1rem;
    opacity: 0.5;
}

.empty-state-icon {
    width: 32px;
    height: 32px;
    margin-bottom: 1rem;
    opacity: 0.5;
}

/* Color empty state icons based on theme (skip _color suffixed icons) */
[data-theme="light"] .empty-state-icon:not([src*="_color"]) {
    filter: none;
}

[data-theme="dark"] .empty-state-icon:not([src*="_color"]) {
    filter: invert(1);
}

/* Color suffixed empty state icons - use as is */
.empty-state-icon[src*="_color"] {
    filter: none;
    opacity: 1;
}

/* ===== Payment History in Balances Tab ===== */
.history-party {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.history-party-link {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem 0.75rem;
    background: transparent;
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    color: var(--primary-color);
    cursor: pointer;
    font-size: 0.8rem;
    font-family: inherit;
    transition: all 0.2s;
    white-space: nowrap;
}

.history-party-link:hover {
    background: var(--hover-bg);
    border-color: var(--primary-color);
}

.history-party-link svg {
    flex-shrink: 0;
}

/* ===== Expenses Table in Balances Tab ===== */
.expense-amount-large {
    font-weight: 700;
    color: var(--primary-color);
    font-size: 1.1rem;
    min-width: 140px;
    text-align: left;
}

html[lang="fa"] .expense-amount-large {
    text-align: right;
}

.expense-description-text {
    color: var(--text-secondary);
    flex: 1;
    min-width: 0;
}

.expense-history-item .history-date {
    min-width: 120px;
}

/* ===== Pagination ===== */
.pagination-controls {
    margin-top: 1.5rem;
    display: flex;
    justify-content: center;
}

.pagination-buttons {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.pagination-btn {
    padding: 0.5rem 0.875rem;
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    color: var(--text-primary);
    cursor: pointer;
    font-size: 0.875rem;
    font-family: inherit;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    gap: 0.375rem;
}

.pagination-btn:hover {
    background: var(--hover-bg);
    border-color: var(--primary-color);
}

.pagination-btn.active {
    background: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
}

.pagination-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.pagination-ellipsis {
    padding: 0.5rem;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

@media (max-width: 768px) {
    /* Balances tab payment history mobile layout */
    #balancesTab .history-item {
        flex-direction: column;
        align-items: stretch;
        gap: 0.5rem;
        padding: 0.75rem 1rem; /* Override the party page padding */
    }
    
    html[lang="fa"] #balancesTab .history-item {
        padding: 0.75rem 1rem; /* Same padding for Farsi */
    }
    
    #balancesTab .history-info {
        flex-direction: row;
        align-items: center;
        gap: 0.75rem;
        flex-wrap: wrap;
    }
    
    #balancesTab .history-text {
        flex: 1;
        min-width: 120px;
    }
    
    #balancesTab .history-amount {
        text-align: right;
        min-width: auto;
    }
    
    html[lang="fa"] #balancesTab .history-amount {
        text-align: left;
    }
    
    #balancesTab .history-date {
        display: none; /* Hide from first row */
    }
    
    /* Second row: date and button */
    #balancesTab .history-party {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-top: 0;
        gap: 1rem;
    }
    
    #balancesTab .history-party::before {
        content: attr(data-date);
        font-size: 0.75rem;
        color: var(--text-secondary);
        opacity: 0.8;
    }
    
    #balancesTab .history-party-link {
        font-size: 0.75rem;
        padding: 0.3rem 0.6rem;
    }
    
    #balancesTab .history-party-link svg {
        width: 12px;
        height: 12px;
    }
    
    /* Expenses table mobile layout */
    #balancesTab .expense-history-item {
        flex-direction: column;
        align-items: stretch;
        gap: 0.5rem;
        padding: 0.75rem 1rem;
    }
    
    html[lang="fa"] #balancesTab .expense-history-item {
        padding: 0.75rem 1rem;
    }
    
    #balancesTab .expense-history-item .history-info {
        flex-direction: row;
        align-items: center;
        gap: 0.75rem;
        flex-wrap: wrap;
    }
    
    #balancesTab .expense-amount-large {
        font-size: 1rem;
        min-width: auto;
    }
    
    #balancesTab .expense-description-text {
        flex: 1;
        min-width: 150px;
        font-size: 0.85rem;
    }
    
    #balancesTab .expense-history-item .history-date {
        display: none; /* Hide from first row */
    }
    
    #balancesTab .expense-history-item .history-party {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-top: 0;
        gap: 1rem;
    }
    
    #balancesTab .expense-history-item .history-party::before {
        content: attr(data-date);
        font-size: 0.75rem;
        color: var(--text-secondary);
        opacity: 0.8;
    }
    
    /* Party Page Balances tab payment history mobile layout */
    #partyPageBalancesTab .history-item {
        flex-direction: column;
        align-items: stretch;
        gap: 0.5rem;
        padding: 0.75rem 1rem;
    }
    
    html[lang="fa"] #partyPageBalancesTab .history-item {
        padding: 0.75rem 1rem;
    }
    
    #partyPageBalancesTab .history-info {
        flex-direction: row;
        align-items: center;
        gap: 0.75rem;
        flex-wrap: wrap;
    }
    
    #partyPageBalancesTab .history-text {
        flex: 1;
        min-width: 120px;
    }
    
    #partyPageBalancesTab .history-amount {
        text-align: right;
        min-width: auto;
    }
    
    html[lang="fa"] #partyPageBalancesTab .history-amount {
        text-align: left;
    }
    
    #partyPageBalancesTab .history-date {
        display: none; /* Hide from first row */
    }
    
    /* Second row: date and button */
    #partyPageBalancesTab .history-party {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-top: 0;
        gap: 1rem;
    }
    
    #partyPageBalancesTab .history-party::before {
        content: attr(data-date);
        font-size: 0.75rem;
        color: var(--text-secondary);
        opacity: 0.8;
    }
    
    #partyPageBalancesTab .history-party-link {
        font-size: 0.75rem;
        padding: 0.3rem 0.6rem;
    }
    
    #partyPageBalancesTab .history-party-link svg {
        width: 12px;
        height: 12px;
    }
    
    /* Party Banner Mobile */
    .party-banner-section {
        margin-top: 5rem; /* Only header on mobile, tabs at bottom */
        margin-bottom: -60px; /* Less overlap on mobile */
    }
    
    .party-banner-container {
        aspect-ratio: 5 / 2; /* Taller on mobile (2.5:1) */
    }
    
    .party-banner-edit-btn {
        width: 40px;
        height: 40px;
        top: 0.75rem;
        left: 0.75rem;
    }
    
    .party-banner-edit-btn svg {
        width: 18px;
        height: 18px;
    }
    
    .party-banner-upload-progress {
        padding: 0.5rem 0.75rem;
        flex-direction: column;
        gap: 0.5rem;
    }
    
    .party-banner-upload-progress .progress-bar {
        width: 100px;
        height: 4px;
    }
    
    .party-banner-upload-progress .progress-text {
        font-size: 0.75rem;
    }

    /* Party Page Expenses table mobile layout */
    #partyPageBalancesTab .expense-history-item {
        flex-direction: column;
        align-items: stretch;
        gap: 0.5rem;
        padding: 0.75rem 1rem;
    }
    
    html[lang="fa"] #partyPageBalancesTab .expense-history-item {
        padding: 0.75rem 1rem;
    }
    
    #partyPageBalancesTab .expense-history-item .history-info {
        flex-direction: row;
        align-items: center;
        gap: 0.75rem;
        flex-wrap: wrap;
    }
    
    #partyPageBalancesTab .expense-amount-large {
        font-size: 1rem;
        min-width: auto;
    }
    
    #partyPageBalancesTab .expense-description-text {
        flex: 1;
        min-width: 150px;
        font-size: 0.85rem;
    }
    
    #partyPageBalancesTab .expense-history-item .history-date {
        display: none; /* Hide from first row */
    }
    
    #partyPageBalancesTab .expense-history-item .history-party {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-top: 0;
        gap: 1rem;
    }
    
    #partyPageBalancesTab .expense-history-item .history-party::before {
        content: attr(data-date);
        font-size: 0.75rem;
        color: var(--text-secondary);
        opacity: 0.8;
    }
    
    .pagination-buttons {
        flex-wrap: wrap;
        gap: 0.375rem;
    }
    
    .pagination-btn {
        padding: 0.375rem 0.625rem;
        font-size: 0.8rem;
    }
}

/* ===== Mobile Styles ===== */
.mobile-sort-filter {
    display: none;
}

.party-mobile-layout {
    display: none;
}

.mobile-filter-group,
.mobile-sort-group {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

/* Ensure mobile modal content uses proper fonts */
#mobileSortFilterModal .modal-content {
    font-family: inherit;
}

#mobileSortFilterModal .form-group label {
    font-family: inherit;
}

.mobile-filter-btn,
.mobile-sort-btn {
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--border-color);
    background-color: var(--surface-color);
    color: var(--text-color);
    border-radius: 0.5rem;
    font-size: 0.875rem;
    cursor: pointer;
    transition: all 0.2s;
    font-family: inherit;
}

.mobile-filter-btn:hover,
.mobile-sort-btn:hover {
    background-color: var(--bg-color);
}

.mobile-filter-btn.active,
.mobile-sort-btn.active {
    background-color: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
}

/* ===== Responsive ===== */
@media (max-width: 768px) {
    /* Tighten all container padding on mobile for more content space */
    .container {
        padding: 0 8px !important;
    }

    /* Adjust header grid spacing on mobile */
    .header-content {
        gap: 0.5rem;
    }

    /* Reserve space for user profile to prevent overlap */
    .header-right {
        min-width: 44px;
        flex-shrink: 0;
    }

    /* Move dark mode and language buttons much closer together */
    .header-left {
        gap: 0.25rem !important;
    }

    /* Make icon buttons narrower on mobile */
    .icon-btn {
        min-width: 42px !important;
        padding: 0.375rem 0.25rem !important;
        font-size: 0.75rem;
    }

    /* Stack logo and version vertically on mobile */
    .header-center {
        flex-direction: column;
        gap: 0.25rem;
        justify-content: center;
        /* Move logo toward the profile picture (left) - clamped to prevent overlap */
        margin-left: clamp(-120px, -30vw, -60px) !important;
        /* Move logo and text down */
        margin-top: 8px !important;
    }

    .logo {
        height: 20px;
        width: auto;
    }

    .logo-version {
        font-size: 0.5rem;
    }

    /* Adjust card padding on mobile for better spacing */
    .party-card {
        padding: 1.25rem 1.125rem;
    }
    
    /* Make guest avatars slightly smaller on mobile */
    .party-card .guest-avatar {
        width: 28px;
        height: 28px;
    }

    /* Tighten spacing in homepage statistics */
    .stat-value {
        margin-bottom: 0.25rem;
    }

    /* Make guest avatars smaller in party page header */
    .party-guests-list-inline .party-guest-avatar {
        width: 28px;
        height: 28px;
    }

    /* Tighten spacing in party page header statistics */
    .amount-label {
        margin-bottom: 0.25rem;
    }

    /* Tighten spacing in guest statistics section */
    .stat-item {
        padding: 0.75rem;
        gap: 0.4rem;
    }

    /* Make floating close button larger */
    .floating-close-btn {
        width: 64px;
        height: 64px;
    }

    .expense-card,
    .share-card {
        padding: 1rem;
    }

    .party-header-card {
        padding: 1.25rem;
    }

    .stat-card {
        padding: 1rem;
    }

    .tag-input-row {
        display: flex;
        flex-direction: row;
        gap: 0.5rem;
        align-items: center;
    }
    
    .tag-input-row input {
        flex: 1;
        min-width: 0;
    }
    
    .tag-input-row .color-picker-wrapper {
        flex-shrink: 0;
    }
    
    .tag-input-row button {
        flex-shrink: 0;
        white-space: nowrap;
    }
    
    /* Make tags larger on mobile for better touch targets */
    .party-tag {
        padding: 0.625rem 1rem;
        font-size: 1rem;
        gap: 0.625rem;
    }
    
    .party-tag-edit svg,
    .party-tag-remove svg {
        width: 18px;
        height: 18px;
    }
    
    .party-tag-edit,
    .party-tag-remove {
        padding: 0.25rem;
        margin: -0.25rem;
    }
    
    /* Fix color picker dropdown on mobile */
    .color-picker-dropdown {
        position: absolute;
        z-index: 1001;
        /* Adjust position to prevent overflow on mobile */
        left: auto;
        right: 0;
    }
    
    /* In Farsi (RTL), position from left */
    html[lang="fa"] .color-picker-dropdown {
        left: 0;
        right: auto;
    }
    
    .color-picker-dropdown.active {
        display: grid !important;
        grid-template-columns: repeat(5, 1fr);
    }
    
    .color-option {
        width: 36px;
        height: 36px;
        min-width: 36px;
        min-height: 36px;
    }
    
    /* Make single guest row wrap on mobile */
    .single-guest-row {
        flex-wrap: wrap;
    }
    
    .single-guest-text,
    .single-guest-text-end {
        font-size: 0.875rem;
    }
    
    .custom-select-trigger-compact {
        min-width: 130px;
    }

    .filters-bar {
        display: none;
    }
    
    .mobile-sort-filter {
        display: block;
        margin-bottom: 1rem;
    }
    
    .debt-filter-container {
        margin: 1rem 0 1.5rem 0;
    }
    
    .debt-filter-container .toggle-label {
        font-size: 0.875rem;
    }
    
    .mobile-sort-filter-btn {
        display: flex;
        align-items: center;
        gap: 0.5rem;
        padding: 0.75rem 1rem;
        background-color: var(--surface-color);
        border: 1px solid var(--border-color);
        border-radius: 0.5rem;
        color: var(--text-color);
        font-size: 0.875rem;
        cursor: pointer;
        transition: all 0.2s;
        width: 100%;
        justify-content: center;
        font-family: inherit;
    }
    
    .mobile-sort-filter-btn:hover {
        background-color: var(--bg-color);
        border-color: var(--primary-color);
    }
    
    /* Mobile Party Card Layout */
    .party-card-header {
        display: none;
    }
    
    .party-mobile-layout {
        display: block;
    }
    
    .party-mobile-row {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 1rem;
    }
    
    /* Add divider below first row (guests + date) */
    .party-mobile-row:first-child {
        padding-bottom: 1rem;
        border-bottom: 1px solid var(--border-color);
        margin-bottom: 1.25rem;
    }
    
    .party-mobile-row:last-child {
        margin-bottom: 0;
    }
    
    .party-mobile-guests {
        display: flex;
        align-items: center;
        gap: 0.25rem;
    }
    
    .party-mobile-date {
        font-size: 0.875rem;
        color: var(--text-secondary);
    }
    
    .party-mobile-status {
        display: flex;
        align-items: center;
        gap: 0.5rem;
    }
    
    .party-mobile-actions {
        display: flex;
        gap: 0.5rem;
    }
    
    .party-mobile-actions .edit-btn,
    .party-mobile-actions .delete-btn {
        padding: 0.5rem;
        border-radius: 0.5rem;
    }
    
    /* Guest overflow indicator */
    .guest-overflow-avatar {
        background-color: var(--text-secondary);
        color: white;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 0.7rem;
        font-weight: 600;
        border-radius: 50%;
        width: 28px;
        height: 28px;
    }

    .party-card-header {
        flex-wrap: wrap;
        gap: 1rem;
    }

    .party-meta {
        gap: 0.5rem;
        width: 100%;
    }

    .party-card-actions {
        margin-inline-start: 0;
        gap: 0.5rem;
        width: 100%;
        justify-content: space-between;
    }
    
    /* Add spacing above badges + description combo */
    .party-info-row-2 {
        align-items: center;
    }
    
    .party-tags-display {
        padding-top: 0.75rem;
    }
    
    .party-description {
        padding-top: 0.75rem;
    }
    
    .party-description-inline {
        line-height: 2; /* Match tag height for better alignment */
    }
    
    .party-status {
        padding: 0.375rem 0.75rem;
        font-size: 0.8125rem;
    }

    .party-info-grid {
        grid-template-columns: 1fr;
    }

    .modal-content {
        margin: 0.5rem;
        margin-left: 8px;
        margin-right: 8px;
    }

    /* Reduce modal padding on mobile */
    .modal-header,
    .modal-body,
    .modal-footer {
        padding: 1rem;
    }

    .modal-footer {
        flex-direction: column-reverse;
        align-items: stretch;
    }

    .modal-footer-buttons {
        flex-direction: column-reverse;
    }

    .modal-footer .btn {
        width: 100%;
        justify-content: center;
    }
    
    .toggle-container {
        justify-content: center;
    }

    .share-card {
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem;
    }

    .share-actions {
        width: 100%;
        justify-content: space-between;
    }
}

@media (max-width: 480px) {
    /* Extra tight padding for all containers on very small phones */
    .container {
        padding: 0 6px !important;
    }

    /* Further reduce spacing on very small phones */
    .header-content {
        gap: 0.375rem;
    }

    /* Reserve space for user profile to prevent overlap */
    .header-right {
        min-width: 40px;
        flex-shrink: 0;
    }

    /* Buttons very close together on tiny phones */
    .header-left {
        gap: 0.125rem !important;
    }

    .header-center {
        gap: 0.25rem;
        /* Move logo toward the profile picture (left) - clamped to prevent overlap */
        margin-left: clamp(-100px, -28vw, -50px) !important;
        /* Move logo and text down */
        margin-top: 8px !important;
    }

    .logo {
        height: 18px;
        width: auto;
    }

    .logo-version {
        font-size: 0.45rem;
    }

    /* Make icon buttons even more compact on small phones */
    .icon-btn {
        min-width: 38px !important;
        padding: 0.3rem 0.2rem !important;
        font-size: 0.7rem;
    }

    /* Adjust card padding on very small phones */
    .party-card {
        padding: 1.125rem 1rem;
    }
    
    /* Make guest avatars even smaller on very small phones */
    .party-card .guest-avatar {
        width: 26px;
        height: 26px;
    }
    
    .guest-overflow-avatar {
        width: 26px;
        height: 26px;
        font-size: 0.65rem;
    }

    /* Tighten spacing in homepage statistics on small phones */
    .stat-value {
        margin-bottom: 0.2rem;
        font-size: 1.75rem;
    }

    /* Make guest avatars smaller in party page header */
    .party-guests-list-inline .party-guest-avatar {
        width: 26px;
        height: 26px;
    }

    /* Tighten spacing in party page header statistics */
    .amount-label {
        margin-bottom: 0.2rem;
    }

    /* Tighten spacing in guest statistics section */
    .stat-item {
        padding: 0.625rem;
        gap: 0.3rem;
    }
    
    .stat-guest-avatar {
        width: 1.75rem;
        height: 1.75rem;
    }
    
    .stat-guest-name {
        font-size: 0.75rem;
        max-width: 60px;
    }
    
    .stat-balance {
        font-size: 0.7rem;
    }
    
    .exception-select {
        font-size: 0.7rem;
        padding: 0.2rem 0.4rem;
    }
    
    .exception-badge {
        font-size: 0.65rem;
        padding: 0.2rem 0.4rem;
    }

    /* Make floating close button even larger on small phones */
    .floating-close-btn {
        width: 68px;
        height: 68px;
    }

    .expense-card,
    .share-card {
        padding: 0.875rem;
    }

    .party-header-card {
        padding: 1rem;
    }

    .stat-card {
        padding: 0.875rem;
    }

    .guests-grid {
        grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    }
    
    .date-presets {
        justify-content: stretch;
    }
    
    .preset-btn {
        flex: 1;
        min-width: 0;
    }
}

/* ===== Login Page ===== */
.login-body {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 2rem 1rem;
}

.login-container {
    width: 100%;
    max-width: 500px;
}

.login-card {
    background-color: var(--surface-color);
    border-radius: 1rem;
    padding: 2rem;
    box-shadow: var(--shadow-lg);
    position: relative;
}

.login-header {
    text-align: center;
    margin-bottom: 2rem;
    padding-top: 5rem;
}

.login-logo {
    height: 25px;
    width: auto;
    margin-bottom: 0.25rem;
}

.logo-version {
    font-size: 0.625rem;
    color: var(--text-secondary);
    opacity: 0.5;
    letter-spacing: 0.05em;
    margin-bottom: 1rem;
}

.header-center .logo-version {
    margin-bottom: 0;
    margin-inline-start: 0.375rem;
    align-self: center;
}

.login-title {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--text-color);
}

.login-controls {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    margin-bottom: 2rem;
}

.login-controls-top-right {
    position: absolute;
    top: 1rem;
    display: flex;
    gap: 0.5rem;
    z-index: 10;
    direction: ltr;
}

[dir="rtl"] .login-controls-top-right {
    right: 1rem;
}

[dir="ltr"] .login-controls-top-right {
    right: 1rem;
}

.brand-color-section {
    margin-bottom: 2rem;
}

.brand-color-section label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-color);
    margin-bottom: 0.75rem;
    text-align: center;
}

.brand-colors {
    display: flex;
    justify-content: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.brand-color-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 3px solid transparent;
    cursor: pointer;
    transition: all 0.2s;
    padding: 0;
}

.brand-color-btn:hover {
    transform: scale(1.1);
}

.brand-color-btn.active {
    border-color: var(--text-color);
    transform: scale(1.15);
}

.brand-color-section-small {
    margin: 1.5rem 0;
}

.brand-color-section-small label {
    display: block;
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
    text-align: center;
}

.brand-colors-small {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.brand-color-btn-small {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 2px solid transparent;
    cursor: pointer;
    transition: all 0.2s;
    padding: 0;
}

.brand-color-btn-small:hover {
    transform: scale(1.1);
}

.brand-color-btn-small.active {
    border-color: rgba(0, 0, 0, 0);
    transform: scale(1.15);
    box-shadow: 0 0 0 3px rgba(var(--text-color-rgb), 0.3);
}

[data-theme="dark"] .brand-color-btn-small.active {
    box-shadow: 0 0 0 3px rgba(249, 250, 251, 0.15);
}

[data-theme="light"] .brand-color-btn-small.active {
    box-shadow: 0 0 0 3px rgba(17, 24, 39, 0.15);
}

.login-content {
    margin-top: 1.5rem;
}

.login-step {
    animation: fadeIn 0.3s;
}

.login-subtitle {
    font-size: 1.25rem;
    font-weight: 600;
    text-align: center;
    margin-bottom: 1.5rem;
    color: var(--text-color);
}

.users-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.user-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 0.75rem;
    border: 2px solid var(--border-color);
    border-radius: 0.75rem;
    cursor: pointer;
    transition: all 0.2s;
    background-color: var(--surface-color);
    position: relative;
}

.user-card:hover {
    background-color: var(--bg-color);
    border-color: var(--primary-color);
    transform: translateY(-2px);
}

.user-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
}

.user-name {
    font-size: 0.875rem;
    font-weight: 500;
    text-align: center;
    color: var(--text-color);
}

.admin-badge {
    position: absolute;
    top: 0.5rem;
    right: 0.5rem;
    background-color: var(--primary-color);
    color: white;
    font-size: 0.625rem;
    padding: 0.125rem 0.375rem;
    border-radius: 0.25rem;
    font-weight: 600;
}

[dir="ltr"] .admin-badge {
    left: 0.5rem;
    right: auto;
}

.selected-user-display {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

.selected-user-avatar {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    object-fit: cover;
}

.selected-user-name {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--text-color);
}

.selected-user-display-large {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    margin-bottom: 2rem;
}

.selected-user-avatar-large {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    object-fit: cover;
    border: 4px solid var(--primary-color);
    box-shadow: var(--shadow-md);
}

.welcome-text {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--text-color);
    text-align: center;
}

.login-error {
    background-color: rgba(239, 68, 68, 0.1);
    color: var(--danger-color);
    padding: 0.75rem;
    border-radius: 0.5rem;
    font-size: 0.875rem;
    margin-top: 1rem;
    text-align: center;
}

.login-buttons {
    display: flex;
    gap: 0.75rem;
    margin-top: 1.5rem;
}

.login-buttons .btn {
    flex: 1;
}

/* ===== User Profile ===== */
.user-profile {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    border-radius: 0.5rem;
    cursor: pointer;
    transition: background-color 0.2s;
}

.user-profile:hover {
    background-color: var(--bg-color);
}

.user-profile-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
}

.user-profile-name {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-color);
}

.user-profile-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    padding: 1.5rem 0;
}

.user-profile-modal-avatar {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
}

.user-profile-modal-name {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-color);
}

.user-profile-actions {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.user-profile-actions .btn {
    width: 100%;
    justify-content: flex-start;
}

.user-profile-actions .upload-progress {
    margin: 0.5rem 0;
    width: 100%;
}

@media (max-width: 768px) {
    .user-profile-name {
        display: none;
    }
    
    .login-card {
        padding: 1.5rem;
    }
    
    .users-grid {
        grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
        gap: 0.75rem;
    }
}

/* ===== Receipt Upload & Management ===== */
.receipt-upload-area {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

.upload-hint {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.upload-progress {
    margin: 1rem 0;
}

.progress-bar {
    width: 100%;
    height: 8px;
    background-color: var(--border-color);
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 0.5rem;
    direction: ltr; /* Always LTR for progress bar */
}

.progress-fill {
    height: 100%;
    background-color: var(--primary-color);
    transition: width 0.3s;
    border-radius: 4px;
    margin-left: 0; /* Force start from left */
    margin-right: auto;
}

.progress-text {
    font-size: 0.875rem;
    color: var(--text-color);
    font-weight: 500;
}

.receipts-grid {
    display: flex;
    gap: 1rem;
    margin-top: 1rem;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 0.5rem;
    scroll-snap-type: x mandatory;
}

.receipts-grid::-webkit-scrollbar {
    height: 6px;
}

.receipts-grid::-webkit-scrollbar-track {
    background: var(--border-color);
    border-radius: 3px;
}

.receipts-grid::-webkit-scrollbar-thumb {
    background: var(--primary-color);
    border-radius: 3px;
}

.receipt-thumbnail {
    flex: 0 0 150px;
    border-radius: 0.5rem;
    border: 2px solid var(--border-color);
    transition: border-color 0.2s;
    scroll-snap-align: start;
    display: flex;
    flex-direction: column;
}

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

.receipt-image-wrapper {
    position: relative;
    cursor: pointer;
}

.receipt-image {
    width: 150px;
    height: 150px;
    object-fit: cover;
    display: block;
    border-radius: 0.375rem 0.375rem 0 0;
}

.receipt-actions {
    display: flex;
    gap: 0.25rem;
    padding: 0.5rem;
    background: var(--card-bg);
    border-top: 1px solid var(--border-color);
    border-radius: 0 0 0.375rem 0.375rem;
}

.receipt-action-btn {
    flex: 1;
    height: 32px;
    border-radius: 0.25rem;
    border: 1px solid var(--border-color);
    background-color: var(--bg-color);
    color: var(--text-color);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
    padding: 0;
}

.receipt-action-btn:hover {
    background-color: var(--surface-color);
    border-color: var(--primary-color);
}

.receipt-action-btn svg {
    width: 16px;
    height: 16px;
}

/* ===== Unified Image Lightbox ===== */
.receipts-lightbox {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.95);
    z-index: 10001;
    display: flex;
    align-items: center;
    justify-content: center;
}

.lightbox-close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    border: none;
    background-color: rgba(255, 255, 255, 0.1);
    color: white;
    font-size: 2rem;
    cursor: pointer;
    transition: background-color 0.2s;
    z-index: 10003;
}

.lightbox-close:hover {
    background-color: rgba(255, 255, 255, 0.2);
}

.lightbox-content {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    cursor: default; /* Click outside image to close */
}

.lightbox-image-container {
    width: 90%;
    height: 90%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    position: relative;
    cursor: grab;
}

.lightbox-image-container.grabbing {
    cursor: grabbing;
}

.lightbox-image-container img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    transition: transform 0.1s;
    user-select: none;
    pointer-events: none;
}

.lightbox-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 56px;
    height: 56px;
    border-radius: 50%;
    border: none;
    background-color: rgba(255, 255, 255, 0.1);
    color: white;
    cursor: pointer;
    transition: background-color 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10002;
}

.lightbox-nav:hover {
    background-color: rgba(255, 255, 255, 0.2);
}

.lightbox-nav:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

.lightbox-nav:disabled:hover {
    background-color: rgba(255, 255, 255, 0.1);
}

.lightbox-prev {
    left: 2rem;
}

.lightbox-next {
    right: 2rem;
}

.lightbox-counter {
    position: absolute;
    top: 1rem;
    left: 50%;
    transform: translateX(-50%);
    color: white;
    font-size: 1rem;
    background-color: rgba(0, 0, 0, 0.6);
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    z-index: 10002;
}

.lightbox-description {
    position: absolute;
    top: 4rem;
    left: 50%;
    transform: translateX(-50%);
    color: white;
    font-size: 0.875rem;
    background-color: rgba(0, 0, 0, 0.75);
    padding: 0.75rem 1.25rem;
    border-radius: 0.5rem;
    z-index: 10002;
    max-width: 80%;
    text-align: center;
    line-height: 1.5;
}

.lightbox-controls {
    position: absolute;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 0.5rem;
    background-color: rgba(0, 0, 0, 0.6);
    padding: 0.5rem;
    border-radius: 0.5rem;
    z-index: 10002;
}

.lightbox-zoom-btn {
    width: 40px;
    height: 40px;
    border-radius: 0.375rem;
    border: none;
    background-color: rgba(255, 255, 255, 0.1);
    color: white;
    cursor: pointer;
    transition: background-color 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
}

.lightbox-zoom-btn:hover {
    background-color: rgba(255, 255, 255, 0.2);
}

.receipts-button {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem 0.75rem;
    background-color: rgba(var(--primary-color-rgb), 0.1);
    color: var(--primary-color);
    border: 1px solid var(--primary-color);
    border-radius: 0.375rem;
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
}

.receipts-button:hover {
    background-color: rgba(var(--primary-color-rgb), 0.2);
}

.receipts-button svg {
    width: 16px;
    height: 16px;
}

@media (max-width: 768px) {
    .receipt-thumbnail {
        flex: 0 0 130px;
    }
    
    .receipt-image {
        width: 130px;
        height: 130px;
    }
    
    .lightbox-nav {
        width: 48px;
        height: 48px;
    }
    
    .lightbox-prev {
        left: 1rem;
    }
    
    .lightbox-next {
        right: 1rem;
    }
}

/* ===== Banner Crop Modal ===== */
#bannerCropModal .modal-body {
    padding: 1rem;
}

.banner-crop-container {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.crop-canvas-wrapper {
    position: relative;
    width: 100%;
    background-color: #000;
    border-radius: 0.5rem;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 300px;
    max-height: 600px;
    touch-action: none; /* Prevent default touch behaviors */
    user-select: none;
}

#bannerCropCanvas {
    display: block;
    max-width: 100%;
    max-height: 100%;
    cursor: move;
    cursor: grab;
    touch-action: none; /* Prevent default touch behaviors like scrolling */
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none; /* Prevent text selection during drag */
}

#bannerCropCanvas:active {
    cursor: grabbing;
}

.crop-controls {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.crop-control-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.crop-control-group label {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-color);
}

#bannerZoomSlider {
    width: 100%;
    height: 6px;
    border-radius: 3px;
    background: var(--border-color);
    outline: none;
    -webkit-appearance: none;
}

#bannerZoomSlider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--primary-color);
    cursor: pointer;
}

#bannerZoomSlider::-moz-range-thumb {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--primary-color);
    cursor: pointer;
    border: none;
}

.crop-instructions {
    display: none; /* Hidden on desktop */
}

.crop-instructions p {
    margin: 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

@media (max-width: 768px) {
    #bannerCropModal .modal-body {
        padding: 0.5rem;
    }
    
    #bannerCropModal .modal-footer {
        padding: 0.75rem;
    }
    
    .crop-canvas-wrapper {
        min-height: 250px;
        max-height: 500px;
        border-radius: 0.25rem;
    }
    
    .crop-control-group {
        display: none; /* Hide zoom slider on mobile */
    }
    
    .banner-crop-container {
        gap: 0; /* No gap on mobile */
    }
}

/* ===== Avatar Crop Modal ===== */
#avatarCropModal .modal-body {
    padding: 1rem;
}

.avatar-crop-container {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

#avatarCropCanvas {
    display: block;
    max-width: 100%;
    max-height: 100%;
    cursor: move;
    cursor: grab;
    touch-action: none; /* Prevent default touch behaviors like scrolling */
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none; /* Prevent text selection during drag */
}

#avatarCropCanvas:active {
    cursor: grabbing;
}

@media (max-width: 768px) {
    #avatarCropModal .modal-body {
        padding: 0.5rem;
    }
    
    #avatarCropModal .modal-footer {
        padding: 0.75rem;
    }
    
    .avatar-crop-container {
        gap: 0; /* No gap on mobile */
    }
}

/* Card Background Crop Modal */
#cardBgCropModal .modal-content {
    max-width: 90vw;
    width: 500px;
    margin: auto;
}

#cardBgCropModal .modal-body {
    padding: 1rem;
}

#cardBgCropModal .modal-footer {
    padding: 1rem;
    gap: 0.5rem;
}

.card-bg-crop-container {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

@media (max-width: 768px) {
    #cardBgCropModal .modal-content {
        width: 95vw;
    }
    
    #cardBgCropModal .modal-body {
        padding: 0.5rem;
    }
    
    #cardBgCropModal .modal-footer {
        padding: 0.75rem;
    }
    
    .card-bg-crop-container {
        gap: 0;
    }
}

/* ===== My Card Tab ===== */

/* Animated body background for My Card page */
[data-theme="light"] body.mycard-active {
    position: relative;
    /* Keep original background */
}

[data-theme="dark"] body.mycard-active {
    position: relative;
    /* Keep original background */
}

/* Shimmer blobs are now generated dynamically via JavaScript */

/* Clip shimmer blobs to viewport */
.shimmer-blob {
    clip-path: inset(0);
    max-width: 100vw;
    max-height: 100vh;
}

/* My Card tab is always dark mode */
html:has(body.mycard-active),
body.mycard-active {
    overflow-x: hidden !important; /* Prevent horizontal scroll from blobs */
    max-width: 100vw;
}

body.mycard-active {
    background-color: #111827 !important; /* Dark gray background */
    color: #f3f4f6 !important; /* Light text */
    position: relative;
}

/* Force dark mode colors for My Card tab elements */
body.mycard-active .navbar {
    background-color: rgba(17, 24, 39, 0.95) !important;
    border-bottom-color: rgba(75, 85, 99, 0.3) !important;
}

/* Tab navigation stays with theme colors - only background is dark */
body.mycard-active .tab-navigation {
    /* Keep original theme colors for tab navigation */
}

body.mycard-active .mycard-info {
    color: rgba(156, 163, 175, 1) !important;
}

/* Make containers transparent to show body background */
body.mycard-active #mycardTab,
body.mycard-active .mycard-section,
body.mycard-active .container {
    background: transparent !important;
}

/* Prevent blob overflow on My Card tab */
body.mycard-active #mycardTab {
    overflow: hidden !important;
}

.mycard-section {
    padding: 2rem 0;
    min-height: calc(100vh - 140px); /* Adjust for navbar + tab nav */
    position: relative;
    display: flex;
    align-items: center; /* Center vertically */
    justify-content: center;
    overflow: hidden; /* Contain blobs within section */
}

.mycard-container {
    position: relative;
    z-index: 10;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2rem;
    max-width: 800px;
    margin: 0;
}

/* Animated glowing border wrapper around card (in container) */
.mycard-container::before {
    content: '';
    position: absolute;
    top: -6px;
    left: 50%;
    transform: translateX(-50%);
    width: 412px; /* Card width (400px) + glow padding */
    height: 612px; /* Card height (600px) + glow padding */
    background: linear-gradient(
        45deg,
        rgba(0, 0, 0, 0.3),
        rgba(255, 255, 255, 0.3),
        rgba(0, 0, 0, 0.3),
        rgba(255, 255, 255, 0.3),
        rgba(0, 0, 0, 0.3)
    );
    background-size: 400% 400%;
    border-radius: 1.5rem;
    z-index: -1;
    animation: borderGlowAnimation 3s linear infinite;
    filter: blur(10px);
    mix-blend-mode: color-dodge;
    pointer-events: none;
}

/* Player Card - Vertical like a Pokemon card */
.player-card {
    position: relative;
    width: 400px; /* Fixed width */
    height: 600px; /* Fixed height (2:3 ratio) */
    border-radius: 1.5rem;
    overflow: hidden; /* Clip to rounded corners */
    z-index: 1; /* Ensure card is above the glow */
    isolation: isolate; /* Prevent blend mode from glow bleeding through */
}

/* Mobile responsive card */
@media (max-width: 768px) {
    .player-card {
        width: min(340px, 85vw); /* Smaller on mobile with padding */
        height: calc(min(340px, 85vw) * 1.5); /* Maintain 2:3 ratio */
    }
    
    /* Enhanced glow for mobile (compensates for no background blobs) */
    .mycard-container::before {
        width: calc(min(340px, 85vw) + 50px); /* Card width + more padding */
        height: calc(calc(min(340px, 85vw) * 1.5) + 50px); /* Card height + more padding */
        background: linear-gradient(
            45deg,
            rgba(17, 24, 39, 0.5),      /* Dark blue */
            rgba(79, 172, 254, 0.7),    /* Bright cyan */
            rgba(0, 0, 0, 0.7),         /* Dark spot */
            rgba(240, 147, 251, 0.7),   /* Bright magenta */
            rgba(102, 126, 234, 0.6),   /* Purple-blue */
            rgba(0, 0, 0, 0.6),         /* Dark spot */
            rgba(79, 172, 254, 0.7),    /* Bright cyan */
            rgba(17, 24, 39, 0.5)       /* Dark blue */
        );
        background-size: 400% 400%; /* Allow gradient to move */
        filter: blur(35px); /* Much more blur on mobile */
        animation: borderGlowAnimation 4s ease-in-out infinite; /* Slightly slower with easing */
    }
}

/* Sharp animated border gradient (on top) */
.player-card::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 1.5rem;
    padding: 2px;
    background: linear-gradient(
        90deg,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, 0.5) 25%,
        rgba(255, 255, 255, 1) 50%,
        rgba(255, 255, 255, 0.5) 75%,
        rgba(255, 255, 255, 0) 100%
    );
    background-size: 200% 100%;
    -webkit-mask: 
        linear-gradient(#fff 0 0) content-box, 
        linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    animation: borderGradientAnimation 3s linear infinite;
    pointer-events: none;
    z-index: 10;
}

@keyframes borderGlowAnimation {
    0%, 100% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
}

@keyframes borderGradientAnimation {
    0% {
        background-position: 0% 0%;
    }
    100% {
        background-position: 200% 0%;
    }
}

.player-card:hover {
    /* Hover effect removed for cleaner interaction */
}

/* Card Background */
.card-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /* Background color and image set via JavaScript */
    background-size: cover;
    background-position: center;
    border-radius: 1.5rem;
    z-index: 0;
}

/* Card Overlay - Not used, user controls background fully */
.card-overlay {
    display: none;
}

/* Card Content */
.card-content {
    position: relative;
    z-index: 2;
    height: 100%;
    padding: 2rem 1.5rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    color: white;
    border-radius: 1.5rem;
}

/* Avatar */
.card-avatar-container {
    position: relative;
    width: 100px;
    height: 100px;
    border-radius: 50%;
    overflow: visible; /* Allow border to show outside */
    background: var(--card-bg);
    margin: 0 auto; /* Center horizontally */
    filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.4));
}

.card-avatar {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
    display: block;
    position: relative;
    z-index: 1;
}

/* Animated gradient border around avatar */
.card-avatar-container::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 50%;
    padding: 3px; /* Slightly thicker for better visibility on small avatar */
    background: linear-gradient(
        90deg,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, 0.5) 25%,
        rgba(255, 255, 255, 1) 50%,
        rgba(255, 255, 255, 0.5) 75%,
        rgba(255, 255, 255, 0) 100%
    );
    background-size: 200% 100%;
    -webkit-mask: 
        linear-gradient(#fff 0 0) content-box, 
        linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    animation: borderGradientAnimation 3s linear infinite;
    pointer-events: none;
    z-index: 10;
}

/* Moving gradient animation for card bottom section */
@keyframes cardGradientSweep {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}

/* Bottom section containing user info and badges */
.card-bottom-section {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    background: linear-gradient(
        110deg,
        rgba(0, 0, 0, 0.2) 0%,
        rgba(0, 0, 0, 0.5) 25%,
        rgba(0, 0, 0, 0.2) 50%,
        rgba(0, 0, 0, 0.5) 75%,
        rgba(0, 0, 0, 0.2) 100%
    );
    background-size: 200% 200%;
    padding: 1rem;
    border-radius: 1.35rem;
    margin: 0 -19px -27px -19px; /* Expand to have only 5px margin from card edges */
    animation: cardGradientSweep 6s ease-in-out infinite;
}

/* User Info */
.card-info {
    display: flex;
    flex-direction: column;
    gap: 0.05rem; /* Even tighter spacing between name and slogan */
}

/* Text alignment based on language */
html[lang="fa"] .card-info {
    text-align: right;
}

html[lang="en"] .card-info {
    text-align: left;
}

.card-display-name,
.card-name {
    font-size: 2rem;
    font-weight: 700;
    margin: 0 0 0.75rem 0;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
    color: white;
    line-height: 1.2;
}

.card-slogan {
    font-size: 1.05rem;
    font-style: italic;
    opacity: 0.9;
    margin: 0;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5);
    color: white;
    line-height: 1.4;
}

.card-slogan p {
    margin: 0;
    color: white;
    font-size: inherit;
    font-style: inherit;
    text-shadow: inherit;
}

/* Badges */
.card-badges {
    display: flex;
    gap: 0.5rem;
    justify-content: center;
    padding-top: 0.5rem;
}

.badge-slot {
    width: 70px;
    height: 70px;
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(10px);
    border: 2px solid rgba(255, 255, 255, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.badge-slot:hover {
    background: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.4);
    transform: scale(1.08);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.badge-empty {
    font-size: 0.75rem;
    opacity: 0.6;
    text-align: center;
    color: white;
    font-weight: 500;
}

.badge-image {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 0.3rem;
}

/* Edit Button */
.card-edit-btn {
    position: absolute;
    top: 1rem;
    right: 1rem;
    z-index: 3;
    background: rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(10px);
    border: 2px solid rgba(255, 255, 255, 0.3);
    color: white;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
}

.card-edit-btn:hover {
    background: rgba(255, 255, 255, 0.3);
    border-color: rgba(255, 255, 255, 0.5);
    transform: scale(1.1);
}

.card-edit-btn svg {
    width: 20px;
    height: 20px;
}

/* Info Text */
.mycard-info {
    text-align: center;
    opacity: 0.7;
    max-width: 500px;
}

.mycard-info p {
    margin: 0;
    line-height: 1.6;
}

/* Edit Card Modal */
#editCardModal .form-group {
    margin-bottom: 1.5rem;
}

#editCardModal label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 600;
}

.char-counter {
    display: block;
    text-align: right;
    margin-top: 0.25rem;
    font-size: 0.85rem;
    opacity: 0.7;
}

.card-background-preview {
    width: 100%;
    max-width: 100%; /* Full width of modal */
    border-radius: 0.5rem;
    border: 2px dashed var(--border-color);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 1rem 0 1rem 0; /* Added top spacing */
    padding: 1rem; /* Padding inside the dotted border */
    position: relative;
    background: var(--secondary-bg);
}

.card-preview-bg-color {
    position: absolute;
    width: 100%;
    max-width: 300px; /* Limit preview size */
    aspect-ratio: 2 / 3; /* Match card ratio */
    border-radius: 0.5rem;
    overflow: hidden;
    z-index: 0;
}

.card-background-preview img {
    position: relative;
    width: 100%;
    max-width: 300px; /* Limit preview size */
    aspect-ratio: 2 / 3; /* Match card ratio */
    object-fit: cover;
    border-radius: 0.5rem; /* Match overlay border radius */
    z-index: 1;
}

.card-background-preview .preview-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 300px; /* Same as image */
    aspect-ratio: 2 / 3; /* Same as image */
    border-radius: 0.5rem; /* Match image and overlay border radius */
    opacity: 0.5;
    position: relative;
    z-index: 2;
}

.color-input {
    width: 100%;
    height: 50px;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    cursor: pointer;
}

/* Mobile Responsive - Card stays fixed size on all screens */
@media (max-width: 768px) {
    .mycard-section {
        padding: 1rem;
        overflow-x: hidden; /* No scroll needed with smaller card */
    }
    
    /* Adjust glow effect for smaller card on mobile */
    .mycard-container::before {
        width: calc(min(340px, 85vw) + 12px); /* Match mobile card width + glow padding */
        height: calc((min(340px, 85vw) * 1.5) + 12px); /* Match mobile card height + glow padding */
    }
}

/* ===== Manage Tab (Admin Only) ===== */
.manage-section {
    padding: 2rem 0;
    min-height: calc(100vh - 140px);
}

.manage-card {
    margin-bottom: 2rem;
}

.manage-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
}

.manage-card-header h2 {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.manage-card-body {
    padding: 0;
}

/* Badges Grid */
.badges-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 1rem;
}

.badge-item {
    background: var(--card-bg);
    border-radius: 1rem;
    padding: 1.5rem 1rem;
    text-align: center;
    transition: all 0.2s ease;
    position: relative;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    min-height: 180px; /* Ensure enough space for content */
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
}

[data-theme="dark"] .badge-item {
    background: rgba(255, 255, 255, 0.05);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.badge-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
}

[data-theme="dark"] .badge-item:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}

.badge-item-image {
    width: 56px;
    height: 56px;
    margin-bottom: 0.75rem;
    object-fit: contain;
    flex-shrink: 0;
}

.badge-item-name {
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--text-primary);
    margin-bottom: 0.75rem;
    word-break: break-word;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3; /* Allow up to 3 lines for longer names */
    -webkit-box-orient: vertical;
    flex: 1;
    line-height: 1.3;
}

.badge-item-actions {
    display: flex;
    gap: 0.5rem;
    justify-content: center;
    width: 100%;
}

.badge-item-actions .btn-icon {
    background: transparent;
    border: none;
    padding: 0.6rem;
    cursor: pointer;
    border-radius: 0.5rem;
    transition: all 0.2s ease;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    min-height: 36px;
}

.badge-item-actions .btn-icon:hover {
    background: var(--input-bg);
    color: var(--text-primary);
}

.badge-item-actions .btn-icon.btn-edit:hover {
    color: var(--primary-color);
}

.badge-item-actions .btn-icon.btn-delete:hover {
    color: #ef4444;
    background: rgba(239, 68, 68, 0.1);
}

/* Users List for Badge Assignment */
.users-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.user-badge-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.25rem;
    background: var(--card-bg);
    border-radius: 1rem;
    transition: all 0.2s ease;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

[data-theme="dark"] .user-badge-item {
    background: rgba(255, 255, 255, 0.05);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.user-badge-item:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
}

[data-theme="dark"] .user-badge-item:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}

.user-badge-info {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex: 1;
}

.user-badge-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--border-color);
}

.user-badge-details {
    flex: 1;
}

.user-badge-name {
    font-size: 1rem;
    font-weight: 500;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
}

.user-badge-current {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    flex-wrap: wrap;
}

.user-badge-current-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.user-badge-mini {
    width: 24px;
    height: 24px;
    object-fit: contain;
    border-radius: 4px;
}

.user-badge-actions {
    display: flex;
    gap: 0.5rem;
}

/* Badge Image Preview in Modal */
.badge-image-preview {
    width: 128px;
    height: 128px;
    margin: 1rem auto;
    border: 2px dashed var(--border-color);
    border-radius: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--input-bg);
    position: relative;
}

.badge-image-preview img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 1rem;
}

.badge-image-preview .preview-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.badge-image-preview .preview-placeholder svg {
    opacity: 0.5;
}

/* Available Badges Grid in Assignment Modal */
.available-badges-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 1rem;
    max-height: 400px;
    overflow-y: auto;
    padding: 0.5rem;
}

/* Empty state in badge grid should span all columns */
.available-badges-grid .empty-state {
    grid-column: 1 / -1;
}

.available-badge-item {
    padding: 1rem;
    border: 2px solid var(--border-color);
    border-radius: 0.75rem;
    background: var(--input-bg);
    text-align: center;
    cursor: pointer;
    transition: all 0.2s ease;
    user-select: none;
}

.available-badge-item:hover {
    border-color: var(--primary-color);
    background: var(--card-bg);
}

.available-badge-item.selected {
    border-color: var(--primary-color);
    background: rgba(var(--primary-rgb), 0.1);
}

.available-badge-item.disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.available-badge-image {
    width: 48px;
    height: 48px;
    margin: 0 auto 0.5rem;
    object-fit: contain;
}

.available-badge-name {
    font-size: 0.875rem;
    color: var(--text-primary);
    word-break: break-word;
}

/* ===== Public Card Viewer Modal ===== */
#viewUserCardModal {
    background-color: rgba(0, 0, 0, 0.8);
}

.modal-card-viewer {
    max-width: 500px;
    background: transparent;
    box-shadow: none;
    animation: fadeIn 0.2s ease !important; /* Use fade instead of slideUp to prevent close button jumping */
    transform: none !important; /* Ensure no transform creates a positioning context */
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

/* Large close button - always positioned at top right of screen (no RTL swap) */
#viewUserCardModal .modal-close {
    position: fixed !important;
    top: 1.5rem !important;
    right: 1.5rem !important;
    left: auto !important;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(10px);
    color: white;
    font-size: 2rem;
    line-height: 1;
    display: flex !important;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    border: 2px solid rgba(255, 255, 255, 0.3);
    transition: background 0.2s ease, transform 0.2s ease; /* Only transition background and transform */
    z-index: 10001 !important;
    margin: 0 !important;
    transform: translate(0, 0); /* Prevent any transform offsets */
}

#viewUserCardModal .modal-close:hover {
    background: rgba(255, 255, 255, 0.3);
    transform: rotate(90deg);
}

@media (max-width: 768px) {
    #viewUserCardModal .modal-close {
        top: 1rem !important;
        right: 1rem !important;
        left: auto !important;
        width: 44px;
        height: 44px;
    }
    
    .public-card-container {
        padding: 1rem;
    }
}

.modal-card-viewer .modal-body {
    padding: 0;
    background: transparent;
}

.public-card-container {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 0;
}

.public-card-container .player-card {
    /* Card is not clickable in public view */
    cursor: default;
    /* Remove hover effect */
    transition: none;
    /* Large drop shadow for prominence */
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

.public-card-container .player-card:hover {
    transform: none;
}

/* Reduce gap between name and slogan in public view */
.public-card-container .card-info {
    gap: 0.05rem; /* Match My Card tab spacing */
}

/* Hide edit button */
.public-card-container .card-edit-btn {
    display: none !important;
}

/* Public badge images - display as a horizontal row */
.public-card-container .card-badges {
    display: flex;
    gap: 0.75rem;
    justify-content: center;
    flex-wrap: wrap;
}

.public-badge-image {
    width: 48px;
    height: 48px;
    object-fit: contain;
    transition: transform 0.2s ease;
    filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.3));
    cursor: help;
}

.public-badge-image:hover {
    transform: scale(1.15);
    filter: drop-shadow(0 6px 12px rgba(0, 0, 0, 0.4));
}

/* Badge tooltip */
.badge-tooltip {
    position: fixed;
    background: rgba(0, 0, 0, 0.95);
    color: white;
    padding: 0.75rem 1rem;
    border-radius: 0.5rem;
    font-size: 0.875rem;
    pointer-events: none;
    z-index: 10000;
    max-width: 250px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.badge-tooltip-name {
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.badge-tooltip-description {
    font-size: 0.8rem;
    opacity: 0.9;
    line-height: 1.4;
}

/* Mobile Responsive */
@media (max-width: 768px) {
    .manage-card-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem;
    }

    .manage-card-header .btn {
        width: 100%;
    }

    .badges-grid {
        grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
        gap: 0.75rem;
    }

    .badge-item {
        padding: 1rem 0.75rem;
    }

    .badge-item-image {
        width: 48px;
        height: 48px;
    }

    .badge-item-name {
        font-size: 0.85rem;
    }

    .user-badge-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem;
        padding: 1rem;
    }

    .user-badge-actions {
        width: 100%;
    }

    .user-badge-actions .btn {
        flex: 1;
    }

    .available-badges-grid {
        grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
    }
}

/* Custom Hue Slider Styling */
#cardHueSlider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: white;
    cursor: pointer;
    border: 3px solid #333;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

#cardHueSlider::-moz-range-thumb {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: white;
    cursor: pointer;
    border: 3px solid #333;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

