/** * Accounts Page - Premium Glassmorphism Style */ .accounts-page { display: flex; flex-direction: column; gap: var(--spacing-xl); width: 100%; animation: fadeIn 0.5s ease-out; padding-bottom: 2rem; } /* Page Header */ .accounts-page__header { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: var(--spacing-md); margin-bottom: var(--spacing-xs); } .accounts-page__title { margin: 0; font-family: 'Outfit', sans-serif; font-size: 2.5rem; font-weight: 800; color: var(--color-text); letter-spacing: -1px; line-height: 1.1; } .accounts-page__subtitle { margin: 0; color: var(--color-text-secondary); font-size: 1rem; margin-top: 0.25rem; } .accounts-page__actions { display: flex; gap: var(--spacing-sm); } .accounts-page__btn { display: flex; align-items: center; justify-content: center; gap: var(--spacing-sm); padding: 0.6rem 1.25rem; border: none; border-radius: var(--radius-full); font-size: 0.875rem; font-weight: 600; cursor: pointer; transition: all 0.2s ease; min-width: 100px; } .accounts-page__btn:disabled { opacity: 0.5; cursor: not-allowed; } .accounts-page__btn--create { background: var(--accent-primary); color: var(--text-inverse); box-shadow: var(--shadow-glow-sm); } .accounts-page__btn--create:hover:not(:disabled) { transform: translateY(-2px); background: var(--accent-primary-hover); box-shadow: var(--shadow-glow-md); } .accounts-page__btn--transfer { background: var(--bg-secondary); color: var(--text-primary); border: 1px solid var(--border-color); } .accounts-page__btn--transfer:hover:not(:disabled) { background: var(--bg-hover); border-color: var(--accent-primary); color: var(--accent-primary); } .accounts-page__btn--graph { background: linear-gradient(135deg, #8B5CF6, #6366F1); color: white; box-shadow: 0 8px 16px rgba(139, 92, 246, 0.2); } .accounts-page__btn--graph:hover:not(:disabled) { transform: translateY(-2px); box-shadow: 0 12px 24px rgba(139, 92, 246, 0.3); filter: brightness(1.1); } .accounts-page__btn--delete { background: var(--color-error); color: white; box-shadow: 0 4px 10px rgba(239, 68, 68, 0.2); } .accounts-page__btn--delete:hover:not(:disabled) { background: #dc2626; transform: translateY(-2px); box-shadow: 0 6px 16px rgba(239, 68, 68, 0.3); } /* Dashboard Grid Layout */ .accounts-page__dashboard { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: var(--spacing-lg); margin-bottom: var(--spacing-md); } /* Net Worth Card (Hero) */ .accounts-page__net-worth-card { background: linear-gradient(135deg, var(--color-primary), #4f46e5); /* Modern Indigo */ border-radius: var(--radius-xl); padding: var(--spacing-xl); color: white; display: flex; flex-direction: column; justify-content: center; position: relative; overflow: hidden; box-shadow: 0 10px 30px rgba(79, 70, 229, 0.3); min-height: 140px; } .accounts-page__net-worth-card::after { content: ''; position: absolute; top: -50%; right: -20%; width: 300px; height: 300px; background: radial-gradient(circle, rgba(255, 255, 255, 0.2) 0%, rgba(255, 255, 255, 0) 70%); border-radius: 50%; } .accounts-page__main-value { font-family: 'Outfit', sans-serif; font-size: 3.5rem; font-weight: 700; line-height: 1; margin: var(--spacing-sm) 0; letter-spacing: -2px; display: flex; align-items: flex-start; } .accounts-page__main-value .currency-symbol { font-size: 1.5rem; margin-top: 0.5rem; margin-right: 0.25rem; opacity: 0.8; font-weight: 500; } .accounts-page__trend-indicator { font-size: 0.875rem; opacity: 0.9; display: flex; align-items: center; gap: 0.5rem; } /* Stat Cards (Assets & Liabilities) */ .accounts-page__stat-card { background: var(--glass-panel-bg); border: 1px solid var(--glass-border); border-radius: var(--radius-xl); padding: var(--spacing-lg); display: flex; align-items: center; gap: var(--spacing-md); box-shadow: var(--shadow-sm); transition: transform 0.2s ease; } .accounts-page__stat-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); } .stat-card__icon { width: 48px; height: 48px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; font-weight: bold; } .accounts-page__stat-card--assets .stat-card__icon { background: rgba(16, 185, 129, 0.1); color: var(--color-success); } .accounts-page__stat-card--liabilities .stat-card__icon { background: rgba(239, 68, 68, 0.1); color: var(--color-error); } .stat-card__content { display: flex; flex-direction: column; } .accounts-page__label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600; opacity: 0.7; margin-bottom: 0.25rem; } .accounts-page__net-worth-card .accounts-page__label { color: rgba(255, 255, 255, 0.9); } .accounts-page__sub-value { font-family: 'Outfit', sans-serif; font-size: 1.5rem; font-weight: 700; color: var(--color-text); letter-spacing: -0.5px; } /* Error Message */ .accounts-page__error { display: flex; justify-content: space-between; align-items: center; padding: var(--spacing-md); background: rgba(239, 68, 68, 0.1); border: 1px solid rgba(239, 68, 68, 0.2); border-radius: var(--radius-lg); color: var(--color-error); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); } .accounts-page__error button { background: rgba(255, 255, 255, 0.2); border: none; color: var(--color-error); cursor: pointer; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; border-radius: 50%; transition: background 0.2s ease; } .accounts-page__error button:hover { background: rgba(255, 255, 255, 0.4); } /* Modal Overlay */ .accounts-page__modal-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0, 0, 0, 0.6); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); display: flex; align-items: center; justify-content: center; padding: var(--spacing-md); z-index: 1000; animation: fadeIn 0.2s ease; } .accounts-page__modal { background: var(--color-bg); border: 1px solid var(--glass-border); border-radius: var(--radius-xl); max-width: 500px; width: 100%; max-height: 90vh; overflow-y: auto; box-shadow: 0 20px 50px rgba(0, 0, 0, 0.3); animation: slideUp 0.3s cubic-bezier(0.16, 1, 0.3, 1); } .accounts-page__modal--fixed { display: flex; flex-direction: column; overflow: hidden; padding: 0; } /* Delete Confirmation */ .accounts-page__delete-confirm { padding: var(--spacing-xl); text-align: center; } .accounts-page__delete-confirm h2 { margin: 0 0 var(--spacing-md) 0; font-family: 'Outfit', sans-serif; font-size: 1.5rem; font-weight: 700; color: var(--color-text); } .accounts-page__delete-confirm p { margin: 0 0 var(--spacing-sm) 0; color: var(--color-text-secondary); font-size: 1rem; } .accounts-page__delete-confirm strong { color: var(--color-text); font-weight: 700; } .accounts-page__delete-warning { font-size: 0.9rem; color: var(--color-warning); background: rgba(245, 158, 11, 0.1); padding: var(--spacing-md); border-radius: var(--radius-lg); margin-bottom: var(--spacing-lg) !important; display: inline-block; width: 100%; } .accounts-page__delete-actions { display: flex; gap: var(--spacing-md); justify-content: center; margin-top: var(--spacing-lg); } /* Responsive Breakpoints */ @media (max-width: 900px) { .accounts-page__dashboard { grid-template-columns: 1fr 1fr; } .accounts-page__net-worth-card { grid-column: span 2; } } /* Account List Section */ .accounts-page__account-list-section { margin-top: var(--spacing-lg); } .accounts-page__section-title { font-family: 'Outfit', sans-serif; font-size: 1.5rem; font-weight: 700; color: var(--color-text); margin: 0 0 var(--spacing-md) 0; } .accounts-page__loading { text-align: center; padding: var(--spacing-xl); color: var(--color-text-secondary); } .accounts-page__draggable-list { margin-top: var(--spacing-md); } .accounts-page__asset-summary { grid-column: span 1; } @media (max-width: 600px) { .accounts-page__header { flex-direction: column; align-items: stretch; } .accounts-page__title { font-size: 2rem; } .accounts-page__actions { justify-content: stretch; margin-top: 1rem; } .accounts-page__actions .accounts-page__btn { flex: 1; } .accounts-page__dashboard { grid-template-columns: 1fr; } .accounts-page__net-worth-card { grid-column: span 1; } .accounts-page__delete-actions { flex-direction: column-reverse; } } @media (min-width: 1024px) { .accounts-page__modal { max-width: 600px; } }