/* ===== MidoManga — "ink & paper" theme (light default + dark "night reading") =====
   Distinct from the three streaming sisters: warm cream-paper canvas, black ink,
   manga-panel borders + a faint halftone/screentone texture, slab-serif display.
   Accent is monochrome (an ink "stamp"), not a colour gradient. */
:root, :root[data-theme="light"]{
  --bg:#f4ecd8;            /* warm cream paper */
  --bg-rgb:244,236,216;
  --bg-soft:#e7dcc2;       /* image placeholders */
  --surface:#fffdf7;       /* page-white panels floating on the cream */
  --surface-2:#f0e7d2;
  --text:#16140f;          /* ink */
  --muted:#6f6650;
  --line:rgba(22,20,15,.18);
  --line-hover:rgba(22,20,15,.5);
  --card-hover:#fffefb;
  --accent-solid:#16140f;  /* ink — buttons are ink on paper */
  --accent-text:#f7f1e2;
  --warn:#b07407;
  --dot:rgba(22,20,15,.10);     /* halftone screentone */
  --amb-op:.18;
  --cat-op:.14;
  --cat-shadow:rgba(70,55,20,.30);
  --focus-ring:rgba(22,20,15,.20);
  --shadow:0 16px 36px -22px rgba(60,45,15,.55);
  --shadow-card:0 8px 22px -16px rgba(60,45,15,.5);
  --panel:5px 5px 0 rgba(22,20,15,.13);   /* hard comic-panel offset */
}
:root[data-theme="dark"]{
  --bg:#15130d;            /* warm near-black (not the sisters' cool blacks) */
  --bg-rgb:21,19,13;
  --bg-soft:#221e14;
  --surface:#1d1910;
  --surface-2:#241f14;
  --text:#efe7d2;          /* off-white ink */
  --muted:#9a9079;
  --line:rgba(239,231,210,.16);
  --line-hover:rgba(239,231,210,.5);
  --card-hover:#241f14;
  --accent-solid:#efe7d2;
  --accent-text:#15130d;
  --warn:#e0b25a;
  --dot:rgba(239,231,210,.06);
  --amb-op:.20;
  --cat-op:.42;
  --cat-shadow:rgba(0,0,0,.6);
  --focus-ring:rgba(239,231,210,.22);
  --shadow:0 18px 50px -20px rgba(0,0,0,.8);
  --shadow-card:0 14px 34px -20px rgba(0,0,0,.75);
  --panel:5px 5px 0 rgba(0,0,0,.4);
}
:root{
  --font-display:'Zilla Slab',Georgia,'Times New Roman',serif;
  --font-body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --radius:6px;            /* manga panels are crisp, not rounded */
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  min-height:100vh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  transition:background .25s,color .25s;
}
/* halftone / screentone wash over the whole page */
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:radial-gradient(var(--dot) 1px,transparent 1.5px);background-size:7px 7px;opacity:.7}
a{color:inherit;text-decoration:none}
.accent{               /* "Manga" half of the wordmark = an inked stamp */
  background:var(--text);color:var(--bg);padding:0 .14em;border-radius:3px;
}

