/* ============================
   TYPOGRAPHY
============================ */

h1,h2,h3,h4,h5,h6{
    font-weight:700;
    line-height:1.2;
    color:#fff;
}

p{
    color:var(--muted);
    line-height:1.8;
    margin-bottom:1.25rem;
}

p:last-child{ margin-bottom:0; }

.prose h2{ font-size:26px; margin:2rem 0 1rem; color:#fff; }
.prose h3{ font-size:20px; margin:1.5rem 0 .75rem; color:#fff; }
.prose ul,.prose ol{ padding-left:1.5rem; margin-bottom:1.25rem; color:var(--muted); line-height:1.9; }
.prose blockquote{
    border-left:3px solid var(--accent);
    padding:.75rem 1.25rem;
    margin:1.5rem 0;
    background:rgba(124,92,255,.07);
    border-radius:0 12px 12px 0;
    color:#c7c9d3;
    font-style:italic;
}

/* ============================
   PAGE HERO BANNER (archives)
============================ */

.archive-hero{
    padding:60px 0 40px;
    border-bottom:1px solid var(--border);
    margin-bottom:40px;
}

.archive-hero-inner{
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:30px;
    flex-wrap:wrap;
}

.archive-hero-title{
    font-size:48px;
    font-weight:800;
    background:linear-gradient(135deg,#fff 40%,var(--accent));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
    margin-bottom:8px;
}

.archive-hero-meta{
    color:var(--muted);
    font-size:15px;
}

.archive-count-pill{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:10px 20px;
    border-radius:999px;
    background:rgba(124,92,255,.12);
    border:1px solid rgba(124,92,255,.3);
    color:var(--accent);
    font-weight:700;
    font-size:15px;
    white-space:nowrap;
}

/* ============================
   FILTER BAR
============================ */

.filter-bar{
    display:flex;
    align-items:center;
    gap:14px;
    flex-wrap:wrap;
    margin-bottom:36px;
    padding:18px 24px;
    background:#171B26;
    border:1px solid var(--border);
    border-radius:18px;
}

.filter-bar-label{
    font-size:13px;
    font-weight:700;
    color:var(--muted);
    text-transform:uppercase;
    letter-spacing:.6px;
    white-space:nowrap;
}

.filter-select{
    flex:1;
    min-width:180px;
    padding:10px 16px;
    background:#0F1117;
    border:1px solid var(--border);
    border-radius:12px;
    color:#fff;
    font-size:14px;
    font-family:Inter,sans-serif;
    appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237C5CFF' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat:no-repeat;
    background-position:right 14px center;
    padding-right:36px;
    cursor:pointer;
    transition:.2s;
}

.filter-select:focus{
    outline:none;
    border-color:var(--accent);
    box-shadow:0 0 0 3px rgba(124,92,255,.18);
}

.filter-tag-group{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
}

.filter-tag{
    padding:8px 16px;
    border-radius:999px;
    border:1px solid var(--border);
    background:transparent;
    color:var(--muted);
    font-size:13px;
    font-weight:600;
    cursor:pointer;
    transition:.2s;
    text-decoration:none;
    display:inline-flex;
}

.filter-tag:hover,.filter-tag.active{
    background:var(--accent);
    border-color:var(--accent);
    color:#fff;
}

.filter-apply-btn{
    padding:10px 22px;
    border-radius:12px;
    background:var(--accent);
    color:#fff;
    font-weight:700;
    font-size:14px;
    border:none;
    cursor:pointer;
    transition:.2s;
    white-space:nowrap;
}

.filter-apply-btn:hover{
    background:#6a4ae8;
}

.filter-clear{
    font-size:13px;
    color:var(--muted);
    text-decoration:underline;
    white-space:nowrap;
}

.filter-clear:hover{ color:#fff; }

/* ============================
   ARCHIVE GRID (premium cards)
============================ */

.archive-grid-4{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
    gap:24px;
}

.archive-grid-3{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
    gap:24px;
}

/* Premium card */
.pcard{
    background:#171B26;
    border:1px solid var(--border);
    border-radius:20px;
    overflow:hidden;
    transition:.3s;
    position:relative;
    display:flex;
    flex-direction:column;
}

.pcard:hover{
    border-color:var(--accent);
    transform:translateY(-5px);
    box-shadow:0 20px 50px rgba(124,92,255,.25);
}

.pcard-thumb{
    width:100%;
    aspect-ratio:2/3;
    overflow:hidden;
    background:linear-gradient(135deg,#1B2030,#0F1117);
    position:relative;
}

.pcard-thumb.pcard-thumb-wide{
    aspect-ratio:16/9;
}

.pcard-thumb img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:.4s;
}

.pcard:hover .pcard-thumb img{
    transform:scale(1.05);
}

.pcard-badges{
    position:absolute;
    top:10px;
    left:10px;
    display:flex;
    gap:6px;
    flex-wrap:wrap;
}

.pcard-badge{
    padding:4px 10px;
    border-radius:999px;
    font-size:11px;
    font-weight:700;
    backdrop-filter:blur(8px);
}

.pcard-badge-type{
    background:rgba(124,92,255,.75);
    color:#fff;
}

.pcard-badge-status-airing{
    background:rgba(16,185,129,.75);
    color:#fff;
}

.pcard-badge-filler{
    background:rgba(245,158,11,.75);
    color:#0F1117;
}

.pcard-badge-canon{
    background:rgba(16,185,129,.75);
    color:#fff;
}

.pcard-rating{
    position:absolute;
    bottom:10px;
    right:10px;
    display:flex;
    align-items:center;
    gap:4px;
    padding:5px 10px;
    border-radius:999px;
    background:rgba(15,17,23,.85);
    backdrop-filter:blur(8px);
    color:#FFD54A;
    font-size:13px;
    font-weight:700;
}

.pcard-body{
    padding:16px 18px;
    flex:1;
    display:flex;
    flex-direction:column;
    gap:6px;
}

.pcard-title{
    font-size:15px;
    font-weight:700;
    color:#fff;
    line-height:1.35;
    overflow:hidden;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
}

.pcard-meta{
    font-size:13px;
    color:var(--muted);
    display:flex;
    align-items:center;
    gap:8px;
    flex-wrap:wrap;
}

.pcard-meta-dot{
    width:3px;
    height:3px;
    border-radius:50%;
    background:var(--border);
    display:inline-block;
}

.pcard-genres{
    display:flex;
    gap:6px;
    flex-wrap:wrap;
    margin-top:2px;
}

.pcard-genre{
    font-size:11px;
    font-weight:600;
    padding:3px 9px;
    border-radius:999px;
    background:rgba(124,92,255,.12);
    color:var(--accent);
    border:1px solid rgba(124,92,255,.2);
}

/* List row view (episode/release) */
.archive-list{
    display:flex;
    flex-direction:column;
    background:#171B26;
    border:1px solid var(--border);
    border-radius:20px;
    overflow:hidden;
}

.archive-list-head{
    display:grid;
    padding:14px 24px;
    font-size:12px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.6px;
    color:var(--muted);
    border-bottom:1px solid var(--border);
}

.archive-list-row{
    display:grid;
    padding:16px 24px;
    align-items:center;
    border-bottom:1px solid var(--border);
    color:#fff;
    transition:.2s;
    text-decoration:none;
}

.archive-list-row:last-child{ border-bottom:none; }

.archive-list-row:hover{ background:#1B2030; }

/* ============================
   PAGINATION
============================ */

.archive-pagination{
    display:flex;
    justify-content:center;
    gap:8px;
    margin-top:50px;
    flex-wrap:wrap;
}

.archive-pagination .page-numbers{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:42px;
    height:42px;
    border-radius:12px;
    background:#171B26;
    border:1px solid var(--border);
    color:#fff;
    font-weight:600;
    font-size:14px;
    transition:.2s;
}

.archive-pagination .page-numbers:hover,
.archive-pagination .page-numbers.current{
    background:var(--accent);
    border-color:var(--accent);
}

.archive-pagination .page-numbers.dots{
    background:transparent;
    border-color:transparent;
}

/* ============================
   SECTION TITLE (shared)
============================ */

.section-heading{
    display:flex;
    align-items:center;
    gap:14px;
    margin-bottom:28px;
}

.section-heading-text{
    font-size:26px;
    font-weight:800;
    color:#fff;
}

.section-heading-bar{
    flex:1;
    height:1px;
    background:var(--border);
}

.section-heading-link{
    font-size:14px;
    font-weight:600;
    color:var(--accent);
}

/* ============================
   ANIME CONTEXT BANNER
   (shown on filtered archives)
============================ */

.anime-context-banner{
    display:flex;
    align-items:center;
    gap:20px;
    padding:20px 24px;
    background:#171B26;
    border:1px solid rgba(124,92,255,.3);
    border-radius:18px;
    margin-bottom:32px;
}

.anime-context-thumb{
    width:54px;
    height:72px;
    border-radius:10px;
    overflow:hidden;
    flex-shrink:0;
}

.anime-context-thumb img{
    width:100%;
    height:100%;
    object-fit:cover;
}

.anime-context-info{
    flex:1;
    min-width:0;
}

.anime-context-label{
    font-size:12px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.5px;
    color:var(--accent);
    margin-bottom:4px;
}

.anime-context-title{
    font-size:20px;
    font-weight:700;
    color:#fff;
}

.anime-context-back{
    padding:10px 18px;
    border-radius:12px;
    background:rgba(124,92,255,.12);
    border:1px solid rgba(124,92,255,.3);
    color:var(--accent);
    font-weight:600;
    font-size:14px;
    white-space:nowrap;
}

.anime-context-back:hover{
    background:var(--accent);
    color:#fff;
}

/* ============================
   RESPONSIVE
============================ */

@media(max-width:768px){

    .archive-hero-title{ font-size:34px; }

    .filter-bar{ gap:10px; }

    .archive-grid-4{
        grid-template-columns:repeat(2,1fr);
        gap:14px;
    }

    .archive-grid-3{
        grid-template-columns:1fr;
    }

}

@media(max-width:480px){

    .archive-hero-title{ font-size:26px; }

    .archive-grid-4{
        grid-template-columns:repeat(2,1fr);
        gap:10px;
    }

}
