/* 3. Stile personalizzato per applicare i font */
body {
    font-family: 'Inter', sans-serif;
    background-color: #1a1a1a; /* Sfondo scuro per il tema */
    color: #e0e0e0; /* Testo grigio chiaro */
}

a,
a:visited {
    text-decoration: none;
    color: inherit;
}

.ml-4 { margin-left: 1rem; } /* 16px */

/* Font "fantasy" per i titoli */
h1, h2, h3, h4, h5, h6, .font-fantasy {
    font-family: 'Cinzel', serif;
    font-weight: 600;
}

/* Stile per i bottoni principali */
.btn {
    background-color: #D97706; /* bg-yellow-600 */
    color: #1F2937; /* text-gray-900 */
    font-weight: 700;
    padding: 0.5rem 1rem;
    border-radius: 0.5rem !important;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.06);
    transition: all 0.3s;
}
.btn:hover {
    background-color: #FBBF24; /* hover:bg-yellow-500 */
}

.btn-logout {
    background-color: #EF4444; /* Tailwind red-500 */
    color: #FFFFFF; /* White text */
    font-weight: 700;
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.06);
    transition: all 0.3s;
    display: flex;
    align-items: center;
    justify-content: center;
}
.btn-logout:hover {
    background-color: #DC2626; /* Tailwind red-600 */
}
.btn-logout i {
    margin-right: 0.5rem; /* Space between icon and text if text is added later */
}

/* Stile per i link di navigazione */
.nav-link {
    font-size: 1.125rem; /* text-lg */
    font-family: 'Cinzel', serif; /* font-fantasy */
    color: #FFFFFF; /* text-white */
    transition: all 0.3s;
    padding: 0.5rem 0.75rem; /* px-3 py-2 */
    border-radius: 0.375rem; /* rounded-md */
    cursor: pointer;
    text-decoration: none;
}
.nav-link:hover {
    color: #FACC15; /* hover:text-yellow-400 */
}

/* Stile per la pagina "attiva" */
.nav-link.active {
    color: #FACC15; /* text-yellow-400 */
}

/* Stili per i campi di input */
.form-input {
    width: 100%;
    padding: 0.5rem 0.75rem;
    background-color: #1F2937; /* bg-gray-800 */
    border: 1px solid #374151; /* border-gray-700 */
    border-radius: 0.5rem; /* rounded-lg */
    color: #FFFFFF; /* text-white */
}
.form-input:focus {
    outline: none;
    box-shadow: 0 0 0 2px #FBBF24; /* focus:ring-2 focus:ring-yellow-500 */
}

.form-input-readonly {
    width: 100%;
    padding: 0.5rem 0.75rem;
    background-color: #374151; /* bg-gray-700 */
    border: 1px solid #4B5563; /* border-gray-600 */
    border-radius: 0.5rem; /* rounded-lg */
    color: #D1D5DB; /* text-gray-300 */
    cursor: not-allowed;
}

.form-label {
    display: block;
    font-size: 0.875rem; /* text-sm */
    font-weight: 500; /* font-medium */
    color: #FACC15; /* text-yellow-400 */
    margin-bottom: 0.25rem; /* mb-1 */
}

/* Usiamo flexbox per il layout principale */
body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

header {
    transition: background-color 0.3s ease-in-out;
}

header.scrolled {
    background-color: #1f2937; /* bg-gray-800 */
}

main {
    flex-grow: 1;
}

/* Utility classes from Tailwind */
.container {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding-left: 1rem;
    padding-right: 1rem;
}

@media (min-width: 640px) {
    .container {
        max-width: 640px;
        padding-left: 2rem;
        padding-right: 2rem;
    }
}
@media (min-width: 768px) {
    .container {
        max-width: 768px;
    }
    .md\:p-8 {
        padding: 2rem;
    }
}
@media (min-width: 1024px) {
    .container {
        max-width: 1024px;
    }
}
@media (min-width: 1280px) {
    .container {
        max-width: 1280px;
    }
}

