/**
 * Quelld Event Organiser — Module Styles
 */

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

/* Override Astra button defaults */
#quelld-events-root button { color: #2D2D3A; }
#quelld-events-root button span { color: inherit; }
#quelld-events-root .quelld-btn-primary { color: #FFFFFF !important; }
#quelld-events-root .quelld-btn-secondary { color: var(--quelld-purple, #954FE0) !important; }

.qe-phase { padding: 24px 20px 32px; }
.qe-eyebrow { font-size: 11px; font-weight: 600; color: var(--quelld-purple, #954FE0); text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 8px; }
.qe-title { font-size: 24px; font-weight: 700; color: #2D2D3A; margin: 0 0 6px; line-height: 1.2; }
.qe-subtitle { font-size: 15px; color: #7A7A8A; margin: 0 0 24px; line-height: 1.5; }
.qe-back { cursor: pointer; font-size: 14px; color: var(--quelld-purple, #954FE0); font-weight: 500; padding: 14px 16px 14px 0; margin: 0 0 8px; display: inline-block; position: relative; z-index: 50; -webkit-user-select: none; user-select: none; }
.qe-section-label { font-size: 12px; font-weight: 600; color: #B0B0BE; text-transform: uppercase; letter-spacing: 1.2px; margin: 20px 0 10px; }
.qe-field { margin-bottom: 20px; }
.qe-field__label { font-size: 14px; font-weight: 600; color: #2D2D3A; margin-bottom: 8px; }
.qe-input { width: 100%; padding: 14px 16px; border-radius: 12px; border: 1px solid #EAEAEF; font-size: 16px; font-family: inherit; color: #3A3A4A; outline: none; -webkit-appearance: none; box-sizing: border-box; }
.qe-input:focus { border-color: var(--quelld-purple, #954FE0); }
.qe-textarea { width: 100%; min-height: 80px; padding: 14px 16px; border-radius: 12px; border: 1px solid #EAEAEF; font-size: 14px; font-family: inherit; color: #3A3A4A; outline: none; resize: vertical; box-sizing: border-box; }

/* Event type cards */
.qe-type-grid { display: flex; flex-direction: column; gap: 8px; }
.qe-type-card { display: flex !important; align-items: center !important; gap: 14px !important; padding: 16px !important; border-radius: 16px !important; border: 1px solid #EAEAEF !important; background: #FFFFFF !important; cursor: pointer !important; font-family: inherit !important; width: 100% !important; text-align: left !important; color: #2D2D3A !important; }
.qe-type-card--active { border: 2px solid var(--quelld-purple, #954FE0) !important; background: var(--quelld-purple-light, #EDE5FF) !important; }
.qe-type-card__icon { font-size: 28px; flex-shrink: 0; }
.qe-type-card__name { font-size: 15px; font-weight: 600; color: #2D2D3A !important; }
.qe-type-card--active .qe-type-card__name { color: var(--quelld-purple, #954FE0) !important; }
.qe-type-card__desc { font-size: 12px; color: #7A7A8A !important; margin-top: 2px; }
.qe-type-card span { color: inherit !important; }

/* Event list */
.qe-event-list-card { display: flex !important; align-items: center !important; gap: 14px !important; padding: 16px 18px !important; margin-bottom: 8px !important; border-radius: 16px !important; border: 1px solid #EAEAEF !important; background: #FFFFFF !important; cursor: pointer !important; transition: all 0.15s !important; color: #2D2D3A !important; font-family: inherit !important; width: 100% !important; text-align: left !important; font-size: 14px !important; font-weight: 500 !important; }
.qe-event-list-card:active { border-color: var(--quelld-purple, #954FE0) !important; }
.qe-event-list-card__icon { font-size: 28px; flex-shrink: 0; }
.qe-event-list-card__name { font-size: 15px; font-weight: 600; color: #2D2D3A !important; }
.qe-event-list-card__meta { font-size: 12px; color: #7A7A8A !important; margin-top: 2px; }
.qe-event-list-card__arrow { color: #B0B0BE !important; font-size: 14px; flex-shrink: 0; margin-left: auto; }
.qe-event-list-card span { color: #2D2D3A !important; }

/* Tabs */
.qe-tabs { display: flex; background: #F7F7FA; border-radius: 10px; padding: 3px; margin-bottom: 16px; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.qe-tab { flex-shrink: 0 !important; padding: 9px 14px !important; border-radius: 8px !important; border: none !important; background: transparent !important; color: #B0B0BE !important; font-weight: 600 !important; font-size: 12px !important; cursor: pointer !important; font-family: inherit !important; white-space: nowrap !important; }
.qe-tab--active { background: #FFFFFF !important; color: #2D2D3A !important; box-shadow: 0 1px 3px rgba(0,0,0,0.08) !important; }

/* Event header */
.qe-event-header { background: linear-gradient(135deg, var(--quelld-purple-light, #EDE5FF), var(--quelld-teal-light, #E5F6F6)); border-radius: 20px; padding: 20px; margin-bottom: 16px; }
.qe-event-header__name { font-size: 22px; font-weight: 700; color: #2D2D3A; margin-bottom: 6px; }
.qe-event-header__meta { display: flex; flex-wrap: wrap; gap: 12px; font-size: 13px; color: #7A7A8A; }

/* Guest cards */
.qe-guest { display: flex; align-items: center; gap: 12px; padding: 12px 14px; margin-bottom: 4px; border-radius: 10px; background: #F7F7FA; }
.qe-guest__avatar { width: 36px; height: 36px; border-radius: 50%; background: var(--quelld-purple-light, #EDE5FF); display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 700; color: var(--quelld-purple, #954FE0); flex-shrink: 0; }
.qe-guest__name { font-size: 14px; font-weight: 500; color: #2D2D3A; }
.qe-guest__status { font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: 5px; flex-shrink: 0; }
.qe-guest__status--confirmed { background: #E6F4EA; color: #34A853; }
.qe-guest__status--pending { background: #FEF3EC; color: #E8834A; }
.qe-guest__status--declined { background: #FDE8E8; color: #E04F4F; }
.qe-guest__remove { background: none !important; border: none !important; color: #B0B0BE !important; cursor: pointer !important; font-size: 14px !important; padding: 4px !important; font-family: inherit !important; }

/* Add row */
.qe-add-row { display: flex; gap: 8px; margin-bottom: 16px; }
.qe-add-input { flex: 1; min-width: 0; padding: 12px 14px; border-radius: 10px; border: 1px solid #EAEAEF; font-size: 16px; font-family: inherit; outline: none; color: #3A3A4A; box-sizing: border-box; }
.qe-add-btn { padding: 12px 16px !important; border-radius: 10px !important; border: none !important; background: var(--quelld-teal, #4AE1E0) !important; color: #FFFFFF !important; font-size: 14px !important; font-weight: 600 !important; cursor: pointer !important; font-family: inherit !important; flex-shrink: 0 !important; }

/* Itinerary */
.qe-itinerary-item { display: flex; gap: 12px; padding: 12px 14px; margin-bottom: 4px; border-radius: 10px; background: #F7F7FA; position: relative; }
.qe-itinerary-item__time { font-size: 13px; font-weight: 600; color: var(--quelld-purple, #954FE0); min-width: 55px; flex-shrink: 0; }
.qe-itinerary-item__title { font-size: 14px; font-weight: 500; color: #2D2D3A; }
.qe-itinerary-item__notes { font-size: 12px; color: #7A7A8A; margin-top: 2px; }

/* Checklist */
.qe-checklist-cat { margin-bottom: 20px; }
.qe-checklist-cat__header { font-size: 14px; font-weight: 600; color: #2D2D3A; display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.qe-check-item { display: flex; align-items: flex-start; gap: 10px; padding: 10px 12px; margin-bottom: 3px; border-radius: 8px; background: #F7F7FA; cursor: pointer; }
.qe-check-item--done { background: var(--quelld-teal-light, #E5F6F6); }
.qe-check-box { width: 22px; height: 22px; border-radius: 6px; border: 2px solid #EAEAEF; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; color: #FFFFFF; flex-shrink: 0; margin-top: 1px; }
.qe-check-box--done { border-color: var(--quelld-teal, #4AE1E0); background: var(--quelld-teal, #4AE1E0); }
.qe-check-text { font-size: 13px; color: #3A3A4A; }
.qe-check-item--done .qe-check-text { text-decoration: line-through; color: #7A7A8A; }
.qe-check-when { font-size: 11px; color: #B0B0BE; margin-top: 2px; }
.qe-check-priority { font-size: 9px; font-weight: 600; padding: 2px 6px; border-radius: 4px; flex-shrink: 0; margin-left: auto; }
.qe-check-priority--high { background: #FDE8E8; color: #E04F4F; }
.qe-check-priority--medium { background: #FEF3EC; color: #E8834A; }
.qe-check-priority--low { background: #E6F4EA; color: #34A853; }

/* Expenses */
.qe-expense { padding: 14px 16px; margin-bottom: 6px; border-radius: 12px; border: 1px solid #EAEAEF; background: #FFFFFF; }
.qe-expense__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.qe-expense__desc { font-size: 14px; font-weight: 500; color: #2D2D3A; }
.qe-expense__amount { font-size: 16px; font-weight: 700; color: var(--quelld-purple, #954FE0); }
.qe-expense__meta { font-size: 12px; color: #7A7A8A; }

.qe-expense-summary { background: linear-gradient(135deg, var(--quelld-purple-light, #EDE5FF), #F7F7FA); border-radius: 16px; padding: 16px 20px; margin-bottom: 16px; }
.qe-expense-summary__total { font-size: 24px; font-weight: 700; color: var(--quelld-purple, #954FE0); }
.qe-expense-summary__label { font-size: 12px; color: #7A7A8A; }
.qe-expense-summary__split { font-size: 14px; color: #2D2D3A; font-weight: 500; margin-top: 6px; }

/* Nearby */
.qe-nearby-card { display: flex; align-items: flex-start; gap: 12px; padding: 14px 16px; margin-bottom: 8px; border-radius: 14px; border: 1px solid #EAEAEF; background: #FFFFFF; }
.qe-nearby-card__icon { font-size: 22px; flex-shrink: 0; }
.qe-nearby-card__name { font-size: 14px; font-weight: 600; color: #2D2D3A; }
.qe-nearby-card__desc { font-size: 13px; color: #7A7A8A; line-height: 1.5; margin-top: 2px; }
.qe-nearby-card__meta { display: flex; gap: 10px; margin-top: 6px; font-size: 12px; color: #7A7A8A; flex-wrap: wrap; }

/* Travel info */
.qe-travel-section { margin-bottom: 20px; }
.qe-travel-card { padding: 14px 16px; border-radius: 14px; background: #F7F7FA; margin-bottom: 6px; }
.qe-travel-card__title { font-size: 13px; font-weight: 600; color: #2D2D3A; margin-bottom: 4px; }
.qe-travel-card__value { font-size: 14px; color: #3A3A4A; line-height: 1.5; }
.qe-phrase { display: flex; align-items: center; gap: 12px; padding: 10px 14px; margin-bottom: 3px; border-radius: 8px; background: #F7F7FA; }
.qe-phrase__en { font-size: 13px; color: #7A7A8A; min-width: 80px; }
.qe-phrase__local { font-size: 14px; font-weight: 600; color: #2D2D3A; }
.qe-phrase__pron { font-size: 11px; color: #B0B0BE; font-style: italic; }

/* Loading */
.qe-loading { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 300px; text-align: center; }

/* Empty state */
.qe-empty { text-align: center; padding: 40px 20px; color: #B0B0BE; }
.qe-empty__icon { font-size: 48px; margin-bottom: 12px; }

@media (max-width: 480px) {
    .qe-phase { padding-top: 16px; }
    #quelld-events-root input, #quelld-events-root textarea { font-size: 16px !important; }
    .qe-tabs { gap: 2px; }
    .qe-tab { padding: 8px 10px !important; font-size: 11px !important; }
}
