/* shared-styles.css — NovelIndex shared page styles */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
[data-theme="dark"]{--bg:#0d0d0f;--bg2:#13131a;--bg3:#1a1a24;--accent:#e8c46a;--accent2:#c97d4e;--accent-rgb:232,196,106;--text:#f0ede6;--text2:#c8c4bc;--muted:#7a7890;--border:rgba(255,255,255,0.08);--border2:rgba(255,255,255,0.04);--card:#15151e;--shadow:rgba(0,0,0,0.5);--green:#63d380;--red:#e06c75;}
[data-theme="light"]{--bg:#f5f3ef;--bg2:#eeece8;--bg3:#e5e2dc;--accent:#b8882a;--accent2:#9a5a28;--accent-rgb:184,136,42;--text:#1a1814;--text2:#3a3628;--muted:#7a7060;--border:rgba(0,0,0,0.1);--border2:rgba(0,0,0,0.05);--card:#ffffff;--shadow:rgba(0,0,0,0.12);--green:#2a8a4a;--red:#c04040;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;font-weight:400;line-height:1.6;min-height:100vh;}

/* BANNER */
.banner{width:100%;background:var(--bg2);border-bottom:2px solid var(--accent);padding:0.65rem 0.9rem;display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;gap:0.5rem;position:sticky;top:0;z-index:200;}
.banner-top{display:flex;align-items:center;flex-shrink:0;}
.banner-logo{font-family:'Playfair Display',serif;font-weight:900;font-size:1.3rem;color:var(--text);text-decoration:none;}
.banner-logo span{color:var(--accent);}
.banner-logo sup{font-size:0.5rem;color:var(--muted);font-family:'DM Mono',monospace;border:1px solid var(--muted);border-radius:3px;padding:0.05rem 0.25rem;margin-left:0.15rem;vertical-align:super;}
.banner-search{flex:1;min-width:200px;display:flex;align-items:center;background:var(--bg3);border:1.5px solid var(--border);border-radius:100px;padding:0 0.8rem;gap:0.4rem;order:2;}
.banner-search input{flex:1;background:none;border:none;outline:none;color:var(--text);font-family:'DM Sans',sans-serif;font-size:0.88rem;padding:0.55rem 0;min-width:0;}
.banner-search input::placeholder{color:var(--muted);}
.search-btn{background:var(--accent);color:#0d0d0f;border:none;border-radius:100px;padding:0.28rem 0.9rem;font-size:0.75rem;font-weight:700;cursor:pointer;flex-shrink:0;font-family:'DM Sans',sans-serif;}
.banner-back{order:3;margin-left:auto;flex-shrink:0;display:flex;align-items:center;gap:0.4rem;color:var(--muted);text-decoration:none;font-size:0.8rem;font-weight:500;padding:0.35rem 0.8rem;border:1px solid var(--border);border-radius:100px;transition:all 0.2s;}
.banner-back:hover{color:var(--accent);border-color:var(--accent);}
@media(max-width:640px){.banner-search{order:10;width:100%;flex-basis:100%;}.banner-back{margin-left:auto;}}
@media(min-width:1024px){.banner{flex-wrap:nowrap;padding:0.7rem 2rem;}.banner-search{flex:1;max-width:none;}.banner-back{margin-left:auto;}}

/* PAGE HEADER */
.page-header{padding:1.2rem 0.9rem 1rem;background:var(--bg2);border-bottom:1px solid var(--border);}
.page-header-title{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:900;margin-bottom:0.2rem;}
.page-header-title em{font-style:italic;color:var(--accent);}
.page-header-sub{font-size:0.8rem;color:var(--muted);}

/* NOVEL LIST */
.novel-list{padding:0.8rem 0.9rem;}
.novel-list-item{display:flex;align-items:center;gap:1rem;padding:0.9rem 0;border-bottom:1px solid var(--border2);text-decoration:none;color:var(--text);transition:opacity 0.15s;}
.novel-list-item:last-child{border-bottom:none;}
.novel-list-item:hover{opacity:0.8;}
.nl-cover{width:60px;height:84px;border-radius:8px;overflow:hidden;flex-shrink:0;border:1px solid var(--border);background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:1.6rem;position:relative;}
.nl-cover img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}
.nl-info{flex:1;min-width:0;}
.nl-title{font-family:'Playfair Display',serif;font-size:0.98rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:0.3rem;}
.nl-chapters{font-size:0.75rem;color:var(--muted);margin-bottom:0.2rem;}
.nl-bottom{display:flex;align-items:center;gap:0.8rem;flex-wrap:wrap;}
.nl-rating{font-family:'DM Mono',monospace;font-size:0.78rem;color:var(--accent);font-weight:500;}
.nl-platform{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.07em;background:var(--bg3);border:1px solid var(--border);border-radius:4px;padding:0.1rem 0.4rem;color:var(--muted);}

/* PAGINATION */
.pagination{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:0.4rem;padding:1.5rem 0.9rem;}
.page-btn{width:40px;height:40px;border-radius:8px;background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-size:0.88rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s;font-family:'DM Mono',monospace;}
.page-btn:hover{border-color:var(--accent);color:var(--accent);}
.page-btn.active{background:var(--accent);border-color:var(--accent);color:#0d0d0f;font-weight:700;}
.page-btn.arrow{font-size:0.75rem;}
.page-btn:disabled{opacity:0.3;cursor:not-allowed;}

/* RECOMMENDATIONS */
.rec-section{padding:1.2rem 0.9rem 2rem;border-top:1px solid var(--border);}
.rec-section-title{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;margin-bottom:1rem;color:var(--muted);}
.rec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0.8rem;}
@media(min-width:640px){.rec-grid{grid-template-columns:repeat(4,1fr);}}
@media(min-width:1024px){.rec-grid{grid-template-columns:repeat(6,1fr);}}
.rec-card{text-decoration:none;color:var(--text);display:block;transition:transform 0.2s;}
.rec-card:hover{transform:translateY(-3px);}
.rec-cover{width:100%;aspect-ratio:2/3;background:var(--bg3);border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin-bottom:0.4rem;border:1px solid var(--border);position:relative;}
.rec-cover img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}
.rec-title{font-family:'Playfair Display',serif;font-size:0.72rem;font-weight:700;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

/* LOADING */
.loading{text-align:center;padding:3rem;color:var(--muted);}
.spinner{display:inline-block;width:22px;height:22px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 0.8s linear infinite;margin-bottom:0.6rem;}
@keyframes spin{to{transform:rotate(360deg);}}

/* FOOTER */
footer{background:var(--bg2);border-top:1px solid var(--border);padding:1.2rem 0.9rem;text-align:center;}
.footer-bottom{font-size:0.68rem;color:var(--muted);}

@media(min-width:1024px){
  .page-header,.novel-list,.pagination,.rec-section{padding-left:2rem;padding-right:2rem;}
}
