/* CruiseLead™ by Ingenio Web Total SAS */

.cl-wrapper {
    padding: 32px 20px;
    font-family: inherit;
    box-sizing: border-box;
    width: 100%;
}

/* ── GRID LAYOUT ──────────────────────────────────────────────
   Shortcode:
     [cruiselead]             → columnas configuradas en admin
     [cruiselead columns="4"] → 4 columnas
     [cruiselead columns="3"] → 3 columnas
     [cruiselead columns="2"] → 2 columnas
──────────────────────────────────────────────────────────────── */

.cl-cols-4 .cl-row { grid-template-columns: repeat(4, 1fr); }
.cl-cols-3 .cl-row { grid-template-columns: repeat(3, 1fr); }
.cl-cols-2 .cl-row { grid-template-columns: repeat(2, 1fr); }

.cl-row {
    display: grid !important;
    gap: 12px;
    align-items: end;
    width: 100%;
}

/* El botón ocupa solo su celda, centrado */
.cl-field--submit {
    display: flex;
    flex-direction: column;
}

/* LABELS */
.cl-field {
    display: flex;
    flex-direction: column;
}

.cl-field label {
    font-size: 13px;
    font-weight: 600;
    color: #3a3a3a;
    margin-bottom: 5px;
    display: block;
}

.cl-required { color: #c0392b; }

/* INPUTS & SELECTS */
.cl-field input,
.cl-field select {
    height: 44px;
    padding: 0 12px;
    background: #fff;
    border: 1.5px solid #d8d8d8;
    border-radius: 6px;
    font-size: 14px;
    color: #444;
    text-align: center;
    transition: border-color .2s, box-shadow .2s;
    box-shadow: 0 2px 4px rgba(0,0,0,0.04);
    width: 100%;
    box-sizing: border-box;
}

.cl-field input:focus,
.cl-field select:focus {
    border-color: #631b1c;
    box-shadow: 0 0 0 3px rgba(99,27,28,0.15);
    outline: none;
}

.cl-field input.cl-error,
.cl-field select.cl-error {
    border-color: #e74c3c;
    box-shadow: 0 0 0 3px rgba(231,76,60,0.15);
}

input[type="date"]::-webkit-calendar-picker-indicator {
    cursor: pointer;
    padding-right: 6px;
}

/* BUTTON */
.cl-field--submit button {
    height: 44px;
    width: 100%;
    background-color: #631b1c;
    border: none;
    border-radius: 6px;
    color: #fff;
    font-weight: 700;
    font-size: 14px;
    cursor: pointer;
    transition: background-color .25s, transform .2s, box-shadow .2s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 0 16px;
    white-space: nowrap;
    box-sizing: border-box;
}

.cl-field--submit button:hover {
    filter: brightness(0.85);
    transform: translateY(-2px);
    box-shadow: 0 4px 14px rgba(0,0,0,0.18);
}

.cl-field--submit button:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

.cl-btn-icon { font-size: 16px; }

/* MESSAGE */
.cl-message {
    margin-top: 16px;
    padding: 12px 16px;
    border-radius: 6px;
    font-size: 14px;
    text-align: center;
    grid-column: 1 / -1;
}

.cl-message.cl-success {
    background: #d4edda;
    color: #155724;
    border: 1px solid #c3e6cb;
}

.cl-message.cl-error-msg {
    background: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
}

/* RESPONSIVE */
@media (max-width: 768px) {
    .cl-cols-4 .cl-row,
    .cl-cols-3 .cl-row,
    .cl-cols-2 .cl-row {
        grid-template-columns: 1fr !important;
    }
}
