:root {
    --e34-bg: #f5f4f1;
    --e34-card: #ffffff;
    --e34-text: #1f1f1f;
    --e34-muted: #6d6d6d;
    --e34-border: #ddd7ce;
    --e34-accent: #8e1f1f;
    --e34-dark: #101010;
    --e34-soft: #ebe7df;
}

body {
    background: var(--e34-bg);
    color: var(--e34-text);
    font-family: Georgia, "Times New Roman", serif;
}

.bg-page {
    background:
        radial-gradient(circle at top right, rgba(142, 31, 31, 0.08), transparent 25%),
        linear-gradient(180deg, #faf9f7 0%, #f5f4f1 100%);
}

.brand-mark {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    background: var(--e34-dark);
    color: #fff;
    display: grid;
    place-items: center;
    font-weight: 700;
    font-size: 1.4rem;
}

.brand-name {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}

.brand-sub {
    color: var(--e34-muted);
    font-size: 0.95rem;
}

.search-box {
    width: min(100%, 640px);
}

.navbar {
    background: rgba(255,255,255,0.88);
    backdrop-filter: blur(12px);
}

.nav-link {
    color: var(--e34-text) !important;
    font-weight: 600;
}

.shipping-bar {
    background: #fff8ef;
    border: 1px solid #f0d8b4;
    border-radius: 18px;
    padding: 0.95rem 1.1rem;
    display: flex;
    align-items: center;
    gap: .75rem;
    font-weight: 600;
}

.hero-card,
.content-card {
    background: rgba(255,255,255,0.92);
    border: 1px solid var(--e34-border);
    border-radius: 28px;
    box-shadow: 0 12px 36px rgba(0,0,0,0.06);
}

.hero-card {
    overflow: hidden;
}

#heroBannerCarousel .carousel-control-prev,
#heroBannerCarousel .carousel-control-next {
    width: 32px;
    opacity: 0.5;
}

#heroBannerCarousel .carousel-control-prev { left: 0; }
#heroBannerCarousel .carousel-control-next { right: 0; }

#heroBannerCarousel .carousel-control-prev:hover,
#heroBannerCarousel .carousel-control-next:hover {
    opacity: 1;
}

.hero-book {
    max-height: 360px;
    border-radius: 16px;
    box-shadow: 0 14px 28px rgba(0,0,0,0.18);
}

.eyebrow,
.section-kicker {
    text-transform: uppercase;
    letter-spacing: .12em;
    font-size: .78rem;
    color: var(--e34-accent);
    font-weight: 700;
}

.news-list li + li,
.reprint-list li + li {
    margin-top: .9rem;
}

.news-list a,
.footer-34 a,
.quick-link,
.reprint-list li {
    color: var(--e34-text);
    text-decoration: none;
}

.news-list a:hover,
.quick-link:hover {
    color: var(--e34-accent);
}

.quick-link {
    display: flex;
    align-items: center;
    gap: .8rem;
    padding: .8rem .95rem;
    border-radius: 14px;
    background: var(--e34-soft);
    transition: transform .15s ease, box-shadow .15s ease;
}

.quick-link:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(0,0,0,0.06);
}

.book-card {
    border-radius: 24px;
    overflow: hidden;
}

.book-cover-wrap {
    background: linear-gradient(180deg, #f4efe7 0%, #faf8f5 100%);
    padding: 1.5rem 1rem 1rem;
}

.book-cover {
    max-height: 260px;
    border-radius: 12px;
    box-shadow: 0 10px 22px rgba(0,0,0,0.14);
}

.availability {
    display: inline-flex;
    width: fit-content;
    border-radius: 999px;
    background: #f1ede7;
    padding: .32rem .7rem;
    font-size: .82rem;
    font-weight: 700;
}

.price-box {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem .8rem;
    align-items: center;
}

.old-price {
    text-decoration: line-through;
    color: var(--e34-muted);
}

.current-price {
    font-size: 1.35rem;
    font-weight: 700;
}

.feature-item {
    display: flex;
    align-items: flex-start;
    gap: .9rem;
    padding: 1rem;
    border-radius: 18px;
    background: var(--e34-soft);
    height: 100%;
}

.feature-item i {
    font-size: 1.15rem;
    color: var(--e34-accent);
}

.reprint-list {
    padding-left: 1.2rem;
}

.footer-34 {
    background: #121212;
}

.footer-title {
    color: #fff;
    font-weight: 700;
    margin-bottom: .85rem;
}

.footer-34 a {
    color: rgba(255,255,255,0.82);
}

.footer-34 a:hover {
    color: #fff;
}

.shadow-sm-sm {
    box-shadow: 0 2px 10px rgba(0,0,0,.04);
}

.breadcrumb-e34 {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.25rem 0.5rem;
    font-size: 0.8rem;
}

.breadcrumb-e34 a {
    color: var(--e34-muted);
    text-decoration: none;
    transition: color 0.15s;
}

.breadcrumb-e34 a:hover {
    color: var(--e34-accent);
}

.breadcrumb-e34 i {
    color: var(--e34-border);
    font-size: 0.65rem;
}

.breadcrumb-e34 span {
    color: var(--e34-text);
    font-weight: 600;
}

.hover-bg {
    transition: background 0.15s;
}

.hover-bg:hover {
    background: var(--e34-soft) !important;
}

@media (max-width: 991.98px) {
    .brand-name {
        font-size: 1.35rem;
    }

    .search-box {
        width: 100%;
    }
}
