
/* ========================================
   MORLENCERIA FRASE PRO
   style.css v1.0.0
   ======================================== */

.morl-frasepro-wrapper {
    margin-top: 20px;
}

.morl-frasepro-label {
    display: block;
    font-size: 13px;
    letter-spacing: .08em;
    margin-bottom: 10px;
    font-weight: 600;
}

#morl_frasepro_text {
    width: 100%;
    height: 54px;
    border-radius: 16px;
    border: 1px solid #e6e6e6;
    padding: 0 16px;
    font-size: 15px;
    outline: none;
    background: #fff;
}

#morl_frasepro_text:focus {
    border-color: #111;
}

.morl-frasepro-counter {
    margin-top: 8px;
    font-size: 12px;
    opacity: .7;
}

/* ─────────  GRID 8 columnas (2 filas para 15 SVGs)  ───────── */
.morl-frasepro-grid {
    display: grid !important;
    grid-template-columns: repeat(8, minmax(0, 1fr)) !important;
    gap: 8px !important;
    margin-top: 16px;
    width: 100% !important;
}

/* ─────────  BOTONES SVG  ───────── */
.morl-frasepro-svg-btn {
    width: 100% !important;
    min-width: 0 !important;
    height: 42px !important;
    border-radius: 12px;
    border: 1px solid #ececec;
    background: #fff;
    cursor: pointer;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: opacity .2s, transform .15s, border-color .2s, filter .2s;
    padding: 0;
    box-sizing: border-box;
    outline: none;
    /* Quita el flash gris/azul de Android e iOS al tocar */
    -webkit-tap-highlight-color: transparent;
    user-select: none;
    -webkit-user-select: none;
}

.morl-frasepro-svg-btn img {
    width: 24px !important;
    height: 24px !important;
    object-fit: contain !important;
    pointer-events: none;
    display: block;
}

/* Hover SOLO en dispositivos con cursor real (PC).
   En móvil esto no se aplica → adiós al estado pegado. */
@media (hover: hover) and (pointer: fine) {
    .morl-frasepro-svg-btn:hover {
        transform: scale(1.05);
        border-color: #111;
    }
}

/* Feedback al pulsar (válido en PC y móvil, dura solo lo que dura el toque) */
.morl-frasepro-svg-btn:active {
    transform: scale(0.92);
    border-color: #111;
}

/* Estado DESACTIVADO — cuando se llegó al máximo de iconos o caracteres */
.morl-frasepro-svg-btn.morl-frasepro-disabled {
    opacity: 0.28 !important;
    filter: grayscale(1) !important;
    cursor: not-allowed !important;
    pointer-events: none !important;
    transform: none !important;
    border-color: #ececec !important;
    background: #fafafa !important;
}

/* ─────────  EDITOR VISUAL  ───────── */
.morl-frasepro-preview-label {
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 6px;
    margin-top: 10px;
}

.morl-frasepro-editor {
    border: 1px solid #dcdcdc !important;
    border-radius: 12px !important;
    min-height: 58px !important;
    padding: 12px !important;
    font-size: 16px !important;
    background: #fff !important;

    /* Layout en bloque (NO flex) — permite espacios y wrap natural */
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    overflow: hidden !important;

    /* Comportamiento del texto */
    white-space: pre-wrap !important;       /* preserva espacios + permite saltos */
    word-break: break-word !important;      /* corta palabras largas */
    overflow-wrap: anywhere !important;     /* fuerza wrap antes que overflow */

    cursor: text;
    line-height: 1.5;

    direction: ltr !important;
    text-align: left !important;
    unicode-bidi: isolate !important;
}

.morl-frasepro-editor:focus {
    outline: none !important;
    border-color: #111 !important;
}

.morl-frasepro-svg-inline {
    width: 26px !important;
    height: 26px !important;
    object-fit: contain !important;
    display: inline-block !important;
    vertical-align: middle !important;
    margin: 0 2px;
    user-select: none;
    -webkit-user-select: none;
}

/* ─────────  MOBILE  ───────── */
@media (max-width: 768px) {

    .morl-frasepro-grid {
        grid-template-columns: repeat(8, minmax(0, 1fr)) !important;
        gap: 6px !important;
    }

    .morl-frasepro-svg-btn {
        height: 36px !important;
    }

    .morl-frasepro-svg-btn img {
        width: 20px !important;
        height: 20px !important;
    }

    .morl-frasepro-svg-inline {
        width: 22px !important;
        height: 22px !important;
    }

}
