:root{
  --bg:#0b0d10;
  --panel:#11151b;
  --panel2:#0f1318;
  --text:#e7edf6;
  --muted:#a7b2c4;
  --line:#1f2733;
  --accent:#7dd3fc;
  --accent2:#a78bfa;
  --good:#34d399;
  --warn:#fbbf24;
  --bad:#fb7185;
  --shadow: 0 10px 30px rgba(0,0,0,.35);
  --radius: 18px;
  --radius2: 26px;
  --max: 1280px;
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Inter, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
}

/* Day theme */
[data-theme="day"]{
  --bg:#f6f7fb;
  --panel:#ffffff;
  --panel2:#f2f4f8;
  --text:#0f172a;
  --muted:#475569;
  --line:#e5e7eb;
  --accent:#2563eb;
  --accent2:#7c3aed;
  --shadow: 0 10px 30px rgba(2,6,23,.08);
}

/* =========================================================
   2D THEME SYSTEM
   data-theme: day | night
   data-world: selo | srok
   ========================================================= */

/* defaults */
body{
  --world-accent: var(--accent);
  --world-accent2: var(--accent2);

  --bg-image-night: url("/assets/bg-selo-night.png");
  --bg-image-day:   url("/assets/bg-selo-day.png");
}

/* world: Selo */
body[data-world="selo"]{
  --world-accent:  #b8924f;
  --world-accent2: #6b8e5a;

  --bg-image-night: url("/assets/bg-selo-night.png");
  --bg-image-day:   url("/assets/bg-selo-day.png");
}

/* world: Srok */
body[data-world="srok"]{
  --world-accent:  #7dd3fc;
  --world-accent2: #a78bfa;

  --bg-image-night: url("/assets/bg-srok-night.png");
  --bg-image-day:   url("/assets/bg-srok-day.png");
}

/* final image based on day/night */
body[data-theme="night"]{ --bg-image: var(--bg-image-night); }
body[data-theme="day"]{   --bg-image: var(--bg-image-day); }

/* ========================================================= */

*{box-sizing:border-box}
html,body{height:100%}

body{
  margin:0;
  font-family:var(--font);
  background:
    radial-gradient(1200px 700px at 70% -10%, rgba(125,211,252,.12), transparent 60%),
    radial-gradient(900px 600px at 20% 10%, rgba(167,139,250,.10), transparent 55%),
    radial-gradient(900px 600px at 80% 80%, rgba(52,211,153,.08), transparent 50%),
    var(--bg);
  color:var(--text);
  line-height:1.4;
  position: relative; /* for layering safety */
}

a{color:inherit; text-decoration:none}
button{font-family:inherit}
input, select{font-family:inherit}

.wrap{max-width:var(--max); margin:0 auto; padding:22px 18px 80px}
.wrap{ position: relative; }
.wrap > *{ position:relative; z-index:1; }

/* Top bar */
.top{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(14px);
  background: color-mix(in oklab, var(--bg) 80%, transparent);
  border-bottom:1px solid var(--line);
  padding:12px 18px;
}
.brand{
  display:flex; align-items:center; gap:12px; min-width: 210px;
}
.logo{
  width:36px; height:36px; border-radius:12px;
  background:
    radial-gradient(18px 18px at 30% 30%, rgba(125,211,252,.9), rgba(125,211,252,0) 60%),
    radial-gradient(22px 22px at 70% 70%, rgba(167,139,250,.8), rgba(167,139,250,0) 65%),
    linear-gradient(135deg, color-mix(in oklab, var(--panel) 40%, var(--accent) 60%), var(--panel));
  box-shadow: var(--shadow);
  border:1px solid color-mix(in oklab, var(--line) 70%, transparent);
}
.brand h1{font-size:14px; margin:0; letter-spacing:.4px}
.brand p{font-size:12px; margin:2px 0 0; color:var(--muted)}

