/* WoskyLab Advisor — frontend (Stripe-inspired) */

/* El atributo `hidden` debe ganar SIEMPRE, incluso sobre display: flex */
.wla-wrapper [hidden] { display: none !important; }

.wla-wrapper {
    --wla-purple: #533afd;
    --wla-purple-hover: #4434d4;
    --wla-purple-deep: #2e2b8c;
    --wla-purple-light: #b9b9f9;
    --wla-purple-soft: #d6d9fc;
    --wla-navy: #061b31;
    --wla-label: #273951;
    --wla-body: #64748d;
    --wla-border: #e5edf5;
    --wla-bg: #ffffff;
    --wla-brand-dark: #1c1e54;
    --wla-success: #15be53;
    --wla-success-text: #108c3d;
    --wla-shadow-elevated: rgba(50,50,93,0.25) 0px 30px 45px -30px, rgba(0,0,0,0.1) 0px 18px 36px -18px;
    --wla-shadow-ambient: rgba(23,23,23,0.08) 0px 15px 35px 0px;
    --wla-radius-card: 8px;
    --wla-radius-input: 4px;
    --wla-col-height: 780px;

    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-feature-settings: "ss01";
    color: var(--wla-navy);
    width: 100%;
    margin: 32px auto;
    line-height: 1.4;
}

/* === KILL SWITCH MOBILE: nada toma altura forzada bajo 900px de viewport === */
@media (max-width: 899px) {
    .wla-wrapper,
    .wla-wrapper .wla-split,
    .wla-wrapper .wla-col,
    .wla-wrapper .wla-card,
    .wla-wrapper .wla-result,
    .wla-wrapper .wla-result-scroll,
    .wla-wrapper .wla-result-empty,
    .wla-wrapper .wla-result-body {
        height: auto !important;
        max-height: none !important;
        min-height: 0 !important;
    }
    .wla-wrapper .wla-result-scroll {
        overflow: visible !important;
        -webkit-mask-image: none !important;
                mask-image: none !important;
    }
}

/* === MOBILE FIRST: una columna, alto natural, sin restricciones === */
.wla-split {
    display: flex;
    flex-direction: column;
    gap: 24px;
    width: 100%;
}

.wla-col {
    display: block;
    width: 100%;
    min-width: 0;
}

.wla-col > .wla-card,
.wla-col > .wla-result {
    display: block;
    width: 100%;
    margin: 0;
    height: auto;
}

/* === DESKTOP: ≥ 900px de viewport físico → dos columnas con altura fija y scroll interno === */
@media (min-width: 900px) {
    .wla-split {
        flex-direction: row;
        align-items: stretch;
    }
    .wla-col {
        display: flex;
        flex-direction: column;
        flex: 1 1 50%;
        width: 50%;
    }
    .wla-col > .wla-card,
    .wla-col > .wla-result {
        display: flex;
        flex-direction: column;
        flex: 1 1 auto;
        height: var(--wla-col-height);
        min-height: 0;
    }
    .wla-result-scroll {
        flex: 1 1 0;
        min-height: 0;
        overflow-y: scroll;
        -webkit-mask-image: linear-gradient(to bottom, #000 calc(100% - 28px), transparent 100%);
                mask-image: linear-gradient(to bottom, #000 calc(100% - 28px), transparent 100%);
    }
    .wla-result-scroll.is-end {
        -webkit-mask-image: none;
                mask-image: none;
    }
    .wla-result-empty {
        flex: 1 1 auto;
    }
}

.wla-wrapper *,
.wla-wrapper *::before,
.wla-wrapper *::after {
    box-sizing: border-box;
}

.wla-card,
.wla-result {
    background: var(--wla-bg);
    border: 1px solid var(--wla-border);
    border-radius: var(--wla-radius-card);
    padding: 32px;
    box-shadow: var(--wla-shadow-elevated);
}

.wla-result {
    overflow: hidden;
    position: relative;
}

.wla-result-scroll {
    overflow-y: auto;
    overflow-x: hidden;
    margin: 0 -12px;
    padding: 4px 12px 32px;
    scrollbar-width: thin;
    scrollbar-color: rgba(83,58,253,0.45) rgba(83,58,253,0.06);
    scroll-behavior: smooth;
}

.wla-result-scroll::-webkit-scrollbar {
    width: 8px;
}
.wla-result-scroll::-webkit-scrollbar-thumb {
    background: rgba(83,58,253,0.4);
    border-radius: 4px;
    border: 2px solid transparent;
    background-clip: padding-box;
}
.wla-result-scroll::-webkit-scrollbar-thumb:hover {
    background: var(--wla-purple);
    background-clip: padding-box;
    border: 2px solid transparent;
}
.wla-result-scroll::-webkit-scrollbar-track {
    background: rgba(83,58,253,0.04);
    border-radius: 4px;
}

.wla-result-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: var(--wla-body);
    padding: 24px;
}

.wla-result-empty-icon {
    color: var(--wla-purple-light);
    margin-bottom: 16px;
}

.wla-result-empty-title {
    font-size: 16px;
    font-weight: 400;
    color: var(--wla-label);
    margin: 0 0 6px;
}

.wla-result-empty-text {
    font-size: 14px;
    font-weight: 300;
    color: var(--wla-body);
    margin: 0;
    max-width: 320px;
    line-height: 1.5;
}


.wla-header {
    margin-bottom: 24px;
}

.wla-eyebrow {
    display: inline-block;
    font-size: 12px;
    font-weight: 400;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--wla-purple);
    margin-bottom: 12px;
}

