/**
 * Quelld Family Calendar - Module Styles
 * Shares the visual engine with Co-Parent Calendar (day strip, event cards,
 * AI panel), colour-coded by household member instead of by custody.
 */

#quelld-family-root { max-width: 640px; margin: 0 auto; background: #FFFFFF; overflow-x: hidden; }

/* ── Generic layout ───────────────────────── */
.qfc-setup { padding: 20px; }
.qfc-setup > a:first-child { margin-top: 0; }
.qfc-title { font-size: 22px; font-weight: 700; line-height: 1.3; color: #2D2D3A; margin: 0 0 8px; }
.qfc-subtitle { font-size: 14px; color: #7A7A8A; line-height: 1.5; margin: 0 0 20px; }
.qfc-label { font-size: 13px; font-weight: 600; color: #2D2D3A; display: block; margin-bottom: 4px; }
.qfc-input { width: 100% !important; padding: 12px 14px !important; border-radius: 12px !important; border: 1px solid #EAEAEF !important; font-size: 16px !important; font-family: inherit !important; color: #3A3A4A !important; outline: none !important; box-sizing: border-box !important; margin-bottom: 12px !important; }
.qfc-input:focus { border-color: #954FE0 !important; }

/* ── Members (setup + manage) ─────────────── */
.qfc-member-row { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border: 1px solid #EAEAEF; border-radius: 14px; margin-bottom: 8px; }
.qfc-member-dot { width: 22px; height: 22px; border-radius: 50%; flex-shrink: 0; }
.qfc-member-name { flex: 1; min-width: 0; font-size: 14px; font-weight: 600; color: #2D2D3A; }
.qfc-member-type { font-size: 11px; color: #94A3B8; text-transform: capitalize; }
.qfc-member-remove { border: none !important; background: none !important; color: #B0B0BE !important; font-size: 18px !important; cursor: pointer !important; padding: 4px 8px !important; -webkit-tap-highlight-color: transparent !important; }

.qfc-swatches { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.qfc-swatch { width: 30px !important; height: 30px !important; border-radius: 50% !important; border: 2px solid transparent !important; cursor: pointer !important; padding: 0 !important; -webkit-tap-highlight-color: transparent !important; }
.qfc-swatch--active { border-color: #2D2D3A !important; transform: scale(1.08); }

.qfc-type-row { display: flex; gap: 8px; margin-bottom: 12px; }
.qfc-type-btn { flex: 1; padding: 10px 6px !important; border-radius: 10px !important; border: 1px solid #EAEAEF !important; background: #FFFFFF !important; font-size: 13px !important; font-family: inherit !important; color: #7A7A8A !important; cursor: pointer !important; text-align: center !important; -webkit-tap-highlight-color: transparent !important; }
.qfc-type-btn--active { border-color: #954FE0 !important; background: #EDE5FF !important; color: #954FE0 !important; font-weight: 600 !important; }

/* ── Calendar view ────────────────────────── */
.qfc-calendar { padding: 0 0 20px; }
.qfc-header { display: flex; align-items: center; justify-content: space-between; padding: 12px 20px; }
.qfc-header__title { font-size: 16px; font-weight: 600; color: #2D2D3A; }

.qfc-toolbar { display: flex; align-items: center; justify-content: space-between; padding: 0 20px 12px; gap: 8px; }
.qfc-labeled-btn { padding: 8px 14px !important; border-radius: 10px !important; border: 1px solid #EAEAEF !important; background: #FFFFFF !important; font-size: 12px !important; font-weight: 500 !important; font-family: inherit !important; color: #7A7A8A !important; cursor: pointer !important; -webkit-tap-highlight-color: transparent !important; white-space: nowrap !important; }
.qfc-labeled-btn--active { border-color: #954FE0 !important; background: #EDE5FF !important; color: #954FE0 !important; font-weight: 600 !important; }
.qfc-labeled-btn--primary { border-color: #954FE0 !important; background: #954FE0 !important; color: #FFFFFF !important; font-weight: 600 !important; }

/* Member legend chips */
.qfc-legend { display: flex; flex-wrap: wrap; gap: 6px; padding: 0 20px 12px; }
.qfc-chip { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 20px; background: #F7F7FA; font-size: 12px; font-weight: 600; color: #2D2D3A; }
.qfc-chip__dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }

/* Week nav */
.qfc-week-nav { display: flex; align-items: center; justify-content: space-between; padding: 0 20px 8px; }
.qfc-week-label { font-size: 13px; font-weight: 600; color: #2D2D3A; }
.qfc-week-arrow { padding: 8px 12px !important; border: none !important; background: none !important; font-size: 16px !important; color: #7A7A8A !important; cursor: pointer !important; -webkit-tap-highlight-color: transparent !important; }

/* Day strip */
.qfc-day-strip { display: flex; padding: 0 12px 12px; gap: 0; }
.qfc-day { flex: 1; text-align: center; padding: 8px 4px; cursor: pointer; border-radius: 12px; -webkit-tap-highlight-color: transparent; }
.qfc-day--selected { background: #F7F7FA; }
.qfc-day--today .qfc-day__num { background: #954FE0; color: #FFFFFF; border-radius: 50%; width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center; }
.qfc-day__abbr { font-size: 10px; text-transform: uppercase; color: #94A3B8; font-weight: 600; letter-spacing: 0.5px; }
.qfc-day__num { font-size: 17px; font-weight: 700; color: #2D2D3A; display: inline-flex; align-items: center; justify-content: center; min-width: 28px; height: 28px; margin: 2px 0; }
.qfc-day__dots { display: flex; gap: 2px; justify-content: center; margin-top: 4px; min-height: 6px; }
.qfc-day__dot { width: 6px; height: 6px; border-radius: 50%; }

/* Selected-day heading */
.qfc-day-heading { padding: 0 20px 8px; font-size: 14px; font-weight: 600; color: #2D2D3A; }

/* Event cards */
.qfc-events { padding: 0 20px; }
.qfc-event-card { display: flex; gap: 12px; padding: 12px 0; border-bottom: 1px solid #F2F2F5; cursor: pointer; -webkit-tap-highlight-color: transparent; }
.qfc-event-card:last-child { border-bottom: none; }
.qfc-event__time-col { width: 52px; flex-shrink: 0; }
.qfc-event__time { font-size: 12px; font-weight: 700; color: #2D2D3A; }
.qfc-event__dur { font-size: 10px; color: #94A3B8; }
.qfc-event__bar { width: 4px; border-radius: 2px; align-self: stretch; flex-shrink: 0; }
.qfc-event__content { flex: 1; min-width: 0; }
.qfc-event__title { font-size: 13px; font-weight: 600; color: #2D2D3A; }
.qfc-event__meta { display: flex; gap: 6px; margin-top: 4px; flex-wrap: wrap; align-items: center; }
.qfc-event__cat { font-size: 10px; padding: 2px 8px; border-radius: 6px; font-weight: 600; }
.qfc-event__loc { font-size: 11px; color: #94A3B8; }
.qfc-event__members { display: flex; gap: 4px; flex-wrap: wrap; }
.qfc-event__mchip { font-size: 10px; padding: 2px 8px; border-radius: 10px; font-weight: 600; color: #FFFFFF; }
.qfc-event__repeat { font-size: 10px; color: #954FE0; font-weight: 600; }

/* Category colours (badges) */
.qfc-cat--school { background: #E0F2FE; color: #0284C7; }
.qfc-cat--activity { background: #D1FAE5; color: #059669; }
.qfc-cat--medical { background: #FFE4E6; color: #E11D48; }
.qfc-cat--appointment { background: #CFFAFE; color: #0891B2; }
.qfc-cat--work { background: #EDE9FE; color: #6D28D9; }
.qfc-cat--family { background: #EDE9FE; color: #7C3AED; }
.qfc-cat--social { background: #FEF3C7; color: #D97706; }

/* AI panel */
.qfc-ai-panel { margin: 0 20px 16px; background: linear-gradient(135deg, #EDE5FF, #E5F6F6); border-radius: 16px; padding: 14px 16px; }
.qfc-ai-panel__label { font-size: 11px; font-weight: 600; color: #954FE0; text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 8px; }
.qfc-ai-card { padding: 10px 0; border-bottom: 1px solid rgba(255,255,255,0.4); font-size: 13px; color: #2D2D3A; line-height: 1.5; }
.qfc-ai-card:last-child { border-bottom: none; }

/* Quick-add bar */
.qfc-quickadd { margin: 0 20px 16px; padding: 14px; border-radius: 16px; background: #F7F7FA; border: 1px solid #EAEAEF; }
.qfc-quickadd__label { font-size: 11px; font-weight: 600; color: #954FE0; text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 8px; }
.qfc-quickadd__row { display: flex; gap: 8px; }
.qfc-quickadd__input { flex: 1; padding: 12px 14px !important; border-radius: 12px !important; border: 1px solid #EAEAEF !important; font-size: 16px !important; font-family: inherit !important; color: #3A3A4A !important; outline: none !important; }
.qfc-quickadd__input:focus { border-color: #954FE0 !important; }
.qfc-quickadd__hint { font-size: 11px; color: #94A3B8; margin-top: 6px; }

/* Type/category select chips */
.qfc-cat-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; margin-bottom: 16px; }
.qfc-cat-btn { padding: 10px 8px !important; border-radius: 10px !important; border: 1px solid #EAEAEF !important; background: #FFFFFF !important; font-size: 13px !important; font-family: inherit !important; color: #7A7A8A !important; cursor: pointer !important; text-align: left !important; -webkit-tap-highlight-color: transparent !important; }
.qfc-cat-btn--active { border-color: #954FE0 !important; background: #EDE5FF !important; color: #954FE0 !important; font-weight: 600 !important; }

/* Member multi-select on event form */
.qfc-pick-row { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.qfc-pick { padding: 8px 14px !important; border-radius: 20px !important; border: 2px solid #EAEAEF !important; background: #FFFFFF !important; font-size: 13px !important; font-family: inherit !important; color: #2D2D3A !important; cursor: pointer !important; display: inline-flex !important; align-items: center !important; gap: 6px !important; -webkit-tap-highlight-color: transparent !important; }
.qfc-pick__dot { width: 12px; height: 12px; border-radius: 50%; }

/* Bottom bar */
.qfc-bottom { display: flex; gap: 8px; padding: 16px 20px; }
.qfc-bottom__btn { flex: 1; padding: 12px 16px !important; border-radius: 12px !important; font-size: 14px !important; font-weight: 600 !important; font-family: inherit !important; cursor: pointer !important; text-align: center !important; -webkit-tap-highlight-color: transparent !important; }
.qfc-bottom__btn--primary { background: #954FE0 !important; color: #FFFFFF !important; border: none !important; }
.qfc-bottom__btn--outline { background: #FFFFFF !important; color: #954FE0 !important; border: 2px solid #954FE0 !important; }

/* Empty state */
.qfc-empty { text-align: center; padding: 30px 20px; color: #B0B0BE; font-size: 13px; }

/* Danger link */
.qfc-delete { border: none !important; background: none !important; color: #E04F4F !important; font-size: 13px !important; font-weight: 500 !important; cursor: pointer !important; font-family: inherit !important; padding: 8px 0 !important; text-decoration: underline !important; -webkit-tap-highlight-color: transparent !important; }

@media (max-width: 480px) {
    #quelld-family-root input, #quelld-family-root select, #quelld-family-root textarea { font-size: 16px !important; }
    .qfc-cat-grid { grid-template-columns: 1fr; }
}