.nav{
  display:flex; gap:8px; flex-wrap:wrap; justify-content:center;
}
.tab{
  border:1px solid var(--line);
  background: color-mix(in oklab, var(--panel) 65%, transparent);
  color:var(--muted);
  padding:10px 12px;
  border-radius:999px;
  font-size:13px;
  cursor:pointer;
  transition:.15s ease;
  display:inline-flex; align-items:center; gap:8px;
}
.tab:hover{transform: translateY(-1px); color:var(--text)}
.tab[aria-selected="true"]{
  color:var(--text);
  border-color: color-mix(in oklab, var(--world-accent) 55%, var(--line));
  background: linear-gradient(
    180deg,
    color-mix(in oklab, var(--world-accent) 18%, var(--panel)),
    color-mix(in oklab, var(--world-accent2) 14%, var(--panel))
  );
  box-shadow: 0 10px 25px rgba(0,0,0,.12);
}
.tab-admin{
  border-color: color-mix(in oklab, var(--accent2) 40%, var(--line));
}

.actions{display:flex; align-items:center; gap:10px; min-width:210px; justify-content:flex-end}
.pill{
  border:1px solid var(--line);
  background: color-mix(in oklab, var(--panel) 70%, transparent);
  padding:10px 12px;
  border-radius:999px;
  color:var(--muted);
  font-size:13px;
  display:inline-flex; align-items:center; gap:8px;
  cursor:pointer;
}
.pill:hover{color:var(--text)}

@media (max-width: 920px){
  .brand, .actions{min-width:unset}
}

.card{
  background: linear-gradient(180deg, var(--panel), color-mix(in oklab, var(--panel2) 85%, transparent));
  border:1px solid var(--line);
  border-radius: var(--radius2);
  box-shadow: var(--shadow);
  padding:18px;
}
.card h2{margin:0 0 10px; font-size:18px}
.card h3{margin:0 0 10px; font-size:15px; color:var(--muted); font-weight:600}
.muted{color:var(--muted)}

.grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:18px;
  margin-top:18px;
}
@media (max-width: 920px){
  .grid{grid-template-columns:1fr}
}

.hero{
  display:flex; gap:16px; align-items:stretch;
}
@media (max-width: 540px){
  .hero{flex-direction:column}
}
.photo{
  flex:0 0 240px;
  aspect-ratio: 3 / 4;
  border-radius: 22px;
  border:1px solid var(--line);
  overflow:hidden;
  background:
    radial-gradient(120px 120px at 30% 35%, rgba(125,211,252,.25), transparent 60%),
    radial-gradient(160px 160px at 70% 75%, rgba(167,139,250,.22), transparent 60%),
    linear-gradient(135deg, color-mix(in oklab, var(--panel) 40%, var(--accent) 60%), var(--panel));
  position:relative;
  min-height: 320px;
}
.photo:after{
  content:"ФОТО";
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-weight:800; letter-spacing:4px;
  color: color-mix(in oklab, var(--text) 35%, transparent);
  font-size:14px;
}

.heroMain{flex:1; display:flex; flex-direction:column; gap:10px}
.heroTitle{font-size:28px; margin:0; letter-spacing:.2px}
.heroSubtitle{margin:0; color:var(--muted)}
.ctaRow{display:flex; gap:10px; flex-wrap:wrap; margin-top:6px}

.btn{
  border:1px solid var(--line);
  background: color-mix(in oklab, var(--panel) 80%, transparent);
  color:var(--text);
  padding:10px 12px;
  border-radius: 999px;
  font-size:13px;
  cursor:pointer;
  transition:.15s ease;
  display:inline-flex; align-items:center; gap:8px;
}
.btn:hover{transform: translateY(-1px)}
.btn.primary{
  border-color: color-mix(in oklab, var(--world-accent) 60%, var(--line));
  background: linear-gradient(
    180deg,
    color-mix(in oklab, var(--world-accent) 25%, var(--panel)),
    color-mix(in oklab, var(--world-accent2) 18%, var(--panel))
  );
}
.btn.ghost{color:var(--muted)}

.search, .select{
  border:1px solid var(--line);
  background: color-mix(in oklab, var(--panel2) 70%, transparent);
  color: var(--text);
  padding:10px 12px;
  border-radius: 14px;
  outline:none;
  font-size:13px;
}
.search{min-width: 220px}
.select{min-width: 170px}
@media (max-width: 620px){
  .search,.select{min-width: unset; width:100%}
}

