/*
Theme Name: Kinosphere
Theme URI: https://example.com
Author: Kinosphere
Description: Тема для сайта скачивания фильмов и сериалов прямыми ссылками. Светлый редакционный дизайн «билет в кино»: бумажная подложка, кирпично-красный/золотой/сосновый акценты, засечная типографика. Оптимизирована для максимальной скорости загрузки: без лишних размеров изображений, без ревизий, поиск только по заголовку, транслитерация ЧПУ.
Version: 2.0
Requires PHP: 7.4
Text Domain: kinosphere
*/

/* ==========================================================================
   TOKENS
   ========================================================================== */
:root {
    /* — Цвет: «бумага» кинотеатра — */
    --bg:            #F1F0EA;   /* тёплая светлая бумага (не кремовая, не белая) */
    --surface:       #FFFFFF;
    --surface-soft:  #FAF9F4;
    --ink:           #201D18;   /* тёплый почти-чёрный, не чистый #000 */
    --ink-soft:      #6B6558;   /* приглушённый вторичный текст */
    --line:          #E1DDD1;   /* волосяная линия-разделитель */
    --line-strong:   #CFC9B8;

    /* — Акценты — */
    --red:           #A83232;  /* «билетный» кирпично-красный — ссылки, CTA */
    --red-dark:      #7E2424;
    --red-soft:      #F4E4E1;
    --gold:          #A9822C;  /* «маркиза» золото — рейтинги, печати */
    --gold-soft:     #F3E9D2;
    --pine:          #3C5B49;  /* сосновый зелёный — шапка, «новинки» */
    --pine-dark:     #294034;
    --pine-soft:     #E4EBE4;

    --shadow-sm: 0 1px 2px rgba(32,29,24,.06);
    --shadow-md: 0 10px 28px -14px rgba(32,29,24,.28);
    --shadow-lg: 0 22px 48px -20px rgba(32,29,24,.34);

    --radius: 10px;
    --radius-sm: 6px;

    --font-display: Georgia, "Times New Roman", "Noto Serif", serif;
    --font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    --font-mono: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
}

/* ==========================================================================
   RESET / BASE
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
    margin: 0;
    background: var(--bg);
    color: var(--ink);
    font-family: var(--font-body);
    line-height: 1.55;
    font-size: 16px;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--red); text-decoration: none; }
a:hover { color: var(--red-dark); }
ul { margin: 0; padding: 0; list-style: none; }
h1, h2, h3, h4 {
    margin: 0 0 12px;
    line-height: 1.2;
    font-family: var(--font-display);
    font-weight: 700;
    color: var(--ink);
}
p { margin: 0 0 12px; }
button, input, select { font-family: inherit; font-size: inherit; }
:focus-visible { outline: 2px solid var(--red); outline-offset: 2px; }

.container { max-width: 1200px; margin: 0 auto; padding: 0 16px; }

.visually-hidden {
    position: absolute !important;
    width: 1px; height: 1px;
    margin: -1px; padding: 0; overflow: hidden;
    clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.skip-link {
    position: absolute; left: -9999px; top: 0;
    background: var(--red); color: #fff; padding: 10px 16px; z-index: 10000;
}
.skip-link:focus { left: 8px; top: 8px; }

/* Разрядка/капс — фирменный приём для заголовков киноплаката */
.eyebrow, .site-logo, .film-card-badge, .film-badge, .dl-badge {
    text-transform: uppercase;
    letter-spacing: .06em;
}

/* ==========================================================================
   HEADER — «маркиза» кинотеатра: сосновая лента с золотыми огоньками
   ========================================================================== */
.site-header {
    background: var(--pine);
    position: relative;
    z-index: 500;
}
.site-header::before {
    /* ряд золотых лампочек-маркизы поверх шапки */
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 5px;
    background-image: radial-gradient(circle, var(--gold) 1.6px, transparent 1.8px);
    background-size: 16px 5px;
    background-position: center;
    opacity: .9;
}
.site-header-inner {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 16px;
    flex-wrap: wrap;
}
.site-logo {
    font-family: var(--font-display);
    font-size: 1.3rem;
    font-weight: 700;
    color: #FBF8EF;
    white-space: nowrap;
    letter-spacing: .08em;
}
.site-logo span { color: var(--gold); }

