
:root {
    --bg: 0 0% 5%;
    --fg: 0 0% 98%;
    --card: 0 0% 7%;
    --muted: 0 0% 70%;
    --border: 0 0% 16%;
    --ruby-1: 348 83% 47%;
    --ruby-2: 338 85% 55%;
    --ruby-3: 350 90% 30%;
    --yellow-1: 45 93% 46%;
    --yellow-2: 48 97% 52%;
    --yellow-3: 45 96% 35%;
    --green-1: 142 71% 45%;
    --green-2: 145 75% 52%;
    --green-3: 142 76% 32%;

    --gray-1: 220 8% 45%;   /* Темно-серый с металлическим оттенком */
    --gray-2: 220 6% 65%;   /* Средне-серый */
    --gray-3: 220 10% 30%;  /* Темно-серый для акцентов */

    --radius: 12px;
}

html.theme-ruby {
    --primary-1: var(--ruby-1);
    --primary-2: var(--ruby-2);
    --primary-3: var(--ruby-3);
}

html.theme-yellow {
    --primary-1: var(--yellow-1);
    --primary-2: var(--yellow-2);
    --primary-3: var(--yellow-3);
}

html.theme-green {
    --primary-1: var(--green-1);
    --primary-2: var(--green-2);
    --primary-3: var(--green-3);
}

html.theme-gray {
    --primary-1: var(--gray-1);
    --primary-2: var(--gray-2);
    --primary-3: var(--gray-3);
}

html.theme-transition * {
    transition: color 0.8s cubic-bezier(0.34, 1.56, 0.64, 1),
    background 0.8s cubic-bezier(0.34, 1.56, 0.64, 1),
    background-color 0.8s cubic-bezier(0.34, 1.56, 0.64, 1),
    border-color 0.8s cubic-bezier(0.34, 1.56, 0.64, 1),
    box-shadow 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}

* { box-sizing: border-box; }
html, body { margin: 0; background: hsl(var(--bg)); color: hsl(var(--fg)); font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, sans-serif; }
.container { width: min(1200px, 100%); margin-inline: auto; padding-inline: 24px; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }
.hide-sm { display: none; }
@media (min-width: 640px) { .hide-sm { display: inline; } }
.header { position: sticky; top: 0; z-index: 10; backdrop-filter: blur(8px); background: color-mix(in oklab, hsl(var(--bg)) 80%, transparent); border-bottom: 1px solid hsl(var(--border)); }
.header-inner { height: 64px; display: flex; align-items: center; justify-content: space-between; }
.brand { font-family: Unbounded, Inter, system-ui, sans-serif; font-weight: 800; font-size: 24px; text-decoration: none; color: hsl(var(--primary-1)); transition: color 0.8s cubic-bezier(0.34, 1.56, 0.64, 1); }
.nav { display: flex; gap: 8px; }
.topnav { display: flex; gap: 12px; align-items: center; }
.navlink { display: inline-flex; align-items: center; gap: 8px; padding: 8px 14px; border-radius: 12px; color: hsl(var(--fg) / .8); text-decoration: none; border: 1px solid transparent; transition: all 0.3s ease; position: relative; background: hsl(var(--fg) / 0.05); }
.navlink::before { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, hsl(var(--primary-1) / 0.15), hsl(var(--primary-2) / 0.08)); opacity: 0; transition: opacity 0.3s ease; z-index: 0; border-radius: 12px; }
.navlink:hover { color: #fff; /* border-color: hsl(var(--primary-1) / 0.5); */ }
.navlink:hover::before { opacity: 1; }
.navlink svg { width: 20px; height: 20px; transition: all 0.3s ease; position: relative; z-index: 1; }
.navlink:hover svg { color: hsl(var(--primary-1)); }
.navlink span { position: relative; z-index: 1; font-weight: 600; font-size: 14px; }
.theme-picker-wrapper { position: relative; }
.theme-picker-trigger { position: relative; width: 40px; height: 40px; border-radius: 12px; border: 1px solid hsl(var(--border)); background: hsl(var(--card)); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1); }
.theme-picker-trigger:hover { border-color: hsl(var(--primary-1)); background: hsl(var(--primary-1) / 0.1); transform: scale(1.08); box-shadow: 0 0 20px hsl(var(--primary-1) / 0.3); }
.theme-picker-trigger svg { width: 20px; height: 20px; color: hsl(var(--primary-1)); transition: all 0.3s ease; }
.theme-picker-trigger:hover svg { transform: rotate(-15deg); }