.list{display:flex; flex-direction:column; gap:10px}
.row{
  display:flex; gap:12px; align-items:flex-start; justify-content:space-between;
  padding:12px;
  border:1px solid var(--line);
  border-radius: 16px;
  background: color-mix(in oklab, var(--panel2) 70%, transparent);
}
.row:hover{border-color: color-mix(in oklab, var(--world-accent) 40%, var(--line))}
.rowLeft{min-width:0}
.rowTitle{margin:0; font-size:14px}
.rowMeta{margin:4px 0 0; font-size:12px; color:var(--muted)}

.chip{
  font-size:12px; color:var(--muted);
  border:1px solid var(--line);
  padding:6px 10px;
  border-radius:999px;
  white-space:nowrap
}
.chip.good{color: color-mix(in oklab, var(--good) 85%, var(--text)); border-color: color-mix(in oklab, var(--good) 35%, var(--line))}
.chip.warn{color: color-mix(in oklab, var(--warn) 85%, var(--text)); border-color: color-mix(in oklab, var(--warn) 35%, var(--line))}
.chip.bad{color: color-mix(in oklab, var(--bad) 85%, var(--text)); border-color: color-mix(in oklab, var(--bad) 35%, var(--line))}

.booksGrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:12px;
}
@media (max-width: 620px){
  .booksGrid{grid-template-columns:1fr}
}

.bookCard{
  border:1px solid var(--line);
  border-radius: 20px;
  padding:16px;
  background: color-mix(in oklab, var(--panel2) 70%, transparent);
  display:flex;
  gap:16px;
  cursor:pointer;
  transition:.15s ease;
  min-height: 200px;
  align-items:flex-start;
  position:relative;
}
.bookCard:hover{
  transform: translateY(-1px);
  border-color: color-mix(in oklab, var(--world-accent) 45%, var(--line));
}

.cover{
  width:120px; height:170px; border-radius: 12px;
  border:1px solid var(--line);
  background:
    radial-gradient(28px 28px at 30% 30%, rgba(125,211,252,.18), transparent 60%),
    radial-gradient(34px 34px at 70% 70%, rgba(167,139,250,.16), transparent 60%),
    linear-gradient(135deg, color-mix(in oklab, var(--panel) 35%, var(--accent) 65%), var(--panel));
  flex: 0 0 auto;
  position:relative;
  overflow:hidden;
}
.cover:after{
  content:"ОБЛОЖКА";
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-size:10px; letter-spacing:2px;
  color: color-mix(in oklab, var(--text) 30%, transparent);
  font-weight:800;
}
.bookInfo{min-width:0; display:flex; flex-direction:column; gap:6px}
.bookTitle{margin:0; font-size:14px}
.bookDesc{margin:6px 0 0; font-size:12px; color:var(--muted); display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden}
.bookMeta{display:flex; gap:8px; flex-wrap:wrap; margin-top:8px}

label{display:block; font-size:12px; color:var(--muted); margin:10px 0 6px}
.two{display:grid; grid-template-columns:1fr 1fr; gap:10px}

/* Form controls */
input, textarea, select{
  width:100%;
  padding:10px 12px;
  border-radius: 14px;
  border:1px solid var(--line);
  background: color-mix(in oklab, var(--panel2) 70%, transparent);
  color: var(--text);
  outline:none;
}
textarea{min-height:110px; resize:vertical}
@media (max-width: 520px){.two{grid-template-columns:1fr}}

.barWrap{margin-top:10px}
.bar{
  height:10px; border-radius:999px; border:1px solid var(--line);
  background: color-mix(in oklab, var(--panel2) 70%, transparent);
  overflow:hidden;
}
.bar > i{
  display:block;
  height:100%;
  width:0%;
  background: linear-gradient(90deg, var(--world-accent), var(--world-accent2));
}

