/* ============================================================
   BizarreReads — JoJo's Bizarre Adventure Design System
   "A work so bizarre, only the finest CSS can contain it."
   ============================================================ */

/* --- Reset --- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; overflow-x: hidden; }

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
    /* Backgrounds — deep purple-blacks */
    --bg:       #050208;
    --surface:  #0a0612;
    --card:     #100918;
    --elevated: #180f24;
    --hover:    #201530;

    /* Borders — gold-tinted */
    --border:    rgba(212,168,39,0.10);
    --border-md: rgba(212,168,39,0.22);
    --border-hi: rgba(212,168,39,0.50);

    /* Gold — primary accent (Araki's gilded world) */
    --gold:      #d4a827;
    --gold-h:    #f2c440;
    --gold-dim:  rgba(212,168,39,0.10);
    --gold-glow: rgba(212,168,39,0.28);

    /* Magenta — Araki's signature pop */
    --pink:      #b8215f;
    --pink-h:    #d4276e;
    --pink-dim:  rgba(184,33,95,0.13);
    --pink-glow: rgba(184,33,95,0.25);

    /* Stand purple */
    --purple:     #7b2fff;
    --purple-dim: rgba(123,47,255,0.14);

    /* Aliases */
    --accent:      var(--gold);
    --accent-h:    var(--gold-h);
    --accent-dim:  var(--gold-dim);
    --accent-glow: var(--gold-glow);

    /* Text */
    --text:      #f2eafa;
    --text-sec:  #9a87b5;
    --text-mute: #4a3a60;

    /* Typography */
    --font-display: 'Bebas Neue', 'Impact', system-ui, sans-serif;
    --font-body:    'Syne', system-ui, sans-serif;

    /* Shape */
    --r:    6px;
    --r-sm: 3px;
    --r-lg: 10px;

    /* Easing */
    --ease-out:    cubic-bezier(.22,1,.36,1);
    --ease-bounce: cubic-bezier(.34,1.56,.64,1);
}

/* ============================================================
   BASE
   ============================================================ */
body {
    background-color: var(--bg);
    color: var(--text);
    font-family: var(--font-body);
    font-size: 1rem;
    line-height: 1.65;
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
    /* Manga halftone dot texture */
    background-image:
        radial-gradient(circle, rgba(212,168,39,0.030) 1px, transparent 1px),
        radial-gradient(circle, rgba(123,47,255,0.018) 1px, transparent 1px);
    background-size: 28px 28px, 14px 14px;
    background-position: 0 0, 7px 7px;
}

a  { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }

::selection { background: var(--gold); color: #000; }

::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--surface); }
::-webkit-scrollbar-thumb { background: rgba(212,168,39,0.3); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: var(--gold); }

/* ============================================================
   LAYOUT UTILITIES
   ============================================================ */
.container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 clamp(1rem, 4vw, 2.5rem);
}

/* ============================================================
   NAVBAR
   ============================================================ */
.navbar {
    position: sticky;
    top: 0;
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 60px;
    padding: 0 clamp(1rem, 4vw, 3rem);
    background: rgba(5,2,8,0.92);
    backdrop-filter: blur(20px) saturate(1.6);
    -webkit-backdrop-filter: blur(20px) saturate(1.6);
    border-bottom: 1px solid var(--border);
    /* Gold pinstripe at top */
    box-shadow: 0 -2px 0 0 var(--gold) inset;
}

.navbar-brand {
    display: inline-flex;
    align-items: center;
    font-family: var(--font-display);
    font-size: 1.9rem;
    letter-spacing: 0.10em;
    line-height: 1;
    user-select: none;
}
.navbar-logo {
    display: block;
    height: 36px;
    width: 36px;
    flex-shrink: 0;
    margin-right: .3em;
    position: relative;
    top: -3px;
}
.brand-accent { color: var(--gold); }
.brand-white  { color: var(--text); }