.theme-menu { position: absolute; top: calc(100% + 8px); right: 0; background: hsl(var(--card)); border: 1px solid hsl(var(--border)); border-radius: 16px; padding: 8px; gap: 6px; display: none; flex-direction: column; min-width: 140px; box-shadow: 0 20px 60px rgba(0,0,0,0.4), 0 0 0 1px hsl(var(--border)) inset; z-index: 100; animation: slideDown 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) forwards; }
.theme-menu.active { display: flex; }

@keyframes slideDown {
    from { opacity: 0; transform: translateY(-12px) scale(0.95); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

.theme-option { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 12px; cursor: pointer; border: 1.5px solid transparent; background: transparent; transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); position: relative; }
.theme-option::before { content: ""; position: absolute; inset: 0; background: hsl(var(--primary-1) / 0.08); opacity: 0; transition: opacity 0.3s ease; border-radius: 12px; }
.theme-option:hover { background: hsl(var(--fg) / 0.05); transform: translateX(4px); }
.theme-option:hover::before { opacity: 1; }
.theme-option.active { border-color: hsl(var(--primary-1)); background: hsl(var(--primary-1) / 0.12); box-shadow: 0 0 15px hsl(var(--primary-1) / 0.2), inset 0 0 8px hsl(var(--primary-1) / 0.08); }

.theme-color-dot { width: 20px; height: 20px; border-radius: 50%; transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); position: relative; z-index: 1; }
.theme-option.ruby .theme-color-dot { background: hsl(var(--ruby-1)); box-shadow: 0 0 10px hsl(var(--ruby-1) / 0.5); }
.theme-option.yellow .theme-color-dot { background: hsl(var(--yellow-1)); box-shadow: 0 0 10px hsl(var(--yellow-1) / 0.5); }
.theme-option.green .theme-color-dot { background: hsl(var(--green-1)); box-shadow: 0 0 10px hsl(var(--green-1) / 0.5); }
.theme-option.gray .theme-color-dot { background: hsl(var(--gray-1)); box-shadow: 0 0 10px hsl(var(--gray-1) / 0.5); }
.theme-option:hover .theme-color-dot { transform: scale(1.15); }