.wla-title {
    font-size: 32px;
    font-weight: 300;
    line-height: 1.10;
    letter-spacing: -0.64px;
    color: var(--wla-navy);
    margin: 0 0 8px;
}

.wla-subtitle {
    font-size: 18px;
    font-weight: 300;
    line-height: 1.40;
    color: var(--wla-body);
    margin: 0;
}

.wla-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.wla-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.wla-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.wla-label {
    font-size: 14px;
    font-weight: 400;
    color: var(--wla-label);
}

.wla-input,
.wla-textarea {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--wla-border);
    border-radius: var(--wla-radius-input);
    font: inherit;
    font-size: 16px;
    font-weight: 300;
    color: var(--wla-navy);
    background: #fff;
    transition: border-color 120ms ease, box-shadow 120ms ease;
}

.wla-input::placeholder,
.wla-textarea::placeholder {
    color: var(--wla-body);
}

.wla-input:focus,
.wla-textarea:focus {
    outline: none;
    border-color: var(--wla-purple);
    box-shadow: 0 0 0 3px rgba(83,58,253,0.15);
}

.wla-textarea {
    resize: vertical;
    min-height: 140px;
    line-height: 1.5;
}

/* --- Hero textarea: more inviting, with glow + animated border --- */
.wla-field-hero .wla-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 500;
    color: var(--wla-navy);
    letter-spacing: -0.01em;
}

.wla-label-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--wla-purple);
    box-shadow: 0 0 0 4px rgba(83,58,253,0.18);
    animation: wla-pulse 2.4s ease-in-out infinite;
}

@keyframes wla-pulse {
    0%, 100% { box-shadow: 0 0 0 4px rgba(83,58,253,0.18); }
    50%      { box-shadow: 0 0 0 6px rgba(83,58,253,0.08); }
}

