@media (max-width:480px){
  #cart-panel{width:100%;max-width:100%;}
  .checkout-field-row{grid-template-columns:1fr;}
}

/* ══ TRANSITIONS ══ */
.page{display:none;padding-top:72px;padding-bottom:40px;opacity:0;transition:opacity .35s ease;transform:none;filter:none;}
.page.active{display:block;position:relative;opacity:1;pointer-events:all;min-height:0;height:auto;}
.page.out{display:block;position:absolute;top:0;left:0;right:0;opacity:0;pointer-events:none;}
#app{position:relative;overflow-x:hidden;}

/* Каскадная анимация для карточек */
@keyframes cardEntry {
  from { opacity: 0; transform: translateY(20px) scale(.96); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
.page.active .mc, .page.active .ac, .page.active .fc, .page.active .alb, .page.active .si, .page.active .cc, .page.active .smc, .page.active .feat, .page.active .loc, .page.active .plan, .page.active .shc, .page.active .blog-card, .page.active .shop-item {
  animation: cardEntry .5s cubic-bezier(.2,.7,.4,1) both;
}
.page.active .row > *:nth-child(1), .page.active .mg > *:nth-child(1), .page.active .tv-grid > *:nth-child(1), .page.active .shop-g > *:nth-child(1), .page.active .alb-g > *:nth-child(1), .page.active .blog-grid > *:nth-child(1) { animation-delay: 0.00s; }
.page.active .row > *:nth-child(2), .page.active .mg > *:nth-child(2), .page.active .tv-grid > *:nth-child(2), .page.active .shop-g > *:nth-child(2), .page.active .alb-g > *:nth-child(2), .page.active .blog-grid > *:nth-child(2) { animation-delay: 0.04s; }
.page.active .row > *:nth-child(3), .page.active .mg > *:nth-child(3), .page.active .tv-grid > *:nth-child(3), .page.active .shop-g > *:nth-child(3), .page.active .alb-g > *:nth-child(3), .page.active .blog-grid > *:nth-child(3) { animation-delay: 0.08s; }
.page.active .row > *:nth-child(4), .page.active .mg > *:nth-child(4), .page.active .tv-grid > *:nth-child(4), .page.active .shop-g > *:nth-child(4), .page.active .alb-g > *:nth-child(4), .page.active .blog-grid > *:nth-child(4) { animation-delay: 0.12s; }
.page.active .row > *:nth-child(5), .page.active .mg > *:nth-child(5), .page.active .tv-grid > *:nth-child(5), .page.active .shop-g > *:nth-child(5), .page.active .alb-g > *:nth-child(5), .page.active .blog-grid > *:nth-child(5) { animation-delay: 0.16s; }
.page.active .row > *:nth-child(6), .page.active .mg > *:nth-child(6) { animation-delay: 0.20s; }
.page.active .row > *:nth-child(7), .page.active .mg > *:nth-child(7) { animation-delay: 0.24s; }
.page.active .row > *:nth-child(8), .page.active .mg > *:nth-child(8) { animation-delay: 0.28s; }
#app{position:relative;overflow-x:hidden;}

/* ══ HEADER ══ */
header{position:fixed;top:0;left:0;right:0;z-index:900;display:flex;align-items:center;gap:16px;padding:0 36px;height:72px;background:rgba(8,0,16,.97);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);}
.logo{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:7px;color:#fff;cursor:pointer;flex-shrink:0;}
.logo span{color:var(--gold);}
.logo:hover{color:var(--gold);}

.hsearch{flex:1;max-width:460px;position:relative;z-index:100;}
.hsearch input{width:100%;background:var(--card);border:1px solid var(--border2);color:var(--text);font-size:13px;padding:9px 38px 9px 14px;outline:none;transition:border-color .3s;}
.hsearch input:focus{border-color:var(--gold);}
.hsearch input::placeholder{color:var(--dim);}
.hsico{position:absolute;right:11px;top:50%;transform:translateY(-50%);color:var(--gold);font-size:15px;pointer-events:none;z-index:101;}
.sdrop{position:absolute;top:100%;left:0;right:0;background:var(--card2);border:1px solid var(--border2);max-height:480px;overflow-y:auto;z-index:10000;display:none;box-shadow:0 16px 48px rgba(0,0,0,.7);}
.sdrop.open{display:block;}
.sri{display:flex;align-items:center;gap:14px;padding:10px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s;}
.sri:hover{background:var(--bg3);}
/* Poster / movie thumbnail */
.sri img,.sri-ph{width:46px;height:68px;object-fit:cover;flex-shrink:0;border-radius:2px;}
.sri-ph{background:var(--card);display:flex;align-items:center;justify-content:center;font-size:18px;}
/* Person avatar — round and square */
.sri-p img{height:46px;border-radius:50%;object-position:top;}
.sri-p .sri-ph{height:46px;border-radius:50%;}
.sri-t{font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:.5px;color:#fff;line-height:1.2;}
.sri-m{font-size:11px;color:var(--muted);margin-top:3px;line-height:1.5;}
.sri-empty{padding:18px;text-align:center;color:var(--dim);font-size:13px;font-style:italic;}

nav{display:flex;gap:2px;margin-left:auto;flex-wrap:wrap;}
.nb{background:none;border:none;cursor:pointer;font-family:'Inter',sans-serif;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);padding:6px 12px;transition:all .2s;}
.nb:hover,.nb.on{color:var(--gold);background:rgba(201,168,76,.07);}

/* ══ AUTH ══ */
.auth-btn{
  flex-shrink:0;display:flex;align-items:center;gap:8px;
  background:transparent;border:1px solid var(--border2);
  color:var(--muted);font-size:11px;letter-spacing:1px;
  padding:6px 14px;cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;
}
.auth-btn:hover{border-color:var(--gold);color:var(--gold);}
.auth-btn.logged{border-color:var(--gold);color:var(--gold);}
.auth-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:2px solid var(--gold);}
.auth-avatar-placeholder{width:28px;height:28px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:13px;color:#000;font-weight:700;}

/* Модальное окно авторизации */
#auth-modal{position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:3000;display:none;align-items:center;justify-content:center;padding:20px;}
#auth-modal.open{display:flex;}
.auth-box{background:var(--card2);border:1px solid var(--border2);border-top:2px solid var(--gold);width:100%;max-width:420px;padding:40px;}
.auth-close{float:right;background:none;border:none;color:var(--muted);font-size:22px;cursor:pointer;margin-top:-8px;}
.auth-close:hover{color:var(--gold);}
.auth-title{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:4px;color:#fff;margin-bottom:4px;}
.auth-sub{font-size:12px;color:var(--muted);margin-bottom:28px;}
.auth-tabs{display:flex;gap:2px;margin-bottom:24px;}
.auth-tab{flex:1;padding:8px;background:transparent;border:1px solid var(--border);color:var(--muted);font-size:11px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;}
.auth-tab.on{background:var(--gold);color:#000;border-color:var(--gold);}
.auth-field{margin-bottom:14px;}
.auth-field label{display:block;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:5px;}
.auth-field input{width:100%;background:var(--bg3);border:1px solid var(--border2);color:var(--text);font-size:14px;padding:10px 12px;outline:none;transition:border-color .2s;font-family:'Inter',sans-serif;}
.auth-field input:focus{border-color:var(--gold);}
.auth-submit{width:100%;padding:12px;background:var(--gold);color:#000;border:none;font-size:11px;letter-spacing:3px;text-transform:uppercase;font-weight:700;cursor:pointer;margin-top:8px;transition:background .2s;}
.auth-submit:hover{background:var(--gold2);}
.google-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px;background:#fff;color:#333;border:1px solid #ddd;font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;margin-bottom:4px;transition:box-shadow .2s;box-sizing:border-box;}
.google-btn:hover{box-shadow:0 2px 8px rgba(0,0,0,.15);}
.auth-divider{text-align:center;margin:14px 0;position:relative;}
.auth-divider::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border);}
.auth-divider span{position:relative;background:var(--card2);padding:0 10px;font-size:11px;color:var(--dim);letter-spacing:2px;}
.auth-avatar-upload{display:flex;align-items:center;gap:14px;margin-bottom:18px;}
.auth-avatar-big{width:64px;height:64px;border-radius:50%;object-fit:cover;border:2px solid var(--gold);flex-shrink:0;}
.auth-avatar-big-ph{width:64px;height:64px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:24px;color:#000;flex-shrink:0;}
.auth-avatar-label{font-size:11px;color:var(--gold);cursor:pointer;text-decoration:underline;}

/* ══ FAV BUTTON ══ */
.fav-btn{position:absolute;top:7px;right:7px;z-index:5;background:rgba(0,0,0,.7);border:none;font-size:16px;cursor:pointer;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .2s;padding:0;}
.fav-btn:hover{transform:scale(1.2);}

/* ══ PROFILE STYLES ══ */
.profile-hero{padding:48px 36px;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;gap:28px;align-items:center;}
.profile-avatar-big{width:96px;height:96px;border-radius:50%;object-fit:cover;border:3px solid var(--gold);flex-shrink:0;}
.profile-avatar-big-ph{width:96px;height:96px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:36px;color:#000;flex-shrink:0;}
.profile-name{font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:4px;color:#fff;}
.profile-email{font-size:12px;color:var(--muted);margin-top:3px;}
.profile-stats{display:flex;gap:24px;margin-top:12px;}
.ps-val{font-family:'Bebas Neue',sans-serif;font-size:22px;color:var(--gold);}
.ps-lbl{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--dim);}
.logout-btn{margin-top:14px;padding:7px 20px;background:transparent;border:1px solid var(--border2);color:var(--muted);font-size:10px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;}
.logout-btn:hover{border-color:var(--red,#e05555);color:#e05555;}

/* История просмотра */
.history-empty{color:var(--dim);font-style:italic;font-size:13px;padding:20px 0;}

/* Пустые состояния профиля */
.profile-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;text-align:center;}
.profile-empty-ico{font-size:48px;margin-bottom:16px;opacity:.7;}
.profile-empty-title{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:3px;color:var(--text);margin-bottom:8px;}
.profile-empty-sub{font-size:12px;color:var(--muted);line-height:1.6;max-width:240px;}
.history-item{display:flex;align-items:center;gap:14px;padding:10px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s;}
.history-item:hover{background:var(--bg3);padding:10px 8px;margin:0 -8px;}
.hi-poster{width:40px;height:58px;object-fit:cover;flex-shrink:0;background:var(--card2);}
.hi-poster-ph{width:40px;height:58px;background:var(--card2);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.hi-title{font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:1px;color:#fff;}
.hi-meta{font-size:10px;color:var(--muted);margin-top:2px;}
.hi-remove{margin-left:auto;background:none;border:none;color:var(--dim);cursor:pointer;font-size:18px;padding:4px;transition:color .2s;}
.hi-remove:hover{color:#e05555;}

/* ══ PROFILE EXTENDED ══ */
/* Прогресс уровня */
.level-bar-wrap{margin-top:10px;max-width:280px;}
.level-bar-labels{display:flex;justify-content:space-between;font-size:9px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin-bottom:5px;}
.level-bar-track{height:4px;background:var(--bg3);border:1px solid var(--border);overflow:hidden;}
.level-bar-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold2));transition:width .6s cubic-bezier(.4,0,.2,1);}
/* Тултип уровня */
.lvl-help{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;border:1px solid var(--muted);color:var(--muted);font-size:8px;cursor:pointer;transition:border-color .2s,color .2s;flex-shrink:0;}
.lvl-help:hover{border-color:var(--gold);color:var(--gold);}
.lvl-tooltip-popup{position:absolute;right:0;top:calc(100% + 6px);background:var(--card2);border:1px solid var(--border2);border-top:2px solid var(--gold);padding:14px 16px;width:260px;z-index:200;box-shadow:0 8px 24px rgba(0,0,0,.35);}
.lvl-tp-title{font-family:'Bebas Neue',sans-serif;font-size:13px;letter-spacing:2px;color:var(--gold);margin-bottom:10px;}
.lvl-tp-row{font-size:11px;color:var(--text);padding:3px 0;line-height:1.5;}
.lvl-tp-levels{font-size:9px;color:var(--muted);margin-top:10px;line-height:1.7;border-top:1px solid var(--border);padding-top:8px;}
.lvl-tp-lbl{font-family:'Bebas Neue',sans-serif;letter-spacing:1.5px;font-size:10px;color:var(--muted);margin-bottom:2px;}
/* Редактирование имени */
.profile-name-wrap{display:flex;align-items:center;gap:8px;}
.profile-edit-btn{background:none;border:none;color:var(--dim);cursor:pointer;font-size:13px;padding:2px 4px;transition:color .2s;flex-shrink:0;}
.profile-edit-btn:hover{color:var(--gold);}
.profile-name-input{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:3px;background:transparent;border:none;border-bottom:2px solid var(--gold);color:var(--text);outline:none;width:200px;padding:0;}
/* Карточки друзей */
.friends-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:28px;}
.friend-card{padding:16px;background:var(--card);border:1px solid var(--border);display:flex;flex-direction:column;gap:10px;transition:box-shadow .2s,border-color .2s;}
.friend-card:hover{border-color:var(--gold);box-shadow:0 4px 16px var(--shadow);}
.friend-card-top{display:flex;align-items:center;gap:12px;}
.friend-avatar{width:44px;height:44px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:16px;color:#000;flex-shrink:0;border:2px solid transparent;}
.friend-avatar.online{border-color:var(--gold);box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--gold);}
.friend-name{font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:1px;color:var(--text);}
.friend-level{font-size:9px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-top:1px;}
.friend-stats{display:flex;gap:14px;}
.friend-stat{text-align:center;}
.friend-stat-val{font-family:'Bebas Neue',sans-serif;font-size:16px;color:var(--gold);}
.friend-stat-lbl{font-size:8px;color:var(--dim);letter-spacing:1px;text-transform:uppercase;}
.friend-actions{display:flex;gap:6px;margin-top:4px;}
.friend-add-btn{flex:1;padding:7px;background:rgba(140,180,80,.12);border:1px solid rgba(140,180,80,.4);color:#6ea832;font-size:9px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;font-family:'Inter',sans-serif;transition:all .2s;}
.friend-add-btn:hover{background:rgba(140,180,80,.22);border-color:#6ea832;}
.friend-remove-btn{padding:7px 10px;background:transparent;border:1px solid var(--border2);color:var(--dim);font-size:12px;cursor:pointer;transition:all .2s;}
.friend-remove-btn:hover{border-color:#e05555;color:#e05555;}
.friend-msg-btn{flex:1;padding:7px;background:transparent;border:1px solid var(--border);color:var(--muted);font-size:9px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;font-family:'Inter',sans-serif;transition:all .2s;}
.friend-msg-btn:hover{border-color:var(--gold);color:var(--gold);}
/* Найти друга */
.friend-search-box{margin-bottom:24px;padding:18px 20px;background:var(--card);border:1px solid var(--border);}
.friend-search-title{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-bottom:10px;}
.friend-search-row{display:flex;gap:8px;}
.friend-search-inp{flex:1;padding:9px 12px;background:var(--bg2);border:1px solid var(--border);color:var(--text);font-size:13px;font-family:'Inter',sans-serif;outline:none;}
.friend-search-inp:focus{border-color:var(--gold);}
.friend-search-inp::placeholder{color:var(--dim);}
.friend-search-go{padding:9px 18px;background:var(--gold);color:#fff;border:none;font-size:10px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;font-family:'Inter',sans-serif;}
.friend-search-go:hover{background:var(--gold2);}
/* Инвайт */
.friend-invite-box{padding:16px 20px;background:var(--bg2);border:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;}
.friend-invite-text{font-size:12px;color:var(--muted);}
.friend-invite-btn{padding:8px 16px;background:transparent;border:1px solid var(--border2);color:var(--muted);font-size:10px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;white-space:nowrap;transition:all .2s;}
.friend-invite-btn:hover{border-color:var(--gold);color:var(--gold);}
/* Вотчлист */
.wl-item{display:flex;align-items:center;gap:14px;padding:10px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s;}
.wl-item:hover{background:var(--bg3);padding:10px 8px;margin:0 -8px;}
.wl-poster{width:40px;height:58px;object-fit:cover;flex-shrink:0;background:var(--card2);}
.wl-poster-ph{width:40px;height:58px;background:var(--card2);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.wl-title{font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:1px;color:var(--text);}
.wl-meta{font-size:10px;color:var(--muted);margin-top:2px;}
.wl-remove{margin-left:auto;background:none;border:none;color:var(--dim);cursor:pointer;font-size:18px;padding:4px;transition:color .2s;}
.wl-remove:hover{color:#e05555;}
/* Кнопка "Хочу посмотреть" на странице фильма */
.fwl-btn{padding:10px 20px;background:transparent;color:var(--muted);border:1px solid var(--border2);font-size:10px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;}
.fwl-btn:hover{border-color:var(--gold);color:var(--gold);}
.fwl-btn.in-wl{background:rgba(168,124,31,.1);border-color:var(--gold);color:var(--gold);}
/* Секция "Смотрят друзья" в профиле */
.friends-watching{margin-bottom:24px;}
.fw-item{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid var(--border);}
.fw-avatar{width:30px;height:30px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:11px;color:#000;flex-shrink:0;}
.fw-info{flex:1;}
.fw-name{font-size:12px;color:var(--text);font-weight:600;}
.fw-film{font-size:10px;color:var(--muted);}
.fw-time{font-size:9px;color:var(--dim);flex-shrink:0;}
:root[data-theme="light"] .friend-card{background:var(--card);}
:root[data-theme="light"] .friend-search-box{background:var(--card);}
:root[data-theme="light"] .friend-name{color:var(--text);}
:root[data-theme="light"] .wl-title{color:var(--text);}
:root[data-theme="light"] .fw-name{color:var(--text);}

/* ══ COMMON ══ */
.sec{padding:56px 36px;}
.sl{font-size:9px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:5px;}
.st{font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:3px;color:#fff;margin-bottom:28px;}
.row{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:11px;padding-bottom:8px;scrollbar-width:thin;scrollbar-color:var(--border2) var(--bg);}
.row::-webkit-scrollbar{height:3px;}
.row::-webkit-scrollbar-thumb{background:var(--gold);border-radius:2px;}
/* .sk перенесён в main.css — shimmer-анимация */
/* ── Footer ── */
.site-footer{border-top:1px solid var(--border);margin-top:60px;background:var(--bg3);}
.footer-inner{display:flex;gap:48px;padding:44px 40px 32px;flex-wrap:wrap;}
.footer-brand{flex:0 0 220px;}
.footer-tagline{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin:8px 0 6px;}
.footer-desc{font-size:12px;color:var(--dim);line-height:1.7;max-width:200px;}
.footer-socials{display:flex;gap:8px;margin-top:14px;}
.footer-social-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border2);color:var(--muted);font-size:14px;text-decoration:none;transition:all .2s;}
.footer-social-btn:hover{border-color:var(--gold);color:var(--gold);}
.footer-cols{display:flex;gap:48px;flex:1;flex-wrap:wrap;}
.footer-col{display:flex;flex-direction:column;gap:6px;}
.footer-col-h{font-family:'Bebas Neue',sans-serif;font-size:14px;letter-spacing:3px;color:var(--gold);margin-bottom:4px;}
.footer-link{background:none;border:none;color:var(--muted);font-size:12px;letter-spacing:1px;cursor:pointer;text-align:left;padding:2px 0;text-decoration:none;display:block;transition:color .2s;}
.footer-link:hover{color:var(--text);}
.footer-bottom{border-top:1px solid var(--border);padding:14px 40px;display:flex;justify-content:space-between;align-items:center;font-size:10px;color:var(--dim);letter-spacing:1px;}
.footer-lang-sw{display:flex;gap:8px;}
/* ── Language toggle ── */
.lang-sw{display:flex;gap:6px;align-items:center;margin-left:8px;}
.lang-btn{font-size:10px;letter-spacing:2px;cursor:pointer;padding:3px 7px;border:1px solid var(--border2);color:var(--dim);transition:all .2s;user-select:none;}
.lang-btn.on{border-color:var(--gold);color:var(--gold);}
.lang-btn:hover{border-color:var(--muted);color:var(--muted);}
/* ── Nav dropdown ── */
.nb-drop{position:relative;display:inline-block;}
.nb-drop-menu{position:absolute;top:calc(100% + 4px);left:0;background:var(--card2);border:1px solid var(--border2);border-top:2px solid var(--gold);min-width:160px;z-index:500;display:none;flex-direction:column;padding:6px 0;}
.nb-drop-menu.open{display:flex;}
.nb-drop-menu button{background:none;border:none;color:var(--muted);font-size:11px;letter-spacing:2px;text-transform:uppercase;padding:9px 16px;cursor:pointer;text-align:left;transition:all .2s;}
.nb-drop-menu button:hover{color:var(--gold);background:var(--bg3);}
footer:not(.site-footer){display:none;}

/* ══ HERO ══ */
.hero{height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:0 24px;position:relative;overflow:hidden;}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 55%,rgba(100,0,200,.16) 0%,transparent 68%);}
.hero-tag{font-size:10px;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:16px;opacity:0;transform:translateY(-18px);transition:opacity .8s ease,transform .8s ease;}
.hero-tag.hr-vis{opacity:1;transform:none;}
.hero h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(80px,13vw,155px);letter-spacing:16px;line-height:.9;color:#fff;}
.hero h1 .eq{color:var(--gold);}
.hero p{margin-top:16px;font-size:14px;color:var(--muted);font-weight:300;max-width:400px;line-height:1.8;opacity:0;transform:translateY(22px);transition:opacity .85s .15s ease,transform .85s .15s ease;}
.hero p.hr-vis{opacity:1;transform:none;}
.hero-ai-cta{margin-top:28px;padding:13px 36px;background:var(--gold);color:#000;border:none;font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:3px;cursor:pointer;transition:all .3s;opacity:0;transform:translateY(22px);transition:opacity .85s .3s ease,transform .85s .3s ease,background .2s;}
.hero-ai-cta.hr-vis{opacity:1;transform:none;}
.hero-ai-cta:hover{background:var(--gold2);transform:translateY(-2px);}
/* scroll-reveal для секций */
.sr{opacity:0;transform:translateY(36px);transition:opacity .7s ease,transform .7s ease;}
.sr.sr-vis{opacity:1;transform:none;}
.hero-btns{display:flex;gap:12px;margin-top:28px;}
.hb1{padding:12px 32px;background:var(--gold);color:#000;border:none;font-size:10px;letter-spacing:3px;text-transform:uppercase;font-weight:700;cursor:pointer;transition:all .3s;}
.hb1:hover{background:var(--gold2);transform:translateY(-2px);}
.hb2{padding:12px 32px;background:transparent;color:var(--muted);border:1px solid var(--border2);font-size:10px;letter-spacing:3px;text-transform:uppercase;cursor:pointer;transition:all .3s;}
.hb2:hover{border-color:var(--gold);color:var(--gold);}

/* ══ MOVIE CARD ══ */
.mc{flex-shrink:0;width:165px;background:var(--card);border:1px solid var(--border);cursor:pointer;transition:border-color .3s,transform .32s;overflow:hidden;}
.mc:hover{border-color:var(--gold);transform:translateY(-8px);}
.mc img{width:165px;height:234px;object-fit:cover;display:block;transition:transform .4s;}
.mc:hover img{transform:scale(1.04);}
.mc-ph{width:165px;height:234px;display:flex;align-items:center;justify-content:center;font-size:38px;background:var(--card2);}
.mc-info{padding:10px;}
.mc-yr{font-size:9px;color:var(--gold);letter-spacing:2px;}
.mc-ttl{font-family:'Bebas Neue',sans-serif;font-size:13px;letter-spacing:1px;color:#fff;margin:2px 0;line-height:1.1;}
.mc-rat{font-size:9px;color:var(--muted);}
.mc-rat b{color:var(--gold);}
/* TV badge */
.mc-tv{position:absolute;top:8px;left:8px;background:rgba(201,168,76,.9);color:#000;font-size:7px;letter-spacing:1px;font-weight:700;padding:2px 6px;font-family:'Inter',sans-serif;}

/* ══ ACTOR CARD ══ */
.ac{flex-shrink:0;width:138px;background:var(--card);border:1px solid var(--border);cursor:pointer;transition:border-color .3s,transform .3s;}
.ac:hover{border-color:var(--gold);transform:translateY(-6px);}
.ac img{width:138px;height:184px;object-fit:cover;object-position:top;display:block;filter:grayscale(10%);transition:filter .3s;}
.ac:hover img{filter:grayscale(0%);}
.ac-ph{width:138px;height:184px;display:flex;align-items:center;justify-content:center;font-size:38px;background:var(--card2);}
.ac-n{font-family:'Bebas Neue',sans-serif;font-size:12px;letter-spacing:2px;color:#fff;padding:8px 8px 2px;}
.ac-d{font-size:9px;color:var(--dim);font-style:italic;padding:0 8px 8px;}

/* ══ FREE FILM CARD ══ */
.fc{flex-shrink:0;width:190px;cursor:pointer;transition:transform .32s;}
.fc:hover{transform:translateY(-9px);}
.fc-t{width:190px;height:268px;position:relative;overflow:hidden;border:1px solid var(--border);transition:border-color .3s;background:#050505;}
.fc:hover .fc-t{border-color:var(--gold);}
.fc-t img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.85);transition:transform .5s,filter .3s;}
.fc:hover .fc-t img{transform:scale(1.05);filter:brightness(1);}
.fc-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0);font-size:48px;color:rgba(255,255,255,0);transition:all .3s;z-index:2;}
.fc:hover .fc-play{background:rgba(0,0,0,.55);color:var(--gold);text-shadow:0 0 28px rgba(201,168,76,.8);}
.fc-grd{position:absolute;bottom:0;left:0;right:0;padding:26px 10px 7px;background:linear-gradient(to top,rgba(0,0,0,.85),transparent);z-index:1;}
.fc-grd-t{font-family:'Bebas Neue',sans-serif;font-size:11px;letter-spacing:2px;color:rgba(255,255,255,.4);}
.fc-info{padding:8px 0;}
.fc-badge{font-size:8px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:3px;}
.fc-title{font-family:'Bebas Neue',sans-serif;font-size:14px;letter-spacing:2px;color:#fff;margin-bottom:2px;}
.fc-meta{font-size:9px;color:var(--dim);}

/* ══ SHOP CARD (home) ══ */
.shc{flex-shrink:0;width:188px;background:var(--card);border:1px solid var(--border);cursor:pointer;transition:border-color .3s,transform .3s;position:relative;overflow:hidden;}
.shc:hover{border-color:var(--gold);transform:translateY(-5px);}
.shc-img{width:188px;height:188px;display:flex;align-items:center;justify-content:center;font-size:52px;}
.shc-info{padding:12px;}
.shc-tag{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:4px;}
.shc-name{font-size:12px;color:#ddd;margin-bottom:5px;line-height:1.3;}
.shc-price{font-family:'Bebas Neue',sans-serif;font-size:14px;color:var(--gold);}
.shc-add{position:absolute;top:8px;right:8px;width:26px;height:26px;background:var(--gold);color:#000;border:none;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;}
.shc:hover .shc-add{opacity:1;}

/* ══ FEAT ══ */
.feat{flex-shrink:0;width:210px;background:var(--bg3);border:1px solid var(--border);padding:22px 18px;transition:border-color .3s,transform .3s;}
.feat:hover{border-color:var(--gold);transform:translateY(-4px);}
.feat-ico{font-size:24px;margin-bottom:11px;display:block;}
.feat h3{font-family:'Bebas Neue',sans-serif;font-size:17px;letter-spacing:2px;color:#fff;margin-bottom:6px;}
.feat p{font-size:11px;color:var(--dim);line-height:1.6;}

/* ══ LOC ══ */
.loc-g{display:grid;grid-template-columns:1fr 1fr;gap:2px;}
.loc{background:var(--bg3);padding:28px;border:1px solid var(--border);position:relative;overflow:hidden;transition:border-color .3s;}
.loc:hover{border-color:var(--gold);}
.loc::before{content:'';position:absolute;top:0;left:0;width:3px;height:0;background:var(--gold);transition:height .4s;}
.loc:hover::before{height:100%;}
.loc-n{position:absolute;top:12px;right:12px;font-family:'Bebas Neue',sans-serif;font-size:42px;color:var(--bg2);}
.loc-ctr{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:4px;}
.loc-city{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:3px;color:#fff;margin-bottom:7px;}
.loc-txt{font-size:11px;color:var(--dim);line-height:1.6;font-style:italic;}

/* ══ SUB ══ */
.sub{padding:72px 36px;text-align:center;background:var(--bg2);border-top:1px solid var(--border);}
.sub .st{margin-bottom:4px;}
.sub>p{color:var(--dim);font-size:13px;margin-bottom:38px;}
.plans{display:flex;gap:2px;max-width:780px;margin:0 auto;}
.plan{flex:1;background:var(--card);padding:28px 18px;border:1px solid var(--border);position:relative;text-align:left;transition:border-color .3s;}
.plan:hover,.plan.hot{border-color:var(--gold);}
.plan-badge{position:absolute;top:-1px;left:50%;transform:translateX(-50%);font-size:8px;letter-spacing:2px;background:var(--gold);color:#000;padding:3px 11px;white-space:nowrap;}
.plan-name{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:3px;color:#fff;margin-bottom:10px;}
.plan-price{font-family:'Bebas Neue',sans-serif;font-size:40px;color:var(--gold);line-height:1;margin-bottom:14px;}
.plan-price span{font-size:12px;color:var(--dim);}
.plan-ul{list-style:none;margin-bottom:18px;}
.plan-ul li{font-size:11px;color:var(--muted);padding:5px 0;border-bottom:1px solid var(--border);}
.plan-ul li::before{content:'— ';color:var(--gold);}
.btn-g{width:100%;padding:9px;background:var(--gold);color:#000;border:none;cursor:pointer;font-size:9px;letter-spacing:3px;text-transform:uppercase;font-weight:700;transition:background .3s;}
.btn-g:hover{background:var(--gold2);}
.btn-o{width:100%;padding:9px;background:transparent;color:var(--muted);border:1px solid var(--border2);cursor:pointer;font-size:9px;letter-spacing:3px;text-transform:uppercase;transition:all .3s;}
.btn-o:hover{border-color:var(--gold);color:var(--gold);}

/* ══ FILM PAGE ══ */
.fhero{position:relative;height:78vh;overflow:hidden;display:flex;align-items:flex-end;}
.fhero-bg{position:absolute;inset:0;background-size:cover;background-position:center 22%;filter:brightness(.2) saturate(1.4);}
.fhero-grad{position:absolute;inset:0;background:linear-gradient(to top,var(--bg) 0%,rgba(8,0,16,.38) 48%,transparent 100%);}
.fhero-in{position:relative;z-index:2;display:flex;gap:32px;align-items:flex-end;padding:0 36px 44px;width:100%;}
#fposter img{width:182px;height:272px;object-fit:cover;display:block;border:1px solid var(--border2);box-shadow:0 22px 60px rgba(0,0,0,.96);}
#fposter .fph{width:182px;height:272px;background:var(--card2);display:flex;align-items:center;justify-content:center;font-size:48px;border:1px solid var(--border2);}
#fmeta{flex:1;}
.f-pills{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:9px;}
.fpill{font-size:8px;letter-spacing:2px;text-transform:uppercase;padding:2px 9px;border:1px solid var(--border2);color:var(--muted);}
.ftitle{font-family:'Bebas Neue',sans-serif;font-size:clamp(42px,7vw,86px);letter-spacing:3px;color:#fff;line-height:.9;margin-bottom:7px;}
.ftagline{font-size:12px;color:var(--muted);font-style:italic;margin-bottom:14px;}
.fstats{display:flex;gap:20px;flex-wrap:wrap;margin-bottom:18px;}
.fsl{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:var(--dim);margin-bottom:2px;}
.fsv{font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:2px;color:var(--gold);}
.fsv.sm{font-size:12px;color:#aaa;}
.fbtns{display:flex;gap:7px;flex-wrap:wrap;}
.fbw{padding:10px 24px;background:var(--gold);color:#000;border:none;font-size:10px;letter-spacing:3px;text-transform:uppercase;font-weight:700;cursor:pointer;transition:all .3s;}
.fbw:hover{background:var(--gold2);transform:translateY(-2px);}
.fbt{padding:10px 24px;background:transparent;color:var(--muted);border:1px solid var(--border2);font-size:10px;letter-spacing:3px;text-transform:uppercase;cursor:pointer;transition:all .3s;}
.fbt:hover{border-color:var(--gold);color:var(--gold);}
.fbody{max-width:1100px;margin:0 auto;padding:44px 36px;}
.fblock{margin-bottom:44px;}
.fbt-t{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:3px;color:#fff;margin-bottom:3px;}
.fbt-l{width:28px;height:2px;background:var(--gold);margin-bottom:16px;}
.fov{font-size:13px;color:var(--muted);line-height:1.9;max-width:700px;font-weight:300;}
.det-g{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:9px;}
.det{background:var(--bg3);border:1px solid var(--border);padding:13px;}
.det-l{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:var(--dim);margin-bottom:4px;}
.det-v{font-size:12px;color:#ccc;font-weight:300;}
/* Season / Episode */
.stabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;}
.stab{padding:5px 13px;background:var(--card);border:1px solid var(--border);color:var(--muted);font-size:10px;letter-spacing:2px;cursor:pointer;transition:all .2s;text-transform:uppercase;}
.stab.on,.stab:hover{background:var(--gold);color:#000;border-color:var(--gold);}
.ep-list{max-height:420px;overflow-y:auto;border:1px solid var(--border);}
.ep-item{display:flex;align-items:flex-start;gap:12px;padding:11px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .18s;}
.ep-item:hover{background:var(--bg3);}
.ep-num{font-family:'Bebas Neue',sans-serif;font-size:20px;color:var(--gold);min-width:38px;line-height:1;}
.ep-title{font-size:12px;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ep-meta{font-size:10px;color:var(--dim);}
.ep-desc{font-size:10px;color:var(--muted);margin-top:3px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.ep-play{color:var(--gold);font-size:16px;padding-top:3px;flex-shrink:0;}
/* cast */
.cc{flex-shrink:0;width:112px;text-align:center;background:var(--card);border:1px solid var(--border);transition:border-color .3s,transform .3s;cursor:pointer;}
.cc:hover{border-color:var(--gold);transform:translateY(-4px);}
.cc img{width:112px;height:146px;object-fit:cover;object-position:top;display:block;filter:grayscale(10%);transition:filter .3s;}
.cc:hover img{filter:grayscale(0%);}
.cc-ph{width:112px;height:146px;background:var(--card2);display:flex;align-items:center;justify-content:center;font-size:28px;}
.cc-n{font-family:'Bebas Neue',sans-serif;font-size:10px;letter-spacing:1px;color:#fff;padding:5px 5px 2px;line-height:1.1;}
.cc-c{font-size:8px;color:var(--dim);font-style:italic;padding:0 5px 6px;}
/* crew (создатели) */
.crew-block{padding-top:8px;}
.crew-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px 32px;margin-top:14px;}
.crew-row{display:flex;flex-direction:column;gap:4px;padding:8px 0;border-bottom:1px solid var(--border);}
.crew-row:last-child{border-bottom:none;}
.crew-role{font-size:10px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;}
.crew-people{display:flex;flex-wrap:wrap;gap:6px 12px;}
.crew-person{color:var(--text);font-size:13px;cursor:pointer;transition:color .2s;border-bottom:1px dotted var(--border2);padding-bottom:1px;}
.crew-person:hover{color:var(--gold);border-bottom-color:var(--gold);}
@media (max-width:640px){
  .crew-grid{grid-template-columns:1fr;gap:8px 0;}
  .crew-role{font-size:9px;}
  .crew-person{font-size:12px;}
}
/* SoundCloud */
.sc-wrap{background:var(--card);border:1px solid var(--border);overflow:hidden;border-radius:2px;}
/* similar */
.smc{flex-shrink:0;width:128px;background:var(--card);border:1px solid var(--border);cursor:pointer;transition:border-color .3s,transform .3s;}
.smc:hover{border-color:var(--gold);transform:translateY(-4px);}
.smc img{width:128px;height:180px;object-fit:cover;display:block;}
.smc-ph{width:128px;height:180px;display:flex;align-items:center;justify-content:center;font-size:28px;background:var(--card2);}
.smc-info{padding:7px;}
.smc-t{font-family:'Bebas Neue',sans-serif;font-size:11px;letter-spacing:1px;color:#fff;line-height:1.1;}
.smc-y{font-size:9px;color:var(--gold);margin-top:2px;}

/* ══ ACTOR PAGE ══ */
.ahero{position:relative;height:66vh;overflow:hidden;display:flex;align-items:flex-end;}
.ahero-bg{position:absolute;inset:0;background-size:cover;background-position:center 12%;filter:brightness(.16) saturate(1.2);}
.ahero-grad{position:absolute;inset:0;background:linear-gradient(to top,var(--bg) 0%,transparent 58%);}
.ahero-in{position:relative;z-index:2;display:flex;gap:32px;align-items:flex-end;padding:0 36px 40px;width:100%;}
#actor-photo img{width:168px;height:224px;object-fit:cover;object-position:top;display:block;border:1px solid var(--border2);box-shadow:0 18px 56px rgba(0,0,0,.96);}
#actor-photo .aph{width:168px;height:224px;background:var(--card2);display:flex;align-items:center;justify-content:center;font-size:48px;border:1px solid var(--border2);}
#actor-meta{flex:1;}
.an-dept{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:7px;}
.an-name{font-family:'Bebas Neue',sans-serif;font-size:clamp(44px,6vw,78px);letter-spacing:3px;color:#fff;line-height:.9;margin-bottom:7px;}
.an-stats{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:14px;}
.asl{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:var(--dim);margin-bottom:2px;}
.asv{font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:2px;color:var(--gold);}
.asv.sm{font-size:12px;color:#aaa;}
.asocs{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap;}
.asoc{font-size:9px;padding:4px 10px;border:1px solid var(--border2);color:var(--muted);cursor:pointer;transition:all .2s;}
.asoc:hover{border-color:var(--gold);color:var(--gold);}

/* ══ MOVIES PAGE ══ */
.mg{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:11px;margin-top:24px;}
.sort-tabs{display:flex;gap:0;margin-bottom:18px;border-bottom:1px solid var(--border2);}
.sort-tab{padding:8px 20px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);font-size:10px;letter-spacing:3px;text-transform:uppercase;cursor:pointer;font-family:'Bebas Neue',sans-serif;font-size:14px;transition:all .2s;margin-bottom:-1px;}
.sort-tab:hover{color:#fff;}
.sort-tab.on{color:var(--gold);border-bottom-color:var(--gold);}
.gf-wrap{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px;}
.gf{padding:5px 14px;background:transparent;border:1px solid var(--border2);color:var(--muted);font-size:9px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;}
.pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:36px 0 16px;flex-wrap:wrap;}
.pg-btn{min-width:36px;height:36px;padding:0 10px;background:transparent;border:1px solid var(--border2);color:var(--muted);font-size:12px;letter-spacing:1px;cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;}
.pg-btn:hover{border-color:var(--gold);color:var(--gold);}
.pg-btn.on{background:var(--gold);color:#000;border-color:var(--gold);font-weight:700;}
.pg-btn:disabled{opacity:.3;cursor:default;}
.pg-info{font-size:11px;color:var(--dim);letter-spacing:1px;padding:0 8px;}
.gf:hover,.gf.on{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.06);}

/* ══ TV PAGE ══ */
.tv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:11px;margin-top:24px;}

/* ══ MUSIC PAGE ══ */
.alb-g{display:grid;grid-template-columns:repeat(auto-fill,minmax(188px,1fr));gap:14px;margin-top:28px;}
.mu-track{display:flex;align-items:center;gap:12px;padding:10px 12px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s;}
.mu-track:hover,.mu-track.active{background:var(--card);}
.mu-track.active .mu-track-num{color:var(--gold);}
.mu-track-num{width:28px;text-align:center;font-size:11px;color:var(--muted);flex-shrink:0;}
.mu-track-thumb{width:56px;height:42px;object-fit:cover;flex-shrink:0;background:var(--card2);}
.mu-track-info{flex:1;min-width:0;}
.mu-track-name{font-size:12px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.mu-track-play{width:28px;text-align:center;font-size:16px;color:var(--muted);flex-shrink:0;}
.alb{background:var(--card);border:1px solid var(--border);cursor:pointer;transition:border-color .3s,transform .3s;overflow:hidden;}
.alb:hover{border-color:var(--gold);transform:translateY(-5px);}
.alb-cover{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:52px;background:var(--card2);}
.alb-info{padding:13px;}
.alb-title{font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:2px;color:#fff;margin-bottom:3px;}
.alb-artist{font-size:11px;color:var(--muted);}
.alb-year{font-size:9px;color:var(--gold);margin-top:3px;}
.sc-main{background:var(--card);border:1px solid var(--border);border-radius:2px;margin-bottom:36px;overflow:hidden;}

/* ══ SHOP PAGE ══ */
.shop-g{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;margin-top:24px;}
.si{background:var(--card);border:1px solid var(--border);cursor:pointer;transition:border-color .3s,transform .3s;position:relative;overflow:hidden;}
.si:hover{border-color:var(--gold);transform:translateY(-5px);}
.si-img{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:58px;}
.si-info{padding:13px;}
.si-cat{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:4px;}
.si-name{font-size:13px;color:#ddd;margin-bottom:5px;line-height:1.3;}
.si-price{font-family:'Bebas Neue',sans-serif;font-size:15px;color:var(--gold);}
.si-film{font-size:9px;color:var(--dim);margin-top:3px;}
.si-add{position:absolute;top:9px;right:9px;width:28px;height:28px;background:var(--gold);color:#000;border:none;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;}
.si:hover .si-add{opacity:1;}
.sf-wrap{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:22px;}
.sf{padding:5px 14px;background:transparent;border:1px solid var(--border2);color:var(--muted);font-size:9px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;}
.sf:hover,.sf.on{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.06);}

/* ══ PLAYER ══ */
/* ═══ PLAYER — Kinopoisk-style ════════════════════════════ */
#pov{position:fixed;inset:0;background:#000;z-index:9999;display:none;flex-direction:column;}
#pov.open{display:flex !important;}
/* Top bar */
#ptopbar{display:flex;align-items:center;gap:12px;padding:0 20px;height:52px;background:linear-gradient(to bottom,rgba(0,0,0,.85) 0%,transparent 100%);position:absolute;top:0;left:0;right:0;z-index:20;flex-shrink:0;}
#ptopbar .pt-logo{font-size:9px;letter-spacing:4px;color:var(--gold);font-family:'Bebas Neue',sans-serif;white-space:nowrap;}
#ptopbar .pt-sep{width:1px;height:16px;background:rgba(255,255,255,.15);}
#ptitle{font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:3px;color:rgba(255,255,255,.85);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
#pclose{margin-left:auto;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.1);border:none;color:#fff;font-size:18px;cursor:pointer;transition:all .2s;flex-shrink:0;}
#pclose:hover{background:rgba(255,255,255,.22);color:var(--gold);}
/* Video area */
#pwrap{flex:1;position:relative;background:#000;overflow:hidden;}
#pwrap iframe,#pwrap video{position:absolute;inset:0;width:100%;height:100%;border:none;object-fit:contain;}
/* Маскируем верхнюю полосу iframe — там обычно рендерятся рекламные баннеры Alloha */
#pov.iframe-mode #pwrap::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:52px;
  z-index:6;
  background:linear-gradient(to bottom,#000 0%,rgba(0,0,0,.6) 70%,transparent 100%);
  pointer-events:none;
}
/* Bottom control bar */
#pbar{display:none;align-items:center;gap:8px;padding:0 16px;height:48px;background:linear-gradient(to top,rgba(0,0,0,.92) 0%,transparent 100%);position:absolute;bottom:0;left:0;right:0;z-index:20;}
#plang{display:none;} /* legacy — hidden, controls moved to pbar */
/* Lang buttons */
.p-lang-btn{padding:4px 12px;border:1px solid rgba(255,255,255,.2);background:transparent;color:rgba(255,255,255,.55);font-size:9px;letter-spacing:2px;cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;white-space:nowrap;border-radius:2px;}
.p-lang-btn.active{background:var(--gold);color:#000;border-color:var(--gold);}
.p-lang-btn:hover:not(.active){border-color:rgba(255,255,255,.5);color:#fff;}
/* Source dropdown */
#p-src-wrap{position:relative;}
#p-src-btn{padding:4px 10px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.06);color:rgba(255,255,255,.5);font-size:9px;letter-spacing:2px;cursor:pointer;font-family:'Inter',sans-serif;border-radius:2px;white-space:nowrap;display:flex;align-items:center;gap:5px;transition:all .2s;}
#p-src-btn:hover{border-color:rgba(255,255,255,.3);color:#fff;}
#p-src-btn.has-dubs{border-color:var(--gold);color:var(--gold);background:rgba(212,175,55,.12);}
#p-src-menu{display:none;position:absolute;bottom:38px;left:0;background:#141414;border:1px solid #2a2a2a;border-radius:4px;min-width:150px;overflow:hidden;box-shadow:0 -8px 24px rgba(0,0,0,.6);}
#p-src-menu.open{display:block;}
.p-src-item{padding:9px 14px;font-size:10px;letter-spacing:1px;color:#aaa;cursor:pointer;transition:background .15s;white-space:nowrap;border-bottom:1px solid #1e1e1e;}
.p-src-item:last-child{border-bottom:none;}
.p-src-item:hover{background:#1e1e1e;color:#fff;}
.p-src-item.active{color:var(--gold);}
/* Quality button */
#pqsel{position:relative;}
#pqbtn{padding:4px 10px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.06);color:rgba(255,255,255,.5);font-size:9px;letter-spacing:2px;cursor:pointer;font-family:'Inter',sans-serif;border-radius:2px;}
#pqbtn:hover{border-color:rgba(255,255,255,.3);color:#fff;}
#pqmenu{display:none;position:absolute;bottom:34px;right:0;background:#141414;border:1px solid #2a2a2a;border-radius:4px;overflow:hidden;min-width:100px;box-shadow:0 -8px 24px rgba(0,0,0,.6);}
#pqmenu.open{display:block;}
.pq-item{padding:8px 14px;font-size:10px;letter-spacing:1px;color:#aaa;cursor:pointer;border-bottom:1px solid #1e1e1e;white-space:nowrap;}
.pq-item:last-child{border-bottom:none;}
.pq-item:hover{background:#1e1e1e;color:#fff;}
.pq-item.active{color:var(--gold);}
#p-spacer{flex:1;}
/* iframe-mode: bar sits BELOW the iframe, not overlaying it */
#pov.iframe-mode #ptopbar{display:none;}
#pov.iframe-mode #pbar{position:relative;bottom:auto;left:auto;right:auto;background:#0d0d0d;border-top:1px solid #1e1e1e;flex-shrink:0;}
#pov.iframe-mode #pru,#pov.iframe-mode #pen,#pov.iframe-mode #p-seek,#pov.iframe-mode #p-seek-sep{display:none!important;}
#pov.iframe-mode #pqsel{display:none!important;}
#pov.iframe-mode #p-esc{display:none;}
#p-esc{font-size:9px;color:rgba(255,255,255,.2);letter-spacing:2px;white-space:nowrap;}
#pbadge{display:none;}
#pnote{display:none;}
/* Seek / playback controls */
#p-seek{display:none;align-items:center;gap:8px;flex:1;}
.p-skip{background:none;border:none;color:rgba(255,255,255,.55);font-size:11px;cursor:pointer;padding:2px 6px;transition:color .15s;white-space:nowrap;}
.p-skip:hover{color:#fff;}
#p-play-btn{background:none;border:none;color:#fff;font-size:15px;cursor:pointer;padding:2px 6px;width:28px;text-align:center;transition:color .15s;}
#p-play-btn:hover{color:var(--gold);}
#p-prog-wrap{flex:1;height:4px;background:rgba(255,255,255,.15);border-radius:2px;cursor:pointer;position:relative;min-width:60px;}
#p-prog-wrap:hover{height:6px;margin-top:-1px;}
#p-prog-fill{height:100%;background:var(--gold);border-radius:2px;width:0%;pointer-events:none;transition:width .1s linear;}
#p-prog-wrap:hover #p-prog-fill{background:#e8c55a;}
#p-time{font-size:9px;color:rgba(255,255,255,.4);letter-spacing:1px;white-space:nowrap;min-width:90px;text-align:right;}
#p-vol-btn{background:none;border:none;color:rgba(255,255,255,.5);font-size:13px;cursor:pointer;padding:2px 4px;}
#p-vol-btn:hover{color:#fff;}
#bar{position:fixed;top:0;left:0;height:2px;background:var(--gold);width:0%;transition:width .3s ease;z-index:9999;}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}

/* ═══════════════════════════════════════════════════════
   МОБИЛЬНАЯ ВЕРСИЯ — срабатывает только на экранах ≤768px
   Десктоп и ноутбук НЕ затрагиваются этими правилами.
═══════════════════════════════════════════════════════ */
@media (max-width: 768px){
  /* Header — компактнее и с меню-бургером */
  header{padding:0 12px;height:58px;gap:8px;flex-wrap:wrap;}
  .logo{font-size:18px;letter-spacing:4px;}
  .hsearch{order:3;flex-basis:100%;max-width:none;margin:-4px 0 6px;}
  .hsearch input{font-size:13px;padding:7px 32px 7px 12px;}
  .hsico{font-size:13px;right:10px;}

  /* Основная навигация скрыта, включается кнопкой */
  nav{display:none;position:fixed;top:58px;left:0;right:0;
    background:var(--card2);border-bottom:1px solid var(--border2);
    padding:8px;flex-direction:column;gap:2px;z-index:800;
    max-height:calc(100vh - 58px);overflow-y:auto;}
  nav.mobile-open{display:flex;}
  .nb{width:100%;padding:12px;font-size:12px;text-align:left;}

  #mobile-menu-btn{display:flex !important;order:2;margin-left:auto;}
  .desktop-only{display:none !important;}
  .mobile-only-nav{display:flex !important;}

  /* Страницы */
  .page{padding-top:58px;}
  .sec{padding:28px 14px;}
  .st{font-size:24px;letter-spacing:2px;margin-bottom:16px;}
  .sl{font-size:9px;letter-spacing:2px;}

  /* Hero */
  .hero{height:auto;min-height:72vh;padding:40px 16px 32px;}
  .hero h1{font-size:52px;letter-spacing:6px;}
  .hero p{font-size:13px;max-width:100%;}
.hero-btns{flex-direction:column;width:100%;max-width:260px;gap:8px;}
  .hero-btns button,.hb1,.hb2{width:100%;}

  /* Карточки в горизонтальных лентах */
  .mc, .mc img{width:130px;}
  .mc img,.mc-ph{height:185px;}
  .mc-info{padding:7px;}
  .mc-ttl{font-size:11px;letter-spacing:0.5px;}
  .mc-yr,.mc-rat{font-size:8px;}

  .ac, .ac img, .ac-ph{width:115px;}
  .ac img, .ac-ph{height:152px;}
  .ac-n{font-size:10px;letter-spacing:1px;padding:6px 6px 1px;}
  .ac-d{font-size:8px;padding:0 6px 6px;}

  .fc, .fc-t{width:150px;}
  .fc-t{height:212px;}
  .fc-title{font-size:12px;letter-spacing:1px;}
  .fc-meta{font-size:8px;}
  .fc-grd-t{font-size:10px;}

  .shc, .shc-img{width:150px;}
  .shc-img{height:150px;font-size:40px;}
  .shc-name{font-size:11px;}
  .shc-price{font-size:13px;}

  .feat{width:165px;padding:16px 13px;}
  .feat h3{font-size:16px;}
  .feat p{font-size:10px;}
  .feat-ico{font-size:22px;}

  /* Локации в одну колонку */
  .loc-g{grid-template-columns:1fr;}
  .loc{padding:22px;}
  .loc-city{font-size:26px;}

  /* Подписка — стопкой */
  .plans{flex-direction:column;gap:2px;}
  .sub{padding:36px 14px;}

  /* Сетки каталогов — 2 колонки */
  .mg, .tv-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-top:18px;}
  .alb-g{grid-template-columns:repeat(2,1fr);gap:10px;margin-top:18px;}
  .shop-g{grid-template-columns:repeat(2,1fr);gap:8px;margin-top:18px;}

  /* Жанровые фильтры — более компактные */
  .gf-wrap, .sf-wrap, .tv-gf-wrap{gap:5px;margin-bottom:14px;}
  .gf, .sf{padding:5px 10px;font-size:8px;letter-spacing:1px;}

  /* Страница фильма — постер и текст вертикально */
  .fhero{height:auto;min-height:auto;padding-top:14px;padding-bottom:20px;}
  .fhero-in{flex-direction:column;align-items:center;text-align:center;gap:16px;padding:0 14px 24px;}
  #fposter img, #fposter .fph{width:150px;height:225px;margin:0 auto;}
  .ftitle{font-size:30px;letter-spacing:2px;text-align:center;}
  .f-pills{justify-content:center;}
  .fstats{gap:14px;justify-content:center;}
  .fsv{font-size:14px;}
  .fbtns{justify-content:center;flex-wrap:wrap;}
  .fbw, .fbt{padding:9px 18px;font-size:9px;letter-spacing:2px;}
  .fbody{padding:24px 14px;}
  .fblock{margin-bottom:28px;}
  .fbt-t{font-size:20px;}
  .fov{font-size:12px;line-height:1.7;}
  .det-g{grid-template-columns:repeat(2,1fr);gap:7px;}
  .det{padding:11px;}
  .det-v{font-size:11px;}

  /* Актёры на странице фильма */
  .cc, .cc img, .cc-ph{width:95px;}
  .cc img, .cc-ph{height:124px;}

  /* Похожие */
  .smc, .smc img, .smc-ph{width:110px;}
  .smc img, .smc-ph{height:156px;}

  /* Страница актёра */
  .ahero{height:auto;min-height:auto;padding-top:14px;}
  .ahero-in{flex-direction:column;align-items:center;text-align:center;gap:16px;padding:0 14px 24px;}
  #actor-photo img, #actor-photo .aph{width:140px;height:186px;}
  .an-name{font-size:28px;letter-spacing:2px;}
  .an-stats{justify-content:center;gap:14px;}
  .asocs{justify-content:center;}

  /* Плеер — на всю ширину */
  #pov{padding:8px;}
  #pwrap{max-width:100%;width:100%;}
  #ptitle{font-size:13px;letter-spacing:2px;padding:0 30px;}
  #pclose{top:6px;right:10px;font-size:22px;}
  #pbadge{font-size:7px;}

  footer{flex-direction:column;gap:10px;padding:18px 14px;text-align:center;}
  .footer-inner{flex-direction:column;gap:28px;padding:28px 20px 20px;}
  .footer-brand{flex:none;}
  .footer-cols{gap:24px;}
  .footer-bottom{flex-direction:column;gap:8px;padding:12px 20px;text-align:center;}
  .lang-sw{display:none;}
}

/* Кнопка бургер-меню — скрыта на десктопе, показана на мобиле */
#mobile-menu-btn{display:none;background:none;border:1px solid var(--border2);
  color:var(--gold);padding:7px 11px;cursor:pointer;font-size:15px;border-radius:2px;
  flex-shrink:0;}

/* Очень узкие экраны (до 380px) */
@media (max-width: 380px){
  .hero h1{font-size:42px;letter-spacing:4px;}
  .mg, .tv-grid, .shop-g{grid-template-columns:repeat(2,1fr);}
  .fc, .fc-t{width:130px;}
  .fc-t{height:184px;}
  .mc, .mc img{width:115px;}
  .mc img, .mc-ph{height:162px;}
  .st{font-size:20px;}
  .ftitle{font-size:26px;}
  .sec{padding:22px 10px;}
}

/* ── AI-модал на мобиле ─────────────────────────────────── */
@media (max-width: 640px){
  .ai-box{padding:22px 16px;max-height:94vh;}
  .ai-box h2{font-size:22px;letter-spacing:3px;}
  .ai-box .sub{font-size:11px;}
  .ai-tab-switch button{font-size:10px;padding:8px 6px;letter-spacing:.5px;}
  .ai-box textarea{font-size:14px;min-height:80px;padding:10px;}  /* iOS не зумит при >=14px */
  .ai-box .ai-sug{font-size:11px;padding:6px 10px;}
  .ai-box .ai-submit{padding:14px;font-size:12px;}
  .ai-quote-input,.ai-find-input,.ai-rec-input,.ai-actor-input{font-size:14px;}
  /* Меню «поделиться» */
  .share-menu-box{padding:18px 14px;}
  .share-opt{padding:13px 12px;font-size:14px;}
  /* Toast уже max-width:92vw — ок */
}

@media (max-width: 380px){
  .ai-tab-switch button{font-size:9px;padding:7px 3px;}
  .ai-box h2{font-size:20px;}
}