.theme-option-text { font-size: 13px; font-weight: 600; color: hsl(var(--fg) / 0.85); position: relative; z-index: 1; }
.btn { position: relative; display: inline-flex; align-items: center; gap: 8px; padding: 8px 12px; border-radius: 8px; font-weight: 600; color: hsl(var(--fg) / 0.85); border: 1px solid transparent; background: transparent; cursor: pointer; transition: all .3s ease; text-decoration: none; }
.btn.outline { border-color: hsl(var(--border)); }
.btn:hover { color: white; /* border-color: hsl(var(--fg) / 0.4); */ background-color: hsl(var(--fg) / 0.05); }
.btn .i { width: 16px; height: 16px; }
.hero { position: relative; overflow: hidden; }
.title { font-family: Unbounded, Inter, system-ui, sans-serif; font-weight: 800; font-size: clamp(28px, 4vw + 6px, 52px); line-height: 1.05; margin: 40px 0 16px; position: relative; z-index: 1; animation: title-slide-in 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) forwards; opacity: 0; }
@keyframes title-slide-in { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.subtitle { color: hsl(var(--fg) / 0.75); max-width: 70ch; margin: 8px 0 0; position: relative; z-index: 1; animation: subtitle-fade-in 0.8s ease 0.2s forwards; opacity: 0; }
@keyframes subtitle-fade-in { from { opacity: 0; } to { opacity: 1; } }
.brand-solid { color: hsl(var(--primary-1)); transition: color 0.8s cubic-bezier(0.34, 1.56, 0.64, 1); }
.marker { background: linear-gradient(0deg, hsl(var(--primary-2) / 0.35) 0 60%, transparent 60% 100%); transition: background 0.8s cubic-bezier(0.34, 1.56, 0.64, 1); }
.hero .container { padding-left: 0px; }
.glows { display: none; }
.glows .glow { position: absolute; width: 300px; height: 300px; border-radius: 999px; filter: blur(64px); background: linear-gradient(90deg, hsl(var(--primary-3)), hsl(var(--primary-2)), hsl(var(--primary-1))); opacity: .2; transition: background 0.8s cubic-bezier(0.34, 1.56, 0.64, 1); }
.glows .glow.a { left: -80px; top: -80px; animation: glow-float 8s ease-in-out infinite; }
.glows .glow.b { right: -80px; top: 120px; animation: glow-float 8s ease-in-out infinite 1s; }

@keyframes glow-float {
    0%, 100% { transform: translate(0, 0); }
    50% { transform: translate(30px, -40px); }
}
.character { position: absolute; right: -15px; bottom: -190px; width: min(30vw, 360px); pointer-events: none; z-index: 0; overflow: hidden; mask-image: linear-gradient(to bottom, black 92%, transparent 98%, transparent 100%); -webkit-mask-image: linear-gradient(to bottom, black 92%, transparent 98%, transparent 100%); }
.character-img { width: 100%; height: auto; opacity: 1; animation: slide-in 800ms cubic-bezier(0.34, 1.56, 0.64, 1) forwards; filter: brightness(0.845); }
@keyframes slide-in { from { opacity: 0; transform: translateX(80px) rotateY(45deg); } to { opacity: 1; transform: translateX(0) rotateY(0); } }

.character-img.fade-transition { animation: fade-out-char 0.5s ease forwards; }
@keyframes fade-out-char {
    from { opacity: 1; transform: translateX(0) scale(1); }
    to { opacity: 0; transform: translateX(-40px) scale(0.9); }
}
.search { display: flex; gap: 8px; align-items: center; background: hsl(var(--bg) / 0.6); border: 1px solid hsl(var(--border)); border-radius: 16px; padding: 8px; margin-top: 24px; max-width: 640px; position: relative; z-index: 1; transition: all 0.3s ease; animation: search-slide-up 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) 0.3s forwards; opacity: 0; transform: translateY(20px); }
@keyframes search-slide-up { to { opacity: 1; transform: translateY(0); } }
.search:focus-within { border-color: hsl(var(--primary-1) / 0.5); box-shadow: 0 0 25px hsl(var(--primary-1) / 0.25); }
.input { flex: 1; background: transparent; border: none; outline: none; color: hsl(var(--fg)); padding: 10px 12px; font-size: 16px; }
.section { padding: 7px 0 48px; }
.section-head { display: flex; align-items: end; justify-content: space-between; margin-bottom: 12px; }
.h2 { font-family: Unbounded, Inter, system-ui, sans-serif; font-size: 28px; margin: 0; }
.muted { color: hsl(var(--muted)); font-size: 14px; }
.grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 640px) { .grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 900px) { .grid { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1200px) { .grid { grid-template-columns: repeat(5, 1fr); } }

.card { position: relative; overflow: hidden; border-radius: 14px; border: 1px solid hsl(var(--border)); background: hsl(var(--card)); box-shadow: 0 20px 60px -20px hsl(var(--primary-1) / 0.2); transition: transform .4s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow .4s cubic-bezier(0.34, 1.56, 0.64, 1), filter .4s ease; }
.card:hover { transform: translateY(-6px); box-shadow: 0 0 0 1px hsl(var(--primary-1) / 0.3) inset, 0 28px 70px -24px hsl(var(--primary-1) / 0.35); filter: brightness(1.05); }

.card-media { position: relative; aspect-ratio: 3/4; overflow: hidden; }
.card-media img { width: 100%; height: 100%; object-fit: cover; display: block; opacity: .80; /* Темнее, как раньше */ transition: opacity 0.4s ease; }
.card:hover .card-media img { opacity: 1; filter: brightness(0.99); }

.card-grad { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.2), rgba(0,0,0,.4), transparent); pointer-events: none; } /* Возвращаем старый градиент */

