/**
 * cly-ui.css — Componentes de UI do Fluxo Diário
 *
 * Prefixo: cly-ui-*
 * Sempre declare variáveis em :root e sobrescreva em body.app_theme_dark.
 * Nunca use cores hardcoded em elementos interativos — use as variáveis abaixo.
 *
 * Componentes disponíveis:
 *   cly-ui-vars         — variáveis de tema claro/escuro
 *   cly-ui-section-title — título de seção com número de passo
 *   cly-ui-info-box     — caixa explicativa contextual
 *   cly-ui-multi-pill   — seleção múltipla via checkbox visual
 */

/* ============================================================
   cly-ui-vars — Variáveis de Tema 
   ============================================================ */
:root {
    --cly-bg:           #ffffff;
    --cly-surface:      #f4f5f7;
    --cly-border:       #dfe1e6;
    --cly-border-focus: #1e88e5;
    --cly-text-main:    #172b4d;
    --cly-text-muted:   #5e6c84;
    --cly-shadow-sm:    0 1px 2px rgba(9, 30, 66, 0.12);
    --cly-shadow-md:    0 4px 8px -2px rgba(9, 30, 66, 0.2);
    --cly-primary:      #1e88e5;
    --cly-primary-bg:   #e3f2fd;
    --cly-primary-text: #1565c0;
}

body.app_theme_dark {
    --cly-bg:           #1e1e1e;
    --cly-surface:      #2d2d2d;
    --cly-border:       #444444;
    --cly-border-focus: #42a5f5;
    --cly-text-main:    #e0e0e0;
    --cly-text-muted:   #9e9e9e;
    --cly-shadow-sm:    0 1px 3px rgba(0, 0, 0, 0.4);
    --cly-shadow-md:    0 5px 10px rgba(0, 0, 0, 0.6);
    --cly-primary:      #42a5f5;
    --cly-primary-bg:   #15324d;
    --cly-primary-text: #64b5f6;
}

/* ============================================================
   cly-ui-section-title — Título de Seção com Passo Numerado
   Uso: <div class="cly-ui-section-title">
            <span class="cly-ui-step">1</span> Título
        </div>
   ============================================================ */
.cly-ui-section-title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--cly-text-muted);
    margin-top: 24px;
    margin-bottom: 12px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--cly-border);
}

.cly-ui-step {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: var(--cly-primary);
    color: #ffffff;
    font-size: 12px;
    font-weight: 700;
    flex-shrink: 0;
}

/* ============================================================
   cly-ui-info-box — Caixa Explicativa Contextual
   Uso: <div class="cly-ui-info-box">
            <i class="material-icons cly-ui-info-icon">info</i>
            <div>
                <strong>Título</strong>
                <p>Descrição...</p>
            </div>
        </div>
   Variantes: cly-ui-info-box--warning (amarelo), --success (verde)
   ============================================================ */
.cly-ui-info-box {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    background: var(--cly-primary-bg);
    border: 1px solid rgba(30, 136, 229, 0.25);
    border-left: 4px solid var(--cly-primary);
    border-radius: 6px;
    padding: 14px 16px;
    margin-bottom: 8px;
}

body.app_theme_dark .cly-ui-info-box {
    border-color: rgba(66, 165, 245, 0.2);
    border-left-color: var(--cly-primary);
}

.cly-ui-info-icon {
    font-size: 20px;
    color: var(--cly-primary);
    flex-shrink: 0;
    margin-top: 1px;
}

.cly-ui-info-box strong {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--cly-primary-text);
    margin-bottom: 4px;
}

body.app_theme_dark .cly-ui-info-box strong {
    color: var(--cly-primary-text);
}

.cly-ui-info-box p {
    margin: 0;
    font-size: 13px;
    color: var(--cly-text-muted);
    line-height: 1.5;
}

/* Variante aviso */
.cly-ui-info-box--warning {
    background: #fffde7;
    border-color: rgba(255, 179, 0, 0.25);
    border-left-color: #ffb300;
}
body.app_theme_dark .cly-ui-info-box--warning {
    background: #2a2000;
    border-color: rgba(255, 179, 0, 0.2);
    border-left-color: #ffb300;
}
.cly-ui-info-box--warning .cly-ui-info-icon { color: #f9a825; }
.cly-ui-info-box--warning strong { color: #e65100; }
body.app_theme_dark .cly-ui-info-box--warning strong { color: #ffcc02; }

/* ============================================================
   cly-ui-multi-pill — Seleção Múltipla via Checkbox Visual
   Uso: <div class="cly-ui-multi-pill-group">
            <input type="checkbox" id="chk_x" name="tipos[]" value="X" checked>
            <label for="chk_x">
                <i class="material-icons">check</i> Rótulo
            </label>
        </div>
   ============================================================ */
.cly-ui-multi-pill-group {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.cly-ui-multi-pill-group input[type="checkbox"] {
    display: none;
}

.cly-ui-multi-pill-group label {
    display: inline-flex;
    align-items: center;
    gap: 0;
    padding: 7px 14px;
    border-radius: 6px;
    background: var(--cly-bg);
    color: var(--cly-text-muted);
    border: 1px solid var(--cly-border);
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    user-select: none;
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.cly-ui-multi-pill-group label:hover {
    background: var(--cly-surface);
    border-color: var(--cly-text-muted);
    color: var(--cly-text-main);
}

/* Ícone de check — oculto por padrão, animado ao selecionar */
.cly-ui-multi-pill-group label i.material-icons {
    font-size: 15px;
    opacity: 0;
    width: 0;
    overflow: hidden;
    transition: opacity 0.15s ease, width 0.15s ease, margin-right 0.15s ease;
    margin-right: 0;
}

/* Estado selecionado */
.cly-ui-multi-pill-group input[type="checkbox"]:checked + label {
    background: var(--cly-primary-bg);
    color: var(--cly-primary-text);
    border-color: var(--cly-primary);
    box-shadow: 0 1px 4px rgba(30, 136, 229, 0.15);
}

.cly-ui-multi-pill-group input[type="checkbox"]:checked + label i.material-icons {
    opacity: 1;
    width: 15px;
    margin-right: 5px;
}
