/*
Theme Name: GIPPF Noir
Description: Тёмная нуар-тема для электронной библиотеки детективов «Универсальная библиотека».
Author: restore
Version: 1.0
*/
:root{
  --bg:#0e0f14; --bg2:#14161e; --panel:#191c26; --panel2:#1f2230;
  --ink:#e7e3d8; --muted:#9a93834f; --muted2:#a59c88;
  --gold:#d4af37; --gold2:#b8902a; --blood:#a4262c; --blood2:#c0392b;
  --line:rgba(212,175,55,.18); --shadow:0 18px 50px rgba(0,0,0,.55);
  --serif:'Playfair Display',Georgia,serif; --body:'PT Serif',Georgia,serif; --ui:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:
    radial-gradient(1200px 600px at 80% -10%,rgba(164,38,44,.10),transparent 60%),
    radial-gradient(900px 500px at -10% 10%,rgba(212,175,55,.06),transparent 55%),
    var(--bg);
  color:var(--ink);font-family:var(--body);font-size:18px;line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--gold);text-decoration:none;transition:.2s}
a:hover{color:var(--blood2)}
img{max-width:100%;height:auto}
.wrap{max-width:1120px;margin:0 auto;padding:0 22px}
.ui{font-family:var(--ui)}

/* header */
.site-head{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);
  background:linear-gradient(180deg,rgba(14,15,20,.96),rgba(14,15,20,.78));
  border-bottom:1px solid var(--line)}
.site-head .wrap{display:flex;align-items:center;gap:26px;height:72px}
.brand{font-family:var(--serif);font-weight:800;font-size:24px;letter-spacing:.3px;color:var(--ink);display:flex;align-items:center;gap:12px;white-space:nowrap}
.brand .mark{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 30% 30%,var(--gold),var(--gold2));color:#1a1305;font-size:18px;box-shadow:0 0 0 3px rgba(212,175,55,.15)}
.brand b{color:var(--gold)}
.nav{display:flex;gap:22px;margin-left:auto;font-family:var(--ui);font-size:15px;font-weight:500}
.nav a{color:var(--muted2)}
.nav a:hover{color:var(--gold)}
.searchbox{display:flex;align-items:center}
.searchbox input{background:var(--panel);border:1px solid var(--line);color:var(--ink);
  padding:9px 14px;border-radius:999px;font-family:var(--ui);font-size:14px;width:190px;outline:none}
.searchbox input:focus{border-color:var(--gold)}

/* hero */
.hero{position:relative;padding:78px 0 54px;text-align:center;border-bottom:1px solid var(--line);overflow:hidden}
.hero:before{content:"";position:absolute;inset:0;background:
  repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(255,255,255,.012) 3px);pointer-events:none}
