.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-grid { display: grid; grid-template-columns: minmax(280px, 360px) minmax(0, 1fr); gap: var(--space-4); padding: 0 var(--space-4); } .birthdays-panel { display: flex; flex-direction: column; gap: var(--space-4); padding: var(--space-4); border: 1px solid var(--color-border); border-radius: calc(var(--radius-md) + 4px); background: radial-gradient(circle at top left, color-mix(in srgb, var(--module-accent) 10%, transparent), transparent 45%), var(--color-surface); box-shadow: var(--shadow-sm); } .birthdays-panel--upcoming { position: sticky; top: var(--space-4); align-self: start; } .birthdays-panel--list { min-width: 0; } .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__title { display: inline-flex; align-items: center; gap: var(--space-2); min-width: 0; flex: 1; font-size: var(--text-lg); font-weight: var(--font-weight-bold); } .birthdays-toolbar__title-icon { width: 20px; height: 20px; color: var(--module-accent); flex-shrink: 0; } .birthdays-toolbar__subtitle { margin: 0 var(--space-4) var(--space-2); color: var(--color-text-secondary); font-size: var(--text-sm); } .birthdays-toolbar--embedded { padding: 0; border: none; background: transparent; } .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, .birthdays-section__header h3 { 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: 1fr; gap: var(--space-3); } .birthday-card, .birthday-item { background: var(--color-surface); border: 1px solid var(--color-border); 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); background: linear-gradient(180deg, color-mix(in srgb, var(--module-accent) 6%, var(--color-surface)), var(--color-surface)); } .birthday-card__body, .birthday-item__body { min-width: 0; flex: 1; } .birthday-card__top { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-3); } .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-card__pill { padding: 0.35rem 0.6rem; border-radius: var(--radius-full); background: color-mix(in srgb, var(--module-accent) 12%, transparent); color: var(--module-accent); font-size: var(--text-xs); font-weight: var(--font-weight-semibold); white-space: nowrap; } .birthday-item__notes { color: var(--color-text-secondary); } .birthdays-list { display: flex; flex-direction: column; gap: 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); } @media (max-width: 960px) { .birthdays-grid { grid-template-columns: 1fr; } .birthdays-panel--upcoming { position: static; } } .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); }