.navbar-actions {
    display: flex;
    align-items: center;
    gap: .5rem;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn-primary {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .6rem 1.4rem;
    background: var(--gold);
    color: #000;
    font-family: var(--font-display);
    font-size: 1rem;
    letter-spacing: .08em;
    border-radius: var(--r-sm);
    transition: background .15s, transform .15s var(--ease-bounce), box-shadow .15s;
    white-space: nowrap;
    font-weight: 400;
}
.btn-primary:hover {
    background: var(--gold-h);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px var(--gold-glow);
}

.btn-ghost {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: .55rem 1.1rem;
    background: transparent;
    color: var(--text-sec);
    font-family: var(--font-body);
    font-size: .82rem;
    font-weight: 600;
    letter-spacing: .04em;
    border: 1px solid var(--border-md);
    border-radius: var(--r-sm);
    transition: color .15s, border-color .15s, background .15s;
    white-space: nowrap;
}
.btn-ghost:hover {
    color: var(--gold);
    border-color: var(--gold);
    background: var(--gold-dim);
}

.btn-sm  { padding: .35rem .8rem;  font-size: .78rem; }
.btn-large { padding: .75rem 2rem; font-size: 1.1rem; }
.btn-block { width: 100%; justify-content: center; }

/* ============================================================
   SECTION TITLES
   ============================================================ */
.section-title {
    font-family: var(--font-display);
    font-size: 2rem;
    letter-spacing: .12em;
    color: var(--text);
    display: flex;
    align-items: center;
    gap: .75rem;
    margin-bottom: 1.25rem;
}
.section-title::before {
    content: '◆';
    color: var(--gold);
    font-size: .55em;
    flex-shrink: 0;
}
.section-title::after {
    content: '';
    flex: 1;
    height: 1px;
    background: linear-gradient(to right, var(--border-md), transparent);
}

.section-title-sm {
    font-family: var(--font-display);
    font-size: 1.1rem;
    letter-spacing: .14em;
    color: var(--text-sec);
    text-transform: uppercase;
    margin-bottom: .85rem;
    display: flex;
    align-items: center;
    gap: .5rem;
}
.section-title-sm::before { content: '◆'; color: var(--pink); font-size: .6em; }

/* ============================================================
   TAGS & BADGES
   ============================================================ */
.genre-tag {
    display: inline-block;
    padding: .18rem .55rem;
    background: var(--purple-dim);
    color: #a78bfa;
    border: 1px solid rgba(123,47,255,0.22);
    border-radius: 2px;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    white-space: nowrap;
}

.status-badge {
    display: inline-block;
    padding: .2rem .65rem;
    border-radius: 2px;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.status-completed { background: rgba(212,168,39,0.15); color: var(--gold); border: 1px solid var(--border-md); }
.status-hiatus    { background: rgba(123,47,255,0.15); color: #a78bfa;     border: 1px solid var(--purple-dim); }

.colored-badge {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .18rem .55rem;
    background: rgba(212,168,39,0.12);
    color: var(--gold);
    border: 1px solid var(--border-md);
    border-radius: 2px;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.colored-badge::before { content: '★'; font-size: .7em; }

.vol-badge {
    display: inline-block;
    padding: .18rem .5rem;
    background: var(--gold-dim);
    color: var(--gold);
    border: 1px solid rgba(233,27,140,0.25);
    border-radius: 2px;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.novel-badge {
    display: inline-block;
    padding: .18rem .5rem;
    background: var(--purple-dim);
    color: #a78bfa;
    border: 1px solid rgba(123,47,255,0.25);
    border-radius: 2px;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}

/* ============================================================
   FLASH MESSAGE
   ============================================================ */
.flash-msg {
    padding: .75rem 1.25rem;
    background: var(--gold-dim);
    border: 1px solid var(--border-md);
    border-left: 3px solid var(--gold);
    border-radius: var(--r-sm);
    color: var(--gold);
    font-size: .85rem;
    font-weight: 600;
    letter-spacing: .04em;
    margin-bottom: 1.5rem;
}

/* ============================================================
   CONTINUE READING STRIP
   ============================================================ */
.continue-section { padding: 2rem 0 .5rem; }

.continue-row {
    display: flex;
    gap: .75rem;
    overflow-x: auto;
    padding-bottom: .75rem;
    scrollbar-width: thin;
}
.continue-row::-webkit-scrollbar { height: 3px; }
.continue-row::-webkit-scrollbar-thumb { background: var(--border-md); border-radius: 99px; }

.continue-card {
    flex-shrink: 0;
    width: 200px;
    border-radius: var(--r);
    overflow: hidden;
    background: var(--card);
    border: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    position: relative;
    transition: border-color .2s, box-shadow .2s, transform .2s var(--ease-out);
}
.continue-card:hover {
    border-color: var(--border-hi);
    box-shadow: 0 4px 20px var(--gold-glow), 0 0 0 1px var(--gold);
    transform: translateY(-3px);
}
.continue-card img {
    width: 100%;
    height: 120px;
    object-fit: cover;
    object-position: top;
}
.continue-card-placeholder {
    width: 100%;
    height: 120px;
    background: var(--elevated);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-size: 2rem;
    color: var(--gold);
    letter-spacing: .1em;
}
.continue-card-info {
    padding: .6rem .7rem .5rem;
    display: flex;
    flex-direction: column;
    gap: .2rem;
    flex: 1;
}
.continue-card-title {
    font-size: .75rem;
    font-weight: 700;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    letter-spacing: .02em;
}
.continue-card-ch {
    font-size: .68rem;
    color: var(--gold);
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.continue-card-icon {
    position: absolute;
    top: .5rem;
    right: .5rem;
    width: 28px;
    height: 28px;
    background: rgba(0,0,0,.65);
    backdrop-filter: blur(6px);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gold);
}

/* ============================================================
   LIBRARY TOOLBAR
   ============================================================ */
.lib-toolbar {
    display: flex;
    align-items: center;
    gap: .6rem;
    flex-wrap: wrap;
    padding: 1.5rem 0 1rem;
}

.lib-count {
    margin-left: auto;
    font-family: var(--font-display);
    font-size: .9rem;
    letter-spacing: .1em;
    color: var(--text-mute);
}

/* ============================================================
   CATEGORY SECTIONS
   ============================================================ */
#catView {
    padding-bottom: 4rem;
}

.cat-section {
    margin-bottom: 2.75rem;
}

.cat-header {
    display: flex;
    align-items: flex-start;
    gap: .65rem;
    margin-bottom: 1rem;
    position: relative;
    overflow: hidden;
}
.cat-header::after {
    content: '';
    flex: 1;
    height: 1px;
    background: linear-gradient(to right, var(--border-md), transparent);
    margin-left: .5rem;
}

.cat-icon {
    font-size: .7rem;
    flex-shrink: 0;
}
[data-accent="gold"]   .cat-icon { color: var(--gold); }
[data-accent="pink"]   .cat-icon { color: var(--pink); }
[data-accent="purple"] .cat-icon { color: #a78bfa; }

.cat-title {
    font-family: var(--font-display);
    font-size: 1.55rem;
    letter-spacing: .1em;
    line-height: 1.15;
    word-break: break-word;
    overflow-wrap: break-word;
    min-width: 0;
}
@media (max-width: 600px) {
    .cat-title { font-size: clamp(.75rem, 3.5vw, 1rem); letter-spacing: .04em; line-height: 1.2; }
    .cat-icon  { display: none; }
    .cat-header::after { display: none; }
}
[data-accent="gold"]   .cat-title { color: var(--gold); }
[data-accent="pink"]   .cat-title { color: var(--pink); }
[data-accent="purple"] .cat-title { color: #a78bfa; }

.cat-count {
    font-family: var(--font-display);
    font-size: .85rem;
    letter-spacing: .1em;
    color: var(--text-mute);
    background: var(--elevated);
    border: 1px solid var(--border);
    border-radius: 2px;
    padding: .05rem .45rem;
    flex-shrink: 0;
}

/* Horizontal scroll row */
.cat-row {
    display: flex;
    gap: .85rem;
    overflow-x: auto;
    width: 100%;
    min-width: 0;
    padding-bottom: .85rem;
    /* snap to cards */
    scroll-snap-type: x proximity;
    scrollbar-width: thin;
    scrollbar-color: var(--border-md) transparent;
}
.cat-row::-webkit-scrollbar { height: 3px; }
.cat-row::-webkit-scrollbar-thumb { background: var(--border-md); border-radius: 99px; }
.cat-row .manga-card {
    flex-shrink: 0;
    width: 165px;
    scroll-snap-align: start;
    animation: none; /* disable stagger in row context */
}

/* Fade edge hint that row scrolls */
.cat-section {
    position: relative;
}

/* ---- Filtering state: collapse rows into a flat grid ---- */
#catView.is-filtering {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 1rem;
}
#catView.is-filtering .cat-section {
    display: contents;
    margin: 0;
}
#catView.is-filtering .cat-header {
    display: none;
}
#catView.is-filtering .cat-row {
    display: contents;
    overflow: visible;
    padding: 0;
}
#catView.is-filtering .cat-row .manga-card {
    width: auto;
}

/* ============================================================
   LEGACY — kept for other pages that still use these classes
   ============================================================ */
.library-header {
    padding: 2rem 0 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.library-title-row {
    display: flex;
    align-items: baseline;
    gap: 1rem;
}
.page-title {
    font-family: var(--font-display);
    font-size: clamp(2.5rem, 6vw, 4rem);
    letter-spacing: .1em;
    line-height: 1;
    color: var(--text);
    position: relative;
}
.page-title::after {
    content: '';
    display: block;
    height: 3px;
    width: 100%;
    background: linear-gradient(to right, var(--gold), var(--gold), transparent);
    margin-top: .2rem;
}
.page-subtitle {
    font-family: var(--font-display);
    font-size: 1rem;
    letter-spacing: .12em;
    color: var(--text-mute);
}
.filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    align-items: center;
}

.search-wrap {
    position: relative;
    flex: 1;
    min-width: 200px;
}
.search-icon {
    position: absolute;
    left: .75rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-mute);
    pointer-events: none;
}
#searchInput {
    width: 100%;
    padding: .55rem .75rem .55rem 2.2rem;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text);
    font-family: var(--font-body);
    font-size: .85rem;
    outline: none;
    transition: border-color .15s, background .15s;
}
#searchInput::placeholder { color: var(--text-mute); }
#searchInput:focus {
    border-color: var(--gold);
    background: var(--elevated);
}

.filter-select {
    padding: .5rem .75rem;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text-sec);
    font-family: var(--font-body);
    font-size: .82rem;
    outline: none;
    cursor: pointer;
    transition: border-color .15s;
    /* Custom arrow */
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%234a3a60'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right .65rem center;
    padding-right: 2rem;
}
.filter-select:focus { border-color: var(--gold); color: var(--text); }

