/* ── GALLERY PAGE ── */

    /* Gallery info block */

    /* Model preview in info */

    /* Source link */

    /* Photo grid */
    .photo-grid{
      display:grid;
      grid-template-columns:repeat(6,1fr);
      gap:2px;
      padding:0 20px;
    }
    @media(max-width:1600px){.photo-grid{grid-template-columns:repeat(5,1fr)}}
    @media(max-width:1300px){.photo-grid{grid-template-columns:repeat(4,1fr)}}
    @media(max-width:1100px){.photo-grid{grid-template-columns:repeat(3,1fr)}}
    @media(max-width:760px) {.photo-grid{grid-template-columns:repeat(2,1fr);padding:0}}
    @media(max-width:480px) {.photo-grid{grid-template-columns:repeat(2,1fr);padding:0}}

    .photo-thumb{
      display:block;position:relative;overflow:hidden;
      background:var(--bg3);cursor:pointer;
      text-decoration:none;
    }
    .photo-thumb::before{
      content:'';display:block;padding-top:134.375%; /* 160:215 vertical ratio */
    }
    .photo-thumb img{
      position:absolute;inset:0;
      width:100%;height:100%;object-fit:cover;
      transition:transform .3s cubic-bezier(.25,.46,.45,.94);
    }
    .photo-thumb:hover img{transform:scale(1.06)}
    .photo-thumb .ph-num{
      position:absolute;bottom:0;left:0;right:0;z-index:2;
      font-size:11px;font-weight:700;color:rgba(255,255,255,.9);
      background:linear-gradient(to top,rgba(0,0,0,.55) 0%,transparent 100%);
      padding:18px 8px 5px;
      text-align:right;
      opacity:0;transition:opacity .22s;
      pointer-events:none;
    }
    .photo-thumb:hover .ph-num{opacity:1}

    /* Section headers */
    .gal-section{padding:20px 20px 0}
    .gal-sec-title{
      font-size:15px;font-weight:700;color:var(--text);
      letter-spacing:-.01em;margin-bottom:14px;
      padding-bottom:10px;
      border-bottom:2px solid var(--accent);
      display:inline-block;
    }

    /* Model galleries grid (same model) */
    .model-strip{
      display:grid;
      grid-template-columns:repeat(6,1fr);
      gap:2px;
      margin-bottom:4px;
    }
    @media(max-width:1400px){.model-strip{grid-template-columns:repeat(5,1fr)}}
    @media(max-width:1100px){.model-strip{grid-template-columns:repeat(4,1fr)}}
    @media(max-width:760px) {.model-strip{grid-template-columns:repeat(3,1fr)}}
    @media(max-width:480px) {.model-strip{grid-template-columns:repeat(2,1fr)}}

    /* Reuse .card styles from index for related galleries */
    .related-grid{
      display:grid;
      grid-template-columns:repeat(6,1fr);
      gap:2px;
    }
    @media(max-width:1600px){.related-grid{grid-template-columns:repeat(5,1fr)}}
    @media(max-width:1400px){.related-grid{grid-template-columns:repeat(4,1fr)}}
    @media(max-width:1100px){.related-grid{grid-template-columns:repeat(3,1fr)}}
    @media(max-width:760px) {.related-grid{grid-template-columns:repeat(2,1fr)}}

    /* Breadcrumb */
    .breadcrumb{
      display:flex;align-items:center;gap:6px;flex-wrap:wrap;
      padding:10px 20px;
      font-size:12px;color:var(--tmute);
      border-bottom:1px solid var(--border);
    }
    .breadcrumb a{color:var(--tdim);text-decoration:none;transition:color .13s}
    .breadcrumb a:hover{color:var(--accent)}
    .breadcrumb span{color:var(--border)}
    .breadcrumb .bc-current{color:var(--tdim);font-weight:500}

    /* View all btn */
    .view-all-btn{
      display:inline-flex;align-items:center;gap:6px;
      font-size:12px;font-weight:600;color:var(--accent);
      padding:7px 16px;margin:12px 20px;
      border:1.5px solid var(--accent);border-radius:6px;
      text-decoration:none;transition:background .13s,color .13s;
    }
    .view-all-btn:hover{background:var(--accent);color:#fff}

    /* Mobile padding fixes */
    @media(max-width:760px){
      .gal-section{padding:14px 12px 0}
      .view-all-btn{margin:10px 12px}
      .model-strip,.related-grid{margin-left:-12px;margin-right:-12px}
    }


    /* ── Gallery detail info block ── */
    @media(max-width:760px){.gal-detail{grid-template-columns:1fr;gap:16px;padding:14px 12px}}

    /* Tags */
    .gal-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}
    .gal-tag{
      font-size:11px;color:var(--tdim);
      padding:3px 9px;border-radius:12px;
      border:1px solid var(--border);background:var(--bg2);
      text-decoration:none;transition:color .12s,border-color .12s;
      white-space:nowrap;
    }
    .gal-tag:hover{color:var(--accent);border-color:var(--accent)}

    /* ── Rating block ── */
    @media(max-width:760px){.gal-rating-block{padding:14px 12px;gap:14px}}
    .gal-stars{display:flex;gap:3px;margin:4px 0}
    .star{font-size:18px;color:var(--accent)}
    .star.half{opacity:.5}
    .star.empty{color:var(--border)}
    .gal-rate-btns{display:flex;flex-direction:column;gap:6px;flex-shrink:0}
    .gal-rate-btn{
      display:flex;align-items:center;gap:6px;
      padding:7px 14px;border-radius:6px;border:1.5px solid var(--border);
      background:var(--bg);font:500 12px 'Inter',sans-serif;
      color:var(--tdim);cursor:pointer;
      transition:color .13s,background .13s,border-color .13s;
    }
    .gal-rate-btn:hover{border-color:var(--accent);color:var(--accent)}
    .gal-rate-btn.up:hover{background:#fff5f0}

    /* ── Comments ── */
    @media(max-width:760px){.gal-comments{padding:14px 12px}}

    .comment{
      display:flex;gap:12px;margin-bottom:16px;
      padding-bottom:16px;border-bottom:1px solid var(--border);
    }
    .comment:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}

    /* Comment form */

    /* ═══════════════════════════════════════
       LAYOUT — from scratch, clean
       ═══════════════════════════════════════ */
    .app-body {
      display: flex;
      flex-direction: column;
      padding-top: var(--hh);
      min-height: 100vh;
    }
    /* content-area: 3-column flex row */
    .content-area {
      display: flex;
      flex-direction: row;
      align-items: stretch;
      flex: 1;
    }
    /* push content away from fixed left sidebar */
    .app-body:has(#leftSidebar:not(.collapsed)) .content-area {
      margin-left: var(--sl-full);
    }
    @media(min-width:761px) and (max-width:1100px) {
      .app-body:has(#leftSidebar:not(.collapsed)) .content-area {
        margin-left: 0 !important;
      }
    }
    @media(max-width:760px) {
      .content-area { margin-left: 0 !important; }
    }
    /* main content column */
    .main-area {
      flex: 1;
      min-width: 0;
    }
    /* right sidebar column — plain in-flow */
    .right-sidebar {
      width: 15vw;
      min-width: 160px;
      max-width: 270px;
      flex-shrink: 1;
      border-left: 1px solid var(--border);
      background: var(--bg);
    }
    @media(max-width:1279px) {
      .right-sidebar { display: none; }
    }
    /* rsb elements */
    .rsb-head { display:flex; align-items:center; justify-content:space-between; padding:10px 12px 9px; border-bottom:2px solid var(--accent); background:var(--bg); }
    .rsb-head-title { font-size:10px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); }
    .rsb-head-link { font-size:11px; font-weight:600; color:var(--tdim); text-decoration:none; transition:color .13s; }
    .rsb-head-link:hover { color:var(--accent); }
    .rsb-list { display:flex; flex-direction:column; gap:2px; }
    .rsb-item { display:block; position:relative; overflow:hidden; text-decoration:none; aspect-ratio:270/400; }
    .rsb-item-info { display:none; }
    .rsb-item img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .3s; }
    .rsb-item:hover img { transform:scale(1.05); }
    .rsb-item-info { position:absolute; inset:0; background:linear-gradient(to bottom,transparent 50%,rgba(0,0,0,.75) 100%); display:flex; flex-direction:column; justify-content:flex-end; padding:10px; opacity:0; transition:opacity .2s; }
    .rsb-item:hover .rsb-item-info { opacity:1; }
    .rsb-item-title { font-size:11px; font-weight:500; color:#fff; line-height:1.35; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
    .rsb-item-date { font-size:10px; color:rgba(255,255,255,.6); margin-top:3px; display:block; }
    .rsb-ad { border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
    .rsb-ad-label { font-size:9px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--tmute); padding:5px 8px; border-bottom:1px solid var(--border); background:var(--bg2); text-align:center; }
    .rsb-ad-body { width:100%; display:block; }
    .rsb-ad-body ins { display:block !important; width:100% !important; }

    /* Footer — same margin as content-area when sidebar open */
    .app-body:has(#leftSidebar:not(.collapsed)) ~ .site-footer {
      margin-left: var(--sl-full);
    }
    @media(max-width:1100px) {
      .app-body:has(#leftSidebar:not(.collapsed)) ~ .site-footer {
        margin-left: 0 !important;
      }
    }

    /* RSB ad card — matches index style */
    .rsb-ad-card { position:relative; background:var(--bg); border-top:1px solid var(--border); border-bottom:1px solid var(--border); overflow:hidden; }
    .rsb-ad-label-bar { font-size:9px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--tmute); text-align:center; padding:5px 0 4px; border-bottom:1px solid var(--border); background:var(--bg2); }
    .rsb-ad-simple { width:100%; display:block; }
    .rsb-ad-simple ins { display:block !important; width:100% !important; }

    /* ══════════════════════════════════════
       GALLERY INFO  gi-*
       ══════════════════════════════════════ */

    /* TOP BAR */
    .gi { border-top:3px solid var(--accent); background:var(--bg); }
    .gi-top { display:flex; align-items:flex-start; justify-content:space-between; gap:16px; padding:14px 20px 12px; border-bottom:1px solid var(--border); background:var(--bg); }
    .gi-breadcrumb { display:flex; align-items:center; gap:8px; margin-bottom:5px; }
    .gi-badge-own { font-size:9px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; background:var(--own); color:#fff; padding:2px 7px; border-radius:3px; }
    .gi-cat-link { font-size:11px; font-weight:600; color:var(--accent); text-transform:uppercase; letter-spacing:.06em; text-decoration:none; }
    .gi-cat-link:hover { text-decoration:underline; }
    .gi-title { font-size:18px; font-weight:700; color:var(--text); line-height:1.3; letter-spacing:-.01em; margin:0; }
    .gi-top-right { display:flex; flex-direction:column; align-items:flex-start; gap:4px; flex-shrink:0; }
    .gi-meta-item { display:grid; grid-template-columns:14px 1fr; align-items:center; gap:6px; font-size:11px; color:var(--tdim); white-space:nowrap; }
    .gi-meta-item svg { color:var(--accent); justify-self:center; }
    .gi-meta-item svg { color:var(--accent); flex-shrink:0; }

    /* ROWS */
    .gi-rows { padding:10px 20px; display:flex; flex-direction:column; gap:9px; border-bottom:1px solid var(--border); }
    .gi-row { display:flex; align-items:flex-start; gap:12px; }
    .gi-row-label { font-size:9px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--tmute); padding-top:4px; min-width:58px; flex-shrink:0; }
    .gi-row-pills { display:flex; flex-wrap:wrap; gap:5px; }

    /* PILLS */
    .gi-pill { display:inline-block; font-size:11px; font-weight:500; color:var(--tdim); padding:3px 11px; border-radius:20px; border:1.5px solid var(--border); background:var(--bg2); text-decoration:none; transition:color .12s,border-color .12s,background .12s; white-space:nowrap; }
    .gi-pill:hover { color:var(--accent); border-color:var(--accent); background:var(--bg); }
    .gi-pill-model { color:var(--text); font-weight:600; }
    .gi-pill-model:hover { color:var(--accent); border-color:var(--accent); }
    .gi-pill-sponsor { color:var(--accent); border-color:var(--accent); background:var(--bg); font-weight:600; }
    .gi-pill-sponsor:hover { background:var(--accent); color:#fff; }

    /* TAGS */
    .gi-row-tags { align-items:flex-start; }
    .gi-tags-wrap { flex:1; min-width:0; }
    .gi-tags { display:flex; flex-wrap:wrap; gap:5px; max-height:32px; overflow:hidden; transition:max-height .35s ease; }
    .gi-tags.open { max-height:400px; }
    .gi-tags-more-btn { background:none; border:none; cursor:pointer; font-size:11px; font-weight:600; color:var(--accent); padding:5px 0 0; display:block; transition:color .13s; font-family:inherit; }
    .gi-tags-more-btn:hover { color:var(--accenth); }
    @media(max-width:760px) {
      .gi-row-tags { flex-direction:column; gap:5px; }
      .gi-tags { flex-wrap:nowrap; overflow-x:auto; overflow-y:hidden; max-height:none !important; -webkit-overflow-scrolling:touch; scrollbar-width:none; padding-bottom:2px; }
      .gi-tags::-webkit-scrollbar { display:none; }
      .gi-tags-more-btn { display:none; }
    }

    /* RATING */
    .gi-rating { display:flex; align-items:center; gap:14px; padding:11px 20px; border-bottom:1px solid var(--border); flex-wrap:wrap; }
    .gi-rating-label { font-size:9px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--tmute); flex-shrink:0; white-space:nowrap; }
    .gi-rating-inner { display:flex; align-items:center; gap:10px; width:360px; max-width:100%; }
    .gi-vote { display:flex; align-items:center; gap:6px; background:var(--bg2); border:1.5px solid var(--border); border-radius:8px; padding:6px 14px; cursor:pointer; font-size:13px; font-weight:600; color:var(--tdim); transition:color .15s,background .15s,border-color .15s,opacity .15s,transform .15s; flex-shrink:0; font-family:inherit; }
    .gi-vote:hover { border-color:var(--accent); color:var(--accent); }
    .gi-vote-like.voted  { background:#e8f5e9; border-color:#4caf50; color:#2e7d32; }
    .gi-vote-dislike.voted { background:#fbe9e7; border-color:#e53935; color:#c62828; }
    .gi-bar-wrap { flex:1; min-width:0; }
    .gi-bar-track { height:7px; background:#ffcdd2; border-radius:4px; overflow:hidden; margin-bottom:4px; }
    .gi-bar-fill { height:100%; background:#4caf50; border-radius:4px; transition:width .4s ease; }
    .gi-bar-info { display:flex; align-items:center; justify-content:center; gap:6px; font-size:11px; }
    .gi-bar-info span:first-child { font-weight:700; color:var(--text); font-size:12px; }
    #giVotesTotal { color:var(--tmute); font-size:10px; }
    @media(max-width:760px) {
      .gi-rating { gap:8px; padding:10px 12px; }
      .gi-rating-label { width:100%; }
      .gi-rating-inner { width:100%; min-width:0; }
    }

    /* ACTIONS */
    .gi-actions { display:flex; align-items:center; gap:8px; padding:12px 20px; flex-wrap:wrap; border-bottom:1px solid var(--border); }
    .gi-btn { display:inline-flex; align-items:center; gap:6px; padding:8px 16px; border-radius:8px; font-size:12px; font-weight:600; cursor:pointer; text-decoration:none; border:1.5px solid transparent; transition:color .15s,background .15s,border-color .15s,opacity .15s,transform .15s; white-space:nowrap; font-family:inherit; line-height:1; }
    .gi-btn-primary { background:var(--accent); color:#fff; border-color:var(--accent); }
    .gi-btn-primary:hover { background:var(--accenth); border-color:var(--accenth); }
    .gi-btn-ghost { background:var(--bg2); color:var(--tdim); border-color:var(--border); }
    .gi-btn-ghost:hover { border-color:var(--accent); color:var(--accent); background:var(--bg); }
    @media(max-width:760px) {
      .gi-actions { padding:10px 12px; gap:6px; }
      .gi-btn { font-size:11px; padding:7px 12px; }
    }

    /* COMMENTS */
    .gi-comments { padding:16px 20px; background:var(--bg); }
    .gi-comments-head { display:flex; align-items:center; gap:7px; font-size:13px; font-weight:700; color:var(--text); margin-bottom:14px; padding-bottom:10px; border-bottom:1px solid var(--border); }
    .gi-comments-head svg { color:var(--accent); }
    .gi-comments-count { font-size:11px; font-weight:600; background:var(--bg3); border:1px solid var(--border); padding:1px 7px; border-radius:10px; color:var(--tdim); }
    .gi-comment-list { display:flex; flex-direction:column; gap:8px; margin-bottom:20px; }
    .gi-comment { padding:10px 14px; background:var(--bg2); border-radius:8px; border:1px solid var(--border); }
    .gi-comment-meta { display:flex; align-items:center; gap:10px; margin-bottom:4px; }
    .gi-comment-author { font-size:12px; font-weight:600; color:var(--text); }
    .gi-comment-date { font-size:10px; color:var(--tmute); }
    .gi-comment-text { font-size:12px; color:var(--tdim); line-height:1.55; }
    .gi-form-title { font-size:13px; font-weight:700; color:var(--text); margin-bottom:12px; }
    .gi-form-row { margin-bottom:10px; }
    .gi-form-input { width:100%; background:var(--bg2); border:1.5px solid var(--border); border-radius:8px; padding:9px 12px; font:13px 'Inter',sans-serif; color:var(--text); box-sizing:border-box; transition:border-color .15s; }
    .gi-form-input:focus { outline:none; border-color:var(--accent); }
    .gi-form-input::placeholder { color:var(--tmute); }
    .gi-form-textarea { resize:vertical; min-height:80px; }
    @media(max-width:760px) {
      .gi-top { flex-direction:column; gap:8px; padding:12px; }
      .gi-top-right { flex-direction:row; flex-wrap:wrap; gap:8px; }
      .gi-title { font-size:15px; }
      .gi-rows { padding:10px 12px; }
      .gi-comments { padding:12px; }
    }

    /* ── GALLERY HEADER (above photo grid) ── */
    .gal-header { display:flex; align-items:flex-start; justify-content:space-between; gap:16px; padding:14px 20px 14px; border-bottom:2px solid var(--accent); background:var(--bg); margin-bottom:16px; }
    .gal-header-meta { display:flex; align-items:center; gap:8px; margin-bottom:5px; }
    .gal-header-badge-own { font-size:9px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; background:var(--own); color:#fff; padding:2px 7px; border-radius:3px; }
    .gal-header-cat { font-size:11px; font-weight:600; color:var(--accent); text-transform:uppercase; letter-spacing:.06em; text-decoration:none; }
    .gal-header-cat:hover { text-decoration:underline; }
    .gal-header-title { font-size:19px; font-weight:700; color:var(--text); line-height:1.3; letter-spacing:-.01em; margin:0 0 7px; }
    .gal-header-sub { display:flex; align-items:center; flex-wrap:wrap; gap:6px; font-size:11px; color:var(--tdim); }
    .gal-header-sub svg { color:var(--accent); flex-shrink:0; vertical-align:middle; }
    .gal-header-models { display:inline-flex; align-items:center; gap:4px; }
    .gal-header-models a { color:var(--text); font-weight:600; text-decoration:none; }
    .gal-header-models a:hover { color:var(--accent); }
    .gal-header-date, .gal-header-count, .gal-header-views { display:inline-flex; align-items:center; gap:4px; }
    .gal-header-dot { color:var(--border); }
    .gal-header-right { flex-shrink:0; display:flex; align-items:center; }
    .gal-header-btn { display:inline-flex; align-items:center; gap:6px; padding:9px 18px; border-radius:8px; font-size:12px; font-weight:600; background:var(--accent); color:#fff; text-decoration:none; border:none; transition:background .15s; white-space:nowrap; }
    .gal-header-btn:hover { background:var(--accenth); }
    @media(max-width:760px) {
      .gal-header { flex-direction:column; gap:10px; padding:12px; margin-bottom:12px; }
      .gal-header-title { font-size:15px; }
      .gal-header-right { width:auto; }
      .gal-header-btn { width:auto; font-size:11px; padding:7px 14px; }
    }

    /* ── GALLERY HEADER ── */


    /* ── CTA BANNER ── */
    .gal-cta-banner {
      margin: 20px 20px 0;
      background: #fff;
      border-radius: 8px;
      border: 2px solid var(--accent);
      overflow: hidden;
      display: block;
      text-decoration: none;
      cursor: pointer;
    }
    [data-theme="dark"] .gal-cta-banner { background: var(--bg2); }
    .gal-cta-banner-inner {
      padding: 22px 28px;
      display: flex;
      align-items: center;
      gap: 20px;
      flex-wrap: wrap;
    }
    .gal-cta-banner-text { flex: 1; min-width: 200px; }
    .gal-cta-banner-title {
      font-size: 16px;
      font-weight: 800;
      color: var(--text);
      letter-spacing: -.01em;
      margin: 0 0 4px;
    }
    .gal-cta-banner-title span { color: var(--accent); }
    .gal-cta-banner-sub {
      font-size: 12px;
      color: var(--tdim);
      margin: 0;
      line-height: 1.5;
    }
    .gal-cta-banner-btn {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      background: var(--accent);
      color: #fff;
      font-size: 12px;
      font-weight: 700;
      letter-spacing: .04em;
      text-transform: uppercase;
      padding: 10px 22px;
      border-radius: 8px;
      text-decoration: none;
      flex-shrink: 0;
      transition: background .15s;
    }
    .gal-cta-banner-btn:hover { background: var(--accenth); }
    .gal-cta-live-dot {
      width: 7px; height: 7px;
      background: #fff;
      border-radius: 50%;
      flex-shrink: 0;
      animation: gal-pulse 1.4s ease-in-out infinite;
    }
    @keyframes gal-pulse {
      0%,100% { opacity:1; transform:scale(1); }
      50% { opacity:.4; transform:scale(.7); }
    }
    @media(max-width:760px) {
      .gal-cta-banner { margin: 14px 12px 0; }
      .gal-cta-banner-inner { padding: 16px 14px; gap: 14px; }
      .gal-cta-banner-title { font-size: 14px; }
    }

    /* DESCRIPTION */
    .gi-row-desc { align-items:flex-start; }
    .gi-desc-wrap { flex:1; min-width:0; }
    .gi-desc-text {
      font-size:12px;
      color:var(--tdim);
      line-height:1.7;
      max-height:3.4em;
      overflow:hidden;
      transition:max-height .35s ease;
    }
    .gi-desc-text.open { max-height:400px; }
    .gi-desc-btn {
      background:none;
      border:none;
      cursor:pointer;
      font-size:11px;
      font-weight:600;
      color:var(--accent);
      padding:5px 0 0;
      display:block;
      transition:color .13s;
      font-family:inherit;
    }
    .gi-desc-btn:hover { color:var(--accenth); }

    .badge-new  { background:#2196f3; color:#fff; }
    .badge-hot  { background:#e53935; color:#fff; }
    .rsb-badge {
      position:absolute;
      top:7px; left:7px;
      font-size:8px; font-weight:700;
      letter-spacing:.08em; text-transform:uppercase;
      padding:2px 6px; border-radius:3px; line-height:1.4;
      z-index:3;
    }
    .rsb-badge-own  { background:var(--own);  color:#fff; }
    .rsb-badge-part { background:var(--part); color:#fff; }
    .rsb-badge-new  { background:#2196f3;     color:#fff; }
    .rsb-badge-hot  { background:#e53935;     color:#fff; }

    /* ── HORIZONTAL SCROLL STRIP ── */
    .hscroll-wrap {
      position: relative;
      padding: 0 20px;
    }
    .hscroll-track {
      display: flex;
      gap: 2px;
      overflow-x: auto;
      overflow-y: hidden;
      scroll-behavior: smooth;
      -webkit-overflow-scrolling: touch;
      scrollbar-width: none;
      padding-bottom: 2px;
    }
    .hscroll-track::-webkit-scrollbar { display: none; }
    .hscroll-card {
      flex-shrink: 0;
      width: 200px;
      text-decoration: none;
      color: inherit;
      display: block;
      position: relative;
      overflow: hidden;
      aspect-ratio: 5/7;
      background: var(--bg3);
    }
    .hscroll-card img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      transition: transform .35s cubic-bezier(.25,.46,.45,.94);
    }
    .hscroll-card:hover img { transform: scale(1.05); }
    .hscroll-card .badge { top:7px; left:7px; }
    /* overlay always visible */
    .hscroll-overlay {
      position: absolute;
      bottom: 0; left: 0; right: 0;
      background: linear-gradient(to bottom, transparent 30%, rgba(0,0,0,.75) 100%);
      padding: 20px 8px 8px;
      pointer-events: none;
    }
    .hscroll-title {
      font-size: 11px;
      font-weight: 600;
      color: #fff;
      line-height: 1.3;
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
      overflow: hidden;
      margin-bottom: 2px;
    }
    .hscroll-meta { font-size: 10px; color: rgba(255,255,255,.65); }
    .hscroll-btn {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      z-index: 4;
      width: 36px; height: 36px;
      border-radius: 50%;
      background: var(--bg);
      border: 1.5px solid var(--border);
      box-shadow: 0 2px 8px rgba(0,0,0,.15);
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--text);
      transition: background .13s, border-color .13s, opacity .2s;
    }
    .hscroll-btn:hover { background: var(--accent); border-color: var(--accent); color: #fff; }
    .hscroll-btn.hidden { opacity: 0; pointer-events: none; }
    .hscroll-prev { left: -4px; }
    .hscroll-next { right: -4px; }
    @media(max-width:760px) {
      .hscroll-wrap { padding: 0; }
      .hscroll-track { padding: 0 12px 2px; }
      .hscroll-btn { display: none; }
      .hscroll-card { width: 150px; }
    }

    .sec-bar-right { display:flex; align-items:center; gap:10px; flex-shrink:0; }
    .hscroll-hint { display:none; align-items:center; gap:4px; font-size:11px; color:var(--tmute); white-space:nowrap; }
    @media(max-width:1100px) {
      .hscroll-hint { display:flex; }
      .sec-title { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
    }
    .rsb-ad-banner-holder { overflow:hidden; display:flex; align-items:center; justify-content:center; min-height:280px; }
    .rsb-ad-banner-inner { width:300px; height:250px; flex-shrink:0; transform-origin:center center; }

    /* ── PICTURE PAGE ── */
    .pic-wrap {
      position: relative;
      background: linear-gradient(135deg, #1c0e05 0%, #130808 50%, #1c0e05 100%);
      display: flex; align-items: center; justify-content: center;
      min-height: 300px; overflow: hidden;
    }
    .pic-wrap::before {
      content: '';
      position: absolute; inset: 0;
      background: inherit;
      background-image: var(--pic-bg);
      background-size: cover;
      background-position: center;
      filter: blur(24px) brightness(.45) saturate(1.4);
      transform: scale(1.1);
      z-index: 0;
    }
    .pic-main { position: relative; z-index: 1; display:block; max-width:100%; max-height:82vh; width:auto; height:auto; object-fit:contain; cursor:pointer; }
    .btn-prev,.btn-next { position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.15); border:none; color:#fff; backdrop-filter:blur(4px); width:44px; height:72px; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .2s; text-decoration:none; z-index:5; }
    .btn-prev { left:0; border-radius:0 6px 6px 0; }
    .btn-next { right:0; border-radius:6px 0 0 6px; }
    .btn-prev:hover,.btn-next:hover { background:var(--accent); }
    .pic-counter { position:absolute; top:10px; left:50%; transform:translateX(-50%); background:rgba(255,255,255,.18); backdrop-filter:blur(6px); color:#fff; font-size:12px; font-weight:600; padding:3px 12px; border-radius:20px; pointer-events:none; z-index:5; }
    .pic-model-tag { position:absolute; bottom:10px; left:10px; display:inline-flex; align-items:center; gap:5px; background:rgba(255,255,255,.18); backdrop-filter:blur(6px); color:#fff; font-size:12px; font-weight:600; padding:5px 10px; border-radius:20px; text-decoration:none; z-index:5; border:1px solid rgba(255,255,255,.12); transition:background .2s; }
    .pic-model-tag:hover { background:var(--accent); }
    .pic-zoom-btn { position:absolute; bottom:10px; right:10px; background:rgba(255,255,255,.18); backdrop-filter:blur(6px); border:1px solid rgba(255,255,255,.2); color:rgba(255,255,255,.8); width:34px; height:34px; border-radius:6px; display:flex; align-items:center; justify-content:center; cursor:pointer; z-index:5; text-decoration:none; transition:background .2s; }
    .pic-zoom-btn:hover { background:var(--accent); color:#fff; }
    .filmstrip-wrap { background:var(--bg3); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
    .filmstrip { display:flex; gap:2px; overflow-x:auto; scrollbar-width:none; scroll-behavior:smooth; padding:3px; }
    .filmstrip::-webkit-scrollbar { display:none; }
    .film-thumb { flex-shrink:0; height:68px; width:auto; min-width:46px; overflow:hidden; border-radius:2px; border:2px solid transparent; cursor:pointer; position:relative; display:block; text-decoration:none; background:#111; transition:border-color .15s; }
    .film-thumb img { height:100%; width:auto; max-width:120px; object-fit:cover; display:block; }
    .film-thumb:hover { border-color:rgba(255,255,255,.5); }
    .film-thumb.active { border-color:var(--accent); }
    .film-num { position:absolute; bottom:2px; right:2px; background:rgba(0,0,0,.7); color:rgba(255,255,255,.8); font-size:8px; font-weight:700; padding:1px 3px; border-radius:2px; }
    .pic-title-bar { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; padding:14px 20px 10px; border-bottom:1px solid var(--border); background:var(--bg); flex-wrap:wrap; }
    .pic-title { font-size:16px; font-weight:700; color:var(--text); line-height:1.3; margin:0; }
    .pic-title a { color:var(--accent); text-decoration:none; }
    .pic-title a:hover { text-decoration:underline; }
    .pic-title-meta { display:flex; align-items:center; gap:8px; flex-wrap:wrap; font-size:11px; color:var(--tdim); margin-top:5px; }
    .pic-title-meta svg { color:var(--accent); flex-shrink:0; }
    .pic-title-meta a { color:var(--tdim); text-decoration:none; transition:color .13s; }
    .pic-title-meta a:hover { color:var(--accent); }
    .pic-gal-link { display:inline-flex; align-items:center; gap:6px; font-size:11px; font-weight:600; color:var(--accent); text-decoration:none; flex-shrink:0; }
    .pic-gal-link:hover { color:var(--accenth); }
    .pic-actions { display:flex; align-items:center; gap:8px; padding:10px 20px; border-bottom:2px solid var(--accent); flex-wrap:wrap; background:var(--bg2); }
    .pic-btn { display:inline-flex; align-items:center; gap:6px; padding:7px 14px; border-radius:8px; font-size:12px; font-weight:600; cursor:pointer; border:1.5px solid var(--border); background:var(--bg); color:var(--tdim); text-decoration:none; transition:color .15s,background .15s,border-color .15s,opacity .15s,transform .15s; white-space:nowrap; font-family:inherit; }
    .pic-btn:hover { border-color:var(--accent); color:var(--accent); }
    .pic-btn.active { background:#fff5f0; border-color:var(--accent); color:var(--accent); }
    .pic-btn-primary { background:var(--accent); border-color:var(--accent); color:#fff; }
    .pic-btn-primary:hover { background:var(--accenth); color:#fff; }
    .pic-btn-share { margin-left:auto; }
    .pic-vote-bar { display:flex; align-items:center; gap:12px; padding:10px 20px; border-bottom:1px solid var(--border); flex-wrap:wrap; }
    .pic-vote-btn { display:inline-flex; align-items:center; gap:6px; padding:6px 14px; border-radius:8px; font-size:13px; font-weight:700; cursor:pointer; border:1.5px solid var(--border); background:var(--bg2); color:var(--tdim); transition:color .15s,background .15s,border-color .15s,opacity .15s,transform .15s; font-family:inherit; }
    .pic-vote-btn.up:hover,.pic-vote-btn.up.voted { background:#e8f5e9; border-color:#4caf50; color:#2e7d32; }
    .pic-vote-btn.dn:hover,.pic-vote-btn.dn.voted { background:#fbe9e7; border-color:#e53935; color:#c62828; }
    .pic-rating-bar { flex:1; min-width:60px; max-width:200px; height:6px; background:#ffcdd2; border-radius:3px; overflow:hidden; }
    .pic-rating-fill { height:100%; background:#4caf50; border-radius:3px; transition:width .4s; }
    .pic-rating-pct { font-size:12px; font-weight:700; color:var(--text); }
    .pic-vote-summary { font-size:11px; color:var(--tmute); }
    .pic-kbd-hint { display:flex; align-items:center; gap:10px; font-size:11px; color:var(--tmute); padding:6px 20px 2px; }
    .pic-kbd-hint kbd { background:var(--bg3); border:1px solid var(--border); border-radius:3px; padding:1px 7px; font-size:10px; color:var(--tdim); font-family:monospace; }
    @media(max-width:760px) { .btn-prev,.btn-next{width:36px;height:56px;} .pic-title-bar{padding:12px;} .pic-actions{padding:8px 12px;gap:6px;} .pic-btn{font-size:11px;padding:6px 10px;} .pic-vote-bar{padding:8px 12px;} .pic-kbd-hint{display:none;} }

    /* ── CTA VARIANTS ── */

    /* V6: двухрядный CTA */
    .cta-v6 { display:flex; flex-direction:column; gap:0; border-bottom:2px solid var(--accent); }
    .cta-v6-h1 { font-size:17px; font-weight:700; color:var(--accent); margin:0; letter-spacing:-.01em; padding:12px 20px 10px; border-bottom:1px solid var(--border); line-height:1.3; background:var(--bg); }
    .cta-v6-h1 span { color:var(--tdim); font-weight:500; font-size:14px; }
    .cta-v6-btns { display:flex; align-items:center; gap:8px; padding:10px 20px; background:#fff; flex-wrap:wrap; }
    .cta-v6-share { display:inline-flex; align-items:center; gap:6px; padding:8px 16px; border-radius:8px; border:1.5px solid var(--border); background:var(--bg); color:var(--tdim); font-size:12px; font-weight:600; cursor:pointer; font-family:inherit; transition:color .15s,background .15s,border-color .15s,opacity .15s,transform .15s; white-space:nowrap; }
    .cta-v6-share:hover { border-color:var(--accent); color:var(--accent); }
    .cta-v6-join { display:inline-flex; align-items:center; padding:8px 20px; border-radius:8px; border:1.5px solid var(--accent); background:var(--bg); color:var(--accent); font-size:12px; font-weight:700; text-decoration:none; transition:color .15s,background .15s,border-color .15s,opacity .15s,transform .15s; white-space:nowrap; }
    .cta-v6-join:hover { background:var(--accent); color:#fff; }
    .cta-v6-dl { display:inline-flex; align-items:center; gap:8px; padding:8px 20px; border-radius:8px; background:var(--accent); color:#fff; font-size:12px; font-weight:700; text-decoration:none; transition:background .15s; white-space:nowrap; margin-left:auto; }

    .cta-v6-dl:hover { background:var(--accenth); }
    .cta-v6-dl svg { flex-shrink:0; }
    @media(max-width:760px) {
      .cta-v6-h1 { font-size:14px; padding:10px 12px 8px; }
      .cta-v6-btns { padding:8px 12px; gap:6px; }
      .cta-v6-share { padding:7px 12px; font-size:11px; }
      .cta-v6-join { padding:7px 12px; font-size:11px; }
      .cta-v6-dl { padding:7px 12px; font-size:11px; }
    }

    .fullwidth-ad-label { font-size:9px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--tmute); text-align:center; padding:4px 0; border-bottom:1px solid var(--border); background:var(--bg2); display:block; }

    .pic-section { padding: 0 20px; }
    @media(max-width:760px) { .pic-section { padding: 0; } }

    [data-theme="dark"] .cta-v6-btns { background:var(--bg2); }
    [data-theme="dark"] .cta-v6-share { background:var(--bg3); }

    .scroll-up-btn {
      position: fixed; bottom: 24px; right: 24px;
      width: 42px; height: 42px; border-radius: 50%;
      background: var(--accent); color: #fff; border: none;
      cursor: pointer; display: flex; align-items: center; justify-content: center;
      z-index: 9999; box-shadow: 0 4px 14px rgba(0,0,0,.3);
      opacity: 0; transform: translateY(12px); pointer-events: none;
      transition: opacity .25s, transform .25s, background .15s;
    }
    .scroll-up-btn.visible { opacity: 1; transform: translateY(0); pointer-events: all; }
    .scroll-up-btn:hover { background: var(--accenth); }
    @media(max-width:760px) { .scroll-up-btn { bottom: 16px; right: 16px; width: 38px; height: 38px; } }

    .pic-nav-btns {
      display: flex; align-items: center; gap: 8px;
      padding: 12px 20px;
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
    }
    .pic-nav-btn {
      flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 6px;
      padding: 9px 14px; border-radius: 8px;
      font-size: 12px; font-weight: 600;
      text-decoration: none; transition: color .15s, background .15s, border-color .15s, opacity .15s, transform .15s; white-space: nowrap;
    }
    .pic-nav-back {
      border: 1.5px solid var(--border); background: var(--bg); color: var(--tdim);
    }
    .pic-nav-back:hover { border-color: var(--accent); color: var(--accent); }
    .pic-nav-join {
      border: 1.5px solid var(--accent); background: var(--accent); color: #fff;
    }
    .pic-nav-join:hover { background: var(--accenth); border-color: var(--accenth); }
    .pic-nav-more {
      border: 1.5px solid var(--border); background: var(--bg); color: var(--tdim);
    }
    .pic-nav-more:hover { border-color: var(--accent); color: var(--accent); }
    @media(max-width:760px) {
      .pic-nav-btns { padding: 8px 12px; gap: 6px; }
      .pic-nav-btn { font-size: 11px; padding: 7px 10px; }
    }

    .pic-nav-metart {
      display: flex; align-items: center; justify-content: center; gap: 7px;
      padding: 10px 20px;
      border-bottom: 1px solid var(--border);
      background: var(--bg); color: var(--tdim);
      font-size: 12px; font-weight: 600;
      text-decoration: none; transition: color .15s, background .15s, border-color .15s, opacity .15s, transform .15s;
    }
    .pic-nav-metart:hover { color: var(--accent); background: var(--bg2); }
    @media(max-width:760px) { .pic-nav-metart { font-size: 11px; padding: 9px 12px; } }

    .ql-link img, .ql-hot-badge img {
      width: 16px !important;
      height: 16px !important;
      max-width: 16px !important;
      flex-shrink: 0;
      vertical-align: middle;
    }
    .ql-link {
      display: inline-flex;
      align-items: center;
      white-space: nowrap;
    }