.hero .kicker{font-family:var(--ui);letter-spacing:.42em;text-transform:uppercase;font-size:12px;color:var(--gold);margin-bottom:18px}
.hero h1{font-family:var(--serif);font-weight:800;font-size:clamp(34px,6vw,64px);line-height:1.05;margin:0 auto 18px;max-width:14ch}
.hero p{color:var(--muted2);max-width:60ch;margin:0 auto;font-size:19px}
.hero .cta{margin-top:30px;display:inline-flex;gap:14px;flex-wrap:wrap;justify-content:center}
.btn{font-family:var(--ui);font-weight:600;font-size:15px;padding:13px 26px;border-radius:999px;display:inline-block;border:1px solid transparent}
.btn-gold{background:linear-gradient(180deg,var(--gold),var(--gold2));color:#1a1305;box-shadow:0 10px 24px rgba(212,175,55,.22)}
.btn-gold:hover{color:#1a1305;transform:translateY(-2px)}
.btn-ghost{border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}

/* section title */
.sec{padding:54px 0}
.sec-h{display:flex;align-items:baseline;gap:16px;margin:0 0 28px}
.sec-h h2{font-family:var(--serif);font-size:30px;margin:0}
.sec-h .line{flex:1;height:1px;background:var(--line)}
.sec-h .count{font-family:var(--ui);font-size:13px;color:var(--muted2)}

/* grid of books */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px}
.card{position:relative;background:linear-gradient(180deg,var(--panel),var(--panel2));
  border:1px solid var(--line);border-radius:16px;padding:24px 22px 22px;overflow:hidden;
  transition:.25s;display:flex;flex-direction:column;min-height:190px}
.card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--gold),var(--blood));opacity:.0;transition:.25s}
.card:hover{transform:translateY(-4px);border-color:rgba(212,175,55,.4);box-shadow:var(--shadow)}
.card:hover:before{opacity:1}
.card .author{font-family:var(--ui);font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.card h3{font-family:var(--serif);font-size:21px;line-height:1.25;margin:0 0 12px}
.card h3 a{color:var(--ink)}
.card h3 a:hover{color:var(--gold)}
.card .excerpt{color:var(--muted2);font-size:15px;line-height:1.6;flex:1;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card .foot{margin-top:16px;display:flex;align-items:center;gap:12px;font-family:var(--ui);font-size:13px;color:var(--muted2)}
.card .foot .read{color:var(--gold)}

/* single book */
.book{padding:48px 0 70px}
.book .crumbs{font-family:var(--ui);font-size:13px;color:var(--muted2);margin-bottom:22px}
.book-head{border-bottom:1px solid var(--line);padding-bottom:30px;margin-bottom:34px}
.book-head .author{font-family:var(--ui);letter-spacing:.12em;text-transform:uppercase;font-size:13px;color:var(--gold);margin-bottom:14px}
.book-head h1{font-family:var(--serif);font-weight:800;font-size:clamp(30px,5vw,48px);line-height:1.1;margin:0 0 22px}
.book-head .meta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.chip{font-family:var(--ui);font-size:13px;padding:7px 15px;border-radius:999px;border:1px solid var(--line);color:var(--muted2)}
.annot{background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--gold);
  border-radius:12px;padding:22px 26px;margin:0 0 36px;color:var(--muted2);font-style:italic}
.reader{max-width:74ch;margin:0 auto;font-size:19px;line-height:1.85}
.reader p{margin:0 0 1.2em;text-indent:1.6em}
.reader p:first-of-type{text-indent:0}
.reader p:first-of-type:first-letter{font-family:var(--serif);font-size:3.4em;line-height:.8;float:left;padding:6px 12px 0 0;color:var(--gold)}
.reader .chapnum{text-align:center;font-family:var(--serif);color:var(--gold);font-size:26px;margin:2em 0 1em;text-indent:0}
.dl{display:flex;gap:14px;flex-wrap:wrap;margin:30px 0 0;padding-top:26px;border-top:1px solid var(--line)}

/* footer */
.site-foot{border-top:1px solid var(--line);background:var(--bg2);margin-top:40px;padding:40px 0 50px;color:var(--muted2);font-family:var(--ui);font-size:14px}
.site-foot .wrap{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}
.site-foot a{color:var(--muted2)}.site-foot a:hover{color:var(--gold)}

/* pagination */
.pager{display:flex;justify-content:center;gap:10px;margin:46px 0 0;font-family:var(--ui)}
.pager a,.pager span{padding:9px 15px;border:1px solid var(--line);border-radius:10px;color:var(--ink)}
.pager .current{background:var(--gold);color:#1a1305;border-color:var(--gold)}

@media(max-width:680px){
  body{font-size:17px}
  .nav{display:none}
  .searchbox input{width:130px}
  .site-head .wrap{gap:14px}
}

/* footer legal + cookie banner */
.foot-legal{display:flex;gap:18px;flex-wrap:wrap}
.cookie-banner{position:fixed;left:18px;right:18px;bottom:18px;z-index:200;
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:space-between;
  background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line);
  border-radius:14px;padding:16px 22px;box-shadow:var(--shadow);font-family:var(--ui);font-size:14px;color:var(--muted2);max-width:1120px;margin:0 auto}
.cookie-banner a{color:var(--gold)}
.cookie-banner .btn{padding:10px 22px;white-space:nowrap}

/* документные страницы (.doc) */
.reader.doc p:first-of-type:first-letter{font-size:inherit;float:none;color:inherit;padding:0;font-family:var(--body)}
.reader.doc p{text-indent:0}
.reader.doc h2{font-family:var(--serif);color:var(--gold);font-size:25px;margin:1.7em 0 .5em;line-height:1.2}
.reader.doc ul{padding-left:1.3em;margin:.6em 0}
.reader.doc li{margin:.35em 0}
.reader.doc a{color:var(--gold);text-decoration:underline}
.reader.doc em{color:var(--muted2)}