.rating-badge { position: absolute; top: 8px; left: 8px; display: inline-flex; align-items: center; gap: 4px; font-size: 12px; font-weight: 700; padding: 6px 10px; border-radius: 12px 8px 12px 4px; background: linear-gradient(135deg, hsl(var(--primary-3)), hsl(var(--primary-2))); box-shadow: 0 8px 24px -8px hsl(var(--primary-2) / 0.8); animation: badge-bounce 0.6s cubic-bezier(0.34, 1.56, 0.64, 1); }
@keyframes badge-bounce {
    from { transform: scale(0) rotate(-45deg); opacity: 0; }
    to { transform: scale(1) rotate(0); opacity: 1; }
}
.rating-badge .star { filter: drop-shadow(0 2px 4px rgba(0,0,0,.6)); animation: star-twirl 0.8s ease-out; }
@keyframes star-twirl {
    from { transform: rotate(0deg) scale(0); }
    to { transform: rotate(360deg) scale(1); }
}
.card-body { position: absolute; inset-inline: 0; bottom: 0; padding: 14px; background: linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.7) 60%, transparent 100%); }
.card-title { margin: 0; font-weight: 700; font-family: Unbounded, Inter, system-ui, sans-serif; font-size: 16px; color: #fff; text-shadow: 0 2px 8px rgba(0,0,0,0.6); }
.card-meta { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 4px; color: rgba(255,255,255,0.85); font-size: 12px; }
.badge { background: rgba(255,255,255,0.15); padding: 4px 8px; border-radius: 999px; }

.watch { position: relative; overflow: hidden; isolation: isolate; display: inline-flex; align-items: center; justify-content: center; gap: 8px; width: 100%; padding: 10px 12px; border: 1px solid hsl(var(--border)); border-radius: 10px; background: transparent; color: hsl(var(--fg) / .85); font-weight: 700; cursor: pointer; transition: all .4s ease; }
.watch::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, hsl(var(--primary-3)) 0%, hsl(var(--primary-2)) 50%, hsl(var(--primary-1)) 100%); transform: translateX(-100%); transition: transform .6s ease; z-index: 0; }
.watch:hover::before, .watch:focus-visible::before { transform: translateX(0); }
.watch > span, .watch svg { position: relative; z-index: 1; }
.watch:hover { color: #fff; /* border-color: hsl(var(--fg) / 0.4); */ }
.footer { border-top: 1px solid hsl(var(--border)); padding: 24px 0 40px; color: hsl(var(--muted)); text-align: center; }
.footer .hover-grad { background: linear-gradient(90deg, hsl(var(--primary-3)), hsl(var(--primary-2)), hsl(var(--primary-1))); -webkit-background-clip: text; background-clip: text; color: hsl(var(--muted)); text-decoration: none; transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1); }
.footer .hover-grad:hover { color: transparent; }
.footer .sep { color: hsl(var(--fg) / .2); margin: 0 .5rem; }
.prose { color: hsl(var(--fg) / 0.85); max-width: none; }
.prose h3 { font-family: Unbounded, Inter, system-ui, sans-serif; }
.hero-bottom-blur { position: absolute; inset-inline: 0; bottom: -1px; height: 80px; background: linear-gradient(to bottom, transparent, hsl(var(--bg))); pointer-events: none; z-index: 1; }
.lava-stage { position: relative; min-height: calc(100dvh - 64px - 96px); overflow: hidden; }
.lava { position: absolute; inset: 0; z-index: 0; filter: blur(16px) contrast(1.05) saturate(1.1); pointer-events: none; }
.lava-blob { position: absolute; width: 140px; height: 140px; border-radius: 50%; will-change: transform; background: radial-gradient(45% 45% at 50% 50%, hsl(var(--primary-2) / .65), transparent 70%), radial-gradient(80% 80% at 60% 40%, hsl(var(--primary-1) / .35), transparent 80%), radial-gradient(100% 100% at 40% 60%, hsl(var(--primary-3) / .25), transparent 90%); mix-blend-mode: screen; opacity: .75; }
.flash { position: absolute; top: 50%; left: 50%; width: 24px; height: 24px; border-radius: 50%; background: radial-gradient(closest-side, rgba(255,255,255,.98), rgba(255,255,255,.7) 40%, transparent 70%), radial-gradient(closest-side, hsl(var(--primary-2) / .6), transparent 60%); transform: translate(-50%, -50%) scale(0); opacity: 0; pointer-events: none; z-index: 3; mix-blend-mode: screen; filter: blur(2px); }
.flash.boom { animation: boom .75s ease-out forwards; }
@keyframes boom { 0% { transform: translate(-50%, -50%) scale(.2); opacity: 1; } 60% { opacity: .9; } 100% { transform: translate(-50%, -50%) scale(32); opacity: 0; } }
.random-btn { position: relative; display: inline-flex; align-items: center; justify-content: center; font-family: Unbounded, Inter, system-ui, sans-serif; font-weight: 800; letter-spacing: .3px; border: 2px solid hsl(var(--border)); color: hsl(var(--fg)); background: hsl(var(--card)); box-shadow: 0 20px 60px -24px hsl(var(--primary-1) / .35), 0 0 0 1px hsl(var(--border)) inset; transition: all .3s cubic-bezier(0.34, 1.56, 0.64, 1); cursor: pointer; }
.random-btn.center { position: absolute; top: 50%; left: 50%; width: 200px; height: 200px; transform: translate(-50%, -50%); border-radius: 50%; font-size: 20px; animation: btn-pulse 2s ease-in-out infinite; }
.random-btn.center::before { content: ""; position: absolute; inset: -6px; border-radius: 50%; background: conic-gradient(from 0deg, hsl(var(--primary-3)), hsl(var(--primary-2)), hsl(var(--primary-1)), hsl(var(--primary-3))); filter: blur(16px); opacity: .35; animation: spin 8s linear infinite; z-index: -1; }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes btn-pulse {
    0%, 100% { transform: translate(-50%, -50%) scale(1); box-shadow: 0 0 30px hsl(var(--primary-1) / 0.4); }
    50% { transform: translate(-50%, -50%) scale(1.05); box-shadow: 0 0 50px hsl(var(--primary-1) / 0.6); }
}
.random-btn.inline { width: auto; padding: 12px 18px; border-radius: 14px; font-size: 16px; animation: none; }
.random-btn:hover { border-color: hsl(var(--primary-1)); box-shadow: 0 30px 84px -26px hsl(var(--primary-2) / .55), 0 0 0 2px hsl(var(--primary-1) / 0.3) inset; background: linear-gradient(135deg, hsl(var(--primary-3) / .15), hsl(var(--primary-2) / .1)); }