/* ambient ink wash (very subtle — paper shouldn't glow much) */
.amb{position:fixed;border-radius:50%;filter:blur(95px);opacity:var(--amb-op);z-index:0;pointer-events:none;animation:float 30s ease-in-out infinite}
.amb1{width:52vmax;height:52vmax;background:radial-gradient(circle,#8a7a4e,transparent 64%);top:-22vmax;left:-12vmax}
.amb2{width:48vmax;height:48vmax;background:radial-gradient(circle,#3a3322,transparent 64%);bottom:-22vmax;right:-14vmax;animation-delay:-10s}
.amb3{width:38vmax;height:38vmax;background:radial-gradient(circle,#b9a36a,transparent 64%);top:46%;left:58%;opacity:calc(var(--amb-op) * .7);animation-delay:-17s}
@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(6vmax,5vmax)}}

/* faint masked grid (kept very light so the halftone dominates) */
.grid-bg{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(circle at 50% 0%,#000,transparent 72%);mask-image:radial-gradient(circle at 50% 0%,#000,transparent 72%)}

/* decorative dancing-cat field in the margins (shared homelab brand) */
.catfield{position:fixed;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.bgcat{position:absolute;line-height:0}
.bgcat.flip{transform:scaleX(-1)}
.bgcat .drift{display:block;width:100%;animation:catdrift var(--dr,13s) ease-in-out infinite var(--dd,0s)}
.bgcat img{width:100%;height:auto;display:block;transform-origin:50% 90%;
  animation:dance var(--dur,.7s) ease-in-out infinite var(--d,0s);
  filter:drop-shadow(0 6px 12px var(--cat-shadow));opacity:var(--cat-op)}
@keyframes dance{0%{transform:translateY(0) rotate(-11deg)}50%{transform:translateY(-9px) rotate(11deg)}100%{transform:translateY(0) rotate(-11deg)}}
@keyframes catdrift{0%{transform:translate(0,0)}20%{transform:translate(16px,-22px)}45%{transform:translate(-12px,-38px)}70%{transform:translate(-26px,-14px)}85%{transform:translate(-8px,10px)}100%{transform:translate(0,0)}}
@media(max-width:1080px){.catfield{display:none}}

/* nav */
.nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:18px;
  padding:16px clamp(18px,4vw,44px);
  background:rgba(var(--bg-rgb),.82);backdrop-filter:blur(14px);border-bottom:2px solid var(--text)}
.brand{display:flex;align-items:center;gap:13px}
.brand-logo{width:48px;height:48px;object-fit:contain;transform-origin:50% 90%;
  animation:dance .7s ease-in-out infinite;filter:drop-shadow(0 5px 9px var(--cat-shadow))}
.brand-name{font-family:var(--font-display);font-weight:700;font-size:1.6rem;letter-spacing:-.01em}
.search{position:relative;margin-left:auto;flex:1;max-width:440px}
.search-ico{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--muted)}
.search input{width:100%;padding:12px 16px 12px 42px;border-radius:var(--radius);border:1.5px solid var(--text);
  background:var(--surface);color:var(--text);font-family:inherit;font-size:.95rem;outline:none;transition:.18s;box-shadow:var(--shadow-card)}
.search input::placeholder{color:var(--muted)}
.search input:focus{box-shadow:0 0 0 3px var(--focus-ring)}
.theme-btn{flex:0 0 auto;width:46px;height:46px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);
  border:1.5px solid var(--text);background:var(--surface);color:var(--text);cursor:pointer;transition:.16s;padding:0;box-shadow:var(--shadow-card)}
.theme-btn:hover{transform:translateY(-2px) rotate(-8deg)}
.theme-btn svg{width:20px;height:20px}

/* layout */
#app{position:relative;z-index:2;padding:0 0 64px}
.loading{padding:80px;text-align:center;color:var(--muted)}
.section{padding:0 clamp(16px,4vw,40px);margin-top:38px}
.section h2{font-family:var(--font-display);font-size:1.3rem;font-weight:700;letter-spacing:-.01em;margin:0 0 16px;
  display:inline-flex;align-items:center;gap:11px}
.section h2::before{content:"";width:16px;height:16px;background:var(--text);transform:rotate(45deg)} /* ink diamond tick */

/* hero */
.hero{position:relative;min-height:min(60vh,520px);display:flex;align-items:flex-end;overflow:hidden;border-bottom:2px solid var(--text)}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 22%;transform:scale(1.04);filter:grayscale(.25)}
.hero::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg,rgba(var(--bg-rgb),.97) 0%,rgba(var(--bg-rgb),.7) 44%,rgba(var(--bg-rgb),.18) 100%),
  linear-gradient(0deg,var(--bg) 1%,transparent 60%)}
.hero-inner{position:relative;z-index:3;padding:clamp(20px,5vw,56px);max-width:660px}
.hero h1{font-family:var(--font-display);font-size:clamp(1.9rem,4.6vw,3.2rem);font-weight:700;letter-spacing:-.02em;margin:0 0 14px;line-height:1.04}
.hero-meta{display:flex;gap:10px;align-items:center;color:var(--muted);font-size:.9rem;margin-bottom:16px;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:4px;border:1.5px solid var(--text);background:var(--surface);font-size:.76rem;font-weight:700}
.badge.rating{color:var(--warn);border-color:var(--warn)}
.hero-overview{color:var(--text);opacity:.78;font-size:.96rem;line-height:1.55;margin-bottom:22px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* buttons — ink on paper, hard panel shadow */
.btn{display:inline-flex;align-items:center;gap:9px;padding:12px 24px;border-radius:var(--radius);font-weight:700;font-size:.95rem;
  border:1.5px solid var(--text);cursor:pointer;transition:.14s;font-family:inherit}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--accent-solid);color:var(--accent-text);box-shadow:4px 4px 0 var(--line)}