/* ============================================================
   MANGA GRID
   ============================================================ */
.manga-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 1rem;
    padding-bottom: 4rem;
}

.manga-card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    position: relative;
    transition: transform .22s var(--ease-out), box-shadow .22s, border-color .22s;
}
.manga-card::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: var(--r);
    background: linear-gradient(135deg, transparent 55%, rgba(212,168,39,0.06));
    opacity: 0;
    transition: opacity .3s;
    pointer-events: none;
}
.manga-card:hover {
    transform: translateY(-5px);
    border-color: var(--border-hi);
    box-shadow:
        0 12px 32px rgba(0,0,0,.6),
        0 0 0 1px var(--gold),
        0 0 24px var(--gold-glow);
}
.manga-card:hover::after { opacity: 1; }

.manga-cover {
    aspect-ratio: 3/4;
    position: relative;
    overflow: hidden;
    background: var(--elevated);
}
.manga-cover img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .4s var(--ease-out);
    touch-action: manipulation;
}
.manga-card:hover .manga-cover img { transform: scale(1.06); }

.cover-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-size: 2.5rem;
    letter-spacing: .08em;
    color: var(--gold);
    background: linear-gradient(160deg, var(--elevated), var(--hover));
}
.cover-placeholder.large { font-size: 4rem; }

.cover-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(5,2,8,.85) 0%, transparent 55%);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: .5rem;
}

.badge-chapters {
    align-self: flex-end;
    background: rgba(0,0,0,.75);
    backdrop-filter: blur(6px);
    color: var(--gold);
    font-family: var(--font-display);
    font-size: .85rem;
    letter-spacing: .08em;
    padding: .1rem .4rem;
    border-radius: 2px;
    border: 1px solid var(--border-md);
}

.badge-user-status {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    align-self: flex-start;
    box-shadow: 0 0 6px currentColor;
}
.badge-user-status--reading      { background: var(--pink); color: var(--pink); }
.badge-user-status--completed    { background: var(--gold); color: var(--gold); }
.badge-user-status--on_hold      { background: #f59e0b; color: #f59e0b; }
.badge-user-status--dropped      { background: #ef4444; color: #ef4444; }
.badge-user-status--plan_to_read { background: #7b2fff; color: #7b2fff; }

.manga-info {
    padding: .65rem .7rem .75rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.manga-title {
    font-size: .82rem;
    font-weight: 700;
    color: var(--text);
    line-height: 1.3;
    height: calc(.82rem * 1.3 * 2);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    letter-spacing: .01em;
}
.manga-author {
    font-size: .68rem;
    color: var(--text-mute);
    font-weight: 500;
    letter-spacing: .02em;
    height: 1rem;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    margin-top: .3rem;
}
.card-progress {
    display: flex;
    align-items: center;
    gap: .4rem;
    margin-top: auto;
    padding-top: .35rem;
    height: 1rem;
}
.card-progress-track {
    flex: 1;
    height: 2px;
    background: var(--elevated);
    border-radius: 99px;
    overflow: hidden;
}
.card-progress-bar {
    height: 100%;
    background: linear-gradient(to right, var(--gold), var(--pink));
    border-radius: 99px;
}
.card-progress-label {
    font-size: .62rem;
    color: var(--text-mute);
    white-space: nowrap;
    font-weight: 600;
    min-width: 2.5rem;
    text-align: right;
}

/* Empty state */
.empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 6rem 2rem;
    text-align: center;
    gap: 1rem;
    color: var(--text-mute);
}
.empty-state.small { padding: 3rem 2rem; }
.empty-icon { opacity: .25; }
.empty-state h2 {
    font-family: var(--font-display);
    font-size: 2rem;
    letter-spacing: .1em;
    color: var(--text-sec);
}
.empty-state p { font-size: .9rem; max-width: 340px; }

/* ============================================================
   SITE FOOTER
   ============================================================ */
.site-footer {
    padding: 2rem clamp(1rem, 4vw, 2.5rem);
    border-top: 1px solid var(--border);
    color: var(--text-mute);
    font-size: .8rem;
    font-weight: 600;
    letter-spacing: .06em;
    text-align: center;
    text-transform: uppercase;
}
.site-footer a { color: var(--gold); transition: color .15s; }
.site-footer a:hover { color: var(--gold-h); }

/* ============================================================
   MANGA HERO (manga.php)
   ============================================================ */
.manga-hero {
    position: relative;
    overflow: hidden;
    min-height: 420px;
    /* Speed-line texture using conic gradient */
    background: var(--surface);
}
.manga-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        var(--hero-img, none) center/cover no-repeat,
        var(--surface);
    filter: blur(70px) saturate(1.4) brightness(.25);
    transform: scale(1.15);
    z-index: 0;
}
/* Diagonal speed-line overlay */
.manga-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        -55deg,
        transparent 0px,
        transparent 18px,
        rgba(212,168,39,0.018) 18px,
        rgba(212,168,39,0.018) 19px
    );
    z-index: 1;
    pointer-events: none;
}
.manga-hero-inner {
    position: relative;
    z-index: 2;
    max-width: 1100px;
    margin: 0 auto;
    padding: 3rem clamp(1rem, 4vw, 2.5rem) 2.5rem;
    display: flex;
    gap: 2.5rem;
    align-items: flex-start;
}
.manga-hero-cover {
    flex-shrink: 0;
    width: clamp(160px, 20vw, 230px);
}
.manga-hero-cover img {
    width: 100%;
    border-radius: var(--r);
    box-shadow:
        0 20px 60px rgba(0,0,0,.7),
        0 0 0 2px var(--border-md),
        0 0 0 4px rgba(212,168,39,0.08);
    transition: box-shadow .3s;
}
.manga-hero-cover img:hover {
    box-shadow:
        0 20px 60px rgba(0,0,0,.8),
        0 0 0 2px var(--gold),
        0 0 30px var(--gold-glow);
}
.manga-hero-cover .cover-placeholder.large {
    border-radius: var(--r);
    min-height: 300px;
    border: 2px solid var(--border-md);
}
.manga-hero-meta {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: .9rem;
    min-width: 0;
}

/* Hero badges row */
.hero-badges { display: flex; flex-wrap: wrap; gap: .4rem; }

/* Hero title */
.hero-title {
    font-family: var(--font-display);
    font-size: clamp(2rem, 5vw, 3.5rem);
    letter-spacing: .05em;
    line-height: 1.0;
    color: var(--text);
    /* Gold underline on first line only */
    padding-bottom: .5rem;
    border-bottom: 2px solid var(--border-md);
}

.hero-author {
    font-size: .85rem;
    color: var(--text-sec);
    font-weight: 600;
    letter-spacing: .04em;
    display: flex;
    align-items: center;
    gap: .4rem;
}

.hero-genres { display: flex; flex-wrap: wrap; gap: .35rem; }

.hero-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    padding: 1rem 1.25rem;
    background: rgba(0,0,0,.4);
    border: 1px solid var(--border);
    border-left: 3px solid var(--gold);
    border-radius: var(--r-sm);
}
.stat { display: flex; flex-direction: column; gap: .1rem; }
.stat-value {
    font-family: var(--font-display);
    font-size: 1.6rem;
    letter-spacing: .06em;
    line-height: 1;
    color: var(--gold);
}
.stat-label {
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--text-mute);
}

