/**
 * Quelld Co-Parent Calendar - Module Styles
 */

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

/* ── Setup Wizard ─────────────────────────── */
.qcp-setup { padding: 20px; }
.qcp-title { font-size: 22px; font-weight: 700; line-height: 1.3; color: #2D2D3A; margin: 0 0 8px; }
.qcp-subtitle { font-size: 14px; color: #7A7A8A; line-height: 1.5; margin: 0 0 20px; }

.qcp-patterns { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
.qcp-pattern { padding: 14px 16px !important; border-radius: 14px !important; border: 2px solid #EAEAEF !important; background: #FFFFFF !important; text-align: left !important; cursor: pointer !important; font-family: inherit !important; -webkit-tap-highlight-color: transparent !important; }
.qcp-pattern--active { border-color: #954FE0 !important; background: #EDE5FF !important; }
.qcp-pattern__name { font-size: 14px; font-weight: 600; color: #2D2D3A; margin-bottom: 2px; }
.qcp-pattern__desc { font-size: 12px; color: #7A7A8A; line-height: 1.4; }
.qcp-pattern__visual { display: flex; gap: 2px; margin-top: 8px; }
.qcp-pattern__day { width: 20px; height: 20px; border-radius: 4px; display: flex; align-items: center; justify-content: center; font-size: 8px; font-weight: 700; color: #FFFFFF; }
.qcp-pattern__day--a { background: #DC2626; }
.qcp-pattern__day--b { background: #7C3AED; }

.qcp-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; }
.qcp-input:focus { border-color: #954FE0 !important; }

.qcp-label { font-size: 13px; font-weight: 600; color: #2D2D3A; display: block; margin-bottom: 4px; }

.qcp-duration-row { display: flex; gap: 8px; margin-bottom: 16px; }
.qcp-dur-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; }
.qcp-dur-btn--active { border-color: #954FE0 !important; background: #EDE5FF !important; color: #954FE0 !important; font-weight: 600 !important; }

/* ── Calendar View ────────────────────────── */
.qcp-calendar { padding: 0 0 20px; }

/* Header */
.qcp-header { display: flex; align-items: center; justify-content: space-between; padding: 12px 20px; }
.qcp-header__title { font-size: 16px; font-weight: 600; color: #2D2D3A; }
.qcp-header__actions { display: flex; gap: 8px; align-items: center; }
.qcp-icon-btn { width: 36px !important; height: 36px !important; border-radius: 10px !important; border: 1px solid #EAEAEF !important; background: #FFFFFF !important; display: flex !important; align-items: center !important; justify-content: center !important; cursor: pointer !important; font-size: 16px !important; padding: 0 !important; -webkit-tap-highlight-color: transparent !important; }
.qcp-icon-btn--active { border-color: #954FE0 !important; background: #EDE5FF !important; }

/* Week nav */
.qcp-week-nav { display: flex; align-items: center; justify-content: space-between; padding: 0 20px 8px; }
.qcp-week-label { font-size: 13px; font-weight: 600; color: #2D2D3A; }
.qcp-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 */
.qcp-day-strip { display: flex; padding: 0 12px 12px; gap: 0; }
.qcp-day { flex: 1; text-align: center; padding: 8px 4px; cursor: pointer; border-radius: 12px; -webkit-tap-highlight-color: transparent; }
.qcp-day--selected { background: #F7F7FA; }
.qcp-day--today .qcp-day__num { background: #954FE0; color: #FFFFFF; border-radius: 50%; width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center; }
.qcp-day__abbr { font-size: 10px; text-transform: uppercase; color: #94A3B8; font-weight: 600; letter-spacing: 0.5px; }
.qcp-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; }
.qcp-day__bar { height: 3px; border-radius: 2px; margin: 2px auto 0; width: 70%; }
.qcp-day__bar--a { background: #DC2626; }
.qcp-day__bar--b { background: #7C3AED; }
.qcp-day__dots { font-size: 8px; color: #B0B0BE; margin-top: 2px; }

/* Custody banner */
.qcp-custody-banner { margin: 0 20px 12px; padding: 10px 14px; border-radius: 12px; display: flex; align-items: center; gap: 10px; }
.qcp-custody-banner--a { background: #FEE2E2; }
.qcp-custody-banner--b { background: #EDE9FE; }
.qcp-custody-avatar { width: 28px; height: 28px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; color: #FFFFFF; flex-shrink: 0; }
.qcp-custody-avatar--a { background: #DC2626; }
.qcp-custody-avatar--b { background: #7C3AED; }
.qcp-custody-text { font-size: 13px; font-weight: 600; color: #2D2D3A; }

/* Event cards */
.qcp-events { padding: 0 20px; }
.qcp-event-card { display: flex; gap: 12px; padding: 12px 0; border-bottom: 1px solid #F2F2F5; }
.qcp-event-card:last-child { border-bottom: none; }
.qcp-event__time-col { width: 50px; flex-shrink: 0; }
.qcp-event__time { font-size: 12px; font-weight: 700; color: #2D2D3A; }
.qcp-event__dur { font-size: 10px; color: #94A3B8; }
.qcp-event__bar { width: 3px; border-radius: 2px; align-self: stretch; flex-shrink: 0; }
.qcp-event__content { flex: 1; min-width: 0; }
.qcp-event__title { font-size: 13px; font-weight: 600; color: #2D2D3A; }
.qcp-event__meta { display: flex; gap: 6px; margin-top: 3px; flex-wrap: wrap; }
.qcp-event__cat { font-size: 10px; padding: 2px 8px; border-radius: 6px; font-weight: 600; }

/* Bottom bar */
.qcp-bottom { display: flex; gap: 8px; padding: 16px 20px; }
.qcp-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; }
.qcp-bottom__btn--primary { background: #954FE0 !important; color: #FFFFFF !important; border: none !important; }
.qcp-bottom__btn--outline { background: #FFFFFF !important; color: #954FE0 !important; border: 2px solid #954FE0 !important; }

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

/* Approval banner */
.qcp-approval { margin: 0 20px 16px; padding: 16px; border-radius: 14px; background: #FEF3C7; border: 1px solid #FDE68A; }
.qcp-approval__title { font-size: 14px; font-weight: 600; color: #92400E; margin-bottom: 6px; }
.qcp-approval__text { font-size: 13px; color: #92400E; line-height: 1.5; margin-bottom: 12px; }
.qcp-approval__btns { display: flex; gap: 8px; }

/* Swap requests */
.qcp-swap { margin: 0 20px 12px; padding: 14px; border-radius: 12px; background: #F7F7FA; border: 1px solid #EAEAEF; }
.qcp-swap__title { font-size: 13px; font-weight: 600; color: #2D2D3A; }
.qcp-swap__date { font-size: 12px; color: #7A7A8A; }
.qcp-swap__status { font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: 6px; display: inline-block; margin-top: 4px; }
.qcp-swap__status--pending { background: #FEF3C7; color: #92400E; }
.qcp-swap__status--approved { background: #D1FAE5; color: #065F46; }
.qcp-swap__status--declined { background: #FEE2E2; color: #991B1B; }

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

/* Category colours */
.qcp-cat--school { background: #E0F2FE; color: #0284C7; }
.qcp-cat--activity { background: #D1FAE5; color: #059669; }
.qcp-cat--medical { background: #FFE4E6; color: #E11D48; }
.qcp-cat--family { background: #EDE9FE; color: #7C3AED; }
.qcp-cat--social { background: #FEF3C7; color: #D97706; }
.qcp-cat--handover { background: #EDE9FE; color: #6D28D9; }

@media (max-width: 480px) {
    .qcp-pattern__visual { gap: 1px; }
    .qcp-pattern__day { width: 16px; height: 16px; font-size: 7px; }
    #quelld-coparent-root input, #quelld-coparent-root select, #quelld-coparent-root textarea { font-size: 16px !important; }
}

/* ── View toggle ──────────────────────────── */
.qcp-view-btn { padding: 8px 16px !important; border: none !important; background: transparent !important; font-size: 13px !important; font-weight: 500 !important; font-family: inherit !important; color: #7A7A8A !important; cursor: pointer !important; -webkit-tap-highlight-color: transparent !important; }
.qcp-view-btn--active { background: #FFFFFF !important; color: #954FE0 !important; font-weight: 600 !important; border-radius: 8px !important; box-shadow: 0 1px 3px rgba(0,0,0,0.08) !important; }

/* ── Labeled buttons ──────────────────────── */
.qcp-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; }
.qcp-labeled-btn--active { border-color: #954FE0 !important; background: #EDE5FF !important; color: #954FE0 !important; font-weight: 600 !important; }
.qcp-labeled-btn--primary { border-color: #954FE0 !important; background: #954FE0 !important; color: #FFFFFF !important; font-weight: 600 !important; }

/* ── Month grid ───────────────────────────── */
.qcp-month-headers { display: grid; grid-template-columns: repeat(7, 1fr); padding: 0 12px; margin-bottom: 4px; }
.qcp-month-hdr { text-align: center; font-size: 11px; font-weight: 600; color: #94A3B8; text-transform: uppercase; padding: 4px 0; }

.qcp-month-grid { display: grid; grid-template-columns: repeat(7, 1fr); padding: 0 12px; gap: 2px; }
.qcp-month-cell { aspect-ratio: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; border-radius: 8px; cursor: pointer; position: relative; -webkit-tap-highlight-color: transparent; min-height: 40px; }
.qcp-month-cell--empty { cursor: default; }
.qcp-month-cell--selected { outline: 2px solid #954FE0; outline-offset: -2px; }
.qcp-month-cell--today .qcp-month-num { background: #954FE0; color: #FFFFFF; border-radius: 50%; width: 26px; height: 26px; display: flex; align-items: center; justify-content: center; }
.qcp-month-num { font-size: 13px; font-weight: 600; color: #2D2D3A; }
.qcp-month-dots { font-size: 6px; color: #954FE0; margin-top: 1px; }