.random-btn.inline { width: auto; padding: 12px 18px; border-radius: 14px; font-size: 16px; animation: none; }
.result-wrap { position: relative; z-index: 1; padding: 24px; display: grid; place-items: center; }
.result { display: grid; gap: 20px; justify-items: center; }
.result .card { width: min(560px, 100%); animation: cardIn .5s cubic-bezier(0.34, 1.56, 0.64, 1) both; }
@keyframes cardIn { from { transform: translateY(30px) scale(0.8); opacity: 0; } to { transform: translateY(0) scale(1); opacity: 1; } }
.result .actions { display: flex; gap: 12px; justify-content: center; }
.fade-out { animation: fadeOut .4s cubic-bezier(0.34, 1.56, 0.64, 1) both; }
@keyframes fadeOut { to { opacity: 0; transform: translateY(-30px) scale(0.8); } }
a.watch, a.btn, a.navlink {
    text-decoration: none !important;
}
.ambient-light {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    background: radial-gradient(circle, hsl(var(--primary-1) / 0.15) 0%, transparent 70%);
    filter: blur(40px);
    z-index: -1;
    pointer-events: none;
}

.error-404 {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: calc(100vh - 64px - 100px);
    text-align: center;
    padding: 40px 24px;
}

.error-404 .error-code {
    font-family: Unbounded, Inter, system-ui, sans-serif;
    font-size: clamp(72px, 12vw, 160px);
    font-weight: 800;
    line-height: 1;
    margin: 0 0 16px;
    background: linear-gradient(135deg, hsl(var(--primary-1)), hsl(var(--primary-2)), hsl(var(--primary-3)));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    animation: gradient-shift 3s ease infinite;
}

