/*
Theme Name: Thutasone Library
Theme URI: https://thutasone.com/
Author: Thutasone
Author URI: https://thutasone.com/
Description: Clean custom theme for Ebook & Audiobook library (no license checks). Grid cards + modal preview + PDF & audio player.
Version: 1.2.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: thutasone-library
Tags: custom-background, custom-logo, custom-menu, featured-images, responsive-layout
*/

:root{
  --bg:#f5f7fb;
  --panel:#ffffff;
  --panel2:#ffffff;
  --text:#111827;
  --muted:#6b7280;
  --brand:#ff3b30;
  --ring:rgba(255,59,48,.18);
  --shadow:0 10px 30px rgba(17,24,39,.10);
}

body{margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;}
a{color:inherit;text-decoration:none}
a:hover{color:var(--brand)}

.container{max-width:1200px;margin:0 auto;padding:16px;}
.site-header{position:sticky;top:0;z-index:50;background:rgba(11,18,32,.85);backdrop-filter:blur(10px);border-bottom:1px solid rgba(148,163,184,.15)}
.brand{display:flex;align-items:center;gap:10px;font-weight:700}
.brand .dot{width:10px;height:10px;border-radius:999px;background:var(--brand);box-shadow:0 0 0 6px var(--ring)}
.nav{display:flex;gap:14px;flex-wrap:wrap}
.nav a{padding:10px 10px;border-radius:12px;color:var(--muted)}
.nav a:hover{background:rgba(148,163,184,.08);color:var(--text)}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:12px}

.search{display:flex;align-items:center;gap:10px;background:rgba(148,163,184,.08);border:1px solid rgba(148,163,184,.15);border-radius:14px;padding:8px 12px;min-width:240px}
.search input{width:100%;border:0;outline:0;background:transparent;color:var(--text)}

.grid{display:grid;gap:12px}
/* Mobile: 3 columns */
.grid{grid-template-columns:repeat(3,minmax(0,1fr))}
/* Tablet: 4 columns */
@media (min-width:768px){.grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
/* Desktop: 6 columns */
@media (min-width:1100px){.grid{grid-template-columns:repeat(6,minmax(0,1fr))}}

.card{background:rgba(148,163,184,.06);border:1px solid rgba(148,163,184,.14);border-radius:16px;overflow:hidden;cursor:pointer;transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;}
.card:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,0,0,.35);border-color:rgba(56,189,248,.35)}
.cover{aspect-ratio:2/3;background:rgba(148,163,184,.08);display:block;width:100%;object-fit:cover}
.card-body{padding:10px}
.title{font-size:13px;line-height:1.25;font-weight:650;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:32px}
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);margin-top:8px}

.section-title{display:flex;align-items:center;justify-content:space-between;margin:6px 0 12px}
.section-title h1,.section-title h2{margin:0;font-size:18px}

