.birthdays-page { --module-accent: var(--module-birthdays); } .birthdays-page { display: flex; flex-direction: column; gap: var(--space-4); max-width: var(--content-max-width); margin: 0 auto; padding-bottom: calc(var(--nav-bottom-height) + var(--space-6)); } .birthdays-toolbar { display: flex; align-items: center; gap: var(--space-2); padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--color-border); border-top: 3px solid var(--module-accent); background: var(--color-surface); } .birthdays-toolbar__search { flex: 1; position: relative; } .birthdays-toolbar__search-icon { position: absolute; left: var(--space-3); top: 50%; transform: translateY(-50%); width: 16px; height: 16px; color: var(--color-text-disabled); pointer-events: none; } .birthdays-toolbar__search-input { width: 100%; min-height: 40px; padding: var(--space-2) var(--space-3) var(--space-2) 36px; border-radius: var(--radius-glass-button); border: 1.5px solid var(--glass-border-subtle); background: var(--color-surface-2); } .birthdays-section { padding: 0 var(--space-4); } .birthdays-section__header h2 { margin: 0; font-size: var(--text-lg); } .birthdays-section__header p { margin: var(--space-1) 0 0; color: var(--color-text-secondary); font-size: var(--text-sm); } .birthday-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: var(--space-3); margin-top: var(--space-3); } .birthday-card, .birthday-item { background: var(--color-surface); border: 1px solid var(--color-border); border-left: 3px solid var(--module-accent); border-radius: var(--radius-md); box-shadow: var(--shadow-sm); } .birthday-card { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-4); } .birthday-card__body, .birthday-item__body { min-width: 0; flex: 1; } .birthday-card__name, .birthday-item__name { font-size: var(--text-base); font-weight: var(--font-weight-semibold); } .birthday-card__date, .birthday-item__meta, .birthday-item__next { color: var(--color-text-secondary); font-size: var(--text-sm); } .birthday-card__note, .birthday-item__note, .birthday-item__notes { margin-top: var(--space-1); font-size: var(--text-sm); } .birthday-item__notes { color: var(--color-text-secondary); } .birthdays-list { display: flex; flex-direction: column; gap: var(--space-3); margin-top: var(--space-3); } .birthday-item { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-4); } .birthday-item__row { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-2); } .birthday-item__actions { display: flex; gap: var(--space-1); } .birthday-avatar { width: 56px; height: 56px; border-radius: var(--radius-full); object-fit: cover; flex-shrink: 0; } .birthday-avatar--fallback { display: inline-flex; align-items: center; justify-content: center; background: color-mix(in srgb, var(--module-accent) 16%, white); color: var(--module-accent); font-weight: var(--font-weight-bold); } .birthday-avatar--xs { width: 34px; height: 34px; font-size: var(--text-sm); } .birthdays-autocomplete { position: absolute; top: calc(100% + 6px); left: 0; right: 0; z-index: var(--z-dropdown); border-radius: var(--radius-md); border: 1px solid var(--color-border); background: var(--color-surface-elevated); box-shadow: var(--shadow-lg); overflow: hidden; } .birthday-suggestion { width: 100%; display: flex; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-3); border: none; background: transparent; text-align: left; cursor: pointer; } .birthday-suggestion:hover { background: var(--color-surface-hover); } .birthday-suggestion span { display: flex; min-width: 0; flex-direction: column; } .birthday-suggestion small { color: var(--color-text-secondary); } .birthday-preview { width: 84px; height: 84px; margin: 0 auto var(--space-3); border-radius: var(--radius-full); overflow: hidden; display: flex; align-items: center; justify-content: center; background: color-mix(in srgb, var(--module-accent) 16%, white); } .birthday-preview__image { width: 100%; height: 100%; object-fit: cover; } .birthday-preview__fallback { color: var(--module-accent); font-size: var(--text-xl); font-weight: var(--font-weight-bold); } .birthday-modal__photo-actions { margin-top: var(--space-2); } .birthday-modal__hint { color: var(--color-text-secondary); font-size: var(--text-sm); } .contact-action-btn { width: 36px; height: 36px; border-radius: var(--radius-full); border: none; background: var(--color-surface-2); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; color: var(--color-text-secondary); }