/* Endcru — общие стили сайта (главная + страницы книг/автора) */
:root{
  --void:#0a0908;
  --ink:#100e0c;
  --panel:#16130f;
  --ash:#1f1a15;
  --line:rgba(201,168,106,.18);
  --gold:#c9a86a;
  --gold-bright:#e3c486;
  --ember:#c1272d;
  --ember-bright:#e0433b;
  --ember-glow:rgba(193,39,45,.35);
  --bone:#ece4d6;
  --bone-soft:#cabfac;
  --muted:#8d8275;
  --muted-2:#6b6258;
  --maxw:1120px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--void);
  color:var(--bone);
  font-family:'Lora',Georgia,serif;
  font-size:17px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}
body::after{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

h1,h2,h3,.display{font-family:'Forum',serif;font-weight:400;letter-spacing:.02em;line-height:1.08}
.label{
  font-family:'Forum',serif;font-size:13px;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);opacity:.85;
}
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}

@keyframes rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.reveal{animation:rise .9s cubic-bezier(.2,.7,.2,1) both}

/* HERO */
.hero{position:relative;min-height:74vh;display:flex;align-items:flex-end;
  padding-bottom:0;overflow:hidden;border-bottom:1px solid var(--line)}
.hero__bg{position:absolute;inset:0;background:
   url('../images/hero-cosmos.jpg') center 28%/cover no-repeat;
   transform:scale(1.04);filter:saturate(.92)}
.hero__scrim{position:absolute;inset:0;background:
   radial-gradient(120% 90% at 50% 18%, rgba(193,39,45,.16), transparent 55%),
   linear-gradient(180deg, rgba(10,9,8,.45) 0%, rgba(10,9,8,.18) 38%, rgba(10,9,8,.82) 82%, var(--void) 100%)}
.hero__inner{position:relative;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px 54px;
  display:flex;align-items:center;gap:30px}
.hero__avatar{width:128px;height:128px;border-radius:50%;flex:0 0 auto;
  background:url('../images/tild3865-3731-4366-b337-323566353733__endcru_final.png') center/cover;
  border:1px solid var(--gold);box-shadow:0 0 0 5px rgba(10,9,8,.6), 0 0 38px var(--ember-glow);}
.hero__title{font-size:clamp(58px,10vw,128px);color:var(--bone);
  text-shadow:0 2px 40px rgba(0,0,0,.6);}
.hero__sub{margin-top:8px;color:var(--bone-soft);font-size:18px;letter-spacing:.02em}
.hero__sub b{color:var(--gold-bright);font-weight:500}

/* SOCIAL BAR */
.socialbar{border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,rgba(193,39,45,.10),transparent)}
.socialbar .container{display:flex;justify-content:center;gap:26px;padding-top:20px;padding-bottom:20px}
.soc{width:42px;height:42px;display:grid;place-items:center;border:1px solid var(--line);
  border-radius:50%;color:var(--bone-soft);transition:.35s}
.soc svg{width:19px;height:19px;fill:currentColor}
.soc:hover{color:var(--void);background:var(--gold);border-color:var(--gold);
  box-shadow:0 0 26px rgba(201,168,106,.4);transform:translateY(-3px)}

/* BOOK BLOCKS */
.book{position:relative;padding:96px 0;border-bottom:1px solid var(--line)}
.book::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 70% at var(--gx,18%) 40%, rgba(193,39,45,.10), transparent 60%)}
.book .grid{position:relative;display:grid;grid-template-columns:480px 1fr;gap:64px;align-items:center}
.book.rev .grid{grid-template-columns:1fr 480px}
.book.rev .book__media{order:2}
.book__media{position:relative;aspect-ratio:1/1;border:1px solid var(--line);
  background:#000;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.book__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s ease;filter:saturate(.95) contrast(1.03)}
.book:hover .book__media img{transform:scale(1.05)}
.book__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(10,9,8,.55));pointer-events:none}
.book__title{font-size:clamp(34px,4.4vw,52px);color:var(--bone);margin:18px 0 22px}
.book__title .dot{color:var(--ember-bright)}
.book__text{color:var(--bone-soft);font-size:16.5px;line-height:1.78}
.book__text p{margin-bottom:14px}
.book__cta{margin-top:30px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.btn{font-family:'Forum',serif;letter-spacing:.16em;text-transform:uppercase;font-size:15px;
  padding:14px 36px;border:1px solid var(--gold);color:var(--gold-bright);
  transition:.4s;background:transparent;position:relative}
.btn:hover{background:var(--gold);color:var(--void);box-shadow:0 0 34px rgba(201,168,106,.45)}
.status{font-family:'Forum',serif;letter-spacing:.22em;text-transform:uppercase;font-size:12.5px;
  color:var(--muted);border:1px dashed var(--line);padding:9px 18px}

/* TELEGRAM FEED */
.feed{padding:100px 0;border-bottom:1px solid var(--line);position:relative;text-align:center}
.feed__head{margin-bottom:54px}
.feed__title{font-size:clamp(34px,5vw,56px);color:var(--bone);margin:14px 0 0}
.feed__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:left}
.tg{position:relative;background:linear-gradient(180deg,var(--panel),var(--ink));
  border:1px solid var(--line);padding:30px 28px 26px;transition:.4s;overflow:hidden}