.hero-actions { display: flex; flex-wrap: wrap; gap: .6rem; }

.hero-description {
    font-size: .88rem;
    line-height: 1.75;
    color: var(--text-sec);
    max-width: 640px;
    padding-top: .25rem;
    border-top: 1px solid var(--border);
}

/* ============================================================
   USER CONTROLS (rating & status)
   ============================================================ */
.user-controls {
    display: flex;
    flex-direction: column;
    gap: .75rem;
    padding: 1rem 1.25rem;
    background: rgba(0,0,0,.35);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
}
.control-group { display: flex; flex-direction: column; gap: .4rem; }
.control-label {
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--text-mute);
}

.score-grid {
    display: flex;
    flex-wrap: wrap;
    gap: .3rem;
    align-items: center;
}
.score-btn {
    width: 34px;
    height: 34px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-size: 1rem;
    letter-spacing: .04em;
    background: var(--elevated);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text-sec);
    transition: all .15s;
}
.score-btn:hover { border-color: var(--gold); color: var(--gold); background: var(--gold-dim); }
/* Score colour ramp */
.score-btn[data-score="1"],.score-btn[data-score="2"],.score-btn[data-score="3"] { --sc: #ef4444; }
.score-btn[data-score="4"],.score-btn[data-score="5"]                            { --sc: #f97316; }
.score-btn[data-score="6"],.score-btn[data-score="7"]                            { --sc: var(--gold); }
.score-btn[data-score="8"],.score-btn[data-score="9"]                            { --sc: #22c55e; }
.score-btn[data-score="10"]                                                       { --sc: var(--pink); }
.score-btn.active {
    background: var(--sc, var(--gold));
    border-color: var(--sc, var(--gold));
    color: #000;
    font-weight: 700;
    box-shadow: 0 0 10px color-mix(in srgb, var(--sc, var(--gold)) 60%, transparent);
}
.score-clear {
    width: 28px; height: 28px;
    display: flex; align-items: center; justify-content: center;
    background: transparent;
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text-mute);
    font-size: .75rem;
    cursor: pointer;
    transition: all .15s;
}
.score-clear:hover { border-color: #ef4444; color: #ef4444; background: rgba(239,68,68,.1); }

.status-grid { display: flex; flex-wrap: wrap; gap: .35rem; }
.status-btn {
    padding: .3rem .75rem;
    background: var(--elevated);
    border: 1px solid var(--border);
    border-radius: 99px;
    color: var(--text-mute);
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .05em;
    cursor: pointer;
    transition: all .15s;
}
.status-btn:hover { border-color: var(--gold); color: var(--gold); background: var(--gold-dim); }
.status-btn--reading      { --stc: var(--pink);    --stc-dim: var(--pink-dim); }
.status-btn--completed    { --stc: var(--gold);    --stc-dim: var(--gold-dim); }
.status-btn--on_hold      { --stc: #f59e0b;        --stc-dim: rgba(245,158,11,.12); }
.status-btn--dropped      { --stc: #ef4444;        --stc-dim: rgba(239,68,68,.12); }
.status-btn--plan_to_read { --stc: var(--purple);  --stc-dim: var(--purple-dim); }
.status-btn.active {
    background: var(--stc-dim);
    border-color: var(--stc);
    color: var(--stc);
}

/* ============================================================
   CHAPTER LIST
   ============================================================ */
.chapter-section { padding: 2rem 0 4rem; }

.chapter-list { display: flex; flex-direction: column; gap: 0; }

.chapter-item {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .75rem 1rem;
    background: transparent;
    border-bottom: 1px solid var(--border);
    transition: background .15s, border-left-color .15s;
    position: relative;
    border-left: 3px solid transparent;
}
.chapter-item:first-child { border-top: 1px solid var(--border); }
.chapter-item:hover {
    background: var(--card);
    border-left-color: var(--gold);
}
.chapter-item--read { opacity: .55; }
.chapter-item--read:hover { opacity: .8; }

.chapter-read-dot {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #22c55e;
}

.chapter-num {
    font-family: var(--font-display);
    font-size: 1.05rem;
    letter-spacing: .08em;
    color: var(--gold);
    flex-shrink: 0;
    min-width: 52px;
}

.chapter-meta { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: .1rem; }
.chapter-title-text {
    font-size: .85rem;
    font-weight: 600;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    letter-spacing: .01em;
}
.chapter-date { font-size: .7rem; color: var(--text-mute); font-weight: 500; }

.chapter-right {
    display: flex;
    align-items: center;
    gap: .4rem;
    flex-shrink: 0;
}
.chapter-pages {
    font-size: .7rem;
    color: var(--text-mute);
    font-weight: 600;
    letter-spacing: .04em;
}
.chapter-arrow {
    color: var(--text-mute);
    transition: color .15s, transform .15s;
}
.chapter-item:hover .chapter-arrow {
    color: var(--gold);
    transform: translateX(2px);
}

/* ============================================================
   READER
   ============================================================ */
.reader-body {
    background: #000;
    /* No halftone dots in reader */
    background-image: none;
}

#reader-progress {
    position: fixed;
    top: 0;
    left: 0;
    height: 2px;
    width: 0%;
    background: linear-gradient(to right, var(--gold), var(--pink));
    z-index: 200;
    transition: width .1s linear;
}

.reader-nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 52px;
    padding: 0 1rem;
    background: rgba(5,2,8,0.90);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--border);
    box-shadow: 0 -2px 0 0 var(--gold) inset;
    transition: transform .3s var(--ease-out), opacity .3s;
}
.reader-nav.is-hidden { transform: translateY(-100%); }

.reader-nav-left { display: flex; align-items: center; gap: .75rem; min-width: 0; }
.reader-nav-right { display: flex; align-items: center; gap: .5rem; flex-shrink: 0; }

.reader-back {
    width: 34px; height: 34px;
    display: flex; align-items: center; justify-content: center;
    color: var(--text-sec);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    transition: color .15s, border-color .15s, background .15s;
    flex-shrink: 0;
}
.reader-back:hover { color: var(--gold); border-color: var(--gold); background: var(--gold-dim); }

.reader-title-block { min-width: 0; display: flex; flex-direction: column; gap: .05rem; }
.reader-manga-name {
    font-size: .7rem;
    color: var(--text-mute);
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.reader-chapter-name {
    font-family: var(--font-display);
    font-size: .95rem;
    letter-spacing: .06em;
    color: var(--gold);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.reader-page-info {
    font-family: var(--font-display);
    font-size: .9rem;
    letter-spacing: .08em;
    color: var(--text-mute);
    white-space: nowrap;
}

.reader-nav-btn {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .3rem .65rem;
    background: var(--elevated);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text-sec);
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .05em;
    transition: all .15s;
}
.reader-nav-btn:hover { border-color: var(--gold); color: var(--gold); background: var(--gold-dim); }
.reader-nav-btn--next { flex-direction: row; }

/* Reader strip */
.reader-strip {
    padding-top: 52px;
    background: #000;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
    min-height: 100vh;
}

.reader-page {
    width: 100%;
    max-width: 900px;
    line-height: 0;
    background: #0a0a0a;
}
.reader-page + .reader-page { margin-top: 2px; }
.reader-page img {
    width: 100%;
    height: auto;
    opacity: 0;
    transition: opacity .3s;
    touch-action: manipulation;
}
.reader-page img.is-loaded { opacity: 1; }

/* End of chapter */
.reader-end {
    width: 100%;
    max-width: 900px;
    padding: 5rem 2rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    text-align: center;
}
.reader-end-label {
    font-family: var(--font-display);
    font-size: 3rem;
    letter-spacing: .12em;
    color: var(--text-mute);
}
.reader-end-next-title {
    font-size: 1rem;
    color: var(--text-sec);
    margin-bottom: .5rem;
}
.reader-end-next-title em { font-style: normal; color: var(--gold); font-weight: 700; }

/* Mobile bottom bar */
.reader-mobile-bar {
    display: none;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    height: 52px;
    z-index: 100;
    background: rgba(5,2,8,.93);
    backdrop-filter: blur(14px);
    border-top: 1px solid var(--border);
    box-shadow: 0 2px 0 0 var(--gold) inset;
    align-items: center;
    justify-content: space-between;
    padding: 0 1rem;
    transition: transform .3s var(--ease-out), opacity .3s;
}
.reader-mobile-bar.is-hidden {
    transform: translateY(100%);
    opacity: 0;
    pointer-events: none;
}
.reader-mobile-btn {
    display: flex;
    align-items: center;
    gap: .35rem;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .06em;
    color: var(--text-sec);
    padding: .4rem .6rem;
}
.reader-mobile-btn--next { flex-direction: row-reverse; }
.reader-mobile-btn--disabled { opacity: 0; pointer-events: none; }
.reader-mobile-info {
    font-family: var(--font-display);
    font-size: .95rem;
    letter-spacing: .1em;
    color: var(--gold);
}

/* PDF container */
.pdf-container {
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 2px;
}
.pdf-container .reader-page { width: 100%; max-width: 100%; }
.pdf-container canvas { width: 100% !important; height: auto !important; display: block; }
.pdf-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    padding: 6rem 2rem;
    color: var(--text-mute);
    font-size: .85rem;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
}
@keyframes spin { to { transform: rotate(360deg); } }
.spin { animation: spin 1.2s linear infinite; color: var(--gold); }

/* Mobile reader */
@media (max-width: 768px) {
    .reader-mobile-bar { display: flex; }
    .reader-strip { padding-bottom: 52px; }
    .reader-nav-btn { display: none; }
}
@media (max-width: 640px) {
    .reader-manga-name { display: none; }
}

/* ============================================================
   NOVEL / TEXT READER
   ============================================================ */
.novel-body .reader-strip { background: #060408; }
.novel-body { background-image: none; }

.novel-container {
    max-width: 720px;
    margin: 0 auto;
    padding: 2.5rem 1.75rem 5rem;
}
.novel-content {
    font-family: 'Lora', Georgia, serif;
    font-size: var(--novel-fs, 1.05rem);
    line-height: 1.9;
    color: #d4ccbe;
    text-align: justify;
    hyphens: auto;
    word-break: break-word;
    transition: font-size .15s var(--ease-out);
}
.novel-content > :first-child::first-letter {
    float: left;
    font-family: var(--font-display);
    font-size: 3.8em;
    line-height: .82;
    padding-right: .12em;
    color: var(--gold);
}
.font-size-controls { display: flex; align-items: center; gap: .2rem; margin-right: .4rem; }
.font-size-btn {
    background: var(--elevated);
    border: 1px solid var(--border);
    color: var(--text-sec);
    border-radius: var(--r-sm);
    padding: .22rem .5rem;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .04em;
    cursor: pointer;
    transition: background .15s, color .15s;
}
.font-size-btn:hover { background: var(--hover); color: var(--gold); border-color: var(--gold); }
#readingPct, #mobileReadingPct { font-variant-numeric: tabular-nums; }

@media (max-width: 600px) {
    .novel-container { padding: 1.5rem 1rem 6rem; }
    .novel-content { font-size: var(--novel-fs, .98rem); text-align: left; hyphens: none; }
    .novel-content > :first-child::first-letter { font-size: 3.2em; }
}

/* ============================================================
   AUTH PAGE
   ============================================================ */
.auth-body {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 2rem 1rem;
    background-image: none;
    background: radial-gradient(ellipse at top, rgba(123,47,255,.08) 0%, transparent 60%),
                radial-gradient(ellipse at bottom, rgba(233,27,140,.06) 0%, transparent 60%),
                var(--bg);
}
.auth-wrap {
    width: 100%;
    max-width: 400px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.75rem;
}
.auth-logo {
    font-family: var(--font-display);
    font-size: 2.2rem;
    letter-spacing: .12em;
    display: flex;
    align-items: center;
    gap: .2rem;
}
.auth-card {
    width: 100%;
    background: var(--card);
    border: 1px solid var(--border-md);
    border-radius: var(--r-lg);
    overflow: hidden;
    box-shadow: 0 24px 60px rgba(0,0,0,.5);
}
.auth-tabs { display: flex; border-bottom: 1px solid var(--border); }
.auth-tab {
    flex: 1;
    padding: .9rem;
    text-align: center;
    font-size: .8rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--text-mute);
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: color .15s, border-color .15s;
}
.auth-tab.active { color: var(--gold); border-bottom-color: var(--gold); }
.auth-tab:hover:not(.active) { color: var(--text-sec); }
.auth-error {
    margin: .75rem 1.25rem 0;
    padding: .65rem .9rem;
    background: rgba(239,68,68,.1);
    border: 1px solid rgba(239,68,68,.25);
    border-left: 3px solid #ef4444;
    border-radius: var(--r-sm);
    color: #f87171;
    font-size: .82rem;
    font-weight: 600;
}
.auth-form { padding: 1.25rem; display: flex; flex-direction: column; gap: .9rem; }
.field { display: flex; flex-direction: column; gap: .35rem; }
.field label {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--text-mute);
}
.field input {
    padding: .65rem .85rem;
    background: var(--elevated);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text);
    font-family: var(--font-body);
    font-size: .9rem;
    outline: none;
    transition: border-color .15s, background .15s;
}
.field input:focus { border-color: var(--gold); background: var(--hover); }