.btn-primary:hover{transform:translate(-1px,-1px);box-shadow:6px 6px 0 var(--line)}
.btn-ghost{background:var(--surface);color:var(--text);box-shadow:var(--shadow-card)}
.btn-ghost:hover{background:var(--card-hover);transform:translateY(-2px)}

/* carousels */
.row-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.rail{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 4px 18px;scrollbar-width:thin;scrollbar-color:var(--text) transparent}
.rail::-webkit-scrollbar{height:8px}
.rail::-webkit-scrollbar-thumb{background:var(--line-hover);border-radius:999px}
.rail::-webkit-scrollbar-track{background:transparent}

/* cover card — a framed manga panel */
.card{position:relative;flex:0 0 auto;width:166px;scroll-snap-align:start;cursor:pointer;border-radius:var(--radius);
  overflow:hidden;background:var(--surface);border:1.5px solid var(--text);transition:transform .18s,box-shadow .18s;text-align:left;box-shadow:var(--panel)}
.card:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--line)}
.card .poster{width:100%;aspect-ratio:2/3;object-fit:cover;display:block;background:var(--bg-soft)}
.card .cap{padding:9px 11px 12px;border-top:1.5px solid var(--text)}
.card .cap .t{font-family:var(--font-display);font-size:.92rem;font-weight:700;line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card .cap .s{margin-top:4px;font-size:.72rem;color:var(--muted);display:flex;gap:7px;align-items:center}
.card .type{position:absolute;top:9px;left:9px;padding:2px 9px;border-radius:3px;font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;background:var(--accent-solid);color:var(--accent-text)}
.card .star{position:absolute;top:9px;right:9px;padding:2px 8px;border-radius:3px;font-size:.7rem;font-weight:800;background:rgba(var(--bg-rgb),.9);border:1px solid var(--text);color:var(--warn)}
.card .prog{position:absolute;left:0;right:0;bottom:0;height:5px;background:rgba(var(--bg-rgb),.55)}
.card .prog i{display:block;height:100%;background:var(--text)}

/* grid (search results) */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:18px;padding:6px 0}
.grid .card{width:auto;flex:initial}

/* ===== detail view ===== */
.detail-wrap{padding:0 0 40px}
.detail{display:flex;gap:30px;padding:28px clamp(16px,4vw,40px);flex-wrap:wrap}
.detail .poster-lg{width:230px;border-radius:var(--radius);border:1.5px solid var(--text);box-shadow:var(--panel);flex:0 0 auto;background:var(--bg-soft)}
.detail .info{flex:1;min-width:280px}
.detail .info h1{font-family:var(--font-display);font-size:clamp(1.6rem,3.6vw,2.5rem);font-weight:700;letter-spacing:-.01em;margin:0 0 12px}
.detail .meta{display:flex;gap:10px;flex-wrap:wrap;align-items:center;color:var(--muted);font-size:.9rem;margin-bottom:16px}
.detail .overview{color:var(--text);opacity:.84;line-height:1.65;font-size:.97rem;max-width:760px}
.genres{display:flex;gap:8px;flex-wrap:wrap;margin:16px 0}
.genres span{padding:5px 13px;border-radius:4px;background:var(--surface);border:1.5px solid var(--text);font-size:.76rem;color:var(--text);font-weight:600}
.back{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-size:.9rem;padding:18px clamp(16px,4vw,40px) 0;cursor:pointer;font-weight:700}
.back:hover{color:var(--text)}