/* Modal */
.modalBack{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.65);
  display:none;
  align-items:center;
  justify-content:center;
  padding:40px;
  z-index:100;
}
.modal{
  width: min(1230px, 92vw);
  margin: 40px auto;
  max-height: 90vh;
  background: linear-gradient(180deg, var(--panel), color-mix(in oklab, var(--panel2) 85%, transparent));
  border:1px solid var(--line);
  border-radius: 28px;
  box-shadow: 0 40px 120px rgba(0,0,0,.55);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.modalHead{
  flex: 0 0 auto;
  position: sticky;
  top: 0;
  z-index: 2;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:14px 16px;
  border-bottom:1px solid var(--line);
  background: color-mix(in oklab, var(--panel2) 85%, var(--panel));
  backdrop-filter: blur(10px);
}
.modalTitle{margin:0; font-size:14px}
.modalBody{
  flex: 1 1 auto;
  overflow:auto;
  padding:16px;
  -webkit-overflow-scrolling: touch;
}

.bookPage{
  display:flex;
  flex-direction:column;
  gap:12px;
}

/* Reviews grid */
.reviewsGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}
@media (max-width: 900px){
  .reviewsGrid{grid-template-columns:1fr}
}

.bookHero{
  border:1px solid var(--line);
  border-radius: 22px;
  padding:14px;
  background:
    radial-gradient(420px 220px at 20% 0%, rgba(125,211,252,.14), transparent 60%),
    radial-gradient(420px 220px at 80% 100%, rgba(167,139,250,.12), transparent 60%),
    linear-gradient(180deg, color-mix(in oklab, var(--panel2) 85%, transparent), transparent);
}

/* Book modal cover layout spacing */
.bookHero > div:first-child{
  display:flex;
  gap:22px;
  align-items:flex-start;
}

/* bigger cover only in modal */
.cover.modalCover{
  width: 220px;
  height: 330px;
  border-radius: 16px;
}
.cover.modalCover:after{ content:""; display:none; }

.ratingRow{display:flex; gap:10px; flex-wrap:wrap; margin-top:14px}
.rating{
  border:1px solid var(--line);
  border-radius: 999px;
  padding:8px 10px;
  font-size:12px;
  color:var(--muted);
  background: color-mix(in oklab, var(--panel2) 70%, transparent);
}
.rating strong{color:var(--text)}

.platforms{display:flex; gap:10px; flex-wrap:wrap; margin-top:12px}
@media (max-width: 900px){.bookPage{grid-template-columns:1fr}}

.kicker{font-size:12px; color:var(--muted); letter-spacing:.14em; text-transform:uppercase}
.hr{height:1px; background:var(--line); margin:14px 0}
.note{font-size:12px; color:var(--muted)}
.right{display:flex; gap:8px; align-items:center}

footer{margin-top:18px; color:var(--muted); font-size:12px; text-align:center;background: color-mix(in oklab, var(--panel) 92%, var(--bg));}

/* Sections visibility */
[data-view]{display:none}
[data-view].active{display:block}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{transition:none !important; scroll-behavior:auto !important}
}

#preBook, #preEdition{ width:100% }

/* Author avatar - header mini */
#authorAvatarMini{
  width: 32px;
  height: 32px;
  border-radius: 999px;
  object-fit: cover;
  display: block;
}

/* Author photo - main big */
#authorAvatarBig{
  width: 100%;
  max-width: 330px;
  max-height: 70vh;
  aspect-ratio: 1 / 1;
  border-radius: 24px;
  object-fit: cover;
  display: block;
}

/* ===== Awards block ===== */
.awardBlock{
  margin-top: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.awardItem{
  padding: 12px 14px;
  border-radius: 16px;
  background: linear-gradient(
    135deg,
    color-mix(in oklab, var(--world-accent) 40%, var(--panel)),
    color-mix(in oklab, var(--world-accent2) 40%, var(--panel))
  );
  border: 1px solid color-mix(in oklab, var(--world-accent2) 65%, var(--line));
  box-shadow: 0 10px 26px rgba(0,0,0,.4);
}

.awardItem:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(0,0,0,.35);
}

.awardText{
  margin: 0;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}

.linkRow { cursor: pointer; }
.linkRow:focus {
  outline: 2px solid color-mix(in oklab, var(--world-accent) 55%, transparent);
  outline-offset: 2px;
}

/* === Book cover zoom (modal) === */
.coverZoomWrap{
  position: relative;
  display: inline-block;
}
.coverZoomWrap .cover{ cursor: zoom-in; }