/* ============================================================
   NAVBAR USER STUFF
   ============================================================ */
.nav-user-btn {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .3rem .6rem;
    border-radius: var(--r-sm);
    border: 1px solid var(--border);
    transition: border-color .15s, background .15s;
}
.nav-user-btn:hover { border-color: var(--gold); background: var(--gold-dim); }
.nav-avatar {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--gold), var(--pink));
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-size: .9rem;
    letter-spacing: .04em;
    color: #000;
    font-weight: 700;
}
.nav-username {
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .04em;
    color: var(--text-sec);
    max-width: 100px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ============================================================
   PROFILE PAGE
   ============================================================ */
.profile-header {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    padding: 2.5rem 0 2rem;
}
.profile-avatar {
    width: 72px; height: 72px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--gold), var(--pink));
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-size: 2.2rem;
    letter-spacing: .06em;
    color: #000;
    flex-shrink: 0;
    box-shadow: 0 0 24px var(--gold-glow);
}
.profile-name {
    font-family: var(--font-display);
    font-size: 2rem;
    letter-spacing: .1em;
    color: var(--text);
}
.profile-since { font-size: .78rem; color: var(--text-mute); font-weight: 600; letter-spacing: .06em; }

.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: .75rem;
    margin-bottom: 2rem;
}
.stat-card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    padding: 1rem 1.1rem;
    display: flex;
    flex-direction: column;
    gap: .25rem;
    transition: border-color .15s;
}
.stat-card:hover { border-color: var(--border-md); }
.stat-card .stat-value { font-size: 1.8rem; }
.stat-card .stat-label { font-size: .62rem; }