.primary-nav { flex: 1; min-width: 0; }
.primary-nav ul { display: flex; flex-wrap: wrap; gap: 2px; }
.primary-nav a {
    display: inline-block;
    padding: 8px 13px;
    border-radius: var(--radius-sm);
    color: #EAE6D8;
    font-weight: 600;
    font-size: .92rem;
}
.primary-nav a:hover { background: rgba(255,255,255,.1); color: #fff; }

.nav-toggle {
    display: none;
    background: none;
    border: 1px solid rgba(255,255,255,.35);
    color: #FBF8EF;
    padding: 8px 12px;
    border-radius: var(--radius-sm);
    cursor: pointer;
}

.header-search { margin-left: auto; }
.header-search form { display: flex; }
.header-search input[type="search"] {
    background: rgba(255,255,255,.94);
    border: 1px solid transparent;
    color: var(--ink);
    padding: 9px 12px;
    border-radius: 999px 0 0 999px;
    width: 210px;
    max-width: 42vw;
}
.header-search input[type="search"]::placeholder { color: var(--ink-soft); }
.header-search button {
    background: var(--gold);
    border: none;
    color: #2A2210;
    padding: 0 16px;
    border-radius: 0 999px 999px 0;
    cursor: pointer;
    font-weight: 700;
}
.header-search button:hover { background: #BE9436; }

@media (max-width: 780px) {
    .nav-toggle { display: inline-block; order: 2; }
    .primary-nav { order: 4; flex-basis: 100%; display: none; }
    .primary-nav.is-open { display: block; }
    .header-search { order: 3; margin-left: auto; }
    .header-search input[type="search"] { width: 140px; }
}

/* ==========================================================================
   LAYOUT
   ========================================================================== */
.page-wrap {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 30px;
    padding: 28px 16px 56px;
    max-width: 1200px;
    margin: 0 auto;
}
.page-wrap.no-sidebar { grid-template-columns: 1fr; }
@media (max-width: 960px) {
    .page-wrap { grid-template-columns: 1fr; }
}

.page-title {
    font-size: 1.9rem;
    margin-bottom: 4px;
}
.archive-desc { color: var(--ink-soft); margin-bottom: 18px; font-size: .96rem; }

/* ==========================================================================
   CARDS / GRID — карточка = билетный корешок
   ========================================================================== */
.film-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
    gap: 22px 18px;
}
.film-card { display: block; color: var(--ink); }

.film-card-poster {
    position: relative;
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--surface-soft);
    aspect-ratio: 460 / 690;
    box-shadow: var(--shadow-sm);
    /* билетный уголок — фирменный срез */
    clip-path: polygon(0 0, calc(100% - 22px) 0, 100% 22px, 100% 100%, 0 100%);
    transition: box-shadow .2s, transform .2s;
    border: 1px solid var(--line);
}
.film-card:hover .film-card-poster { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.film-card-poster img { width: 100%; height: 100%; object-fit: cover; }

.film-card-badge {
    position: absolute; top: 9px; left: 9px;
    background: rgba(32,29,24,.72);
    color: #FBF8EF;
    font-size: 10.5px;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 4px;
}
/* «золотая печать» рейтинга — таблетка внизу справа (не в зоне билетного
   среза сверху, иначе её обрезает clip-path постера; фиксированный круг
   ранее не вмещал двузначные оценки — заменён на авто-ширину) */
.film-card-rating {
    position: absolute; bottom: 8px; right: 8px;
    display: inline-flex; align-items: center; gap: 3px;
    background: var(--gold);
    color: #2A2210;
    font-size: 11.5px;
    font-weight: 800;
    line-height: 1;
    padding: 5px 8px;
    border-radius: 999px;
    box-shadow: 0 2px 8px -2px rgba(32,29,24,.45), 0 0 0 2px var(--surface);
    font-family: var(--font-mono);
    white-space: nowrap;
}

.film-card-title {
    margin-top: 10px;
    font-family: var(--font-display);
    font-size: .98rem;
    font-weight: 700;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.film-card-meta { font-size: .8rem; color: var(--ink-soft); margin-top: 3px; }

/* ==========================================================================
   CAROUSEL (главная страница)
   ========================================================================== */
.carousel-block { margin: 0 0 40px; }
.carousel-head {
    display: flex; align-items: baseline; justify-content: space-between;
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--line-strong);
}
.carousel-head h2 { font-size: 1.3rem; margin-bottom: 0; }
.carousel-head a {
    font-size: .85rem; font-weight: 700; color: var(--red); white-space: nowrap;
}
.carousel-track {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x proximity;
    padding: 4px 4px 10px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: var(--line-strong) transparent;
}
.carousel-track::-webkit-scrollbar { height: 6px; }
.carousel-track::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 4px; }
.carousel-track .film-card { flex: 0 0 155px; scroll-snap-align: start; }
@media (min-width: 640px) { .carousel-track .film-card { flex-basis: 170px; } }