.coverZoomOverlay{
  position: absolute;
  z-index: 60;
  left: calc(100% + 14px);
  top: 0;
  width: 420px;
  height: 620px;
  border-radius: 18px;
  background-size: cover;
  background-position: center;
  border: 1px solid color-mix(in oklab, var(--line), transparent 30%);
  box-shadow: 0 24px 70px rgba(0,0,0,.55);
  opacity: 0;
  transform: translateY(6px) scale(.98);
  pointer-events: none;
  transition: opacity .14s ease, transform .14s ease;
}
.coverZoomWrap:hover .coverZoomOverlay{
  opacity: 1;
  transform: translateY(0) scale(1);
}
@media (max-width: 720px){
  .coverZoomOverlay{
    position: fixed;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%) scale(.98);
    width: min(92vw, 460px);
    height: min(92vh, 680px);
    opacity: 0;
  }
  .coverZoomWrap:hover .coverZoomOverlay{
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
  }
}

/* =========================
   RATING BADGES (книга)
   ========================= */
.ratingBadge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 12px;
  border-radius:999px;
  font-size:13px;
  font-weight:600;
  box-shadow:0 6px 18px rgba(0,0,0,.25);
  transition:.2s ease;
}
.ratingBadge:hover{ transform:translateY(-2px); }