.status-breakdown {
    display: flex;
    gap: .35rem;
    height: 6px;
    border-radius: 99px;
    overflow: hidden;
    margin-bottom: .5rem;
}
.status-breakdown-bar {
    height: 100%;
    background: var(--bar-color);
    flex: 0 0 var(--bar-pct);
    min-width: var(--bar-pct);
    transition: flex .4s var(--ease-out);
}

.activity-list { display: flex; flex-direction: column; gap: 0; }
.activity-item {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .65rem 0;
    border-bottom: 1px solid var(--border);
}
.activity-item:last-child { border-bottom: none; }
.activity-thumb {
    width: 36px; height: 50px;
    border-radius: var(--r-sm);
    overflow: hidden;
    flex-shrink: 0;
    background: var(--elevated);
}
.activity-thumb img { width: 100%; height: 100%; object-fit: cover; }
.activity-info { flex: 1; min-width: 0; }
.activity-manga { font-size: .8rem; font-weight: 700; color: var(--text); }
.activity-ch { font-size: .72rem; color: var(--gold); font-weight: 600; }
.activity-date { font-size: .65rem; color: var(--text-mute); }

.my-manga-list { display: flex; flex-direction: column; gap: .4rem; }
.my-manga-item {
    display: flex;
    align-items: center;
    gap: .85rem;
    padding: .6rem .8rem;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    transition: border-color .15s;
}
.my-manga-item:hover { border-color: var(--border-md); }
.my-manga-thumb {
    width: 36px; height: 50px;
    border-radius: var(--r-sm);
    overflow: hidden;
    flex-shrink: 0;
}
.my-manga-thumb img { width: 100%; height: 100%; object-fit: cover; }
.my-manga-thumb--placeholder {
    background: var(--elevated);
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-display);
    font-size: .9rem;
    color: var(--gold);
}
.my-manga-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: .2rem; }
.my-manga-title {
    font-size: .8rem; font-weight: 700; color: var(--text);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.my-manga-progress { display: flex; align-items: center; gap: .4rem; }
.mini-bar { flex: 1; height: 2px; background: var(--elevated); border-radius: 99px; overflow: hidden; }
.mini-bar-fill { height: 100%; background: linear-gradient(to right, var(--gold), var(--pink)); border-radius: 99px; }
.my-manga-progress span { font-size: .62rem; color: var(--text-mute); white-space: nowrap; font-weight: 600; }
.my-manga-right { display: flex; flex-direction: column; gap: .25rem; align-items: flex-end; flex-shrink: 0; }
.my-manga-score { font-family: var(--font-display); font-size: 1.1rem; color: var(--gold); line-height: 1; }

.status-pill {
    padding: .12rem .45rem;
    border-radius: 99px;
    font-size: .62rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    white-space: nowrap;
}
.status-pill--reading      { background: var(--pink-dim);              color: var(--pink); }
.status-pill--completed    { background: var(--gold-dim);              color: var(--gold); }
.status-pill--on_hold      { background: rgba(245,158,11,.12);         color: #f59e0b; }
.status-pill--dropped      { background: rgba(239,68,68,.12);          color: #ef4444; }
.status-pill--plan_to_read { background: var(--purple-dim);            color: #a78bfa; }

/* ============================================================
   HERO BADGE ROW
   ============================================================ */
.hero-badges { display: flex; flex-wrap: wrap; gap: .4rem; align-items: center; }

/* ============================================================
   CARD PROGRESS BAR (index.php — wrap missing in old code)
   ============================================================ */
.card-progress {
    display: flex;
    align-items: center;
    gap: .4rem;
    margin-top: .2rem;
}
.card-progress-track {
    flex: 1;
    height: 2px;
    background: var(--elevated);
    border-radius: 99px;
    overflow: hidden;
}
.card-progress-bar {
    height: 100%;
    background: linear-gradient(to right, var(--gold), var(--pink));
    border-radius: 99px;
}
.card-progress span {
    font-size: .62rem; color: var(--text-mute); white-space: nowrap; font-weight: 600;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
    .manga-hero-inner { flex-direction: column; gap: 1.5rem; }
    .manga-hero-cover { width: clamp(130px, 35vw, 180px); }
    .hero-title { font-size: clamp(1.6rem, 7vw, 2.4rem); }
    .manga-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: .75rem; }
}
@media (max-width: 480px) {
    .manga-grid { grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: .5rem; }
    .stats-grid { grid-template-columns: repeat(2, 1fr); }
    .filter-bar { gap: .4rem; }
    .search-wrap { min-width: 100%; }
}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes fadeUp {
    from { opacity: 0; transform: translateY(16px); }
    to   { opacity: 1; transform: translateY(0); }
}

.manga-card { animation: fadeUp .35s var(--ease-out) both; }
/* Stagger grid cards */
.manga-card:nth-child(1)  { animation-delay: .00s; }
.manga-card:nth-child(2)  { animation-delay: .03s; }
.manga-card:nth-child(3)  { animation-delay: .06s; }
.manga-card:nth-child(4)  { animation-delay: .09s; }
.manga-card:nth-child(5)  { animation-delay: .12s; }
.manga-card:nth-child(6)  { animation-delay: .15s; }
.manga-card:nth-child(7)  { animation-delay: .18s; }
.manga-card:nth-child(8)  { animation-delay: .21s; }
.manga-card:nth-child(n+9) { animation-delay: .24s; }

/* ============================================================
   MODAL (Shift+Alt+S admin code prompt)
   ============================================================ */
.modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 1000;
    background: rgba(0,0,0,.75);
    backdrop-filter: blur(6px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    animation: fadeIn .15s ease;
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

.modal-box {
    background: var(--elevated);
    border: 1px solid var(--border-hi);
    border-radius: var(--r-lg);
    padding: 2rem;
    width: 100%;
    max-width: 380px;
    position: relative;
    box-shadow: 0 24px 64px rgba(0,0,0,.8), 0 0 0 1px var(--gold-glow);
    animation: slideUp .2s var(--ease-out);
}
@keyframes slideUp { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

.modal-close {
    position: absolute;
    top: .75rem;
    right: .85rem;
    font-size: 1.3rem;
    color: var(--text-mute);
    background: none;
    border: none;
    cursor: pointer;
    line-height: 1;
    transition: color .15s;
}
.modal-close:hover { color: var(--text); }

.modal-title {
    font-family: var(--font-display);
    font-size: 1.6rem;
    letter-spacing: .1em;
    color: var(--gold);
    margin-bottom: .35rem;
}
.modal-desc {
    font-size: .82rem;
    color: var(--text-sec);
    margin-bottom: 1.25rem;
}
.modal-msg {
    padding: .55rem .75rem;
    border-radius: var(--r-sm);
    font-size: .82rem;
    font-weight: 600;
    margin-bottom: .75rem;
}
.modal-msg--ok  { background: rgba(212,168,39,.12); color: var(--gold); border: 1px solid var(--border-md); }
.modal-msg--err { background: rgba(239,68,68,.12);  color: #f87171;     border: 1px solid rgba(239,68,68,.25); }

/* ============================================================
   SETTINGS & ADMIN PAGES
   ============================================================ */
.settings-wrap,
.admin-wrap {
    max-width: 720px;
    margin: 0 auto;
    padding-bottom: 4rem;
}

.settings-header {
    padding: 2.5rem 0 1.5rem;
}
.settings-username {
    color: var(--text-sec);
    font-size: .9rem;
    margin-top: .3rem;
    display: flex;
    align-items: center;
    gap: .6rem;
}

.settings-section {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    padding: 1.5rem;
    margin-bottom: 1.25rem;
}
.settings-section-title {
    font-family: var(--font-display);
    font-size: 1.3rem;
    letter-spacing: .1em;
    color: var(--gold);
    margin-bottom: 1rem;
    padding-bottom: .6rem;
    border-bottom: 1px solid var(--border);
}
.settings-desc {
    font-size: .85rem;
    color: var(--text-sec);
    margin-bottom: 1rem;
    line-height: 1.6;
}
.settings-form { display: flex; flex-direction: column; gap: .75rem; }
.settings-form--inline { padding-top: .85rem; }

/* Backup code display */
.codes-box {
    background: var(--surface);
    border: 1px solid var(--border-hi);
    border-radius: var(--r);
    padding: 1.25rem;
    margin-bottom: 1rem;
}
.codes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: .5rem;
    margin-bottom: 1rem;
}
.backup-code {
    font-family: monospace;
    font-size: .9rem;
    letter-spacing: .1em;
    color: var(--gold);
    background: var(--elevated);
    border: 1px solid var(--border-md);
    border-radius: var(--r-sm);
    padding: .4rem .65rem;
    text-align: center;
}
.codes-actions { display: flex; gap: .5rem; }

.codes-forms { display: flex; flex-direction: column; gap: .6rem; }
.codes-panel {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    padding: .75rem 1rem;
}
.codes-panel summary {
    cursor: pointer;
    font-size: .85rem;
    font-weight: 600;
    color: var(--text-sec);
    user-select: none;
    list-style: none;
}
.codes-panel summary::-webkit-details-marker { display: none; }
.codes-panel summary::before { content: '▶ '; font-size: .6em; color: var(--gold); }
.codes-panel[open] summary::before { content: '▼ '; }
.codes-panel-warn { font-size: .78rem; color: var(--gold); margin-left: .4rem; }

/* Admin table */
.admin-table-wrap { overflow-x: auto; }
.admin-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .85rem;
}
.admin-table th {
    text-align: left;
    padding: .5rem .75rem;
    font-family: var(--font-display);
    font-size: .8rem;
    letter-spacing: .1em;
    color: var(--text-mute);
    border-bottom: 1px solid var(--border);
}
.admin-table td {
    padding: .6rem .75rem;
    border-bottom: 1px solid var(--border);
    vertical-align: middle;
}
.admin-table tr:last-child td { border-bottom: none; }
.admin-table-self td { background: rgba(212,168,39,.04); }
.admin-table-actions { display: flex; gap: .4rem; flex-wrap: wrap; }
.admin-you { font-size: .72rem; color: var(--text-mute); }

/* Badges */
.admin-badge {
    display: inline-block;
    padding: .15rem .55rem;
    background: rgba(212,168,39,.15);
    color: var(--gold);
    border: 1px solid var(--border-md);
    border-radius: 2px;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.user-badge {
    display: inline-block;
    padding: .15rem .55rem;
    background: var(--purple-dim);
    color: #a78bfa;
    border: 1px solid rgba(123,47,255,.22);
    border-radius: 2px;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}

/* Reveal box (new codes shown once) */
.reveal-box {
    background: rgba(212,168,39,.06);
    border: 1px solid var(--gold);
    border-radius: var(--r);
    padding: 1.25rem;
    margin-bottom: 1.5rem;
}
.reveal-label {
    font-size: .82rem;
    color: var(--text-sec);
    margin-bottom: .75rem;
}
.reveal-once { color: var(--gold); font-weight: 700; font-size: .78rem; }
.reveal-code {
    display: block;
    font-family: monospace;
    font-size: 1.15rem;
    letter-spacing: .15em;
    color: var(--gold);
    margin-bottom: .75rem;
}
.inline-code {
    font-family: monospace;
    font-size: .88rem;
    letter-spacing: .1em;
    color: var(--gold);
}

/* Flash message variants */
.flash-msg--err {
    background: rgba(239,68,68,.1);
    color: #f87171;
    border-color: rgba(239,68,68,.3);
}

/* Nav active state */
.nav-active { color: var(--gold) !important; border-color: var(--gold) !important; }

/* kbd element */
kbd {
    display: inline-block;
    padding: .1rem .4rem;
    background: var(--elevated);
    border: 1px solid var(--border-md);
    border-radius: 3px;
    font-family: monospace;
    font-size: .8em;
    color: var(--text-sec);
}

/* ============================================================
   PROFILE — additional rules
   ============================================================ */
.profile-info { display: flex; flex-direction: column; gap: .2rem; }
.profile-username {
    font-family: var(--font-display);
    font-size: 2rem;
    letter-spacing: .1em;
    color: var(--text);
}

.stat-card-value {
    font-family: var(--font-display);
    font-size: 1.8rem;
    letter-spacing: .08em;
    line-height: 1;
    color: var(--gold);
}
.stat-card-label {
    font-size: .62rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--text-mute);
}

/* Status breakdown bar */
.breakdown-bar {
    flex: 0 0 var(--bar-pct);
    min-width: var(--bar-pct);
    height: 100%;
    background: var(--bar-color);
    border-radius: 0;
    transition: flex .4s var(--ease-out);
}

/* Legend */
.status-legend {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem .85rem;
    margin-top: .4rem;
}
.legend-item {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .05em;
    color: var(--text-mute);
}
.legend-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--leg-color, var(--text-mute));
    flex-shrink: 0;
}

/* Profile two-column layout */
.profile-cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    margin-top: 2rem;
}
@media (max-width: 700px) {
    .profile-cols { grid-template-columns: 1fr; }
}
.profile-section { display: flex; flex-direction: column; gap: .75rem; }

/* Activity */
.activity-chapter {
    font-size: .72rem;
    color: var(--gold);
    font-weight: 600;
}
.activity-thumb {
    width: 36px;
    height: 50px;
    border-radius: var(--r-sm);
    overflow: hidden;
    flex-shrink: 0;
    background: var(--elevated);
    object-fit: cover;
}
.activity-thumb--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-size: .85rem;
    color: var(--gold);
}
.activity-time {
    font-size: .65rem;
    color: var(--text-mute);
    font-weight: 600;
    white-space: nowrap;
    letter-spacing: .04em;
    margin-left: auto;
    flex-shrink: 0;
}

