@charset "utf-8";

*{margin:0;padding:0;box-sizing:border-box}
body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:16px;line-height:1.6;color:#333;background:linear-gradient(135deg,#f8f9fa,#e9ecef);min-height:100vh}
input,textarea,button{font-family:inherit;font-size:inherit}

/* Header */
.header{background:linear-gradient(135deg,#ff69b4,#8a2be2,#dda0dd);color:#fff;padding:1rem 0;box-shadow:0 2px 10px rgba(0,0,0,.1);position:sticky;top:0;z-index:1000}
.header-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:0 1rem}
.header-left a{display:flex;align-items:center;text-decoration:none;color:#fff;font-weight:700;font-size:1.2rem}
.header-left img{margin-right:.5rem}
.nav{display:flex;list-style:none;gap:2rem}
.nav li a{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:20px;transition:background-color .3s;white-space:nowrap;min-width:96px;text-align:center}
.nav li a:hover,.nav li.active a{background:rgba(255,255,255,.2)}
.header-right{display:flex;align-items:center;gap:1rem}
.header-right a{color:#fff;text-decoration:none;font-size:1.5rem}

/* User Nav */
.user-nav{background:#fff;border-bottom:1px solid #f0d9fc;box-shadow:0 2px 8px rgba(204,51,153,.06)}
.user-nav-inner{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;gap:.5rem;justify-content:flex-end;overflow-x:auto}
.user-nav a{display:inline-block;padding:.75rem 1rem;color:#666;text-decoration:none;font-size:14px;font-weight:500;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap}
.user-nav a:hover,.user-nav a.active{color:#8a2be2;border-bottom-color:#8a2be2}
.user-nav a.logout{color:#dc3545}
.user-nav a.logout:hover{border-bottom-color:#dc3545}

/* Search */
.search-form{display:flex;background:rgba(255,255,255,.1);border-radius:25px;overflow:hidden}
.search-form input{border:none;padding:.5rem 1rem;background:transparent;color:#fff;outline:none}
.search-form input::placeholder{color:rgba(255,255,255,.7)}
.search-form button{border:none;background:rgba(255,255,255,.2);color:#fff;cursor:pointer;transition:background-color .3s;display:flex;align-items:center;justify-content:center}
.search-form button:hover{background:rgba(255,255,255,.3)}
.search-btn{width:40px;min-width:40px;height:36px;border:none;background:rgba(255,255,255,.2);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:0 25px 25px 0;transition:background-color .3s;flex-shrink:0}
.search-btn:hover{background:rgba(255,255,255,.35)}
.search-btn svg{width:20px;height:20px;stroke:#fff;fill:none}
.user-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;transition:background-color .2s}
.user-icon:hover{background:rgba(255,255,255,.2)}

/* Main */
.main{max-width:1200px;margin:0 auto}

/* Page Header */
.page-header{text-align:center;margin:1rem 0}
.page-header h1{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;color:#1a1a2e;display:inline-flex;align-items:center;gap:.5rem}
.icon-title{width:28px;height:28px;flex-shrink:0;color:#8a2be2}
.back-link,.page-back a{display:inline-flex;align-items:center;gap:.3rem;color:#666;text-decoration:none;transition:color .2s}
.back-link:hover,.page-back a:hover{color:#8a2be2}
.back-link svg,.page-back a svg{width:16px;height:16px}
.page-info{font-size:.9rem;color:#999;margin-top:.5rem}
.page-back{text-align:center;margin-bottom:1rem}
.page-back a{color:#8a2be2;font-weight:700}
.page-back a:hover{color:#ff69b4}

/* Home List */
.homelist{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;list-style:none}
.homelist li{background:#fff;border-radius:15px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.1);transition:transform .3s,box-shadow .3s}
.homelist li:hover{transform:translateY(-5px);box-shadow:0 8px 30px rgba(0,0,0,.15)}
.homelist h3{padding:1rem;font-size:1.2rem;text-align:center;background:linear-gradient(135deg,#dda0dd,#ff69b4);color:#fff;margin:0}
.homelist h3 a{color:#fff;text-decoration:none}
.homelist dl{display:flex;flex-direction:column}
.homelist dt{text-align:center;padding:1rem}
.homelist dt img{width:100%;max-width:250px;height:auto;border-radius:10px;box-shadow:0 2px 10px rgba(0,0,0,.1)}
.homelist dd{padding:1rem;text-align:center}
.homelist dd a{color:#8a2be2;text-decoration:none;font-weight:700;transition:color .3s}
.homelist dd a:hover{color:#ff69b4}
.favorite-time,.history-time,.chapter-title{color:#999;font-size:13px}
.chapter-title a{color:#e91e63;font-weight:700}

/* Author */
.author-list{margin-bottom:2rem}
.author-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;list-style:none;padding:0}
.author-card{background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:15px;padding:1.5rem;box-shadow:0 4px 20px rgba(0,0,0,.1);transition:all .3s;text-align:center;position:relative;overflow:hidden}
.author-card::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,105,180,.1),transparent);animation:flowGradient 3s infinite}
.author-card:hover{transform:translateY(-5px) scale(1.02);box-shadow:0 8px 30px rgba(138,43,226,.2);animation:float 2s ease-in-out infinite}
.author-card:hover::before{left:100%;transition:left .5s}
.author-card h3{margin-bottom:.5rem;font-size:1.3rem}
.author-card h3 a{color:#8a2be2;text-decoration:none;font-weight:700}
.author-card h3 a:hover{color:#ff69b4}
.author-info{color:#666;font-size:.9rem;margin:0}
.no-data{text-align:center;font-size:1.2rem;color:#999;padding:2rem;background:#fff;border-radius:15px;box-shadow:0 2px 10px rgba(0,0,0,.1)}
@keyframes flowGradient{0%,100%{background-position:0 50%}50%{background-position:100% 50%}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* Category/Tags */
.category-list{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 16px rgba(204,51,153,.12)}
.category-tags{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none;justify-content:center;width:100%}
.category-tag{flex:0 0 auto}
.category-tag a{display:block;padding:.5rem 1rem;background:#fff;color:#1a1a2e;text-decoration:none;border:2px solid #f0d9fc;border-radius:8px;font-size:14px;font-weight:600;transition:all .3s;box-shadow:0 2px 8px rgba(204,51,153,.08);text-align:center}
.category-tag a:hover{background:linear-gradient(135deg,#ff6ec7,#c77dff,#9d4edd);color:#fff;box-shadow:0 4px 16px rgba(204,51,153,.12)}
.category-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 .5rem;background:#ff6ec7;color:#fff;border-radius:12px;font-size:12px;font-weight:700}
.category-tag a:hover .category-count{background:#fff;color:#ff6ec7}

/* Comic Info */
.comic-info{margin-bottom:2rem;text-align:center;background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 16px rgba(204,51,153,.1)}
.comic-info h1{font-size:2rem;color:#8a2be2;margin-bottom:.75rem;line-height:1.3}
.comic-info h1 a{color:inherit;text-decoration:none;transition:color .3s}
.comic-info h1 a:hover{color:#ff69b4}
.comic-desc{color:#666;font-size:1rem;line-height:1.8;margin-bottom:1rem;padding:0 1rem}
.comic-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;justify-content:center}
.meta-label{color:#8a2be2;font-weight:700;font-size:.95rem;flex-shrink:0}
.meta-tags{display:inline-flex;flex-wrap:wrap;gap:.4rem;align-items:center}
.meta-author,.meta-tag{display:inline-flex;align-items:center;padding:.4rem .8rem;background:#fff;color:#1a1a2e;text-decoration:none;border:2px solid #f0d9fc;border-radius:20px;font-size:.85rem;font-weight:600;transition:all .3s;box-shadow:0 2px 8px rgba(204,51,153,.08)}
.meta-author:hover,.meta-tag:hover{background:linear-gradient(135deg,#ff6ec7,#c77dff,#9d4edd);color:#fff;box-shadow:0 4px 12px rgba(204,51,153,.15);transform:translateY(-1px)}
.meta-author{color:#8a2be2}

/* Chapter Images */
.chapter_images{margin:2rem 0}
.chapter_images h2{text-align:center;font-size:1.4rem;color:#8a2be2;margin-bottom:1rem}
.chapter_images ul{margin:0;padding:0;list-style:none;display:block}
.chapter_images ul li{margin:0;padding:0;border:0;list-style:none}
.chapter_images ul li img{display:block;width:100%;max-width:100%;height:auto;margin:0;border-radius:0}

/* Role List */
.rolelist{margin:2rem 0}
.rolelist h2{color:#8a2be2;font-size:1.5rem;margin-bottom:1rem;text-align:center}
.rolelist ul{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem;list-style:none;padding:0}
.rolelist li{background:#fff;border-radius:15px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.1);transition:transform .3s,box-shadow .3s;text-align:center;padding:1rem}
.rolelist li:hover{transform:translateY(-5px);box-shadow:0 8px 30px rgba(0,0,0,.15)}
.rolelist img{width:100%;max-width:150px;height:auto;border-radius:10px;margin-bottom:1rem}
.rolelist h3{color:#8a2be2;font-size:1.1rem;margin-bottom:.5rem}
.rolelist p{color:#666;font-size:.9rem;line-height:1.4}

/* Chapters */
.chapters{margin:2rem 0}
.chapters h2{color:#8a2be2;font-size:1.5rem;margin-bottom:1rem;text-align:center}
.chapters ul{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem;list-style:none;padding:0}
.chapters li{background:#fff;border-radius:15px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.1);transition:transform .3s,box-shadow .3s;text-align:center;padding:1rem}
.chapters li:hover{transform:translateY(-5px);box-shadow:0 8px 30px rgba(0,0,0,.15)}
.chapters img{width:100%;max-width:200px;height:auto;border-radius:10px;margin-bottom:1rem}
.chapters h3{font-size:1rem;margin:0}
.chapters h3 a{color:#8a2be2;text-decoration:none;font-weight:700;transition:color .3s}
.chapters h3 a:hover{color:#ff69b4}

/* Chapter Navigation */
.chapter-navigation{margin-top:2rem;text-align:center;display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}
.chapter-navigation-top{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #f0d9fc}
.chapter-navigation-bottom{margin-top:2rem;padding-top:1.5rem;border-top:2px solid #f0d9fc}
.nav-btn{display:inline-flex;align-items:center;justify-content:center;min-width:120px;height:44px;padding:0 1.5rem;font-size:15px;font-weight:600;background:#fff;color:#1a1a2e;border:2px solid #f0d9fc;border-radius:8px;box-shadow:0 2px 8px rgba(204,51,153,.08);transition:all .3s;cursor:pointer;text-decoration:none}
.nav-btn:hover{background:linear-gradient(135deg,#ff6ec7,#c77dff,#9d4edd);color:#fff;box-shadow:0 4px 16px rgba(204,51,153,.12)}
.nav-btn-directory{background:linear-gradient(135deg,#7b2cbf,#9d4edd);color:#fff;border:2px solid transparent}
.nav-btn-directory:hover{background:linear-gradient(135deg,#ff6ec7,#c77dff,#9d4edd);box-shadow:0 0 20px rgba(255,110,199,.3)}
.nav-btn-disabled{opacity:.5;cursor:not-allowed;background:#fdf4fc;color:#9ca3af}
.nav-btn-disabled:hover{background:#fdf4fc;color:#9ca3af;border-color:#f0d9fc;transform:none;box-shadow:0 2px 8px rgba(204,51,153,.08)}

/* Carousel */
.carousel{position:relative;width:100%;overflow:hidden;margin-bottom:2rem}
.carousel-inner{display:flex;transition:transform .5s}
.carousel-item{flex:0 0 100%;opacity:0;visibility:hidden;transition:opacity .5s,visibility .5s}
.carousel-item.active{opacity:1;visibility:visible}
.carousel-item img{width:100%;height:auto;max-height:400px;object-fit:cover}

/* Favorite */
.favorite-btn-container{position:fixed;top:70px;right:20px;z-index:1000}
.favorite-btn{background:#fff;border:2px solid #e91e63;border-radius:20px;padding:8px 16px;font-size:14px;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.15);transition:all .3s}
.favorite-btn:hover{background:#fff0f5;transform:scale(1.05)}
.favorite-btn.active{background:#e91e63;color:#fff}

/* Pagination */
.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin:2rem 0;flex-wrap:wrap}
.pagination-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1rem;background:#fff;color:#1a1a2e;text-decoration:none;border:2px solid #f0d9fc;border-radius:8px;font-weight:600;font-size:.9rem;transition:all .3s;box-shadow:0 2px 8px rgba(204,51,153,.08)}
.pagination-btn:hover{background:linear-gradient(135deg,#ff6ec7,#c77dff,#9d4edd);color:#fff;box-shadow:0 4px 16px rgba(204,51,153,.12);transform:translateY(-2px)}
.pagination-btn svg{width:16px;height:16px;stroke:#8a2be2;fill:none;flex-shrink:0;transition:stroke .3s}
.pagination-btn:hover svg{stroke:#fff}
.pagination-btn.pagination-disabled{background:#f5f5f5;color:#ccc;border-color:#e0e0e0;cursor:not-allowed;box-shadow:none}
.pagination-btn.pagination-disabled:hover{transform:none;box-shadow:none;background:#f5f5f5;color:#ccc;border-color:#e0e0e0}
.pagination-btn.pagination-disabled svg{stroke:#ccc}
.pagination-info{display:inline-flex;align-items:center;gap:.3rem;padding:.6rem 1.2rem;background:#fff;border-radius:8px;font-weight:600;font-size:.9rem;color:#333;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.pagination-current{color:#ff69b4;font-weight:700}
.pagination-separator{color:#ccc}
.pagination-total{color:#666}
.pagination-count{color:#999;font-weight:400;font-size:.85rem;margin-left:.3rem}

/* Content/Forms */
.content{max-width:600px;margin:0 auto;padding:1rem}
.form-row{display:flex;align-items:center;margin-bottom:1.25rem;gap:1rem}
.form-row label{flex:0 0 90px;font-size:15px;font-weight:500;color:#333}
.form-row input{flex:1;padding:12px 16px;font-size:15px;border:2px solid #f0d9fc;border-radius:10px;outline:none;transition:border-color .2s}
.form-row input:focus{border-color:#8a2be2}
.form-row input[readonly]{background:#f5f5f5;color:#999}
.form-group{margin-bottom:15px}
.form-group label{display:block;margin-bottom:5px;font-weight:700}
.form-group input,.register-form input,.register-form select{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;box-sizing:border-box}
.form-actions{margin-top:2rem;text-align:center}
.radio-group{display:flex;gap:1.5rem}
.radio-label{display:flex;align-items:center;gap:.5rem;font-size:15px;cursor:pointer}
.radio-label input[type=radio]{width:18px;height:18px;accent-color:#8a2be2}
.login-form,.register-form{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px rgba(0,0,0,.08)}
.login-links{text-align:center;margin-top:20px}
.login-links a{color:#007bff;text-decoration:none}
.login-links a:hover{text-decoration:underline}

/* Buttons */
.btn{display:inline-block;padding:12px 32px;font-size:15px;border:none;border-radius:25px;cursor:pointer;text-decoration:none;background:linear-gradient(135deg,#ff69b4,#8a2be2);color:#fff;transition:transform .2s,box-shadow .2s}
.btn:hover{transform:scale(1.02);box-shadow:0 4px 15px rgba(138,43,226,.3)}
.btn-primary{background:linear-gradient(135deg,#ff69b4,#8a2be2);color:#fff}
.btn-primary:hover{transform:scale(1.02);box-shadow:0 4px 15px rgba(138,43,226,.3)}
.btn-secondary{background:#6c757d;color:#fff}
.btn-outline{background:transparent;color:#666;border:2px solid #ddd;margin-left:10px}
.btn-outline:hover{border-color:#8a2be2;color:#8a2be2}

/* Messages */
.msg-error,.msg-success,.error-message,.success-message{padding:12px 16px;border-radius:10px;margin-bottom:1rem;font-size:14px}
.msg-error,.error-message{background:#fff0f0;color:#dc3545;border:1px solid #ffcdd2}
.msg-success,.success-message{background:#f0fff0;color:#28a745;border:1px solid #c3e6cb}
.hint{padding:12px 16px;border-radius:10px;margin-bottom:1rem;font-size:14px;background:#e7f3ff;color:#004085;border:1px solid #b8daff}
.hint-success{background:#d4edda;color:#155724;border-color:#c3e6cb}
.hint-error{background:#f8d7da;color:#721c24;border-color:#f5c6cb}
.hint-warning{background:#fff3cd;color:#856404;border-color:#ffeeba}

/* Empty State */
.empty-state{text-align:center;padding:50px 20px;background:#fff;border-radius:15px;box-shadow:0 4px 20px rgba(0,0,0,.1);color:#666}
.empty-state p{font-size:18px;margin-bottom:20px}

/* Search Results */
.no-result,.search-hint{background:#fff;border-radius:15px;padding:2rem;box-shadow:0 4px 20px rgba(0,0,0,.1)}
.no-result p,.search-hint p{font-size:16px;color:#666}
.search-hint h2{margin-bottom:1rem}

/* User Info */
.user-info{margin-bottom:30px;padding:20px;border:1px solid #ddd;border-radius:8px;background:#f9f9f9}
.user-info h2{margin-top:0;color:#333}
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px}
.info-item{padding:10px 0;border-bottom:1px solid #eee}
.info-item strong{color:#555}

/* Footer */
footer{background:linear-gradient(135deg,#8a2be2,#dda0dd);color:#fff;text-align:center;padding:1rem;margin-top:2rem}
footer p{margin-bottom:1rem}
footer a{color:#ff69b4;text-decoration:none}
footer a:hover{text-decoration:underline}

/* Responsive */
@media(max-width:768px){
.header-inner{flex-direction:column;gap:1rem}
.nav{gap:1rem}
.homelist{grid-template-columns:1fr}
.page-header h1{font-size:2rem}
.pagination{flex-direction:column;gap:.5rem}
.author-cards{grid-template-columns:repeat(1,350px)}
}
@media(min-width:1200px){.author-cards{grid-template-columns:repeat(4,250px)}}
@media(max-width:1199px) and (min-width:769px){.author-cards{grid-template-columns:repeat(2,300px)}}
@media(max-width:480px){
.form-row{flex-direction:column;align-items:flex-start;gap:.5rem}
.form-row label,.form-row input{flex:none;width:100%}
}

/* Not Found Page */
.notfound-container{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    min-height:calc(100vh - 200px);
    padding:2rem;
    text-align:center
}
.notfound-icon{
    width:min(60vh,300px);
    height:min(60vh,300px);
    color:#8a2be2;
    margin-bottom:2rem
}
.notfound-icon svg{
    width:100%;
    height:100%
}
.notfound-title{
    font-size:2.5rem;
    color:#1a1a2e;
    margin-bottom:1rem;
    font-weight:700
}
.notfound-message{
    font-size:1.2rem;
    color:#666;
    margin-bottom:.5rem
}
.notfound-hint{
    font-size:1rem;
    color:#999;
    margin-bottom:2rem
}
.notfound-links{
    display:flex;
    gap:1rem;
    flex-wrap:wrap;
    justify-content:center
}
.btn-home,.btn-browse{
    display:inline-block;
    padding:.75rem 2rem;
    border-radius:25px;
    text-decoration:none;
    font-weight:600;
    transition:all .3s
}
.btn-home{
    background:linear-gradient(135deg,#ff69b4,#8a2be2);
    color:#fff;
    box-shadow:0 4px 15px rgba(138,43,226,.3)
}
.btn-home:hover{
    transform:translateY(-2px);
    box-shadow:0 6px 20px rgba(138,43,226,.4)
}
.btn-browse{
    background:#fff;
    color:#8a2be2;
    border:2px solid #8a2be2
}
.btn-browse:hover{
    background:#8a2be2;
    color:#fff
}

