/*
Theme Name: Alted Library
Theme URI: https://alted.ru
Description: Современная тёплая тема для электронной библиотеки alted.ru — типографика под чтение, каталог жанров, удобный поиск.
Author: Claude
Version: 1.0
Text Domain: alted-library
*/

:root{
  --paper:#faf8f3; --surface:#ffffff; --ink:#1f2024; --soft-ink:#4a4c52;
  --muted:#7c7e86; --line:#ece7dc; --line-2:#e3ddd0;
  --accent:#9a4a1f; --accent-2:#b9601f; 
  --accent-soft:#f5ece1; --ok:#0f7a5f;
  --radius:14px; --radius-sm:9px; --shadow:0 1px 2px rgba(31,32,36,.04),0 6px 22px rgba(31,32,36,.06);
  --shadow-hover:0 4px 10px rgba(31,32,36,.07),0 16px 40px rgba(31,32,36,.10);
  --maxw:1120px; --serif:"Lora",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto}
a{color:var(--accent);text-decoration:none;transition:color .15s}
a:hover{color:var(--accent-2);text-decoration:underline}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.25;color:var(--ink);margin:0 0 .5em}
h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.2rem}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.btn{display:inline-block;background:var(--accent);color:#fff;border:0;border-radius:var(--radius-sm);
  padding:.7em 1.2em;font:inherit;font-weight:600;cursor:pointer;transition:background .15s,transform .05s}
.btn:hover{background:var(--accent-2);color:#fff;text-decoration:none}
.btn:active{transform:translateY(1px)}

/* header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(250,248,243,.92);
  backdrop-filter:saturate(1.4) blur(8px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:22px;padding:14px 22px;max-width:var(--maxw);margin:0 auto;flex-wrap:wrap}
.brand{display:flex;flex-direction:column;line-height:1.1;text-decoration:none}
.brand .name{font-family:var(--serif);font-size:1.45rem;font-weight:700;color:var(--ink)}
.brand .tag{font-size:.78rem;color:var(--muted);margin-top:2px;max-width:34ch}
.brand:hover{text-decoration:none}
.header-search{flex:1;min-width:220px;max-width:520px;margin-left:auto}
.search-form{display:flex;background:var(--surface);border:1px solid var(--line-2);border-radius:999px;
  overflow:hidden;box-shadow:var(--shadow)}
.search-form input[type=search]{flex:1;border:0;background:transparent;padding:.7em 1.1em;font:inherit;color:var(--ink);outline:none}
.search-form button{border:0;background:var(--accent);color:#fff;padding:0 1.2em;cursor:pointer;font-weight:600}
.search-form button:hover{background:var(--accent-2)}

/* genre nav */
.genre-bar{border-bottom:1px solid var(--line);background:var(--surface)}
.genre-bar .wrap{display:flex;gap:18px;overflow-x:auto;padding-top:11px;padding-bottom:11px;scrollbar-width:thin}
.genre-bar a{color:var(--soft-ink);font-size:.92rem;white-space:nowrap;font-weight:500}
.genre-bar a:hover{color:var(--accent);text-decoration:none}

/* hero */
.hero{text-align:center;padding:64px 22px 40px}
.hero h1{font-size:2.7rem;margin-bottom:.25em;letter-spacing:-.01em}
.hero p{font-size:1.15rem;color:var(--soft-ink);max-width:60ch;margin:0 auto 30px}
.hero .search-form{max-width:600px;margin:0 auto;border-radius:999px}
.hero .search-form input{padding:1em 1.3em;font-size:1.05rem}

/* genre grid */
.section-title{text-align:center;margin:46px 0 26px;position:relative}
.section-title h2{display:inline-block;font-size:1.7rem}
.genre-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px;padding-bottom:60px}
.genre-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 22px 20px;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s,border-color .15s;
  display:flex;flex-direction:column;gap:6px}
.genre-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover);border-color:var(--line-2);text-decoration:none}
.genre-card .gname{font-family:var(--serif);font-size:1.2rem;font-weight:600;color:var(--ink)}
.genre-card .gcount{font-size:.85rem;color:var(--muted)}
.genre-card .gcount b{color:var(--accent);font-weight:600}

/* content layout */
.content{max-width:var(--maxw);margin:0 auto;padding:36px 22px 70px}
.page-head{margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid var(--line)}
.page-head h1{margin-bottom:.15em}
.page-head .meta{color:var(--muted);font-size:.92rem}
.crumbs{font-size:.86rem;color:var(--muted);margin-bottom:18px}
.crumbs a{color:var(--soft-ink)}

/* author/post list */
.post-list{display:grid;gap:14px;list-style:none;margin:0;padding:0}
.post-list li{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:16px 20px;box-shadow:var(--shadow);transition:transform .12s,box-shadow .12s}
.post-list li:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.post-list a.title{font-family:var(--serif);font-size:1.18rem;font-weight:600;color:var(--ink)}
.post-list a.title:hover{color:var(--accent)}
.post-list .excerpt{color:var(--soft-ink);font-size:.95rem;margin-top:4px}

/* single article */
.article{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:40px 44px;box-shadow:var(--shadow);max-width:820px;margin:0 auto}
.article-body{font-size:1.05rem;line-height:1.75}
.article-body p{margin:0 0 1.1em}
.article-body a{text-decoration:underline;text-underline-offset:2px}
.article-body ul{padding-left:1.3em}
.article-body h2,.article-body h3{margin-top:1.4em}

/* pagination */
.pager{display:flex;gap:8px;justify-content:center;margin-top:38px;flex-wrap:wrap}
.pager a,.pager span{padding:.5em .9em;border-radius:var(--radius-sm);border:1px solid var(--line-2);
  background:var(--surface);color:var(--soft-ink);font-size:.95rem}
.pager .current{background:var(--accent);color:#fff;border-color:var(--accent)}
.pager a:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}

/* footer */
.site-footer{border-top:1px solid var(--line);background:var(--surface);padding:34px 22px;margin-top:40px}
.site-footer .wrap{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:.9rem}
.site-footer a{color:var(--soft-ink)}

@media(max-width:760px){
  body{font-size:16px}
  .hero{padding:42px 18px 30px}.hero h1{font-size:2rem}
  .header-inner{gap:14px}.header-search{order:3;flex-basis:100%;max-width:none;margin-left:0}
  .article{padding:26px 20px}
}

/* footer menu */
.footer-menu{list-style:none;display:flex;gap:18px;flex-wrap:wrap;margin:0;padding:0}
.footer-menu a{color:var(--soft-ink)}
.footer-menu a:hover{color:var(--accent)}

/* cookie notice */
.cookie-notice{position:fixed;left:16px;right:16px;bottom:16px;z-index:100;max-width:880px;margin:0 auto;
  background:var(--ink);color:#f3efe7;border-radius:var(--radius);padding:16px 20px;
  display:flex;align-items:center;gap:16px;box-shadow:0 10px 40px rgba(0,0,0,.25);font-size:.92rem}
.cookie-notice a{color:#f0c79a;text-decoration:underline}
.cookie-notice .btn{flex:none;white-space:nowrap}
@media(max-width:560px){.cookie-notice{flex-direction:column;align-items:stretch;text-align:center}}

/* cookie notice fix: hidden by default, shown via .show */
.cookie-notice{display:none}
.cookie-notice.show{display:flex}
