/* Tale Ljud Sömlös - Styling v1.8.0 */
/* Färgpalett:
   Grå nyans 1 (mörkaste bakgrund): #121212 
   Grå nyans 2 (elementbakgrund): #242424
   Blå (accent): #0000FF 
   Vit (text): #FFFFFF
   Svart (detaljer): #000000 
   Varningsfärg (radera): #e74c3c 
*/

body.tls-modal-open { overflow: hidden; }

.tls-sagor-container {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 25px;
    margin-bottom: 30px;
}

.tls-saga-item {
    background-color: #242424; color: #FFFFFF; border: 1px solid #000000; 
    border-radius: 8px; padding: 0; box-shadow: 0 5px 15px rgba(0,0,0,0.3); 
    display: flex; flex-direction: column; overflow: hidden; 
    transition: transform 0.2s ease-out, box-shadow 0.2s ease-out;
}
.tls-saga-item:hover { transform: translateY(-5px); box-shadow: 0 8px 25px rgba(0,0,0,0.4); }

img.tls-saga-image {
    width: 100%; height: 200px!important; object-fit: cover; 
    display: block; border-bottom: 1px solid #000000; 
}
.tls-saga-image-placeholder { 
    width: 100%; height: 200px; display: flex; align-items: center; justify-content: center;
    background-color: #333; color: #777; font-size: 0.9em; text-align: center;
    padding: 10px; box-sizing: border-box; border-bottom: 1px solid #000000;
}