/* Generic muted text */
.text-muted {
    color: var(--text-mute);
    font-size: .85rem;
    font-weight: 500;
}

/* ============================================================
   ADMIN PAGE
   ============================================================ */
.admin-wrap {
    max-width: 960px;
}

/* Stats grid */
.admin-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: .75rem;
    margin-bottom: 1.5rem;
}

.admin-stat-card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    padding: 1rem 1.1rem;
    display: flex;
    flex-direction: column;
    gap: .25rem;
    transition: border-color .15s;
}
.admin-stat-card:hover { border-color: var(--border-md); }
.admin-stat-card .stat-value {
    font-family: var(--font-display);
    font-size: 1.8rem;
    letter-spacing: .08em;
    line-height: 1;
    color: var(--gold);
}
.admin-stat-card .stat-label {
    font-size: .62rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--text-mute);
}
.admin-stat-card small { font-size: .65em; color: var(--text-mute); }

/* Section header row (title + action button side by side) */
.section-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

/* Two-column layout for activity + most-read */
.admin-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem;
    margin-bottom: 0;
}
@media (max-width: 720px) {
    .admin-two-col { grid-template-columns: 1fr; }
}

/* Top manga bar chart */
.top-manga-list { display: flex; flex-direction: column; gap: .6rem; }

