splay: inline-flex;
      align-items: center;
      white-space: nowrap;
    }

    /* ── 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;
     cursor:pointer; text-decoration:none; display:block; }
    .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; }

    .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; }
    [data-theme="dark"] .gal-cta-banner { background: var(--bg2); }

    .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; } }
  
    .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;
    }
  
    /* ── index-side layout fix ── */
    .content-area {
      display: flex !important;
      flex-direction: row !important;
      flex: 1 !important;
      min-width: 0 !important;
    }
    .content-area .main-area {
      flex: 1 !important;
      min-width: 0 !important;
      margin-left: 0 !important;
      width: 0 !important;
    }
    .app-body:has(#leftSidebar:not(.collapsed)) .content-area {
      margin-left: var(--sl-full) !important;
    }
    .app-body:has(#leftSidebar:not(.collapsed)) .content-area .main-area {
      margin-left: 0 !important;
    }
    .right-sidebar {
      width: 15vw !important;
      min-width: 160px !important;
      max-width: 200px !important;
      flex-shrink: 1 !important;
      border-left: 1px solid var(--border) !important;
      background: var(--bg) !important;
      position: static !important;
      overflow: visible !important;
    }
    @media(max-width:1279px) {
      .right-sidebar { display: none !important; }
    }
    @media(max-width:1100px) {
      .app-body:has(#leftSidebar:not(.collapsed)) .content-area {
        margin-left: 0 !important;
      }
    }