/* Modal */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:16px;background:rgba(0,0,0,.6);z-index:9999}
.modal.open{display:flex}
.modal-card{width:min(820px,100%);background:var(--panel);border:1px solid rgba(148,163,184,.18);border-radius:20px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.55)}
.modal-top{display:flex;gap:14px;padding:14px;border-bottom:1px solid rgba(148,163,184,.15)}
.modal-top img{width:120px;aspect-ratio:2/3;object-fit:cover;border-radius:14px;border:1px solid rgba(148,163,184,.18)}
.modal-meta{flex:1;min-width:0}
.modal-meta h3{margin:0 0 6px;font-size:18px}
.modal-meta p{margin:0;color:var(--muted);font-size:13px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.modal-actions{display:flex;gap:10px;flex-wrap:wrap;padding:14px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:14px;padding:10px 12px;font-weight:650;font-size:13px;border:1px solid rgba(148,163,184,.18);background:rgba(148,163,184,.08);color:var(--text);transition:transform .12s ease, background .12s ease, border-color .12s ease}
.btn:hover{background:rgba(148,163,184,.12);border-color:rgba(56,189,248,.35)}
.btn:active{transform:scale(.98)}
.btn-primary{background:rgba(56,189,248,.15);border-color:rgba(56,189,248,.35)}
.btn-danger{background:rgba(248,113,113,.12);border-color:rgba(248,113,113,.35)}

.single-hero{display:flex;gap:18px;align-items:flex-start;background:rgba(148,163,184,.06);border:1px solid rgba(148,163,184,.14);border-radius:20px;padding:14px}
.single-hero img{width:160px;aspect-ratio:2/3;object-fit:cover;border-radius:16px;border:1px solid rgba(148,163,184,.18)}
.single-content{color:var(--text);line-height:1.8}
.single-content p{color:var(--text)}
.player{margin-top:14px;background:rgba(148,163,184,.06);border:1px solid rgba(148,163,184,.14);border-radius:16px;padding:12px}
.player iframe{width:100%;height:80vh;border:0;border-radius:12px;background:#000}

.footer{border-top:1px solid rgba(148,163,184,.15);color:var(--muted);padding:18px 0;margin-top:30px}


/* Language toggle + Ads */
.lang-toggle{
  display:flex;
  align-items:center;
  gap:6px;
  padding:8px 10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:var(--text);
  border-radius:12px;
  cursor:pointer;
  font-size:13px;
}
.lang-toggle:hover{ background:rgba(255,255,255,.1); }

.tl-ad{
  margin: 14px auto;
  max-width: 100%;
}
.tl-ad ins, .tl-ad iframe { max-width: 100%; }


/* Header (screenshot-like) */
.site-header{position:sticky;top:0;z-index:50;background:rgba(245,247,251,.92);backdrop-filter:blur(10px);border-bottom:1px solid rgba(17,24,39,.08)}
.topbar{display:flex;align-items:center;gap:12px;padding:10px 0}
.hamburger{border:0;background:transparent;font-size:20px;padding:8px 10px;border-radius:10px;cursor:pointer}
.hamburger:hover{background:rgba(17,24,39,.06)}
.top-search{flex:1;display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid rgba(17,24,39,.08);border-radius:999px;padding:10px 14px;box-shadow:0 1px 0 rgba(17,24,39,.02)}
.top-search input{border:0;outline:none;background:transparent;width:100%;font-size:14px}
.sicon{opacity:.6}
.top-icons{display:flex;align-items:center;gap:8px}
.icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:999px;border:1px solid rgba(17,24,39,.10);background:var(--panel);font-size:13px}
.icon:hover{border-color:rgba(255,59,48,.35);box-shadow:0 0 0 4px var(--ring)}
.pill{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(17,24,39,.10);background:var(--panel);padding:7px 10px;border-radius:999px;font-size:12px}
.userpill{font-weight:700}
.chipnav{display:flex;gap:10px;overflow:auto;padding:6px 0 12px}
.chipnav::-webkit-scrollbar{height:8px}
.chip{white-space:nowrap;color:var(--muted);font-size:13px;padding:8px 0;border-bottom:2px solid transparent}
.chip:hover{color:var(--text)}
.chip.active{color:var(--brand);border-bottom-color:var(--brand)}
.mobile-nav{display:none;flex-direction:column;gap:6px;padding:10px 0 14px}
.mobile-nav.open{display:flex}
.mobile-nav a{padding:10px 12px;border-radius:10px;background:var(--panel);border:1px solid rgba(17,24,39,.08)}

/* Sections */
.home-section{margin:20px 0}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.section-head h2{margin:0;font-size:16px}
.seeall{font-size:12px;color:var(--brand)}

/* Hero slider */
.hero{margin-top:10px}
.hero-slider{position:relative;overflow:hidden;border-radius:18px}
.hero-track{display:flex;width:200%;transition:transform .45s ease}
.hero-slide{width:50%;min-height:140px;display:flex;align-items:center;justify-content:flex-start;padding:26px;box-shadow:var(--shadow)}
.hero-purple{background:#5b21b6;color:#fff}
.hero-magenta{background:#9f1239;color:#fff}
.hero-title{font-size:20px;font-weight:800;margin-bottom:6px}
.hero-sub{opacity:.9;font-size:13px}
.hero-content.center{width:100%;text-align:center}
.hero-btn{display:inline-block;margin-top:10px;background:#fff;color:#111827;padding:9px 14px;border-radius:10px;font-weight:700;font-size:13px}
.hero-dots{position:absolute;left:0;right:0;bottom:10px;display:flex;gap:8px;justify-content:center}
.hero-dots .dot{width:7px;height:7px;border-radius:999px;background:rgba(255,255,255,.5)}
.hero-dots .dot.active{background:#fff}

/* Horizontal scroll rows */
.hscroll{display:flex;gap:14px;overflow:auto;padding-bottom:8px}
.hscroll::-webkit-scrollbar{height:10px}
.muted{color:var(--muted)}
.cat-pill{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:72px}
.cat-img{width:54px;height:54px;border-radius:14px;overflow:hidden;background:rgba(17,24,39,.06);border:1px solid rgba(17,24,39,.08)}
.cat-img img{width:100%;height:100%;object-fit:cover}
.cat-ph{display:block;width:100%;height:100%}
.cat-name{font-size:12px;color:var(--muted);max-width:72px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.cards .mini-card{min-width:120px;max-width:120px;border-radius:14px;overflow:hidden;background:var(--panel);border:1px solid rgba(17,24,39,.08);box-shadow:0 2px 10px rgba(17,24,39,.06);cursor:pointer}
.cards .mini-card img{width:100%;height:160px;object-fit:cover;display:block}
.cards .mini-card:hover{transform:translateY(-2px);box-shadow:0 14px 26px rgba(17,24,39,.12)}

.authors .author-pill{min-width:74px;display:flex;flex-direction:column;align-items:center;gap:8px}
.author-avatar{width:54px;height:54px;border-radius:999px;overflow:hidden;border:3px solid rgba(255,59,48,.22);background:var(--panel)}
.author-avatar img{width:100%;height:100%;object-fit:cover}
.author-name{font-size:12px;color:var(--muted);max-width:80px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Blog */
.blog-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.blog-card{background:var(--panel);border:1px solid rgba(17,24,39,.08);border-radius:16px;overflow:hidden;box-shadow:0 2px 10px rgba(17,24,39,.06)}
.blog-thumb{height:140px;background:rgba(17,24,39,.06)}
.blog-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.blog-body{padding:12px}
.blog-tag{display:inline-block;font-size:10px;font-weight:700;color:#1d4ed8;background:#e0e7ff;padding:4px 7px;border-radius:999px;margin-bottom:8px}
.blog-title{font-size:13px;font-weight:800;line-height:1.25}
.blog-card:hover{transform:translateY(-2px);box-shadow:0 14px 26px rgba(17,24,39,.12)}

@media (max-width: 1000px){
  .blog-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 640px){
  .top-icons .icon{display:none}
  .chipnav{gap:14px}
  .blog-grid{grid-template-columns:1fr}
}


/* Term listing pages (Genres/Writers) */
.term-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap:14px;
  padding: 0 16px 24px;
}
.term-card{
  display:flex;
  gap:12px;
  align-items:center;
  text-decoration:none;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  padding: 12px;
}
.term-thumb{
  width:56px;
  height:56px;
  border-radius: 14px;
  overflow:hidden;
  flex:0 0 auto;
  background: rgba(255,255,255,0.06);
}
.term-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.term-ph{ display:block; width:100%; height:100%; background: rgba(255,255,255,0.10); }
.term-meta{ display:flex; flex-direction:column; gap:4px; min-width:0; }
.term-name{ font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.term-count{ font-size:12px; opacity:0.7; }

.writer-card .writer-avatar{
  width:56px;
  height:56px;
  border-radius: 50%;
  overflow:hidden;
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,0.06);
  border: 2px solid rgba(255,255,255,0.10);
}
.writer-card .writer-avatar img{ width:100%; height:100%; object-fit:cover; display:block; }
.author-initials{ font-weight:800; letter-spacing:0.5px; }