/* ЛитРес */
.rating-litres{
  background:linear-gradient(135deg,#ff7a00,#ff9e3d);
  color:#fff;
}

/* LiveLib */
.rating-livelib{
  background:linear-gradient(135deg,#1e90ff,#5fb3ff);
  color:#fff;
}

/* Playlist image */
.playlistCover{
  width: 100%;
  display: block;
  border-radius: 16px;
  margin: 10px 0 8px;
  box-shadow: 0 10px 26px rgba(0,0,0,.35);
}

/* Toast */
.toastCopy{
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: linear-gradient(135deg, var(--world-accent), var(--world-accent2));
  color: #fff;
  padding: 10px 18px;
  border-radius: 999px;
  font-size: 13px;
  box-shadow: 0 12px 30px rgba(0,0,0,.4);
  opacity: 0;
  pointer-events: none;
  transition: .25s ease;
  z-index: 999;
}
.toastCopy.show{
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* Extra modal layout helpers */
.modalHero{
  display:flex;
  gap:24px;
  align-items:flex-start;
}
.modalCover{
  width: 280px;
  height: 420px;
  border-radius: 20px;
  background-size: cover;
  background-position: center;
  border:1px solid var(--line);
  flex:0 0 auto;
}
.modalText{ flex:1; }

.playlistRow{
  display:flex;
  gap:14px;
  align-items:center;
  margin-top:14px;
}
.playlistThumb{
  width:86px;
  height:86px;
  object-fit:cover;
  border-radius:16px;
  border:1px solid var(--line);
  box-shadow: 0 10px 26px rgba(0,0,0,.35);
  flex:0 0 auto;
}

/* awards under tagline (badges) */
.awardsInline{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}
.awardBadge{
  font-size:11px;
  padding:6px 10px;
  border-radius:999px;
  background: linear-gradient(
    135deg,
    color-mix(in oklab, var(--world-accent) 28%, var(--panel)),
    color-mix(in oklab, var(--world-accent2) 28%, var(--panel))
  );
  border:1px solid color-mix(in oklab, var(--world-accent2) 50%, var(--line));
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
  font-weight:600;
  white-space:nowrap;
}

/* ===== Awards in top-right corner of book cards ===== */
.bookAwardsCorner{
  position:absolute;
  top:12px;
  right:12px;
  display:flex;
  flex-direction:column;
  gap:4px;
  align-items:flex-end;
  max-width: 55%;
}
.bookAwardCorner{
  font-size:11px;
  padding:5px 8px;
  border-radius:10px;

  background: linear-gradient(
    135deg,
    color-mix(in oklab, var(--world-accent) 20%, var(--panel)),
    color-mix(in oklab, var(--world-accent2) 20%, var(--panel))
  );

  border:1px solid color-mix(in oklab, var(--world-accent2) 40%, var(--line));

  font-weight:600;

  max-width: 220px;
  line-height:1.25;

  display:-webkit-box;
  -webkit-line-clamp: 2;      /* максимум 2 строки */
  -webkit-box-orient: vertical;
  overflow:hidden;
  word-break: break-word;
}

/* mobile: awards corner constraints */
@media (max-width: 520px){
  .bookAwardsCorner{ max-width: 70%; }
}

/* ===== Smaller news modal image ===== */
#newsModalBody img{
  max-width: 360px;
  width: 100%;
  height: auto;
  border-radius: 18px;
  display: block;
  margin: 0 auto 16px;
  box-shadow: 0 12px 30px rgba(0,0,0,.35);
}

/* ===== News modal two-column layout ===== */
.newsModalGrid{
  display:grid;
  grid-template-columns: 360px 1fr;
  gap:20px;
  align-items:start;
}
.newsModalImage img{
  width:100%;
  border-radius:18px;
  box-shadow: 0 12px 30px rgba(0,0,0,.35);
}
.newsModalText{ line-height:1.6; }

/* mobile */
@media (max-width: 800px){
  .newsModalGrid{ grid-template-columns: 1fr; }
}

/* ===== News preview truncate ===== */
.newsPreview{
  display:-webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow:hidden;
}

/* ===== Big background image behind blocks ===== */
body::before{
  content:"";
  position: fixed;
  inset: 0;
  background: var(--bg-image) no-repeat center;
  background-size: cover;
  pointer-events: none;
  z-index: 0;
  opacity: 1;
}

/* ensure layers */
.top, .wrap{ position: relative; z-index: 1; }

/* =========================================================
   MOBILE / RESPONSIVE PATCH
   Добавь в конец styles.css
   ========================================================= */

/* 1) Шапка: переносы, кнопки, табы */
@media (max-width: 920px){
  .top{
    flex-wrap: wrap;
    gap: 10px;
    padding: 10px 12px;
  }

  .brand{
    min-width: unset;
    flex: 1 1 auto;
  }

  .nav{
    width: 100%;
    justify-content: flex-start;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 6px;
  }
  .nav::-webkit-scrollbar{ height: 0; }

  .actions{
    min-width: unset;
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 8px;
  }

  .pill{
    flex: 1 1 auto;
    justify-content: center;
    white-space: nowrap;
  }
}

/* 2) Общая сетка страниц: меньше отступы */
@media (max-width: 620px){
  .wrap{ padding: 16px 12px 72px; }
  .card{ padding: 14px; border-radius: 22px; }
  .grid{ gap: 12px; margin-top: 12px; }
}

/* 3) Hero (страница автора): картинка + текст */
@media (max-width: 540px){
  .hero{ gap: 12px; }
  #authorAvatarBig{
    max-width: 100%;
    max-height: 52vh;
    border-radius: 18px;
  }
  .heroTitle{ font-size: 22px; }
}

/* 4) Контролы в книгах (поиск/статус) — на мобилках в столбик */
@media (max-width: 620px){
  .right{
    flex-wrap: wrap;
    align-items: stretch;
  }
  .search{ width: 100%; min-width: unset; }
  .select{ width: 100%; min-width: unset; }
}

/* 5) Карточки книг: чтобы не "распухали" и текст читался */
@media (max-width: 520px){
  .bookCard{
    gap: 12px;
    padding: 12px;
    min-height: unset;
  }
  .cover{
    width: 92px;
    height: 132px;
  }
  .bookDesc{
    -webkit-line-clamp: 4;
  }

  /* награды в правом верхнем углу — не перекрывать контент */
  .bookAwardsCorner{
    top: 10px;
    right: 10px;
    max-width: 65%;
  }
}

/* 6) Модалки: меньше паддинги, удобнее скролл */
@media (max-width: 800px){
  .modalBack{
    padding: 14px;
    align-items: flex-start; /* на телефонах удобнее сверху */
  }
  .modal{
    width: 100%;
    max-height: calc(100vh - 28px);
    margin: 0;
    border-radius: 22px;
  }
  .modalHead{
    padding: 12px 12px;
  }
  .modalBody{
    padding: 12px;
  }
}

/* 7) Модалка новости: 2 колонки -> 1 колонка + норм размер */
@media (max-width: 800px){
  .newsModalGrid{
    grid-template-columns: 1fr;
    gap: 12px;
  }
  #newsModalBody img{
    max-width: 100%;
  }
}