@keyframes gradient-shift {
    0%, 100% { filter: hue-rotate(0deg); }
    50% { filter: hue-rotate(20deg); }
}

.error-404 .error-title {
    font-family: Unbounded, Inter, system-ui, sans-serif;
    font-size: clamp(20px, 3.5vw, 36px);
    font-weight: 700;
    margin: 0 0 12px;
    color: hsl(var(--fg));
}

.error-404 .error-description {
    color: hsl(var(--muted));
    font-size: clamp(14px, 2.2vw, 18px);
    line-height: 1.6;
    margin: 0 auto 32px;
    max-width: 60ch;
}

.error-404 .error-actions {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}

.error-404 .error-actions .watch,
.error-404 .error-actions .btn {
    min-width: 260px;
    padding: 12px 20px;
}
/* ========================= */
/* ========================= */
@media (max-width: 639px) {
    .header-inner { height: 56px; padding-inline: 8px; }
    .brand { font-size: 20px; }
    .topnav { gap: 6px; align-items: center; overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 4px; }
    .topnav .navlink { padding: 6px 10px; border-radius: 10px; }
    .nav { gap: 6px; }
    .character, .glows { display: none !important; }
    .title { margin: 20px 0 8px; font-size: clamp(22px, 6vw, 36px); }
    .subtitle { font-size: 14px; max-width: 100%; margin-bottom: 12px; }

    .hero .container { padding-inline: 12px; }
    .search { width: 100%; max-width: 100%; padding: 6px; border-radius: 12px; margin-top: 16px; }
    .input { font-size: 15px; padding: 8px; }
    .grid { gap: 12px; }
    .card { border-radius: 12px; }
    .card-media { aspect-ratio: 4/3; }
    .card-body { padding: 12px; }
    .card-title { font-size: 15px; }
    .watch, .btn { width: 100%; justify-content: center; }
    .btn.outline { padding: 10px; }
    .footer { padding: 16px 12px 32px; font-size: 13px; }
    .player-wrapper { padding-bottom: 56.25%; border-radius: 12px; }
    .episodes-grid { grid-template-columns: repeat(auto-fill, minmax(64px, 1fr)); gap: 10px; }
    .ep-btn { aspect-ratio: 1/0.6; padding: 8px; border-radius: 8px; font-size: 14px; }
    .ambient-light { display: none !important; }
    .navlink, .btn, .watch, .ep-btn { min-height: 44px; }
    @media (max-width: 420px) {
        .brand { font-size: 18px; }
        .header-inner { height: 52px; }
        .title { font-size: clamp(18px, 8vw, 28px); }
        .search { padding: 6px; gap: 6px; }
        .card-media { aspect-ratio: 1.6/1; }
    }
}
@media (hover: none) {
    .card { transition: none; box-shadow: none; }
    .card:hover { transform: none; box-shadow: none; filter: none; }
    .rating-badge { box-shadow: none; }
    .theme-picker-trigger { transform: none; }
}
/* Скрытый чекбокс */
.nav-toggle {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}
.hamburger {
    display: none; /* покажем только на мобильных */
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 10px;
    border: 1px solid hsl(var(--border));
    background: hsl(var(--card));
    color: hsl(var(--fg));
    cursor: pointer;
    padding: 8px;
    transition: transform .12s ease, background .12s ease;
}
.hamburger svg { width: 20px; height: 20px; }
@media (max-width: 639px) {
    .hamburger {
        display: inline-flex;
    }

    .topnav {
        display: none !important;
    }
    .mobile-menu {
        display: none; /* по-умолчанию спрятано */
        position: absolute;
        top: calc(100% + 8px);
        left: 8px;
        right: 8px;
        margin: 0 auto;
        z-index: 250;
        background: hsl(var(--card));
        border: 1px solid hsl(var(--border));
        border-radius: 12px;
        padding: 8px;
        gap: 6px;
        box-shadow: 0 16px 40px rgba(0, 0, 0, 0.36);
        -webkit-backdrop-filter: blur(6px);
        backdrop-filter: blur(6px);
        flex-direction: column;
    }
    .nav-toggle:checked ~ .container ~ .mobile-menu,
    .nav-toggle:checked ~ .mobile-menu,
    .nav-toggle:checked + .container + .mobile-menu {
        display: flex;
    }
    .mobile-link {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 10px 12px;
        border-radius: 10px;
        text-decoration: none;
        color: hsl(var(--fg));
        font-weight: 700;
        font-size: 15px;
        border: 1px solid transparent;
        background: transparent;
    }

    .mobile-link svg {
        width: 18px;
        height: 18px;
    }

    .mobile-link:hover {
        background: hsl(var(--fg) / 0.04);
        border-color: hsl(var(--border));
    }
    .nav {
        gap: 6px;
    }

    .btn.outline {
        padding: 8px;
        min-width: 44px;
    }
    .grid {
        grid-template-columns: 1fr;
        gap: 12px;
        padding-inline: 8px;
    }

    .card {
        max-width: 420px;
        margin: 0 auto;
        border-radius: 12px;
    }

    .card-media {
        aspect-ratio: 3 / 4;
    }

    .card-body {
        padding: 12px;
    }

    .card-title {
        font-size: 16px;
    }
    .title {
        margin: 18px 0 8px;
        font-size: clamp(20px, 6.5vw, 34px);
    }

    .subtitle {
        font-size: 14px;
        margin-bottom: 10px;
    }

    .search {
        padding: 6px;
        margin-top: 12px;
        border-radius: 12px;
    }
    .glows, .character, .ambient-light {
        display: none !important;
    }

    .random-btn.center {
        display: inline-flex !important;
        width: 140px !important;
        height: 140px !important;
        font-size: 16px !important;
    }

    .center-wrap {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 2;
    }

    .card {
        box-shadow: 0 12px 36px -20px hsl(var(--primary-1) / 0.32);
        transition: none;
    }

    .navlink, .btn, .watch, .mobile-link {
        min-height: 44px;
    }

    @media (max-width: 420px) {
        .card {
            max-width: 360px;
        }

        .mobile-menu {
            left: 6px;
            right: 6px;
            padding: 6px;
        }

        .mobile-link {
            padding: 8px 10px;
            font-size: 14px;
            gap: 8px;
        }
    }


    @media (hover: none) {
        .card {
            transition: none;
        }

        .card:hover {
            transform: none;
        }
    }
    @media (max-width: 639px) {
        .random-btn.center {
            width: 140px !important;
            height: 140px !important;
            font-size: 16px !important;
        }
    }

    .center-wrap {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 2;
    }
}