.tg::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--ember);opacity:.8}
.tg:hover{transform:translateY(-6px);border-color:rgba(201,168,106,.4);
  box-shadow:0 24px 60px rgba(0,0,0,.55), 0 0 30px var(--ember-glow)}
.tg__meta{display:flex;align-items:center;gap:10px;margin-bottom:16px;color:var(--gold);
  font-family:'Forum',serif;letter-spacing:.16em;text-transform:uppercase;font-size:12px}
.tg__meta svg{width:16px;height:16px;fill:var(--gold)}
.tg__text{color:var(--bone-soft);font-size:16px;line-height:1.7;min-height:118px}
.tg__date{margin-top:18px;color:var(--muted-2);font-size:13px;letter-spacing:.05em}
.tg__more{margin-top:14px;display:inline-block;color:var(--gold-bright);font-size:13px;
  letter-spacing:.08em;border-bottom:1px solid var(--line);padding-bottom:2px}
.feed__cta{margin-top:54px}

/* CHARACTERS */
.chars{padding:100px 0;border-bottom:1px solid var(--line);text-align:center;position:relative}
.chars__title{font-size:clamp(34px,5vw,56px);color:var(--bone);margin:14px 0 56px}
.chars__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:left}
.char{position:relative;aspect-ratio:9/16;overflow:hidden;border:1px solid var(--line);background:#000}
.char img{width:100%;height:100%;object-fit:cover;transition:transform 1s ease;filter:grayscale(.15) contrast(1.05)}
.char:hover img{transform:scale(1.07);filter:none}
.char__scrim{position:absolute;inset:0;background:
  linear-gradient(180deg,transparent 38%,rgba(10,9,8,.5) 64%,rgba(10,9,8,.96) 100%)}
.char__body{position:absolute;left:0;right:0;bottom:0;padding:20px 18px}
.char__name{font-family:'Forum',serif;font-size:23px;color:var(--bone);letter-spacing:.04em}
.char__name::after{content:"";display:block;width:26px;height:1px;background:var(--gold);margin:8px 0 0;
  transition:width .5s ease}
.char:hover .char__name::after{width:54px}
.char__descr{color:var(--bone-soft);font-size:13.5px;line-height:1.55;margin-top:10px;
  max-height:0;opacity:0;overflow:hidden;transition:.55s ease}
.char:hover .char__descr{max-height:120px;opacity:1}

/* FOOTER */
.footer{padding:80px 0 70px;text-align:center;position:relative;
  background:radial-gradient(80% 130% at 50% 0%, rgba(193,39,45,.14), transparent 60%)}
.footer__text{font-family:'Forum',serif;font-size:clamp(22px,3vw,30px);color:var(--bone);
  max-width:620px;margin:0 auto 34px;line-height:1.4}
.footer .socs{display:flex;justify-content:center;gap:24px}
.footer .soc{width:50px;height:50px}
.footer .soc svg{width:22px;height:22px}
.footer__sign{margin-top:46px;color:var(--muted-2);font-size:12.5px;letter-spacing:.2em;
  text-transform:uppercase;font-family:'Forum',serif}

/* RESPONSIVE */
@media(max-width:900px){
  .book .grid,.book.rev .grid{grid-template-columns:1fr;gap:34px}
  .book.rev .book__media{order:0}
  .book__media{max-width:440px;margin:0 auto}
  .feed__grid{grid-template-columns:1fr;max-width:460px;margin:0 auto}
  .chars__grid{grid-template-columns:repeat(2,1fr)}
  .hero__inner{flex-direction:column;align-items:flex-start;gap:20px}
  .hero__avatar{width:96px;height:96px}
}
@media(max-width:520px){
  .chars__grid{grid-template-columns:1fr 1fr;gap:12px}
  .char__descr{max-height:120px;opacity:1}
}

/* --- вторичная кнопка (Купить рядом с Подробнее) --- */
.btn--soft{border-color:var(--line);color:var(--bone-soft)}
.btn--soft:hover{background:transparent;border-color:var(--gold);color:var(--gold-bright);box-shadow:none}

/* --- навигация в подвале --- */
.footer__nav{display:flex;justify-content:center;gap:28px;margin-top:30px;flex-wrap:wrap}
.footer__nav a{font-family:'Forum',serif;letter-spacing:.14em;text-transform:uppercase;font-size:13px;
  color:var(--bone-soft);border-bottom:1px solid var(--line);padding-bottom:3px;transition:.3s}
.footer__nav a:hover{color:var(--gold-bright);border-color:var(--gold)}

/* === страница книги / автора === */
.subhero{position:relative;padding:80px 0 70px;border-bottom:1px solid var(--line);overflow:hidden}
.subhero::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(70% 80% at 30% 20%,rgba(193,39,45,.14),transparent 60%)}
.crumb{position:relative;font-family:'Forum',serif;letter-spacing:.16em;text-transform:uppercase;font-size:12px;
  color:var(--muted);margin-bottom:34px}