/* 8) Зум-обложка: на мобилке только fixed-оверлей и без дерганий */
@media (max-width: 720px){
  .coverZoomWrap{ display: block; }
  .coverZoomOverlay{
    /* у тебя это уже есть, но закрепим поведение */
    left: 50%;
    top: 50%;
  }
}

/* 9) Кнопки в секции "где купить": на маленьких — на всю ширину */
@media (max-width: 520px){
  .btn{
    justify-content: center;
  }
  #buyLinks .btn{
    width: 100%;
  }
}

/* 10) Тост "Скопировано": не упирается в края */
@media (max-width: 520px){
  .toastCopy{
    width: calc(100vw - 24px);
    max-width: 420px;
    text-align: center;
  }
}

/* =========================================================
   MOBILE HEADER FIX
   ========================================================= */

@media (max-width: 920px){

  /* делаем табы компактнее */
  .tab{
    padding: 6px 10px;
    font-size: 12px;
    gap: 6px;
  }

  /* nav не переносится вниз столбиком */
  .nav{
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    gap: 6px;
    padding-bottom: 4px;
  }

  /* убираем скроллбар */
  .nav::-webkit-scrollbar{
    display: none;
  }

  /* чтобы табы не сжимались */
  .tab{
    flex: 0 0 auto;
    white-space: nowrap;
  }

  /* уменьшаем отступы header */
  .top{
    padding: 8px 12px;
  }

  .brand h1{
    font-size: 13px;
  }

  .brand p{
    font-size: 11px;
  }
}

/* 1) NEWS: компактное превью на мобилке */
@media (max-width: 520px){
  #newsList .rowMeta{
    display: -webkit-box;
    -webkit-line-clamp: 2;      /* 2 строки */
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.35;
  }

  #newsList .rowTitle{
    display: -webkit-box;
    -webkit-line-clamp: 1;      /* заголовок в 1 строку */
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
}
/* 2) NEWS: фильтр над лентой на мобилке */
@media (max-width: 800px){
  section[data-view="news"] .grid{
    display: flex;
    flex-direction: column;
    gap: 12px;
  }

  /* aside (фильтр) сверху */
  section[data-view="news"] .grid > aside.card{
    order: -1;
  }

  /* лента новостей ниже */
  section[data-view="news"] .grid > .card{
    order: 0;
  }
}
/* 3) BOOKS: награды не перекрывают описание */
.bookInfo{
  padding-right: 180px; /* резерв под правый угол с наградами */
}

@media (max-width: 720px){
  .bookInfo{ padding-right: 0; }

  .bookAwardsCorner{
    position: static;          /* убрать absolute */
    max-width: 100%;
    margin-top: 8px;
    align-items: flex-start;
  }

  .bookAwardCorner{
    max-width: 100%;
  }
}
/* 4) BOOK MODAL: hero в колонку на мобилке */
@media (max-width: 720px){
  .bookHero > div:first-child{
    flex-direction: column;
    gap: 14px;
    align-items: stretch;
  }

  .coverZoomWrap{
    align-self: center;
  }

  .cover.modalCover{
    width: 180px;
    height: 270px;
  }

  .ratingRow{
    gap: 8px;
    margin-top: 12px;
  }
}
@media (max-width: 720px){
  .bookAwardCorner{
    max-width: 100%;
    -webkit-line-clamp: 3;
  }
}

/* =========================================================
   iPad mini / small tablets: awards should NOT overlap text
   ========================================================= */

/* Диапазон iPad mini в портрете/ландшафте часто попадает сюда */
@media (max-width: 1024px){
  /* убираем резерв, если он у тебя есть где-то выше — и делаем награды "в потоке" */
  .bookInfo{
    padding-right: 0 !important;
  }

  .bookAwardsCorner{
    position: static !important;     /* вместо absolute */
    max-width: 100% !important;
    margin-top: 8px;
    align-items: flex-start;
  }

  /* длинные награды аккуратно режем */
  .bookAwardCorner{
    max-width: 100% !important;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
    line-height: 1.25;
  }
}

@media (max-width: 600px){
  footer{
    margin-top: 28px;
    padding: 16px 12px;
  }
}