.wla-textarea-wrap {
    position: relative;
    border-radius: 10px;
    padding: 1.5px;
    background: linear-gradient(135deg, #d6d9fc 0%, #ffd7ef 50%, #d6d9fc 100%);
    background-size: 200% 200%;
    transition: background-position 600ms ease, box-shadow 200ms ease;
    box-shadow: var(--wla-shadow-ambient);
}

.wla-textarea-wrap:hover {
    background-position: 100% 0;
    box-shadow: rgba(83,58,253,0.12) 0px 12px 30px -10px, rgba(0,0,0,0.06) 0px 6px 14px -6px;
}

.wla-textarea-wrap:focus-within {
    background: linear-gradient(135deg, #533afd 0%, #f96bee 50%, #533afd 100%);
    background-size: 200% 200%;
    animation: wla-shimmer 4s linear infinite;
    box-shadow: rgba(83,58,253,0.25) 0px 18px 40px -12px, rgba(83,58,253,0.15) 0px 4px 10px -2px;
}

@keyframes wla-shimmer {
    0%   { background-position: 0% 0; }
    100% { background-position: 200% 0; }
}

.wla-textarea-hero {
    position: relative;
    z-index: 1;
    width: 100%;
    min-height: 168px;
    padding: 18px 20px;
    border: none;
    border-radius: 8.5px;
    background: #ffffff;
    font-size: 16px;
    font-weight: 300;
    line-height: 1.55;
    color: var(--wla-navy);
    transition: background 200ms ease;
}

.wla-textarea-hero:focus {
    outline: none;
    box-shadow: none;
    background: linear-gradient(180deg, #fafbff 0%, #ffffff 100%);
}

.wla-textarea-hero::placeholder {
    color: #94a0b8;
    font-style: italic;
    font-weight: 300;
}

.wla-textarea-glow {
    position: absolute;
    inset: -20px;
    z-index: 0;
    border-radius: 24px;
    background: radial-gradient(60% 60% at 50% 0%, rgba(83,58,253,0.18) 0%, rgba(83,58,253,0) 70%);
    opacity: 0;
    pointer-events: none;
    transition: opacity 280ms ease;
    filter: blur(8px);
}

.wla-textarea-wrap:focus-within .wla-textarea-glow {
    opacity: 1;
}


.wla-helper {
    font-size: 13px;
    font-weight: 300;
    color: var(--wla-body);
}

.wla-actions {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
}

.wla-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 18px;
    border-radius: var(--wla-radius-input);
    font-size: 16px;
    font-weight: 400;
    line-height: 1;
    cursor: pointer;
    border: 1px solid transparent;
    transition: background-color 120ms ease, border-color 120ms ease, color 120ms ease, transform 60ms ease;
    font-family: inherit;
    font-feature-settings: "ss01";
}

.wla-btn:active {
    transform: translateY(1px);
}

.wla-btn-primary {
    background: var(--wla-purple);
    color: #fff;
}

.wla-btn-primary:hover {
    background: var(--wla-purple-hover);
}

.wla-btn-primary:disabled {
    background: var(--wla-purple-light);
    cursor: not-allowed;
}

.wla-btn-ghost {
    background: transparent;
    color: var(--wla-purple);
    border-color: var(--wla-purple-light);
}

.wla-btn-ghost:hover {
    background: rgba(83,58,253,0.05);
}

.wla-btn-spinner {
    display: none;
    width: 14px;
    height: 14px;
    border: 2px solid rgba(255,255,255,0.4);
    border-top-color: #fff;
    border-radius: 50%;
    animation: wla-spin 700ms linear infinite;
}

.wla-btn.is-loading .wla-btn-spinner {
    display: inline-block;
}

@keyframes wla-spin {
    to { transform: rotate(360deg); }
}

.wla-error {
    padding: 10px 12px;
    background: #fff1f3;
    border: 1px solid #fbcfd6;
    color: #a8243a;
    border-radius: var(--wla-radius-input);
    font-size: 14px;
}

.wla-result-header {
    margin-bottom: 16px;
}

.wla-result-title {
    font-size: 22px;
    font-weight: 300;
    letter-spacing: -0.22px;
    color: var(--wla-navy);
    margin: 0;
}

.wla-result-body {
    color: var(--wla-navy);
    font-size: 16px;
    font-weight: 300;
    line-height: 1.6;
}

.wla-result-body h1,
.wla-result-body h2,
.wla-result-body h3,
.wla-result-body h4,
.wla-result-body h5,
.wla-result-body h6 {
    color: var(--wla-navy);
    font-weight: 400;
    line-height: 1.2;
    margin: 22px 0 8px;
}

.wla-result-body h1 { font-size: 24px; font-weight: 300; letter-spacing: -0.26px; }
.wla-result-body h2 { font-size: 20px; font-weight: 300; letter-spacing: -0.22px; padding-bottom: 6px; border-bottom: 1px solid var(--wla-border); }
.wla-result-body h3 { font-size: 17px; letter-spacing: -0.18px; }
.wla-result-body h4 {
    font-size: 15px;
    color: var(--wla-purple);
    text-transform: none;
    margin: 24px 0 10px;
    padding: 8px 12px;
    background: linear-gradient(90deg, rgba(83,58,253,0.06) 0%, rgba(83,58,253,0) 100%);
    border-left: 3px solid var(--wla-purple);
    border-radius: 0 var(--wla-radius-input) var(--wla-radius-input) 0;
}
.wla-result-body h5 { font-size: 14px; color: var(--wla-label); text-transform: uppercase; letter-spacing: 0.04em; }
.wla-result-body h6 { font-size: 13px; color: var(--wla-body); text-transform: uppercase; letter-spacing: 0.04em; }

.wla-result-body h1:first-child,
.wla-result-body h2:first-child,
.wla-result-body h3:first-child,
.wla-result-body h4:first-child {
    margin-top: 0;
}

.wla-result-body hr {
    border: none;
    border-top: 1px solid var(--wla-border);
    margin: 20px 0;
}

.wla-result-body code {
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
    font-size: 0.9em;
    background: rgba(83,58,253,0.08);
    color: var(--wla-purple-deep);
    padding: 1px 6px;
    border-radius: 3px;
}

.wla-result-body pre.wla-code {
    background: #f6f8ff;
    border: 1px solid var(--wla-purple-soft);
    border-radius: var(--wla-radius-input);
    padding: 12px 14px;
    overflow-x: auto;
    margin: 12px 0;
}

.wla-result-body pre.wla-code code {
    background: none;
    padding: 0;
    color: var(--wla-navy);
    font-size: 13px;
    line-height: 1.55;
}

.wla-result-body a {
    color: var(--wla-purple);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 2px;
}
.wla-result-body a:hover { color: var(--wla-purple-hover); }

.wla-result-body p {
    margin: 0 0 12px;
    color: var(--wla-body);
}

.wla-result-body strong {
    color: var(--wla-navy);
    font-weight: 500;
}

.wla-result-body ul {
    margin: 0 0 16px;
    padding-left: 18px;
    color: var(--wla-body);
}

.wla-result-body li {
    margin-bottom: 6px;
}

.wla-result-body blockquote {
    margin: 16px 0;
    padding: 16px 18px;
    background: #f6f8ff;
    border-left: 3px solid var(--wla-purple);
    border-radius: 0 var(--wla-radius-input) var(--wla-radius-input) 0;
    color: var(--wla-navy);
}

.wla-result-body blockquote p:last-child {
    margin-bottom: 0;
}

.wla-result-cta {
    margin: 28px 0 16px;
    padding: 18px 20px;
    background: linear-gradient(135deg, rgba(83,58,253,0.06) 0%, rgba(249,107,238,0.06) 100%);
    border: 1px solid var(--wla-purple-soft);
    border-radius: var(--wla-radius-card);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.wla-result-cta::before {
    content: "¿Listo para el siguiente paso?";
    font-size: 14px;
    font-weight: 500;
    color: var(--wla-navy);
    flex: 1 1 auto;
    min-width: 0;
}

.wla-btn-cta {
    padding: 10px 18px;
    font-size: 14px;
    text-decoration: none;
    flex-shrink: 0;
    box-shadow: rgba(83,58,253,0.30) 0px 6px 14px -4px;
}

.wla-btn-cta:hover {
    text-decoration: none;
    color: #fff;
}

.wla-btn-arrow {
    display: inline-block;
    margin-left: 4px;
    transition: transform 150ms ease;
}

.wla-btn-cta:hover .wla-btn-arrow {
    transform: translateX(3px);
}

.wla-disclaimer {
    font-size: 11px;
    color: var(--wla-body);
    margin: 16px 0 0;
    line-height: 1.45;
    text-align: center;
    opacity: 0.85;
}

/* Cuando el contenedor está en una sola columna, la zona de scroll necesita un techo */
@container wla (max-width: 759px) {
    .wla-result-scroll {
        max-height: 540px;
    }
}

@container wla (max-width: 540px) {
    .wla-card,
    .wla-result { padding: 20px; }
    .wla-title { font-size: 26px; letter-spacing: -0.26px; }
    .wla-grid { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
    .wla-wrapper { margin: 16px auto; }
}
