/* AI Story Generator Frontend Styles */



.narratia-form-container {

    max-width: 1100px;

    margin: 2rem auto;

    padding: 2.5rem;

    background: #fff;

    border-radius: 16px;

    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);

    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;

    transition: transform 0.3s ease, box-shadow 0.3s ease;

}



.narratia-form-container:hover {

    transform: translateY(-2px);

    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.12);

}



.narratia-title {

    text-align: center;

    color: #22262a;

    font-size: 30px;

    font-weight: 700;

    margin-bottom: 1rem;

    line-height: 1.2;

}



.narratia-description {

    text-align: center;

    color: #22262a;

    font-size: 1.2rem;

    margin-bottom: 2.5rem;

    line-height: 1.6;

    max-width: 600px;

    margin-left: auto;

    margin-right: auto;

}



.narratia-form-group {

    margin-bottom: 2rem;

    position: relative;

}



.narratia-form-label {

    display: block;

    margin-bottom: 0.75rem;

    font-weight: 600;

    color: #000;

    font-size: 1rem;

    transition: color 0.3s ease;

    position: relative;

    padding-right: 80px;

}



.narratia-result-container{

    display: none;

}



.narratia-form-input,

.narratia-form-select,

.narratia-form-textarea {

    width: 100%;

    padding: 1rem 1.25rem;

    border: 2px solid #d5d9dd;

    border-radius: 12px;

    font-size: 1rem;

    transition: all 0.3s ease;

    background: #fff;

    color: #222;

    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.02);

}



.narratia-form-input:hover,

.narratia-form-select:hover,

.narratia-form-textarea:hover {

    border-color: #7a0de7;

    background: #fff;

}



form.narratia-form {

    margin-top: 20px;

}



.narratia-form-textarea {

    min-height: 150px;

    resize: vertical;

    font-family: inherit;

    line-height: 1.6;

}



.narratia-creativity-container {

    position: relative;

}