/* ==========================================================================
   SINGLE (страница фильма)
   ========================================================================== */
.film-hero {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 34px;
    margin-bottom: 34px;
    padding-bottom: 30px;
    border-bottom: 1px solid var(--line-strong);
}
@media (max-width: 680px) {
    .film-hero { grid-template-columns: 1fr; }
    .film-hero-poster { max-width: 260px; margin: 0 auto; }
}
.film-hero-poster {
    position: relative;
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--surface-soft);
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--line);
    clip-path: polygon(0 0, calc(100% - 30px) 0, 100% 30px, 100% 100%, 0 100%);
    aspect-ratio: 460 / 690;
}
.film-hero-poster img { width: 100%; height: 100%; object-fit: cover; display: block; }

.film-title { font-size: 2.05rem; }
.film-badges { display: flex; flex-wrap: wrap; gap: 8px; margin: 10px 0 16px; }
.film-badge {
    background: var(--surface); border: 1px solid var(--line-strong);
    color: var(--ink-soft); font-size: .8rem; font-weight: 700;
    padding: 5px 11px; border-radius: 999px;
}
.film-badge.rating { color: #7A5C15; background: var(--gold-soft); border-color: transparent; }
.film-badge.age { color: var(--red-dark); background: var(--red-soft); border-color: transparent; }

.film-meta-table { margin: 16px 0; font-size: .96rem; }
.film-meta-table div { display: flex; gap: 10px; padding: 7px 0; border-bottom: 1px dashed var(--line-strong); }
.film-meta-table span:first-child {
    font-family: var(--font-display); font-weight: 700;
    color: var(--pine); min-width: 140px; flex-shrink: 0;
}
.film-meta-table span:last-child a { color: var(--ink); }
.film-meta-table span:last-child a:hover { color: var(--red); }

.film-desc { color: var(--ink); margin: 18px 0; max-width: 68ch; }
.film-cast { margin: 18px 0; }
.film-cast h3 { font-size: 1.05rem; }
.film-cast ul { display: flex; flex-wrap: wrap; gap: 9px; }
.film-cast li {
    background: var(--surface); border: 1px solid var(--line-strong);
    border-radius: var(--radius-sm); padding: 7px 12px; font-size: .85rem;
}
.film-cast li b { color: var(--ink); font-family: var(--font-display); }
.film-cast li span { color: var(--ink-soft); display: block; font-size: .78rem; }

/* ==========================================================================
   SIDEBAR
   ========================================================================== */
.widget {
    background: var(--surface); border: 1px solid var(--line);
    border-radius: var(--radius); padding: 18px 20px; margin-bottom: 20px;
    box-shadow: var(--shadow-sm);
}
.widget h3 {
    font-size: 1rem; margin-bottom: 12px; padding-bottom: 10px;
    border-bottom: 2px solid var(--gold);
    display: inline-block;
}
.widget-cat-list li { margin-bottom: 8px; }
.widget-cat-list a { color: var(--ink); font-size: .93rem; font-weight: 600; }
.widget-cat-list a:hover { color: var(--red); }
.widget-cat-list .count { color: var(--ink-soft); font-size: .8rem; font-weight: 400; }


/* ==========================================================================
   PAGINATION
   ========================================================================== */
.pagination { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 32px; }
.pagination a, .pagination span {
    display: inline-block; padding: 9px 14px; border-radius: var(--radius-sm);
    background: var(--surface); border: 1px solid var(--line-strong); color: var(--ink);
    font-size: .9rem; font-weight: 600;
}
.pagination .current { background: var(--red); border-color: var(--red); color: #fff; }
.pagination a:hover { border-color: var(--red); color: var(--red); }

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer {
    background: var(--pine-dark);
    padding: 32px 16px;
    margin-top: 44px;
    color: #D9D3C0;
    font-size: .88rem;
    text-align: center;
}
.site-footer a { color: var(--gold); }
.site-footer nav ul { display: flex; justify-content: center; gap: 16px; margin-bottom: 10px; flex-wrap: wrap; }

/* ==========================================================================
   404 / EMPTY
   ========================================================================== */
.empty-state {
    background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
    padding: 48px 20px; text-align: center; color: var(--ink-soft);
    box-shadow: var(--shadow-sm);
}
.empty-state h1 { font-size: 1.5rem; }

/* ==========================================================================
   REDUCED MOTION
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
    * { transition: none !important; scroll-behavior: auto !important; }
}