/* chapter list */
.ch-controls{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin:24px 0 16px}
.sel{position:relative}
.sel select{appearance:none;padding:11px 40px 11px 18px;border-radius:var(--radius);border:1.5px solid var(--text);background:var(--surface);color:var(--text);font-family:inherit;font-size:.9rem;font-weight:700;cursor:pointer;outline:none;box-shadow:var(--shadow-card)}
.sel::after{content:"";position:absolute;right:16px;top:50%;width:7px;height:7px;border-right:2px solid var(--text);border-bottom:2px solid var(--text);transform:translateY(-70%) rotate(45deg);pointer-events:none}
.chips{display:flex;gap:8px;align-items:center}
.chapters{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px;padding:6px clamp(16px,4vw,40px) 0}
.ch{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:13px 15px;border-radius:var(--radius);border:1.5px solid var(--text);background:var(--surface);cursor:pointer;transition:.14s;text-align:left;box-shadow:var(--shadow-card)}
.ch:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--line)}
.ch.reading{background:var(--surface-2)}
.ch .cn{font-family:var(--font-display);font-size:.95rem;font-weight:700}
.ch .ct{font-size:.74rem;color:var(--muted);margin-top:2px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.ch .cg{font-size:.66rem;color:var(--muted);white-space:nowrap}

/* ===== reader view ===== */
.reader{min-height:100vh}
.rbar{position:sticky;top:0;z-index:60;display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding:11px clamp(12px,3vw,28px);background:rgba(var(--bg-rgb),.92);backdrop-filter:blur(12px);border-bottom:2px solid var(--text)}
.rbar .rtitle{font-family:var(--font-display);font-weight:700;font-size:1rem;max-width:38vw;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rbar .spacer{flex:1}
.rbtn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:38px;min-width:38px;padding:0 12px;border-radius:var(--radius);
  border:1.5px solid var(--text);background:var(--surface);color:var(--text);font-family:inherit;font-weight:700;font-size:.85rem;cursor:pointer;transition:.14s;box-shadow:var(--shadow-card)}
.rbtn:hover:not(:disabled){transform:translateY(-1px)}
.rbtn:disabled{opacity:.4;cursor:not-allowed}
.rbtn.toggle.active{background:var(--accent-solid);color:var(--accent-text)}
.rcount{font-weight:700;font-size:.85rem;color:var(--muted);min-width:64px;text-align:center}

/* paged */
.page-view{position:relative;display:flex;justify-content:center;align-items:flex-start;padding:18px 0 70px;min-height:calc(100vh - 60px)}
.page-view img{max-width:100%;max-height:calc(100vh - 120px);width:auto;object-fit:contain;display:block;background:var(--bg-soft);border:1px solid var(--line)}
.page-nav{position:fixed;top:0;bottom:0;width:32%;z-index:55;cursor:pointer;display:flex;align-items:center;border:0;background:transparent;color:var(--text);opacity:0;transition:opacity .15s}
.page-nav:hover{opacity:.8}
.page-nav.prev{left:0;justify-content:flex-start;padding-left:14px;background:linear-gradient(90deg,rgba(var(--bg-rgb),.5),transparent)}
.page-nav.next{right:0;justify-content:flex-end;padding-right:14px;background:linear-gradient(270deg,rgba(var(--bg-rgb),.5),transparent)}
.page-nav svg{width:42px;height:42px}
.page-nav:disabled{display:none}

/* long-strip */
.strip{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 0 80px}
.strip img{width:min(860px,100%);height:auto;display:block;background:var(--bg-soft)}

.rfoot{display:flex;justify-content:center;gap:12px;padding:8px 0 60px}

.empty{padding:70px 20px;text-align:center;color:var(--muted)}
.foot{position:relative;z-index:2;text-align:center;padding:28px;color:var(--muted);font-size:.82rem;border-top:2px solid var(--text)}
.foot a{color:var(--text);font-weight:700;text-decoration:underline}

@media(max-width:560px){
  .brand-name{display:none}
  .card{width:142px}
  .detail .poster-lg{width:150px}
  .rbar .rtitle{max-width:30vw}
  .page-view img{max-height:calc(100vh - 96px)}
}