.tls-saga-content { padding: 20px; display: flex; flex-direction: column; flex-grow: 1; }
.tls-saga-title {
    font-size: 1.6em; margin-top: 0; margin-bottom: 10px;
    color: #FFFFFF; font-weight: 600; line-height: 1.3;
}
.tls-saga-excerpt {
    font-size: 1em; color: #cccccc; flex-grow: 1; margin-bottom: 15px; line-height: 1.6;
}
.tls-saga-date { font-size: 0.85em; color: #888888; margin-bottom: 20px; }
.tls-saga-actions { display: flex; gap: 12px; margin-top: auto; }

.tls-button { 
    padding: 10px 18px; border: none; border-radius: 6px; cursor: pointer; 
    font-size: 0.95em; font-weight: bold; text-align: center; 
    text-transform: uppercase; letter-spacing: 0.5px;
    transition: background-color 0.2s ease, transform 0.1s ease, box-shadow 0.2s ease;
    box-shadow: 0 2px 4px rgba(0,0,0,0.2); 
}
.tls-button:hover { box-shadow: 0 4px 8px rgba(0,0,0,0.3); }
.tls-button:active { transform: translateY(1px); box-shadow: 0 1px 2px rgba(0,0,0,0.2); }

.tls-play-generate-button { background-color: #0000ff; color: #FFFFFF; }
.tls-play-generate-button:hover { background-color: #0000DD; }
.tls-delete-button { background-color: #3d3d3d; color: #FFFFFF; }
.tls-delete-button:hover { background-color: #4f4f4f; }

.tls-modal {
    display: none; position: fixed; z-index: 10000; 
    left: 0; top: 0; width: 100%; height: 100%; overflow-y: auto; 
    background-color: rgba(0,0,0,0.85); padding: 30px 15px; box-sizing: border-box;
}
.tls-modal-content {
    background-color: #242424; color: #FFFFFF; margin: auto; 
    padding: 30px 35px 35px 35px; border: 1px solid #000000; 
    width: 90%; max-width: 800px; border-radius: 10px; 
    box-shadow: 0 10px 30px rgba(0,0,0,0.5); position: relative; 
    animation: tls-modal-appear 0.3s ease-out; display: flex; 
    flex-direction: column; min-height: 500px; max-height: 90vh; 
}
@keyframes tls-modal-appear {
    from {transform: translateY(-30px) scale(0.98); opacity: 0;}
    to {transform: translateY(0) scale(1); opacity: 1;}
}
.tls-modal-close-button {
    color: #bbbbbb; position: absolute; top: 15px; right: 20px; 
    font-size: 36px; font-weight: bold; line-height: 1; cursor: pointer;
    transition: color 0.2s ease, transform 0.2s ease;
}
.tls-modal-close-button:hover { color: #FFFFFF; transform: rotate(90deg); }
.tls-modal-title {
    margin-top: 0; margin-bottom: 25px; font-size: 2.2em; 
    color: #FFFFFF; padding-right: 40px; font-weight: 600; line-height: 1.3;
}
#tlsModalSagaTextContainer {
    overflow-y: auto; margin-bottom: 25px; padding-right: 15px; 
    font-size: 1.15em; line-height: 1.75; flex-grow: 1; color: #dddddd; 
}
#tlsModalSagaTextContainer p { margin-top: 0; margin-bottom: 1.2em; }
#tlsModalSagaTextContainer p:last-child { margin-bottom: 0; }

.tls-modal-actions-extra {
    display: flex; gap: 12px; margin-bottom: 25px; flex-wrap: wrap; 
}
.tls-modal-actions-extra .tls-button {
    background-color: #3d3d3d; color: #FFFFFF; font-size: 0.9em;
    padding: 8px 15px; text-transform: none; letter-spacing: normal;
}
.tls-modal-actions-extra .tls-button:hover { background-color: #4f4f4f; }

#tlsModalAudioContainer audio.tls-audio-player {
    width: 100%; margin-top: 10px; margin-bottom: 15px; 
}
#tlsModalAudioContainer .tls-button { 
    display: block; width: 100%; padding: 14px; font-size: 1.15em; 
    background: linear-gradient(90deg, #6e00ff, #b300ff); color: #FFFFFF; 
}
#tlsModalAudioContainer .tls-button:hover { background-color: #0000DD; }

.tls-modal-spinner { text-align: center; padding: 25px; width: 100%; }
.tls-gemini-loader {
    display: inline-block; position: relative;
    width: 70px; height: 70px; margin: 0 auto 20px auto;
}
.tls-gemini-loader-star {
    display: flex; align-items: center; justify-content: center;
    font-size: 38px; color: #FFFFFF; /* Vit stjärna */
    width: 100%; height: 100%;
    animation: tls-gemini-star-pulse 1.2s ease-in-out infinite alternate;
}
.tls-gemini-loader::before, .tls-gemini-loader::after {
    content: ""; position: absolute; border-radius: 50%;
    border-style: solid; border-color: transparent; 
    top: 0; left: 0; right: 0; bottom: 0;
}
.tls-gemini-loader::before { 
    border-width: 4px; 
    border-top-color: rgba(255, 255, 255, 0.7); 
    border-left-color: rgba(255, 255, 255, 0.7); 
    animation: tls-gemini-spin 1.5s linear infinite;
}
.tls-gemini-loader::after { 
    border-width: 3px; top: 5px; left: 5px; right: 5px; bottom: 5px; 
    border-bottom-color: rgba(255, 255, 255, 0.4); 
    border-right-color: rgba(255, 255, 255, 0.4); 
    animation: tls-gemini-spin-reverse 1s linear infinite;
}
@keyframes tls-gemini-star-pulse {
    0% { transform: scale(0.9); opacity: 0.8; }
    100% { transform: scale(1.1); opacity: 1; }
}
@keyframes tls-gemini-spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }
@keyframes tls-gemini-spin-reverse { 0% { transform: rotate(0deg); } 100% { transform: rotate(-360deg); } }

.tls-modal-spinner p {
    font-size: 1.2em; color: #FFFFFF; /* Vit text */
    font-weight: 500; margin-top: 10px; 
}

.tls-modal-error, .tls-feedback-message {
    padding: 12px 15px; margin-top: 15px;
    border-radius: 6px; text-align: center; font-size: 0.95em;
}
.tls-modal-error {
    background-color: rgba(231, 76, 60, 0.1); color: #e74c3c; 
    border: 1px solid #e74c3c;
}
/* Länk i felmeddelande (Punkt 1) */
.tls-modal-error a, .tls-feedback-message a, a.tls-buy-credits-link {
    color: #0000FF; /* Blå länkfärg för bättre synlighet mot mörk bakgrund */
    text-decoration: underline;
}
.tls-modal-error a:hover, .tls-feedback-message a:hover, a.tls-buy-credits-link:hover {
    text-decoration: none;
    color: #5555FF; /* Ljusare blå vid hover */
}

.tls-feedback-message.tls-error { 
    background-color: #242424; color: #e74c3c; border: 1px solid #e74c3c;
}
.tls-feedback-message { 
    background-color: transparent; color: #FFFFFF; border: 1px solid #0000FF; padding: 15px;
}

/* Paginering Styling - Uppdaterad för minimalistisk radvy */
.tls-pagination-container { /* Omslutande div för att enklare kunna centrera */
    margin-top: 40px;
    margin-bottom: 30px;
    text-align: center; /* Centrera innehållet i diven */
}
.tls-pagination-container ul.page-numbers { /* Rikta in oss på ul-elementet som paginate_links() skapar */
    list-style: none !important;
    padding: 0 !important;
    margin: 0 auto !important; /* Centrera själva ul-elementet om det har en max-bredd */
    display: inline-block; /* Gör att text-align: center på föräldern fungerar */
}
.tls-pagination-container ul.page-numbers li {
    display: inline-block !important; /* Lägg li-elementen på rad */
    margin: 0 2px !important; /* Lite marginal mellan varje pagineringsdel */
}
.tls-pagination-container .page-numbers {
    display: inline-block;
    padding: 10px 15px;
    border: none; 
    color: #FFFFFF; 
    background-color: transparent; 
    text-decoration: none;
    border-radius: 6px; 
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
    font-size: 0.9em;
    min-width: 40px; 
    box-sizing: border-box;
    line-height: 1.2; /* Förbättra vertikal centrering av text */
}
.tls-pagination-container .page-numbers.current {
    background-color: #fff; 
    color: #000; 
}
.tls-pagination-container .page-numbers.current {
    font-weight: bold; /* Gör aktuell sida tydligare */
}
.tls-pagination-container .page-numbers.dots {
    border: none;
    background-color: transparent;
    color: #FFFFFF; 
    padding: 10px 5px; 
}
.tls-player-error-message { /* Stil för felmeddelande om ljudspelare inte laddar */
    color: #e74c3c;
    font-size: 0.9em;
    margin-top: 5px;
}

/* Nytt för v1.8.8: Styling för "Din saga är redo!"-sektionen med stor Play-ikon */

/* Denna container kommer att ersätta spinnern, eller visas i $modalAudioContainer */
.tls-saga-ready-play-area {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 30px 10px; /* Mer padding för att centrera vertikalt om det är enda innehållet */
    text-align: center;
    opacity: 0; /* Startar osynlig för fade-in */
    width: 100%;
    box-sizing: border-box;
    /* transition sätts via JS .fade-in-fast eller direkt */
}

.tls-big-play-icon {
    width: 80px; /* Storlek på play-ikonens klickområde */
    height: 80px;
    border-radius: 50%;
    background-color: #0000FF; /* Blå bakgrund för ikonen */
    color: #FFFFFF; /* Vit pil */
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    margin-bottom: 15px; /* Space till texten under */
    transition: transform 0.2s ease-out, background-color 0.2s ease;
    box-shadow: 0 4px 12px rgba(0, 0, 255, 0.4); /* Subtil blå skugga */
}

.tls-big-play-icon:hover {
    background-color: #0000DD; /* Mörkare blå */
    transform: scale(1.1);
}
.tls-big-play-icon:active {
    transform: scale(1.0);
}

.tls-big-play-icon svg { /* SVG play-pil */
    width: 45%; /* Storlek på själva pilen inuti cirkeln */
    height: 45%;
    fill: #FFFFFF; /* Vit färg på pilen */
}

.tls-saga-ready-message { /* Texten under play-ikonen */
    font-size: 1.3em; 
    color: #FFFFFF; 
    font-weight: 500;
}

/* Uppdatera spinnerns container för att matcha positioneringen bättre */
/* om "redo"-knappen ska ersätta den visuellt */
/* Du har redan #tlsModalSpinner. Om "redo"-knappen hamnar i $modalAudioContainer, */
/* kanske du vill att $modalAudioContainer är centrerad när den bara innehåller "redo"-knappen. */
/* Detta är en anpassning som kan behövas beroende på hur du vill att det ska se ut. */
/* För nu antar vi att .tls-saga-ready-play-area hanterar sin egen centrering. */

/* Befintlig fade-effekt för spinnern (om du vill ha kvar den från v1.8.7) */
#tlsModalSpinner.fade-out-fast {
    opacity: 0 !important; 
    transition: opacity 0.5s ease-out !important;
}
/* Fade-in för den nya play-knappen (om du vill ha kvar den från v1.8.7) */
.tls-saga-ready-play-area.fade-in-fast {
    opacity: 1 !important; 
    transition: opacity 0.7s ease-in 0.2s !important; /* 0.2s delay */
}

/* Stil för felmeddelande om ljudspelare inte laddar */
.tls-player-error-message {
    color: #e74c3c; 
    font-size: 0.9em;
    text-align: center;
    padding: 10px;
    background-color: rgba(40, 40, 40, 0.7); 
    border-radius: 4px;
    margin-top: 10px;
}