.crumb a{color:var(--gold);border-bottom:1px solid var(--line);padding-bottom:2px}
.crumb a:hover{color:var(--gold-bright)}
.bookgrid{position:relative;display:grid;grid-template-columns:360px 1fr;gap:60px;align-items:start}
.bookcover{position:relative;aspect-ratio:1/1;border:1px solid var(--line);overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.6)}
.bookcover img{width:100%;height:100%;object-fit:cover}
.bookcover::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(10,9,8,.5));pointer-events:none}
.booktitle{font-size:clamp(36px,5vw,60px);color:var(--bone);margin:16px 0 22px}
.booktitle .dot{color:var(--ember-bright)}
.epigraph{border-left:2px solid var(--ember);padding:6px 0 6px 22px;margin:0 0 26px;
  color:var(--bone-soft);font-style:italic;font-size:18px;line-height:1.6}
.epigraph cite{display:block;margin-top:10px;font-style:normal;font-size:13px;letter-spacing:.08em;color:var(--muted)}
.cta-row{display:flex;gap:18px;flex-wrap:wrap;margin-top:8px}
.section{padding:84px 0;border-bottom:1px solid var(--line);position:relative}
.section__inner{max-width:760px;margin:0 auto}
.prose{color:var(--bone-soft);font-size:17px;line-height:1.85}
.prose p{margin-bottom:18px}
.chap{font-family:'Forum',serif;font-size:24px;color:var(--gold);letter-spacing:.06em;margin:0 0 26px;text-align:center}
.excerpt{position:relative}
.excerpt__fade{position:relative;margin-top:-90px;height:90px;
  background:linear-gradient(180deg,transparent,var(--void))}
.scenebreak{text-align:center;color:var(--gold);letter-spacing:.5em;margin:26px 0;opacity:.6}
.center{text-align:center}
.minigrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:8px}
.minigrid figure{position:relative;aspect-ratio:9/16;overflow:hidden;border:1px solid var(--line)}
.minigrid img{width:100%;height:100%;object-fit:cover;filter:grayscale(.2) contrast(1.05);transition:.7s}
.minigrid figure:hover img{filter:none;transform:scale(1.05)}
.gamecard{display:grid;grid-template-columns:1fr;gap:18px;border:1px solid var(--line);
  background:linear-gradient(180deg,var(--panel),var(--ink));padding:34px 32px}
@media(max-width:760px){
  .bookgrid{grid-template-columns:1fr;gap:30px}
  .bookcover{max-width:320px;margin:0 auto}
  .minigrid{grid-template-columns:repeat(2,1fr)}
}

/* --- атмосферная картинка в отрывке --- */
.excerpt-art{position:relative;margin:0 0 30px;border:1px solid var(--line);overflow:hidden;
  box-shadow:0 24px 70px rgba(0,0,0,.6)}
.excerpt-art img{width:100%;height:clamp(240px,42vw,440px);object-fit:cover;object-position:center 30%;
  display:block;filter:saturate(1.04) contrast(1.02)}
.excerpt-art::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(10,9,8,.15),transparent 30%,transparent 65%,rgba(10,9,8,.75))}

/* --- заставка в карточке игры --- */
.gamecard__art{margin:-34px -32px 26px;border-bottom:1px solid var(--line);overflow:hidden;position:relative}
.gamecard__art img{width:100%;height:clamp(190px,30vw,320px);object-fit:cover;object-position:center 40%;display:block}
.gamecard__art::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 60%,rgba(10,9,8,.55))}