.narratia-creativity-slider {

    width: 100%;

    height: 4px;

    background: linear-gradient(to right, #e5cffc, #efb7fb);

    outline: none;

    appearance: none;

    transition: all 0.3s ease;

    position: relative;

    border-radius: 10px;

    border: none;

}



.narratia-creativity-slider:hover {

    background: linear-gradient(to right, #d9b7fb, #ea9ff9);

}



.narratia-creativity-slider::-webkit-slider-thumb {

    -webkit-appearance: none;

    appearance: none;

    width: 0;

    height: 0;

    background: transparent;

    border: none;

    box-shadow: none;

}



.narratia-creativity-slider::-moz-range-thumb {

    width: 0;

    height: 0;

    background: transparent;

    border: none;

    box-shadow: none;

}



.narratia-creativity-slider::-webkit-slider-runnable-track {

    width: 100%;

    height: 4px;

    cursor: pointer;

    border-radius: 2px;

    border: none;

}



.narratia-creativity-slider::-moz-range-track {

    width: 100%;

    height: 4px;

    cursor: pointer;

    border-radius: 2px;

    border: none;

}



.narratia-creativity-labels {

    display: flex;

    justify-content: space-between;

    margin-top: 0px;

    font-size: 0.9rem;

    color: #808c99;

    font-weight: 500;

}



.narratia-creativity-value {

    position: absolute;

    right: 0;

    top: -20px;

    transform: translateY(-50%);

    font-weight: 600;

    color: #7a0de7;

    font-size: 0.9rem;

    padding: 1px 15px;

    background: #7a0de71a;

    border-radius: 6px;

    display: inline-block;

}



.narratia-advanced-settings {

    border: 2px solid #d5d9dd;

    border-radius: 12px;

    padding: 1.5rem;

    margin-bottom: 2rem;

    background: #fff;

    color: #000;

    transition: all 0.3s ease;

}



.narratia-advanced-settings:hover {

    border-color: #7a0de7;

    background: #fff;

}



.narratia-advanced-toggle {

    background: none;

    border: none;

    font-size: 1.1rem;

    font-weight: 600;

    background: #fff;

    color: #000;

    cursor: pointer;

    display: flex;

    align-items: center;

    gap: 0.75rem;

    margin-bottom: 0px;

    padding: 0;

    transition: all 0.3s ease;

}



.narratia-advanced-content {

    margin-top: 20px;

}



.narratia-advanced-toggle:hover {

    color: #7a0de7;

    transform: translateX(4px);

}



.narratia-advanced-toggle::after {

    content: '▼';

    font-size: 0.8rem;

    transition: transform 0.3s ease;

}



.narratia-advanced-toggle.collapsed::after {

    transform: rotate(-90deg);

}



.narratia-advanced-content {

    display: block;

    animation: slideDown 0.4s ease;

}



.narratia-advanced-content.hidden {

    display: none;

}



@keyframes slideDown {

    from {

        opacity: 0;

        transform: translateY(-10px);

    }

    to {

        opacity: 1;

        transform: translateY(0);

    }

}



.narratia-generate-btn {

    width: 100%;

    padding: 1.25rem 2rem;

    background: linear-gradient(135deg, #7a0de7, #8e0aa9) !important;

    color: #fff;

    border: none;

    border-radius: 12px;

    font-size: 1.2rem;

    font-weight: 600;

    cursor: pointer;

    transition: all 0.3s ease;

    text-transform: uppercase;

    letter-spacing: 0.5px;

    position: relative;

    overflow: hidden;

}



.narratia-generate-btn::before {

    content: '';

    position: absolute;

    top: 0;

    left: -100%;

    width: 100%;

    height: 100%;

    background: linear-gradient(

        90deg,

        transparent,

        rgba(255, 255, 255, 0.2),

        transparent

    );

    transition: 0.5s;

}



.narratia-generate-btn:hover {

    background: linear-gradient(135deg, #660bc1, #7a0891);

    transform: translateY(-2px);

    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);

}



.narratia-generate-btn:hover::before {

    left: 100%;

}



.narratia-generate-btn:active {

    transform: translateY(0);

}



.narratia-generate-btn:disabled {

    background: #bfc5ca;

    cursor: not-allowed;

    transform: none;

    box-shadow: none;

}



.narratia-loading {

    display: flex;

    align-items: center;

    justify-content: center;

    gap: 1rem;

}



.narratia-loading-spinner {

    width: 24px;

    height: 24px;

    border: 3px solid transparent;

    border-top: 3px solid #ffffff;

    border-radius: 50%;

    animation: spin 1s linear infinite;

}



@keyframes spin {

    0% { transform: rotate(0deg); }

    100% { transform: rotate(360deg); }

}



.narratia-result-container {

    margin-top: 2.5rem;

    padding: 2rem;

    background: #f9fafb;

    border-radius: 12px;

    border-left: 4px solid #6a00ff;

    animation: fadeIn 0.5s ease;

}



@keyframes fadeIn {

    from {

        opacity: 0;

        transform: translateY(10px);

    }

    to {

        opacity: 1;

        transform: translateY(0);

    }

}



.narratia-result-title {

    font-size: 1.4rem;

    font-weight: 600;

    color: #23272a;

    margin-bottom: 1.25rem;

    display: flex;

    align-items: center;

    gap: 0.75rem;

}



.narratia-result-title::before {

    content: '📖';

    font-size: 1.3rem;

}



.narratia-result-story {

    font-size: 1.1rem;

    line-height: 1.8;

    color: #3b4146;

    white-space: pre-wrap;

    word-wrap: break-word;

}



.narratia-result-meta {

    margin-top: 1.5rem;

    padding-top: 1.5rem;

    border-top: 1px solid #d9dde0;

    font-size: 0.95rem;

    color: #8c949b;

}



.narratia-error-message {

    background: #ffe5e5;

    color: #992a2a;

    padding: 1.25rem;

    border-radius: 12px;

    border-left: 4px solid #d93232;

    margin-top: 1.5rem;

    animation: shake 0.5s ease;

}



@keyframes shake {

    0%, 100% { transform: translateX(0); }

    25% { transform: translateX(-5px); }

    75% { transform: translateX(5px); }

}



.narratia-character-count {

    text-align: right;

    font-size: 0.9rem;

    color: #8c949b;

    margin-top: 0.5rem;

    transition: color 0.3s ease;

}



.narratia-character-count.warning {

    color: #ff6d00;

}



.narratia-character-count.error {

    color: #d93232;

}



/* Responsive Design */

@media (max-width: 768px) {

    .narratia-form-container {

        padding: 1.5rem;

        margin: 1rem;

    }

    

    .narratia-title {

        font-size: 2rem;

    }

    

    .narratia-description {

        font-size: 1.1rem;

    }

    

    .narratia-form-input,

    .narratia-form-select,

    .narratia-form-textarea {

        padding: 0.875rem 1rem;

        font-size: 16px;

    }

    

    .narratia-generate-btn {

        padding: 1rem 1.5rem;

        font-size: 1.1rem;

    }

}


/* Elementor Widget Specific Styles */

.narratia-elementor-widget .narratia-title {

    margin-top: 0;

}



/* Preview Notice for Elementor Editor */

.narratia-preview-notice {

    text-align: center;

    padding: 40px 20px;

    background: #f4f5f6;        /* hsl(210 11% 96%) */

    border: 2px dashed #c7ccd1; /* hsl(210 11% 80%) */

    border-radius: 8px;

    color: #8c949b;             /* hsl(210 11% 55%) */

}



.narratia-preview-notice p {

    margin: 0;

    font-style: italic;

}

