/**
 * Quelld Home Organiser — Module Styles
 */

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

.qo-phase { padding: 24px 20px 32px; }
.qo-eyebrow { font-size: 11px; font-weight: 600; color: var(--quelld-purple, #954FE0); text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 8px; }
.qo-title { font-size: 24px; font-weight: 700; color: #2D2D3A; margin: 0 0 6px; line-height: 1.2; }
.qo-subtitle { font-size: 15px; color: #7A7A8A; margin: 0 0 24px; line-height: 1.5; }
.qo-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; }

/* Steps indicator */
.qo-steps { display: flex; gap: 6px; margin-bottom: 24px; }
.qo-step { flex: 1; height: 4px; border-radius: 2px; background: #EAEAEF; }
.qo-step--done { background: var(--quelld-teal, #4AE1E0); }
.qo-step--current { background: var(--quelld-purple, #954FE0); }

/* Fields */
.qo-field { margin-bottom: 20px; }
.qo-field__label { font-size: 14px; font-weight: 600; color: #2D2D3A; margin-bottom: 8px; }
.qo-field__hint { font-size: 12px; color: #B0B0BE; margin-top: 4px; }
.qo-input { width: 100% !important; padding: 14px 16px !important; border-radius: 12px !important; border: 1px solid #EAEAEF !important; font-size: 16px !important; font-family: inherit !important; color: #3A3A4A !important; outline: none !important; -webkit-appearance: none !important; box-sizing: border-box !important; }
.qo-input:focus { border-color: var(--quelld-purple, #954FE0) !important; }
.qo-textarea { width: 100% !important; min-height: 80px !important; padding: 14px 16px !important; border-radius: 12px !important; border: 1px solid #EAEAEF !important; font-size: 14px !important; font-family: inherit !important; color: #3A3A4A !important; outline: none !important; resize: vertical !important; box-sizing: border-box !important; }

/* Home type cards */
.qo-type-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.qo-type-card { padding: 16px !important; border-radius: 14px !important; border: 1px solid #EAEAEF !important; background: #FFFFFF !important; cursor: pointer !important; font-family: inherit !important; text-align: center !important; color: #2D2D3A !important; }
.qo-type-card--active { border: 2px solid var(--quelld-purple, #954FE0) !important; background: var(--quelld-purple-light, #EDE5FF) !important; color: var(--quelld-purple, #954FE0) !important; }
.qo-type-card__icon { font-size: 28px; margin-bottom: 6px; display: block; }
.qo-type-card__label { font-size: 13px; font-weight: 600; }

/* Bedroom stepper */
.qo-stepper { display: flex; align-items: center; gap: 16px; }
.qo-stepper__btn { width: 44px !important; height: 44px !important; border-radius: 12px !important; border: 1px solid #EAEAEF !important; background: #FFFFFF !important; font-size: 20px !important; cursor: pointer !important; font-family: inherit !important; display: flex !important; align-items: center !important; justify-content: center !important; color: #3A3A4A !important; }
.qo-stepper__num { font-size: 28px; font-weight: 700; color: var(--quelld-purple, #954FE0); text-align: center; min-width: 60px; }
.qo-stepper__unit { font-size: 11px; color: #B0B0BE; text-align: center; }

/* Area selection */
.qo-area-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.qo-area-chip { padding: 14px 12px !important; border-radius: 12px !important; border: 1px solid #EAEAEF !important; background: #FFFFFF !important; cursor: pointer !important; font-family: inherit !important; display: flex !important; align-items: center !important; gap: 10px !important; text-align: left !important; color: #3A3A4A !important; font-size: 13px !important; }
.qo-area-chip--active { border: 2px solid var(--quelld-purple, #954FE0) !important; background: var(--quelld-purple-light, #EDE5FF) !important; color: var(--quelld-purple, #954FE0) !important; font-weight: 600 !important; }
.qo-area-chip__icon { font-size: 20px; flex-shrink: 0; }
.qo-area-chip__check { width: 20px; height: 20px; border-radius: 6px; border: 2px solid #EAEAEF; display: flex; align-items: center; justify-content: center; font-size: 11px; color: #FFFFFF; flex-shrink: 0; margin-left: auto; }
.qo-area-chip--active .qo-area-chip__check { border-color: var(--quelld-purple, #954FE0); background: var(--quelld-purple, #954FE0); }

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

/* Summary */
.qo-summary { background: linear-gradient(135deg, var(--quelld-purple-light, #EDE5FF), var(--quelld-teal-light, #E5F6F6)); border-radius: 20px; padding: 20px; margin-bottom: 20px; }
.qo-summary__title { font-size: 16px; font-weight: 700; color: #2D2D3A; margin-bottom: 12px; }
.qo-summary-row { display: flex; justify-content: space-between; padding: 6px 0; font-size: 14px; }
.qo-summary-row__label { color: #7A7A8A; }
.qo-summary-row__value { color: #2D2D3A; font-weight: 500; }

/* Pre-move banner */
.qo-premove-banner { background: var(--quelld-teal-light, #E5F6F6); border-radius: 14px; padding: 16px 18px; margin-bottom: 20px; display: flex; align-items: flex-start; gap: 12px; }
.qo-premove-banner__icon { font-size: 24px; flex-shrink: 0; }
.qo-premove-banner__text { font-size: 13px; color: #2CB8B8; line-height: 1.5; }

/* Confirmation */
.qo-confirm { text-align: center; padding: 40px 20px; }
.qo-confirm__icon { font-size: 56px; margin-bottom: 16px; }
.qo-confirm__title { font-size: 22px; font-weight: 700; color: #2D2D3A; margin-bottom: 8px; }
.qo-confirm__desc { font-size: 14px; color: #7A7A8A; line-height: 1.6; margin-bottom: 24px; }

@media (max-width: 480px) {
    .qo-phase { padding-top: 16px; }
    .qo-type-grid { grid-template-columns: 1fr 1fr; }
    .qo-area-grid { grid-template-columns: 1fr; }
    #quelld-organiser-root input, #quelld-organiser-root textarea { font-size: 16px !important; }
}