.mx-auto { margin-left: auto; margin-right: auto; }
.p-4 { padding: 1rem; }
.p-8 { padding: 2rem; }
.py-3 { padding-top: 0.75rem; padding-bottom: 0.75rem; }
.px-4 { padding-left: 1rem; padding-right: 1rem; }
.flex { display: flex; }
.justify-between { justify-content: space-between; }
.items-center { align-items: center; }
.space-x-2 > :not([hidden]) ~ :not([hidden]) { margin-left: 0.5rem; }
.text-3xl { font-size: 1.875rem; }
.text-white { color: #fff; }
.text-yellow-500 { color: #f59e0b; }
.bg-gray-900 { background-color: #111827; }
.bg-opacity-80 { background-color: rgba(17, 24, 39, 0.8); }
.backdrop-blur-md { backdrop-filter: blur(12px); }
.shadow-lg { box-shadow: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -2px rgba(0,0,0,0.05); }
.sticky { position: sticky; }
.top-0 { top: 0; }
.z-50 { z-index: 50; }

/* Compendio and Regolamento Search Input Legibility */
#compendio-search,
#regolamento-search {
    color: #FFFFFF; /* Ensure text is white */
    background-color: #1F2937; /* Darker background for contrast */
    border: 1px solid #374151;
    width: 100%; /* Fixed width */
    display: block; /* Ensure margin auto works */
}

#compendio-search::placeholder,
#regolamento-search::placeholder {
    color: #9CA3AF; /* Light gray for placeholder */
    opacity: 1; /* Firefox default opacity is lower */
    font-size: 0.9em; /* Make placeholder text slightly smaller */
}

/* Spacing under skills */
.compendio-abilita-blocco {
    margin-bottom: 10px; /* Add 10px space below each skill block */
}

/* Make compendio-lettera-titolo bigger */
.compendio-lettera-titolo {
    font-size: 2.5rem; /* Example: make it significantly larger */
    font-weight: bold;
    color: #FACC15; /* Example: make it yellow for emphasis */
}

/* Regolamento Page Styles */
#regolamento-container {
    margin-top: 2rem;
}

.regolamento-blocco {
    margin-bottom: 2rem;
    padding: 1.5rem;
    background-color: rgba(0,0,0,0.2);
    border-radius: 0.5rem;
    border: 1px solid #374151;
}

/* Custom list styles */
.ck-content ul {
    list-style-type: none;
    padding-left: 0;
}

.ck-content ul li {
    position: relative;
    padding-left: 1em;
    margin-bottom: 0.5em;
}

.ck-content ul li::before {
    content: "\27A4"; /* Right arrow */
    color: #FACC15; /* text-yellow-400 */
    font-weight: bold;
    display: inline-block;
    width: 1em;
    position: absolute;
    left: 0;
    margin-left: -0.2em;
}

.compendio-sticky-nav {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding: 1rem;
    background-color: rgba(17, 24, 39, 0.8);
    border-radius: 0.5rem;
    margin-bottom: 1rem;
    position: sticky;
    top: 1rem;
    z-index: 10;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.compendio-sticky-nav a {
    color: #FBBF24;
    font-weight: bold;
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
    transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
}

.compendio-sticky-nav a:hover {
    background-color: #FBBF24;
    color: #111827;
}

.compendio-sticky-nav span {
    color: #4B5563;
    font-weight: bold;
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
}

#audio-player-container {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

#audio-controls button {
    background-color: transparent;
    color: #FBBF24;
    border: none;
    padding: 0.5rem;
    border-radius: 50%;
    cursor: pointer;
    font-size: 1.5rem;
    width: 40px;
    height: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
}

#audio-controls button:hover {
    background-color: rgba(251, 191, 36, 0.2);
}

/* ===== TAIKA AI WIDGET STYLES ===== */

#taika-log {
    background-color: #111827; /* bg-gray-900 */
    display: flex;
    flex-direction: column;
    gap: 0.75rem; /* space-y-3 */
    scrollbar-width: thin;
    scrollbar-color: #E83F8C #3f3f3f;
}

#taika-log::-webkit-scrollbar {
    width: 8px;
}

#taika-log::-webkit-scrollbar-track {
    background: #3f3f3f;
}

#taika-log::-webkit-scrollbar-thumb {
    background-color: #E83F8C;
    border-radius: 4px;
}

.taika-message-container {
    display: flex;
    width: 100%;
}

.taika-message-container.user {
    justify-content: flex-end;
}

.taika-message {
    padding: 0.75rem 1rem;
    border-radius: 1rem;
    line-height: 1.5;
    max-width: 80%;
    width: fit-content;
}

.taika-message.user {
    background-color: #E83F8C; /* bg-pink-600 */
    color: white;
    border-bottom-right-radius: 0.25rem;
    text-align: right;
}



.taika-message.taika {

    background-color: #3f3f3f; /* bg-gray-700 */

    color: #f0f0f0;

    border-bottom-left-radius: 0.25rem;

}















/* Force Google's Noto Color Emoji font */







.taika-avatar-emoji {







    font-family: 'Noto Color Emoji', sans-serif;







}















@media (max-width: 640px) {







    .btn-responsive {







        padding: 0.5rem 0.75rem;







        font-size: 0.875rem;







        white-space: nowrap;







    }







}












