body {
    font-family: "Lexend", sans-serif;
    background: #F9F7F3;
    color: #111418;
}

.bg-dark-mode {
    background: #111921 !important;
    color: #F9F7F3 !important;
}

.primary      { color: #003366 !important; }
.bg-primary-c { background-color: #003366 !important; }
.accent       { background-color: #E8A87C !important; color:#003366 !important; }

.search-icon {
    font-variation-settings: 'FILL' 0;
}

.book-card img:hover {
    transform: scale(1.05);
}

.book-card img {
    transition: transform .3s ease;
}

.login-card, .register-card {
    border-radius: 1rem;
    background: white;
    box-shadow: 0 0 20px rgba(0,0,0,0.08);
}

.login-card {
    max-width: 420px;
    margin: 60px auto;
    padding: 25px;
}

.register-card {
    max-width: 520px;
    margin: 40px auto;
    padding: 30px;
}

.bg-cover{
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.badge.rounded-pill { padding: .35rem .6rem; }

.material-symbols-outlined {
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}
.icon-filled {
    font-variation-settings: 'FILL' 1;
}

.book-cover {
    width: 112px;
    height: 160px;
    object-fit: cover;
}

/* Cover ratios (Tailwind aspect-[2/3] helyett) */
.cover-2x3 {
    aspect-ratio: 2 / 3;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    width: 100%;
}

/* Kicsit “kártyásabb” érzet */
.shadow-soft { box-shadow: 0 .25rem 1rem rgba(0,0,0,.08) !important; }
.shadow-strong { box-shadow: 0 1rem 3rem rgba(0,0,0,.20) !important; }

/* Related books: finom hover */
.hover-shadow:hover { box-shadow: 0 .75rem 1.75rem rgba(0,0,0,.14) !important; }