.top-manga-row {
    display: flex;
    align-items: center;
    gap: .65rem;
}

.top-manga-rank {
    font-family: var(--font-display);
    font-size: 1rem;
    letter-spacing: .06em;
    color: var(--text-mute);
    min-width: 1.4rem;
    text-align: right;
    flex-shrink: 0;
}

.top-manga-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: .25rem;
}

.top-manga-title {
    font-size: .8rem;
    font-weight: 700;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: color .15s;
}
.top-manga-title:hover { color: var(--gold); }

.top-manga-bar-wrap {
    height: 4px;
    background: var(--elevated);
    border-radius: 99px;
    overflow: hidden;
}
.top-manga-bar {
    height: 100%;
    background: linear-gradient(to right, var(--gold), var(--pink));
    border-radius: 99px;
    transition: width .4s var(--ease-out);
}

.top-manga-count {
    font-family: var(--font-display);
    font-size: .85rem;
    letter-spacing: .06em;
    color: var(--gold);
    flex-shrink: 0;
    min-width: 2rem;
    text-align: right;
}

/* System info grid */
.system-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: .75rem;
}

.system-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    padding: .85rem 1rem;
    display: flex;
    flex-direction: column;
    gap: .25rem;
}

.system-label {
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--text-mute);
}

.system-val {
    font-family: var(--font-display);
    font-size: 1.15rem;
    letter-spacing: .06em;
    color: var(--text-sec);
}

/* Inline manga edit form */
.manga-edit-form {
    padding: .75rem 0 .25rem;
}

.manga-edit-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: .65rem .85rem;
}

.manga-edit-grid .field input,
.manga-edit-grid .field select,
.manga-edit-grid .field textarea {
    padding: .5rem .75rem;
    background: var(--elevated);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text);
    font-family: var(--font-body);
    font-size: .85rem;
    width: 100%;
    outline: none;
    transition: border-color .15s;
    resize: vertical;
}
.manga-edit-grid .field input:focus,
.manga-edit-grid .field select,
.manga-edit-grid .field textarea:focus { border-color: var(--gold); }

/* ============================================================
   MOBILE HAMBURGER + FULLSCREEN MENU
   ============================================================ */

.mobile-menu-btn {
    display: none;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px;
    width: 40px;
    height: 40px;
    padding: 0;
    background: none;
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    cursor: pointer;
    transition: border-color .2s, background .2s;
    flex-shrink: 0;
}
.mobile-menu-btn:hover { border-color: var(--gold); background: var(--gold-dim); }
.mobile-menu-btn .bar {
    display: block;
    width: 18px;
    height: 2px;
    background: var(--text-sec);
    border-radius: 2px;
    transition: transform .35s var(--ease-out), opacity .25s, width .25s, background .25s;
    transform-origin: center;
}
.mobile-menu-btn.is-open .bar:nth-child(1) { transform: translateY(7px) rotate(45deg); background: var(--gold); }
.mobile-menu-btn.is-open .bar:nth-child(2) { opacity: 0; width: 0; }
.mobile-menu-btn.is-open .bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); background: var(--gold); }

@media (max-width: 768px) {
    .mobile-menu-btn { display: flex; }
    .navbar-actions  { display: none; }
}

/* Overlay — display:none when closed so it never affects layout or scroll */
.mobile-menu-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 400;
    flex-direction: column;
    background: var(--bg);
    background-image:
        radial-gradient(ellipse at top right, rgba(212,168,39,.09) 0%, transparent 55%),
        radial-gradient(ellipse at bottom left, rgba(123,47,255,.09) 0%, transparent 55%),
        repeating-linear-gradient(
            -55deg,
            transparent 0px, transparent 22px,
            rgba(212,168,39,.012) 22px, rgba(212,168,39,.012) 23px
        );
    /* Circular reveal from hamburger (top-right) */
    clip-path: circle(0% at calc(100% - 20px) 30px);
    transition: clip-path .48s var(--ease-out);
}
.mobile-menu-overlay.is-open {
    clip-path: circle(170% at calc(100% - 20px) 30px);
}

.mobile-menu-inner {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 0 clamp(1.5rem, 8vw, 3rem);
}

.mobile-menu-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 60px;
    flex-shrink: 0;
    border-bottom: 1px solid var(--border);
}

.mobile-menu-brand {
    display: inline-flex;
    align-items: center;
    font-family: var(--font-display);
    font-size: 1.7rem;
    letter-spacing: .12em;
    line-height: 1;
}

.mobile-menu-close {
    width: 40px; height: 40px;
    display: flex; align-items: center; justify-content: center;
    background: none;
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text-sec);
    cursor: pointer;
    transition: color .15s, border-color .15s, background .15s;
}
.mobile-menu-close:hover { color: var(--gold); border-color: var(--gold); background: var(--gold-dim); }

.mobile-menu-nav {
    display: flex;
    flex-direction: column;
    justify-content: center;
    flex: 1;
    gap: .25rem;
    padding: 2rem 0;
}

.mobile-menu-link {
    font-family: var(--font-display);
    font-size: clamp(2.4rem, 10vw, 3.6rem);
    letter-spacing: .1em;
    color: var(--text);
    line-height: 1.1;
    padding: .35rem 0;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: .5rem;
    opacity: 0;
    transform: translateX(24px);
    transition: opacity .3s ease, transform .3s var(--ease-out), color .15s;
}
.mobile-menu-link::before { content: '◆'; font-size: .35em; color: var(--gold); flex-shrink: 0; transition: color .15s; }
.mobile-menu-link:hover { color: var(--gold); }
.mobile-menu-link:hover::before { color: var(--gold); }
.mobile-menu-link--dim { color: var(--text-mute); font-size: clamp(1.4rem, 6vw, 2rem); }
.mobile-menu-link--dim::before { color: var(--text-mute); }
.mobile-menu-link--dim:hover { color: var(--text-sec); }

.mobile-menu-overlay.is-open .mobile-menu-link {
    opacity: 1;
    transform: translateX(0);
}

.mobile-menu-footer {
    padding: 1.25rem 0;
    border-top: 1px solid var(--border);
    flex-shrink: 0;
}
.mobile-menu-user {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-size: .85rem;
    font-weight: 600;
    color: var(--text-mute);
    letter-spacing: .04em;
}

/* Danger button modifier */
.btn-danger {
    color: #f87171 !important;
    border-color: rgba(239,68,68,.35) !important;
}
.btn-danger:hover {
    color: #fff !important;
    background: rgba(239,68,68,.18) !important;
    border-color: #ef4444 !important;
}
