/* ===== GALLERY PAGE STYLES ===== */
:root{--bg:#0d0d0d;--bg2:#111;--border:#1e1e1e;--red:#F22E4B;--header-h:58px;--sb-w:220px}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:#ccc;font-family:'Open Sans',sans-serif;font-size:14px}
.site-header{position:sticky;top:0;z-index:300;height:var(--header-h);background:#0a0a0a;border-bottom:1px solid var(--border);display:flex;align-items:center}
.page-body{display:flex;min-height:calc(100vh - var(--header-h))}
.main-content{flex:1;min-width:0}
.sidebar{width:var(--sb-w);flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border)}
.sidebar.right{border-right:none;border-left:1px solid var(--border)}
.sidebar.closed,.sidebar.left.closed,.sidebar.right.closed{display:none!important}
html.sb-left-closed #sidebar-left{display:none!important}
html.sb-right-closed #sidebar-right{display:none!important}
html.sb-right-closed #sidebar-right.mob-open{display:flex!important;transform:translateX(0)!important}
.gal-header{padding:16px 20px 0;position:relative;z-index:1}
.gal-breadcrumb{font-size:11px;color:#555;margin-bottom:10px}
.gal-title{font-size:20px;font-weight:700;color:#fff;line-height:1.3;margin-bottom:8px}
#gallery-grid{overflow-anchor:none}
.gal-thumb{break-inside:avoid;-webkit-column-break-inside:avoid;float:none;width:100%;display:block;margin-bottom:3px;padding:0;cursor:zoom-in}
.gal-thumb-inner{position:relative;overflow:hidden;background:#161616}
.gal-thumb-inner img{display:block;width:100%;height:auto;vertical-align:bottom}
@media(min-width:1200px){#gallery-grid{column-count:5;column-gap:3px}}
@media(min-width:900px)and(max-width:1199px){#gallery-grid{column-count:4;column-gap:3px}}
@media(min-width:600px)and(max-width:899px){#gallery-grid{column-count:3;column-gap:3px}}
@media(max-width:599px){#gallery-grid{column-count:2;column-gap:2px}}
/* ── Gallery: light theme fixes ── */
.main-content { display: block !important; }
.gal-thumb-inner { background: #f0f0f0 !important; }
html.dark-mode .gal-thumb-inner { background: #161616 !important; }
.gal-header { background: #fff !important; border-color: #e5e5e5 !important; }
.gal-title { color: #111 !important; }
.gal-meta-item { color: #555 !important; }
.gal-btn { background: #fff !important; border-color: #e0e0e0 !important; color: #555 !important; }
.gal-btn-primary { background: #EF4444 !important; border-color: #EF4444 !important; color: #fff !important; }
.gal-info-wrap { background: #fff !important; border-color: #e5e5e5 !important; }
.gal-desc { color: #333 !important; }
.gal-tag { background: #f5f5f5 !important; border-color: #e0e0e0 !important; color: #555 !important; }
.rating-block { background: #fff !important; border-color: #e5e5e5 !important; }
.rating-score { color: #111 !important; }
.related-heading { background: #fff !important; border-color: #e5e5e5 !important; }
.related-heading h2 { color: #111 !important; }
.breadcrumb { background: #fff !important; border-color: #e5e5e5 !important; }
.breadcrumb a { color: #666 !important; }
.breadcrumb-cur { color: #111 !important; }
.comments-panel { background: #fff !important; border-color: #e5e5e5 !important; }

/* dark mode for gallery elements */
html.dark-mode .gal-header { background: #111 !important; border-color: #222 !important; }
html.dark-mode .gal-title { color: #fff !important; }
html.dark-mode .gal-btn { background: #1a1a1a !important; border-color: #2a2a2a !important; color: #aaa !important; }
html.dark-mode .gal-btn-primary { background: #EF4444 !important; color: #fff !important; }
html.dark-mode .gal-info-wrap { background: #111 !important; border-color: #222 !important; }
html.dark-mode .gal-desc { color: #bbb !important; }
html.dark-mode .gal-tag { background: #1a1a1a !important; border-color: #2a2a2a !important; color: #aaa !important; }
html.dark-mode .rating-block { background: #111 !important; border-color: #222 !important; }
html.dark-mode .related-heading { background: #111 !important; border-color: #222 !important; }
html.dark-mode .breadcrumb { background: #0d0d0d !important; border-color: #222 !important; }
html.dark-mode .comments-panel { background: #111 !important; border-color: #222 !important; }


/* ── Lightbox bar fixes ── */
.lb-bar { display: flex !important; align-items: center !important; justify-content: space-between !important; }
.lb-bar-right { display: flex !important; align-items: center !important; gap: 5px !important; }
.lb-bar-left { display: flex !important; align-items: center !important; gap: 8px !important; }
.lb-btn { display: flex !important; align-items: center !important; justify-content: center !important; color: #ccc !important; }
.lb-btn:hover { color: #fff !important; background: rgba(255,255,255,.12) !important; }
.lb-btn svg { opacity: 1 !important; flex-shrink: 0; }
.lb-close { display: flex !important; align-items: center !important; justify-content: center !important; color: #ccc !important; }
.lb-close:hover { color: #fff !important; }


/* ===== COMMENTS ===== */
.comments-btn{position:relative;display:inline-flex;align-items:center;gap:6px}
    .comments-dot{display:none;position:absolute;top:-3px;right:-3px;width:8px;height:8px;border-radius:50%;background:var(--red);border:2px solid var(--bg2);box-shadow:0 0 6px rgba(242,46,75,.7)}
    /* Show dot only when there are comments: .comments-panel.filled ~ button */
    .comments-panel.filled + * .comments-dot,
    [data-has-comments] .comments-dot{display:block}
    /* Controlled via 'filled' class on the panel */
    .comments-panel.filled .comments-count-label::before{content:attr(data-count)}
    .comments-panel:not(.filled) .comment-list{display:none}
    .comments-panel:not(.filled) .comments-count-label::before{content:"No comments yet"}

    /* Panel */
    .comments-panel{display:none;border-top:1px solid var(--border);background:var(--bg2)}
    .comments-panel.open{display:block}
    .comments-inner{max-width:700px;padding:20px 18px 24px}
    .comments-heading{font-size:13px;font-weight:700;color:#fff;letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:8px}
    .comments-heading span{font-size:11px;color:#555;font-weight:400;text-transform:none;letter-spacing:0}

    /* Comments */
    .comment-list{display:flex;flex-direction:column;gap:16px;margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--border)}
    .comment-item{display:flex;gap:10px}
    .comment-avatar{width:34px;height:34px;border-radius:50%;background:#1e1e1e;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:13px;font-weight:700;color:var(--red);border:1px solid var(--border)}
    .comment-body{flex:1;min-width:0}
    .comment-meta{display:flex;align-items:center;gap:8px;margin-bottom:4px}
    .comment-name{font-size:12px;font-weight:600;color:#ddd}
    .comment-date{font-size:11px;color:#444}
    .comment-text{font-size:13px;color:#999;line-height:1.6}

    /* Form */
    .comment-form-title{font-size:11px;font-weight:700;color:#888;margin-bottom:12px;text-transform:uppercase;letter-spacing:.07em}
    .comment-form-row{display:flex;gap:10px;margin-bottom:10px}
    .comment-form-field{display:flex;flex-direction:column;gap:5px;flex:1}
    .comment-form-field label{font-size:11px;color:#555;font-weight:500}
    .comment-form-field input,.comment-form-field textarea{background:#111;border:1px solid var(--border);border-radius:6px;color:#eee;font-size:13px;font-family:'Open Sans',sans-serif;padding:8px 12px;outline:none;transition:border-color .15s;resize:none}
    .comment-form-field input:focus,.comment-form-field textarea:focus{border-color:var(--red)}
    .comment-form-field input::placeholder,.comment-form-field textarea::placeholder{color:#333}
    .comment-form-field textarea{min-height:80px}
    .comment-captcha{margin-bottom:14px}
    .comment-captcha-mock{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;background:#111;border:1px solid var(--border);border-radius:6px;transition:border-color .15s}
    .comment-captcha-mock:has(.cf-captcha:checked){border-color:#2a5a2a}
    .comment-captcha-mock input[type=checkbox]{width:18px;height:18px;accent-color:#2a9d2a;cursor:pointer;flex-shrink:0}
    .comment-captcha-mock span{font-size:13px;color:#888;user-select:none}
    .comment-captcha-mock .recaptcha-logo{margin-left:16px;font-size:8px;color:#444;line-height:1.3;text-align:center;border-left:1px solid var(--border);padding-left:12px}
    .comment-submit{display:inline-flex;align-items:center;gap:7px;padding:8px 20px;background:var(--red);color:#fff;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;font-family:'Open Sans',sans-serif;border:none;transition:background .15s}
    .comment-submit:hover{background:var(--red-d)}
    @media(max-width:600px){.comment-form-row{flex-direction:column}}

/* ── Light theme: comments & rating ── */
.comments-panel { background: #fff !important; border-color: #e5e5e5 !important; }
.comments-inner { color: #333 !important; }
.comments-heading { color: #111 !important; }
.comment-item { color: #333 !important; }
.comment-avatar { background: #EF4444 !important; color: #fff !important; }
.comment-name { color: #111 !important; }
.comment-date { color: #888 !important; }
.comment-text { color: #444 !important; }
.comment-list { border-color: #e5e5e5 !important; }
.comment-form-title { color: #888 !important; }
.comment-form-field label { color: #555 !important; }
.comment-form-field input,
.comment-form-field textarea { background: #f8f8f8 !important; border-color: #e0e0e0 !important; color: #111 !important; }
.comment-form-field input::placeholder,
.comment-form-field textarea::placeholder { color: #aaa !important; }
.comment-captcha-mock { background: #f8f8f8 !important; border-color: #e0e0e0 !important; }
.comment-captcha-mock span { color: #444 !important; }
.comment-submit { background: #EF4444 !important; color: #fff !important; }

.rating-block { background: #f8f8f8 !important; border-color: #e5e5e5 !important; }
.rating-score-num { color: #111 !important; }
.rating-total { color: #888 !important; }
.rating-bar-fill { background: #EF4444 !important; }
.rating-bar-track { background: #e5e5e5 !important; }
.rating-vote-btn { background: #fff !important; border-color: #e0e0e0 !important; color: #555 !important; }
.rating-vote-btn:hover { border-color: #EF4444 !important; color: #EF4444 !important; }

/* ── Dark mode: comments & rating ── */
html.dark-mode .comments-panel { background: #111 !important; border-color: #222 !important; }
html.dark-mode .comments-heading { color: #fff !important; }
html.dark-mode .comment-name { color: #ddd !important; }
html.dark-mode .comment-date { color: #444 !important; }
html.dark-mode .comment-text { color: #999 !important; }
html.dark-mode .comment-avatar { background: #1e1e1e !important; color: var(--red) !important; }
html.dark-mode .comment-form-field input,
html.dark-mode .comment-form-field textarea { background: #111 !important; border-color: var(--border) !important; color: #fff !important; }
html.dark-mode .comment-captcha-mock { background: #111 !important; border-color: var(--border) !important; }
html.dark-mode .comment-captcha-mock span { color: #888 !important; }
html.dark-mode .rating-block { background: #111 !important; border-color: #222 !important; }
html.dark-mode .rating-score-num { color: #fff !important; }
html.dark-mode .rating-vote-btn { background: #1a1a1a !important; border-color: #2a2a2a !important; color: #aaa !important; }


/* ── Light theme: rating block ── */
.gal-rating-block { background: #fff !important; border-color: #e5e5e5 !important; }
.gal-rating-num { color: #111 !important; }
.gal-rating-denom { color: #888 !important; }
.gal-rating-bar-wrap { background: #e5e5e5 !important; }
.gal-rating-cnt { color: #888 !important; }
.gal-vote-btn { background: #fff !important; border-color: #e0e0e0 !important; color: #555 !important; }
.gal-vote-btn:hover { border-color: #EF4444 !important; color: #EF4444 !important; background: #fff5f5 !important; }
.gal-vote-btn.voted-up { border-color: #EF4444 !important; color: #EF4444 !important; background: #fff0f0 !important; }
.gal-vote-btn.voted-down { border-color: #888 !important; color: #555 !important; background: #f5f5f5 !important; }

/* ── Light theme: tags ── */
.gal-tag { background: #f5f5f5 !important; border-color: #ddd !important; color: #444 !important; }
.gal-tag:hover { border-color: #EF4444 !important; color: #EF4444 !important; background: #fff5f5 !important; }
.gal-tags-row { border-color: #e5e5e5 !important; }

/* ── Dark mode: rating ── */
html.dark-mode .gal-rating-block { background: #111 !important; border-color: #222 !important; }
html.dark-mode .gal-rating-num { color: #fff !important; }
html.dark-mode .gal-rating-denom { color: #555 !important; }
html.dark-mode .gal-rating-bar-wrap { background: #2a2a2a !important; }
html.dark-mode .gal-rating-cnt { color: #555 !important; }
html.dark-mode .gal-vote-btn { background: #1a1a1a !important; border-color: #2a2a2a !important; color: #888 !important; }
html.dark-mode .gal-vote-btn:hover { border-color: #444 !important; color: #fff !important; }
html.dark-mode .gal-vote-btn.voted-up { border-color: var(--red) !important; color: var(--red) !important; background: #1a0008 !important; }

/* ── Dark mode: tags ── */
html.dark-mode .gal-tag { background: #1a1a1a !important; border-color: var(--border) !important; color: #888 !important; }
html.dark-mode .gal-tag:hover { border-color: var(--red) !important; color: var(--red) !important; }
html.dark-mode .gal-tags-row { border-color: var(--border) !important; }


/* ── Light theme: gal-btn-outline & saved states ── */
.gal-btn-outline { background: #fff !important; border-color: #d0d0d0 !important; color: #555 !important; }
.gal-btn-outline:hover { background: #f5f5f5 !important; border-color: #aaa !important; color: #111 !important; }
.gal-btn-outline.saved { background: #fff0f0 !important; border-color: #EF4444 !important; color: #EF4444 !important; }
.gal-btn-outline.saved:hover { background: #ffe0e0 !important; }

/* ── Dark mode: gal-btn-outline & saved ── */
html.dark-mode .gal-btn-outline { background: #181818 !important; border-color: #2e2e2e !important; color: #bbb !important; }
html.dark-mode .gal-btn-outline:hover { background: #222 !important; color: #fff !important; border-color: #444 !important; }
html.dark-mode .gal-btn-outline.saved { background: #1a0008 !important; border-color: var(--red) !important; color: var(--red) !important; }


/* ── gal-model-badges: single row + mobile scroll ── */
.gal-model-badges {
  display: flex;
  flex-wrap: nowrap;
  gap: 6px;
  margin-bottom: 10px;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  min-width: 0;
  width: 100%;
}
.gal-model-badges::-webkit-scrollbar { display: none; }
.gal-model-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--red);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 4px;
  letter-spacing: .04em;
  text-decoration: none;
  transition: background .15s;
  white-space: nowrap;
  flex-shrink: 0;
}
.gal-model-badge:hover { background: var(--red-d); }
.gal-model-badge svg { flex-shrink: 0; }
@media (min-width: 901px) {
  .gal-model-badges { flex-wrap: nowrap; overflow-x: auto; }
}


/* ── gal-model-badge: dark mode explicit ── */
html.dark-mode .gal-model-badge { background: #EF4444 !important; color: #fff !important; border: none !important; }
html.dark-mode .gal-model-badge:hover { background: #DC2626 !important; }


/* ── gal-model-badge: FINAL fix both themes ── */
.gal-model-badge,
.gal-model-badges a.gal-model-badge {
  background: #EF4444 !important;
  color: #fff !important;
  border: none !important;
}
.gal-model-badge:hover,
.gal-model-badges a.gal-model-badge:hover {
  background: #DC2626 !important;
  color: #fff !important;
}
html.dark-mode .gal-model-badge,
html.dark-mode .gal-model-badges a.gal-model-badge {
  background: #EF4444 !important;
  color: #fff !important;
}
html.dark-mode .gal-model-badge:hover {
  background: #DC2626 !important;
}


/* ── sb-toggle.active in dark mode ── */
html.dark-mode .sb-toggle.active { color: #EF4444 !important; }


/* ── Dark mode: muted red ── */
html.dark-mode { --red: #CC3333 !important; --red-d: #AA2222 !important; --accent: #CC3333 !important; --accent-d: #AA2222 !important; --text: #ddd !important; --text-dim: #888 !important; --bg: #0d0d0d !important; --bg2: #141414 !important; --bg3: #1c1c1c !important; --border: #252525 !important; }


/* ── Load More Button ── */
.load-more-btn {
  border: 1.5px solid #d0d0d0 !important;
  color: #555 !important;
  background: #fff !important;
  text-decoration: none;
  letter-spacing: .02em;
}
.load-more-btn:hover {
  background: #f0f0f0 !important;
  color: #111 !important;
  border-color: #999 !important;
}
html.dark-mode .load-more-btn {
  background: #1a1a1a !important;
  border-color: #333 !important;
  color: #bbb !important;
}
html.dark-mode .load-more-btn:hover {
  background: #252525 !important;
  color: #fff !important;
  border-color: #555 !important;
}
html.dark-mode .load-more-btn::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
}
.load-more-btn::after {
  content: '';
  display: block;
  width: 14px;
  height: 14px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  flex-shrink: 0;
}

/* Dark mode */
html.dark-mode .load-more-btn {
  background: #1a1a1a;
  border-color: #2a2a2a;
  color: #aaa;
}
html.dark-mode .load-more-btn:hover {
  background: #242424;
  color: #fff;
  border-color: #444;
}
html.dark-mode .load-more-btn::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
}


/* ── gal-btn: equal height for a and button ── */
.gal-btn {
  height: 34px !important;
  box-sizing: border-box !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  align-items: center !important;
}


/* ── related-heading dark mode fix ── */
html.dark-mode .related-heading { background: #111 !important; border-color: #222 !important; }
html.dark-mode .related-heading h2 { color: #eee !important; }
html.dark-mode .related-heading h2 span { color: var(--red) !important; }






/* ── gal-rating-block: badges on new line ── */





/* PH Style */
.ph-vote-section { padding:14px 18px 10px;display:flex;flex-direction:column;gap:6px; }
.ph-vote-btns { display:flex;gap:8px; }
.ph-like-btn,.ph-dislike-btn { display:inline-flex;align-items:center;gap:8px;padding:8px 20px;border-radius:3px;font-size:14px;font-weight:700;cursor:pointer;border:none;min-width:100px;font-family:inherit; }
.ph-like-btn { background:#2ea44f;color:#fff; }
.ph-like-btn:hover { background:#2c974b; }
.ph-dislike-btn { background:#1a1a1a;color:#888;border:1px solid #333; }
.ph-dislike-btn:hover { color:#fff;border-color:#555; }
html.dark-mode .ph-dislike-btn { background:#1a1a1a; }
html:not(.dark-mode) .ph-dislike-btn { background:#f5f5f5;color:#888;border-color:#ddd; }
.ph-bar-wrap { display:flex;height:4px;border-radius:0;overflow:hidden;gap:2px; }
.ph-bar-like { background:#2ea44f;height:100%; }
.ph-bar-dislike { background:#e74c3c;height:100%;flex:1; }
.ph-bar-labels { display:flex;justify-content:space-between;font-size:11px; }
.ph-pct-like { color:#2ea44f;font-weight:700; }
.ph-pct-dislike { color:#e74c3c;font-weight:700; }
.ph-meta-row { display:flex;align-items:center;gap:10px;padding:8px 18px 12px;flex-wrap:wrap; }
.ph-score-num { font-size:28px;font-weight:800;color:var(--red);line-height:1; }
.ph-score-sub { font-size:11px;color:var(--text-dim);margin-left:4px; }
.ph-score-wrap { display:flex;align-items:baseline;gap:0; }
.ph-btn-fav { display:inline-flex;align-items:center;gap:7px;padding:7px 16px;border-radius:3px;font-size:12px;font-weight:700;cursor:pointer;background:transparent;border:1px solid var(--border);color:var(--text-dim);font-family:inherit;transition:all .15s; }
.ph-btn-fav:hover { border-color:var(--red);color:var(--red); }
.ph-btn-download { display:inline-flex;align-items:center;gap:7px;padding:7px 16px;border-radius:3px;font-size:12px;font-weight:700;background:var(--red);color:#fff;text-decoration:none;transition:background .15s; }
.ph-btn-download:hover { background:var(--red-d); }
.ph-models-row { display:flex;flex-wrap:nowrap;gap:6px;overflow-x:auto;scrollbar-width:none;padding:4px 18px 10px;border-top:1px solid var(--border); }
.ph-models-row::-webkit-scrollbar { display:none; }
.ph-tags-row { display:flex;flex-wrap:wrap;gap:5px;padding:10px 18px 14px;border-top:1px solid var(--border); }
.ph-tag { display:inline-flex;padding:4px 10px;border-radius:2px;font-size:11px;font-weight:500;border:1px solid var(--border);color:var(--text-dim);text-decoration:none;transition:all .15s; }
.ph-tag:hover { border-color:var(--red);color:var(--red);background:rgba(239,68,68,.06); }
.ph-model-badge { display:inline-flex;align-items:center;gap:5px;background:var(--red);color:#fff!important;font-size:11px;font-weight:700;padding:4px 11px;border-radius:2px;letter-spacing:.02em;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:background .15s; }
.ph-model-badge:hover { background:var(--red-d); }
html.dark-mode .ph-model-badge { background:var(--red)!important; }

/* MindGeek Style */
.mg-top-row { display:flex;align-items:center;gap:20px;padding:16px 18px;flex-wrap:wrap; }
.mg-score { display:flex;align-items:center;gap:14px; }
.mg-score-ring { position:relative;width:64px;height:64px;flex-shrink:0; }
.mg-score-val { position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;color:var(--red); }
.mg-score-label { font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim); }
.mg-votes { font-size:13px;color:var(--text-dim);margin-top:2px; }
.mg-vote-counts { display:flex;gap:10px;margin-top:4px; }
.mg-up { font-size:12px;font-weight:700;color:#2ea44f; }
.mg-dn { font-size:12px;font-weight:700;color:#e74c3c; }
.mg-actions { display:flex;flex-direction:column;gap:8px; }
.mg-btn-fav { display:inline-flex;align-items:center;gap:7px;padding:8px 18px;border-radius:4px;font-size:12px;font-weight:700;cursor:pointer;background:transparent;border:1px solid var(--border);color:var(--text-dim);font-family:inherit;white-space:nowrap;transition:all .15s; }
.mg-btn-fav:hover { border-color:var(--red);color:var(--red); }
.mg-btn-dl { display:inline-flex;align-items:center;gap:7px;padding:8px 18px;border-radius:4px;font-size:12px;font-weight:700;background:var(--red);color:#fff;text-decoration:none;white-space:nowrap;transition:background .15s; }
.mg-btn-dl:hover { background:var(--red-d); }
.mg-section-label { font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);flex-shrink:0;width:50px; }
.mg-models { display:flex;align-items:center;gap:8px;padding:10px 18px;border-top:1px solid var(--border);overflow-x:auto;scrollbar-width:none; }
.mg-models::-webkit-scrollbar { display:none; }
.mg-tags { display:flex;align-items:flex-start;gap:8px;padding:10px 18px 14px;border-top:1px solid var(--border);flex-wrap:wrap; }


/* ── gal-rating-block redesign ── */
.gal-rating-block { display:flex; flex-direction:column; gap:0; padding:0 !important; background:#fff !important; }
html.dark-mode .gal-rating-block { background:#111 !important; border-color:#222 !important; }

.grb-row1 { display:flex; align-items:center; gap:14px; padding:14px 18px; flex-wrap:wrap; }
.grb-sep { flex:1; min-width:16px; }
.grb-actions { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }

/* Rating circle */
.grb-score-num { font-size:20px; font-weight:800; color:var(--red); line-height:1; }
.grb-score-denom { font-size:10px; color:var(--text-dim); font-weight:500; line-height:1.4; }

/* Meta */
.grb-meta { display:flex; flex-direction:column; gap:5px; }
.grb-rating-bar-wrap { width:80px; height:4px; background:var(--border); border-radius:2px; overflow:hidden; }
.grb-rating-bar { height:100%; background:var(--red); border-radius:2px; }
.grb-cnt { font-size:10px; color:var(--text-dim); }
.grb-vote-btns { display:flex; gap:6px; }

/* Sections */
.grb-section { display:flex; align-items:center; gap:12px; padding:9px 18px; border-top:1px solid var(--border); min-height:38px; overflow:hidden; width:100%; box-sizing:border-box; }
html.dark-mode .grb-section { border-color:#222; }
.grb-label { font-size:10px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--text-dim); flex-shrink:0; width:46px; }

/* Models — nowrap + scroll */
.grb-models-wrap { display:flex; flex-wrap:nowrap; gap:6px; overflow-x:auto; scrollbar-width:none; min-width:0; flex:1; }
.grb-models-wrap::-webkit-scrollbar { display:none; }

/* Tags — nowrap + scroll on mobile, wrap on desktop */
/* ── gal-rating-block layout ── */
.gal-rating-block { display: flex !important; flex-direction: column !important; align-items: stretch !important; gap: 0 !important; padding: 0 !important; min-height: 0 !important; overflow: hidden !important; }
.grb-row1 { display: flex !important; align-items: center !important; gap: 14px; padding: 14px 18px; flex-wrap: wrap; width: 100%; box-sizing: border-box; }
.grb-sep { flex: 1; min-width: 8px; }
.grb-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
@media(max-width:900px) { .grb-row1 { padding:12px 14px; gap:10px; } .grb-sep { display:none; } .grb-actions { width:100%; } .grb-actions .gal-btn { flex:1; justify-content:center; } }


/* ── Tags: single row + scroll everywhere ── */
.grb-tags-wrap {
  display: flex;
  flex-wrap: nowrap;
  overflow-x: auto;
  gap: 5px;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-bottom: 2px;
  min-width: 0;
  flex: 1;
}
.grb-tags-wrap::-webkit-scrollbar { display: none; }

/* ── grb-score-box: rating rectangle ── */
.grb-score-box {
  display: flex;
  align-items: baseline;
  gap: 2px;
  padding: 8px 14px;
  border-radius: 6px;
  border: 2px solid var(--red);
  flex-shrink: 0;
  background: transparent;
}
.grb-score-box .grb-score-num {
  font-size: 28px;
  font-weight: 800;
  color: var(--red);
  line-height: 1;
  letter-spacing: -0.02em;
}
.grb-score-box .grb-score-denom {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-dim);
}

/* Light theme */
.grb-score-box { border-color: #EF4444; }
.grb-score-box .grb-score-num { color: #EF4444; }
html.dark-mode .grb-score-box { border-color: var(--red); }
html.dark-mode .grb-score-box .grb-score-num { color: var(--red); }

/* ── Kill float clearfix on related-grid ── */
#related-grid::after { content: none !important; display: none !important; clear: none !important; }





/* ── gal-actions: icon-only on narrow mobile ── */




    /* ── Lightbox CTA v4 ── */
    .lb-cta { position:fixed; bottom:68px; left:0; right:0; z-index:10; pointer-events:none; display:flex; justify-content:center; padding:0 16px; }
    .lb-cta-card { width:100%; max-width:700px; }
    .lb-cta-card { display:flex; align-items:center; gap:14px; background:rgba(10,10,10,.95); border:1px solid rgba(239,68,68,.6); border-radius:10px; padding:12px 16px; pointer-events:all; }
    .lb-cta-info { flex:1; min-width:0; }
    .lb-cta-title { font-size:14px; font-weight:700; color:#fff; letter-spacing:-.01em; }
    .lb-cta-sub { font-size:11px; color:#888; margin-top:2px; }
    .lb-cta-btn { display:inline-flex; align-items:center; gap:8px; background:#EF4444; color:#fff; font-size:13px; font-weight:700; padding:10px 20px; border-radius:6px; text-decoration:none; white-space:nowrap; flex-shrink:0; transition:background .15s; letter-spacing:.01em; }
    .lb-cta-btn:hover { background:#DC2626; }
    html.dark-mode .lb-cta-card { background:rgba(10,10,10,.95); border-color:rgba(239,68,68,.5); }

  /* Keyboard focus */
  :focus-visible { outline: 2px solid #EF4444; outline-offset: 2px; }
  /* Respect reduced motion */
  @media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  }

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
    html{min-width:320px;scrollbar-width:thin;scrollbar-color:#333 #111}
    body{font-family:'Open Sans',sans-serif;font-size:16px;line-height:1.5;color:#eee;background:#0d0d0d;min-height:100vh}
    a{text-decoration:none;color:inherit}
    ul{list-style:none}
    img{display:block;max-width:100%}
    button{cursor:pointer;font-family:inherit;border:none;background:none}
    :root{
      --red:#F22E4B;--red-d:#c41f3a;
      --header-h:58px;--sb-w:220px;
      --bg:#0d0d0d;--bg2:#141414;--bg3:#1c1c1c;
      --border:#252525;--text:#ccc;--text-dim:#666;
    }

    /* ── HEADER ── */
    .site-header{position:sticky;top:0;z-index:300;height:var(--header-h);background:#111;border-bottom:1px solid #222;display:flex;align-items:center;overflow:visible}
    .header-inner{width:100%;padding:0 16px;display:flex;align-items:center;gap:6px}
    .sb-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:6px;color:#bbb;transition:background .15s,color .15s;flex-shrink:0}
    .sb-toggle:hover{background:#1e1e1e;color:#fff}
    .sb-toggle.active{color:var(--red)}
    .logo-link{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;margin:0 20px 0 8px}
    .logo-mark{width:34px;height:34px;background:var(--red);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
    .logo-mark svg{display:block}
    .logo-text{display:flex;flex-direction:column;line-height:1}
    .logo-text-top{font-size:25px;font-weight:700;color:#fff;letter-spacing:-0.02em}
    .logo-text-top span{color:var(--red)}
    .logo-text-bot{font-size:8px;font-weight:400;letter-spacing:0.25em;color:#999;margin-top:2px}
    .main-nav{display:flex;align-items:center;gap:1px;flex:1}
    .main-nav a{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:500;color:#b0b0b0;padding:5px 8px;border-radius:6px;white-space:nowrap;position:relative;transition:background .15s,color .15s}
    .main-nav a svg{flex-shrink:0;opacity:.7}
    .main-nav a:hover{background:#1e1e1e;color:#fff}
    .main-nav a:hover svg{opacity:1}
    .nav-red{color:var(--red)!important}
    .nav-red:hover{background:#1a0008!important}
    .nav-discount,
.nav-discount:link,
.nav-discount:visited,
.nav-discount:hover,
html.dark-mode .nav-discount,
html.dark-mode .nav-discount:hover,
html:not(.dark-mode) .nav-discount,
html:not(.dark-mode) .nav-discount:hover {
  background: var(--red) !important;
  color: #ffffff !important;
  border: none !important;
  position: relative !important;
  overflow: visible !important;
  margin-left: 10px !important;
}
.nav-discount svg,
html.dark-mode .nav-discount svg,
html:not(.dark-mode) .nav-discount svg {
  opacity: 1 !important;
  stroke: #ffffff !important;
}
html.dark-mode .nav-discount svg circle[fill="currentColor"],
html.dark-mode .nav-discount svg path[fill="currentColor"] {
  fill: #ffffff !important;
}
.nav-discount::before,.nav-discount::after{
  content:'';
  position:absolute;
  inset:0;
  border-radius:8px;
  border:1.5px solid var(--red);
  opacity:0;
  animation:ripple-ring 2.2s ease-out infinite;
  pointer-events:none;
}
.nav-discount::after{
  animation-delay:.7s;
}
@keyframes ripple-ring{
  0%{opacity:.7;inset:-2px}
  100%{opacity:0;inset:-10px}
}
@keyframes pulse-border{0%,100%{border-color:rgba(180,0,30,.3)}50%{border-color:rgba(180,0,30,.85)}}
    @keyframes pulse-border{0%,100%{border-color:rgba(180,0,30,.3)}50%{border-color:rgba(180,0,30,.85)}}
    .header-icons{display:flex;align-items:center;gap:2px;margin-left:4px;flex-shrink:0}
    .hicon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:6px;color:#999;transition:background .15s,color .15s;position:relative}
    .hicon:hover{background:#1e1e1e;color:#fff}
    .hicon.active{color:var(--red)}
    .history-dot{display:none;position:absolute;top:5px;right:5px;width:7px;height:7px;border-radius:50%;background:var(--red);border:1.5px solid var(--bg);box-shadow:0 0 6px rgba(180,0,30,.7)}
    #history-btn{position:relative}
    #history-btn.has-history .history-dot{display:block}
    #history-btn.has-history{color:#eee}
    .mobile-history-btn.has-history .history-dot{display:block}
    .mobile-history-btn.has-history{color:#eee}
    .search-drop{display:none;position:fixed;top:var(--header-h);left:0;right:0;background:#161616;border-bottom:1px solid var(--border);padding:10px 16px;z-index:400}
    .search-drop.open{display:block}
    .search-drop form{display:flex;gap:8px;max-width:500px;margin:0 auto}
    .search-drop input{flex:1;padding:8px 14px;background:#1e1e1e;border:1px solid var(--border);border-radius:6px;color:#fff;font-size:13px;font-family:'Open Sans',sans-serif;outline:none}
    .search-drop input:focus{border-color:var(--red)}
    .search-drop button[type=submit]{padding:8px 18px;background:var(--red);color:#fff;border-radius:6px;font-size:13px;font-weight:600;transition:background .15s}
    .search-drop button[type=submit]:hover{background:var(--red-d)}

    /* ── HISTORY DROP ── */
    .history-drop{display:none;position:fixed;top:var(--header-h);right:0;width:320px;background:#161616;border:1px solid var(--border);border-top:none;border-radius:0 0 0 10px;z-index:400;box-shadow:-4px 8px 24px rgba(0,0,0,.5)}
    .history-drop.open{display:block}
    .history-drop-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 8px;border-bottom:1px solid var(--border);font-size:11px;font-weight:600;color:#888;letter-spacing:.06em;text-transform:uppercase}
    .history-clear-btn{font-size:10px;color:#888;transition:color .15s;font-family:'Open Sans',sans-serif}
    .history-clear-btn:hover{color:var(--red)}
    .history-drop-list{max-height:420px;overflow-y:auto;padding:6px}
    .history-drop-list::-webkit-scrollbar{width:4px}
    .history-drop-list::-webkit-scrollbar-thumb{background:#2a2a2a;border-radius:2px}
    .history-drop-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:6px;text-decoration:none;transition:background .15s}
    .history-drop-item:hover{background:#1e1e1e}
    .history-drop-thumb{width:44px;height:58px;object-fit:cover;border-radius:4px;flex-shrink:0;background:#1a1a1a}
    .history-drop-info{flex:1;min-width:0}
    .history-drop-model{font-size:10px;color:var(--red);font-weight:600;letter-spacing:.04em}
    .history-drop-title{font-size:11.5px;color:#eee;line-height:1.35;margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
    .history-drop-empty{padding:20px;text-align:center;font-size:12px;color:#888}
    .history-drop-foot{padding:6px 8px 8px;border-top:1px solid var(--border)}
    .history-close-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:7px;border-radius:6px;font-size:12px;font-weight:500;color:#999;font-family:'Open Sans',sans-serif;background:#1a1a1a;transition:background .15s,color .15s}
    .history-close-btn:hover{background:#222;color:#fff}

    /* ── MOBILE ── */
    .hamburger{display:none;flex-direction:column;gap:5px;padding:6px;flex-shrink:0;position:relative;z-index:10}
    .hamburger span{display:block;width:20px;height:2px;background:#888;border-radius:1px;transition:transform .2s,opacity .2s,background .2s}
    .hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
    .hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}
    .hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
    .hamburger.active span{background:var(--red)}
    .mobile-nav{display:none;position:fixed;top:var(--header-h);left:0;right:0;bottom:0;background:#111;z-index:290;flex-direction:column;overflow-y:auto;padding:8px 0}
    .mobile-nav.open{display:flex}
    .mobile-nav-link{display:flex;align-items:center;gap:12px;padding:13px 18px;font-size:14px;color:#888;border-bottom:1px solid var(--border);transition:color .15s,background .15s}
    .mobile-nav-link svg{flex-shrink:0;opacity:.6}
    .mobile-nav-link:hover{color:#fff;background:#181818}
    .mob-section{border-top:1px solid var(--border)}
    .mob-section-head{display:flex;align-items:center;justify-content:space-between;width:100%;padding:13px 18px;font-size:12px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#999;background:none;border:none;font-family:'Open Sans',sans-serif;cursor:pointer;transition:color .15s;user-select:none}
    .mob-section-head span{display:flex;align-items:center;gap:8px}
    .mob-section-head:hover{color:#bbb}
    .mob-section-arrow{transition:transform .2s;flex-shrink:0}
    .mob-section.open .mob-section-arrow{transform:rotate(180deg)}
    .mob-section-body{display:none}
    .mob-section.open .mob-section-body{display:block}
    .mobile-nav-hist-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:6px;text-decoration:none;transition:background .15s}
    .mobile-nav-hist-item:hover{background:#1a1a1a}
    .mobile-nav-hist-thumb{width:38px;height:50px;object-fit:cover;border-radius:4px;flex-shrink:0;background:#1a1a1a}
    .mobile-nav-hist-info{flex:1;min-width:0}
    .mobile-nav-hist-model{font-size:10px;color:var(--red);font-weight:600}
    .mobile-nav-hist-title{font-size:12px;color:#bbb;line-height:1.3;margin-top:2px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
    .mobile-nav-hist-empty{padding:12px 18px;font-size:13px;color:#888}
    .mobile-search-btn{display:none;flex-shrink:0}
    .mobile-history-btn{display:none;flex-shrink:0;position:relative}
    .mobile-sb-btn{display:none;flex-shrink:0}
    .mobile-theme-btn{display:none;flex-shrink:0}
    .btn-icon-default{display:block}
    .btn-icon-close{display:none}
    .hicon.active .btn-icon-default{display:none}
    .hicon.active .btn-icon-close{display:block;color:var(--red)}
    .mobile-history-btn.active .history-dot{display:none!important}
    @media (max-width:1024px){.header-search{display:none;pointer-events:none}}
@media (max-width:1024px){.main-nav{display:none}.header-icons{display:none}.sidebar.left{display:none !important}.sb-toggle{display:none}.logo-text-bot{display:none}.logo-link{margin:0 4px;flex:1}.main-content{width:100%;min-width:0}.intro{padding:12px 10px 10px}.gallery-grid{padding:0}.gallery-card{padding:0 1px 2px}.mobile-search-btn{display:flex}.mobile-history-btn{display:flex}.mobile-theme-btn{display:flex}.hamburger{display:flex}}
.mobile-sb-btn{display:none;flex-shrink:0}@media(max-width:1024px){.mobile-sb-btn{display:flex !important}.sidebar.right{display:flex!important;position:fixed;top:var(--header-h);right:0;bottom:0;width:260px;height:auto;min-height:unset;z-index:280;transform:translateX(100%);transition:transform .25s ease;overflow-y:auto;border-left:1px solid #252525;box-shadow:-8px 0 24px rgba(0,0,0,.5)}.sidebar.right.mob-open{display:flex!important;transform:translateX(0)}.sb-right-overlay{display:none;position:fixed;inset:0;top:var(--header-h);z-index:279;background:rgba(0,0,0,.5)}.sb-right-overlay.open{display:block}}
    @media(max-width:400px){.logo-text{display:none}.logo-link{margin:0 2px}}

    /* ── SIDEBAR ── */
    .page-body{display:flex;align-items:flex-start;min-height:calc(100vh - var(--header-h))}
    .sidebar{width:var(--sb-w);flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);min-height:calc(100vh - var(--header-h));position:sticky;top:var(--header-h);height:calc(100vh - var(--header-h));overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}
    .sidebar::-webkit-scrollbar{display:none}
    .sidebar.right{border-right:none;border-left:1px solid var(--border)}
    .sidebar.closed{display:none!important}
    .sidebar-inner{padding:14px;width:var(--sb-w)}
    .sb-section{margin-bottom:22px}
    .sb-title{font-size:9px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-dim);padding-bottom:8px;border-bottom:1px solid var(--border);margin-bottom:10px}
    .sb-nav{display:flex;flex-direction:column;gap:1px}
    .sb-nav a{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:6px;font-size:13px;color:#bbb;transition:background .12s,color .12s}
    .sb-nav a:hover{background:var(--bg3);color:#fff}
    .sb-nav a.active{background:#1a0008;color:var(--red)}
    .sb-nav .icon{width:15px;height:15px;flex-shrink:0;opacity:.5}
    .sb-nav a:hover .icon{opacity:.9}
    .sb-nav a.active .icon{opacity:1;stroke:var(--red)}
    .sb-nav .count{margin-left:auto;font-size:10px;color:#888;font-weight:600}
    .sb-models{display:flex;flex-direction:column}
    .sb-model{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid #1a1a1a;transition:color .12s}
    .sb-model:hover{color:#fff}
    .sb-model-rank{font-size:10px;color:#888;font-weight:700;width:16px;flex-shrink:0;text-align:right}
    .sb-model-name{font-size:12px;color:#bbb;flex:1}
    .sb-model:hover .sb-model-name{color:#fff}
    .sb-model-cnt{font-size:10px;color:#888}
    .sb-tags{display:flex;flex-wrap:wrap;gap:4px}
    .sb-tags a{font-size:11px;padding:3px 8px;background:#1a1a1a;border:1px solid var(--border);border-radius:3px;color:#888;transition:all .12s}
    .sb-tags a:hover{border-color:var(--red);color:var(--red);background:#160007}
    .sb-history{display:flex;flex-direction:column;gap:1px}
    .sb-empty{font-size:11px;color:#888;padding:4px 0}
    .sb-hist-item{display:flex;align-items:center;gap:6px;padding:5px 6px;border-radius:5px;font-size:11px;color:#888;transition:background .12s,color .12s;text-decoration:none}
    .sb-hist-item:hover{background:#1a1a1a;color:#eee}
    .sb-hist-thumb{width:28px;height:28px;object-fit:cover;border-radius:3px;flex-shrink:0;background:#222}
    .sb-hist-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
    .sb-friends{display:flex;flex-direction:column;gap:1px}
    .sb-friends li{list-style:none}
    .sb-friends li a{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;font-size:12px;color:#999;transition:background .12s,color .12s}
    .sb-friends li a:hover{background:var(--bg3);color:#fff}
    .sb-friends li a svg{flex-shrink:0;opacity:.45}
    .sb-friends li a:hover svg{opacity:1}
    @media(max-width:900px){
      .sidebar.left{display:none!important}
      .sb-toggle{display:none}
    }

    /* ── MAIN CONTENT ── */
    .main-content{flex:1;min-width:0}

    /* ── BREADCRUMB ── */
    .breadcrumb{display:flex;align-items:center;gap:6px;padding:10px 16px;font-size:11.5px;color:#555;border-bottom:1px solid var(--border);flex-wrap:wrap}
    .breadcrumb a{color:#999;transition:color .15s}
    .breadcrumb a:hover{color:var(--red)}
    .breadcrumb-sep{color:#444}
    .breadcrumb-cur{color:#bbb}

    /* ── GALLERY HEADER ── */
    .gal-header{padding:16px 18px 14px;border-bottom:1px solid var(--border)}
    .gal-model-badge{display:inline-flex;align-items:center;gap:6px;background:var(--red);color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:4px;letter-spacing:.04em;margin-bottom:10px;text-decoration:none;transition:background .15s}
    .gal-model-badge:hover{background:var(--red-d)}
    .gal-title{font-size:22px;font-weight:700;color:#fff;line-height:1.25;letter-spacing:-0.02em;margin-bottom:8px}
    .gal-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
    .gal-meta-item{display:flex;align-items:center;gap:5px;font-size:12px;color:#888}
    .gal-meta-item svg{flex-shrink:0;opacity:.6}
    .gal-meta-item strong{color:#999;font-weight:500}
    .gal-actions{display:flex;align-items:center;gap:8px;margin-top:14px;flex-wrap:wrap}
    .gal-btn{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border-radius:6px;font-size:12px;font-weight:600;transition:background .15s,color .15s,border-color .15s;letter-spacing:.01em}
    .gal-btn-primary{background:var(--red);color:#fff}
    .gal-btn-primary:hover{background:var(--red-d)}
    .gal-btn-outline{background:#181818;border:1px solid #2e2e2e;color:#bbb}
    .gal-btn-outline:hover{background:#222;color:#fff;border-color:#444}
    .gal-btn-outline.saved{background:#1a0008;border-color:var(--red);color:var(--red)}
    .gal-btn svg{flex-shrink:0}
    @media(max-width:600px){
      .gal-title{font-size:17px}
      .gal-actions{gap:6px}
      .gal-btn{padding:6px 10px;font-size:11px}
    }

    /* ── VIEWER ── */
    /* ── GALLERY THUMBS ── */
    .gallery-grid{position:relative;width:100%;overflow-anchor:none}
    
    .gallery-sizer{display:none}
    .gal-thumb{float:left;box-sizing:border-box;padding:0 1.5px 3px;cursor:zoom-in}
    .gal-thumb-inner{position:relative;overflow:hidden;background:#161616}
    .gal-thumb-inner img{display:block;width:100%;height:auto;transition:transform .35s ease;filter:brightness(1)}
    .gal-thumb:hover .gal-thumb-inner img{transform:scale(1.06);filter:brightness(1)}
    .gal-thumb-num{position:absolute;bottom:6px;right:8px;font-size:11px;font-weight:600;color:rgba(255,255,255,.7);opacity:0;transition:opacity .2s;pointer-events:none;text-shadow:0 1px 3px rgba(0,0,0,.8)}
    .gal-thumb:hover .gal-thumb-num{opacity:1}

    /* ── LIGHTBOX ── */
    .lightbox{display:none;position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.95);flex-direction:column;align-items:center;justify-content:center}
    .lightbox.open{display:flex}
    body.lb-open{overflow:hidden}
    
    .lb-img-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%;padding:56px 60px 144px}
    .lb-img{max-width:100%;max-height:100%;object-fit:contain;display:block;transition:opacity .15s;user-select:none}
    .lb-img.fading{opacity:0}
    @media(max-width:600px){.lb-img-wrap{padding:50px 10px 140px}}
    .lb-arrow{position:fixed;top:50%;transform:translateY(-50%);width:48px;height:48px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#ddd;z-index:10;transition:background .15s,color .15s;cursor:pointer}
    .lb-arrow:hover{background:rgba(255,255,255,.18);color:#fff}
    .lb-arrow.prev{left:12px}
    .lb-arrow.next{right:12px}
    @media(max-width:600px){.lb-arrow{width:38px;height:38px}.lb-arrow.prev{left:4px}.lb-arrow.next{right:4px}}
    @media(max-width:700px){
      .lb-bar{background:rgba(0,0,0,.9);height:48px;padding:0 8px}
      .lb-title{display:none}
      /* Hide button text — icons only */
      .lb-btn-text{display:none}
      #lb-fs-label{display:none}
      /* Download Full Set — icon only, square */
      .lb-btn-dl{padding:0;width:34px;height:34px;justify-content:center}
      .lb-btn{width:34px;height:34px;padding:0}
      .lb-btn svg{opacity:1}
      .lb-bar-right{gap:5px}
      .lb-close{width:34px;height:34px}
      .lb-img-wrap{padding:48px 6px 130px}
    }

    .lb-strip-wrap{position:fixed;bottom:0;left:0;right:0;height:68px;background:linear-gradient(to top,rgba(0,0,0,.85),transparent);display:flex;align-items:flex-end;padding-bottom:6px;z-index:10}
    .lb-strip{display:flex;gap:3px;padding:0 8px;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none;width:100%}
    .lb-strip::-webkit-scrollbar{display:none}
    .lb-strip-thumb{flex-shrink:0;cursor:pointer;border-radius:3px;overflow:hidden;border:2px solid transparent;transition:border-color .15s,opacity .15s;opacity:.5}
    .lb-strip-thumb:hover{opacity:.85}
    .lb-strip-thumb.active{border-color:var(--red);opacity:1}
    .lb-strip-thumb img{display:block;width:auto;height:54px;object-fit:cover}

    /* Main displayed frame */

    /* Navigation arrows */

    /* Counter */

    /* ── THUMBNAIL STRIP ── */

    /* ── GALLERY INFO BLOCK ── */

    /* Tags — inside rating-block, single row with scroll */
    .gal-tags-row{width:100%;padding-top:10px;border-top:1px solid var(--border);margin-top:4px}
    .gal-info-tags{display:flex;flex-wrap:nowrap;gap:5px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:2px}
    .gal-info-tags::-webkit-scrollbar{display:none}
    .gal-tag{display:inline-flex;align-items:center;white-space:nowrap;flex-shrink:0;padding:3px 9px;background:#1a1a1a;border:1px solid var(--border);border-radius:4px;font-size:11px;color:#888;transition:all .12s}
    .gal-tag:hover{border-color:var(--red);color:var(--red);background:#160007}

    /* ── RELATED GALLERIES ── */
    .related-section{padding:0}
    .related-heading{padding:12px 16px 10px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}
    .related-heading h2{font-size:13px;font-weight:700;color:#fff;letter-spacing:.04em;text-transform:uppercase}
    .related-heading h2 span{color:var(--red);margin-left:6px;font-weight:400;font-size:11px}

    /* Related grid — same cards as on index */
    .gallery-grid{position:relative;width:100%;overflow-anchor:none}
    
    .gallery-sizer{display:none}
    .gallery-card{float:left;box-sizing:border-box;padding:0 1.5px 3px}
    .gallery-card-inner{position:relative;overflow:hidden;background:#161616}
    .gallery-card img{display:block;width:100%;height:auto;transition:transform .4s ease;filter:brightness(1)}
    .gallery-card:hover .gallery-card-inner img{transform:scale(1.05);filter:brightness(1)}
    .gc-info{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.92) 0%,transparent 75%);opacity:0;transition:opacity .2s;padding:30px 10px 10px;pointer-events:none;z-index:2}
    .gallery-card:hover .gc-info{opacity:1}
    .gc-model{font-size:11px;font-weight:700;color:#fff;background:var(--red);display:inline-block;padding:1px 6px;border-radius:3px;letter-spacing:.04em;margin-bottom:3px}
    .gc-title{font-size:13px;color:#fff;line-height:1.35;margin-top:2px}
    .gc-date{font-size:11px;color:#bbb;margin-top:4px}
    .gc-save{position:absolute;top:6px;right:6px;width:28px;height:28px;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.12);border-radius:6px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,background .15s,border-color .15s;z-index:3;cursor:pointer;color:#bbb}
    .gallery-card:hover .gc-save{opacity:1}
    .gc-save:hover{background:var(--red);border-color:var(--red);color:#fff}
    .gc-save.saved{opacity:1;background:var(--red);border-color:var(--red);color:#fff}
    .gc-save svg{display:block;pointer-events:none}
    @media(max-width:900px){.gc-save{opacity:1}}
    /* Related label */
    .gc-related{position:absolute;top:6px;left:6px;font-size:9px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#bbb;background:rgba(0,0,0,.65);padding:2px 7px;border-radius:3px;pointer-events:none;z-index:3;border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(2px)}

    /* ── FOOTER ── */
    .load-more-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 28px;border-radius:6px;font-size:13px;font-weight:600;transition:background .15s,color .15s,border-color .15s}
    /* load-more hover — see below */
    .load-more-btn::after{content:'';display:block;width:14px;height:14px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:contain}
    .footer-banner{background:#111;padding:40px 20px;text-align:center;border-bottom:1px solid var(--border)}
    .footer-banner h2{font-size:26px;font-weight:300;color:#fff;margin-bottom:8px}
    .footer-banner h2 strong{color:var(--red);font-weight:700}
    .footer-banner p{font-size:13px;color:#999;margin-bottom:18px}
    .btn-join{display:inline-block;background:var(--red);color:#fff;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:12px 28px;transition:background .15s}
    .btn-join:hover{background:var(--red-d)}
    .footer-bottom{max-width:1200px;margin:0 auto;padding:20px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
    .footer-logo{display:flex;align-items:center;gap:8px;text-decoration:none}
    .footer-nav{display:flex;gap:18px}
    .footer-nav a{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#888;transition:color .15s}
    .footer-nav a:hover{color:var(--red)}
    .footer-copy{font-size:10px;color:#888}
    .scroll-up{position:fixed;bottom:20px;right:20px;width:36px;height:36px;background:#1a1a1a;border:1px solid #333;color:#888;font-size:14px;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:all .2s;z-index:50;border-radius:4px}
    .scroll-up.visible{opacity:1;pointer-events:all}
    .scroll-up:hover{border-color:var(--red);color:var(--red)}
  
    /* ── RATING ── */
    .gal-rating-block{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;flex-wrap:wrap;row-gap:0}
    .gal-rating-score{display:flex;align-items:baseline;gap:4px}
    .gal-rating-num{font-size:36px;font-weight:800;color:#fff;line-height:1;letter-spacing:-0.03em}
    .gal-rating-denom{font-size:14px;color:#555;font-weight:500}
    .gal-rating-meta{display:flex;flex-direction:column;gap:2px}
    .gal-rating-bar-wrap{width:80px;height:5px;background:#2a2a2a;border-radius:3px;overflow:hidden}
    .gal-rating-bar{height:100%;background:var(--red);border-radius:3px;transition:width .3s}
    .gal-rating-cnt{font-size:10px;color:#555;margin-top:2px}
    .gal-vote-btns{display:flex;align-items:center;gap:6px}
    .gal-vote-btn{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:6px;font-size:12px;font-weight:600;border:1px solid #2a2a2a;color:#888;background:none;transition:all .15s;font-family:'Open Sans',sans-serif;cursor:pointer}
    .gal-vote-btn:hover{border-color:#444;color:#fff}
    .gal-vote-btn.voted-up{border-color:var(--red);color:var(--red);background:#1a0008}
    .gal-vote-btn.voted-down{border-color:#444;color:#fff;background:#1a1a1a}
    .gal-rating-actions{display:flex;align-items:center;gap:8px;margin-left:auto;flex-wrap:wrap}

    /* ── BANNER ── */
    .gal-banner-wrap{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;justify-content:center}
    .gal-banner{display:block;max-width:728px;width:100%;border-radius:4px;overflow:hidden;line-height:0}
    .gal-banner img{width:100%;height:auto;display:block}

    /* ── LIGHTBOX top-bar buttons ── */
    .lb-bar{position:fixed;top:0;left:0;right:0;height:54px;display:flex;align-items:center;justify-content:space-between;padding:0 12px;background:linear-gradient(to bottom,rgba(0,0,0,.85),transparent);z-index:10}
    .lb-bar-left{display:flex;align-items:center;gap:8px}
    .lb-bar-right{display:flex;align-items:center;gap:6px}
    .lb-counter{font-size:12px;color:#bbb;font-weight:500;min-width:44px}
    .lb-title{font-size:12px;color:#bbb;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:220px}
    .lb-btn{display:flex;align-items:center;justify-content:center;gap:4px;height:28px;padding:0 8px;border-radius:5px;font-size:11px;font-weight:500;color:#888;background:transparent;border:1px solid rgba(255,255,255,.1);transition:background .15s,color .15s;white-space:nowrap;font-family:'Open Sans',sans-serif}
    .lb-btn:hover{background:rgba(255,255,255,.1);color:#eee}
    .lb-btn.active{color:var(--red);border-color:rgba(242,46,75,.5)}
    .lb-btn svg{flex-shrink:0;opacity:.7}
    .lb-btn-dl{color:#ddd;border-color:rgba(255,255,255,.2)}
    .lb-btn-dl:hover{color:#fff;background:rgba(255,255,255,.12)}
    .lb-close{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:6px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);color:#ddd;transition:background .15s,color .15s}
    .lb-close:hover{background:var(--red);border-color:var(--red);color:#fff}

    /* ── LIGHTBOX CTA block ── */
    
    
    
    
  
    /* ── COL TOGGLE + RANDOM (from index) ── */
    .random-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;color:#999;border:1px solid #222;transition:background .12s,color .12s,border-color .12s;flex-shrink:0;text-decoration:none}
    .random-btn:hover{background:#1e1e1e;color:#fff;border-color:#333}
    .col-toggle-tb{display:none;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;color:#888;border:1px solid #222;transition:background .15s,color .15s;flex-shrink:0}
    .col-toggle-tb:hover{background:#1e1e1e;color:#fff}
    .col-toggle-tb.active{color:var(--red);border-color:var(--red)}
    @media(max-width:900px){.col-toggle-tb{display:flex}}

    /* ── SLIDESHOW OVERLAY on first photo ── */
    /* Slideshow — rectangular icon in bottom-right corner */
    .gal-thumb-play{position:absolute;bottom:7px;right:7px;opacity:0;transition:opacity .2s;pointer-events:none;z-index:4}
    .gal-thumb:first-of-type .gal-thumb-play{opacity:1;pointer-events:all}
    .gal-thumb-play-btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;height:24px;padding:0 10px;border-radius:4px;background:rgba(0,0,0,.55);border:1.5px solid rgba(255,255,255,.6);color:#fff;cursor:pointer;font-size:11px;font-weight:700;letter-spacing:.04em;font-family:inherit;transition:background .15s,border-color .15s}
    .gal-thumb-play-btn:hover{background:var(--red);border-color:rgba(242,46,75,.6)}
    @media(max-width:900px){.gal-thumb-play{opacity:1;pointer-events:all}}

    /* gal-actions flex with spacer */
    .gal-actions-right{display:flex;align-items:center;gap:6px;margin-left:auto}
  
    /* ── MOBILE RIGHT SIDEBAR BUTTON ── */

    /* ── RIGHT SIDEBAR OVERLAY ON MOBILE ── */
    @media(max-width:900px){
      .sidebar.right{
        display:flex !important;   /* override closed */
        position:fixed;
        top:var(--header-h);
        right:0;
        bottom:0;
        width:260px;
        height:auto;
        min-height:unset;
        z-index:280;
        transform:translateX(100%);
        transition:transform .25s ease;
        overflow-y:auto;
        border-left:1px solid var(--border);
        box-shadow:-8px 0 24px rgba(0,0,0,.5);
      }
      .sidebar.right.mob-open{transform:translateX(0)}
      /* Overlay under sidebar */
      .sb-right-overlay{display:none;position:fixed;inset:0;top:var(--header-h);z-index:279;background:rgba(0,0,0,.5)}
      .sb-right-overlay.open{display:block}
    }
  
    /* ── COMMENTS ── */
    .comments-btn{position:relative;display:inline-flex;align-items:center;gap:6px}
    .comments-dot{display:none;position:absolute;top:-3px;right:-3px;width:8px;height:8px;border-radius:50%;background:var(--red);border:2px solid var(--bg2);box-shadow:0 0 6px rgba(242,46,75,.7)}
    /* Show dot only when there are comments: .comments-panel.filled ~ button */
    .comments-panel.filled + * .comments-dot,
    [data-has-comments] .comments-dot{display:block}
    /* Controlled via 'filled' class on the panel */
    .comments-panel.filled .comments-count-label::before{content:attr(data-count)}
    .comments-panel:not(.filled) .comment-list{display:none}
    .comments-panel:not(.filled) .comments-count-label::before{content:"No comments yet"}

    /* Panel */
    .comments-panel{display:none;border-top:1px solid var(--border);background:var(--bg2)}
    .comments-panel.open{display:block}
    .comments-inner{max-width:700px;padding:20px 18px 24px}
    .comments-heading{font-size:13px;font-weight:700;color:#fff;letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:8px}
    .comments-heading span{font-size:11px;color:#555;font-weight:400;text-transform:none;letter-spacing:0}

    /* Comments */
    .comment-list{display:flex;flex-direction:column;gap:16px;margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--border)}
    .comment-item{display:flex;gap:10px}
    .comment-avatar{width:34px;height:34px;border-radius:50%;background:#1e1e1e;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:13px;font-weight:700;color:var(--red);border:1px solid var(--border)}
    .comment-body{flex:1;min-width:0}
    .comment-meta{display:flex;align-items:center;gap:8px;margin-bottom:4px}
    .comment-name{font-size:12px;font-weight:600;color:#ddd}
    .comment-date{font-size:11px;color:#444}
    .comment-text{font-size:13px;color:#999;line-height:1.6}

    /* Form */
    .comment-form-title{font-size:11px;font-weight:700;color:#888;margin-bottom:12px;text-transform:uppercase;letter-spacing:.07em}
    .comment-form-row{display:flex;gap:10px;margin-bottom:10px}
    .comment-form-field{display:flex;flex-direction:column;gap:5px;flex:1}
    .comment-form-field label{font-size:11px;color:#555;font-weight:500}
    .comment-form-field input,.comment-form-field textarea{background:#111;border:1px solid var(--border);border-radius:6px;color:#eee;font-size:13px;font-family:'Open Sans',sans-serif;padding:8px 12px;outline:none;transition:border-color .15s;resize:none}
    .comment-form-field input:focus,.comment-form-field textarea:focus{border-color:var(--red)}
    .comment-form-field input::placeholder,.comment-form-field textarea::placeholder{color:#333}
    .comment-form-field textarea{min-height:80px}
    .comment-captcha{margin-bottom:14px}
    .comment-captcha-mock{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;background:#111;border:1px solid var(--border);border-radius:6px;transition:border-color .15s}
    .comment-captcha-mock:has(.cf-captcha:checked){border-color:#2a5a2a}
    .comment-captcha-mock input[type=checkbox]{width:18px;height:18px;accent-color:#2a9d2a;cursor:pointer;flex-shrink:0}
    .comment-captcha-mock span{font-size:13px;color:#888;user-select:none}
    .comment-captcha-mock .recaptcha-logo{margin-left:16px;font-size:8px;color:#444;line-height:1.3;text-align:center;border-left:1px solid var(--border);padding-left:12px}
    .comment-submit{display:inline-flex;align-items:center;gap:7px;padding:8px 20px;background:var(--red);color:#fff;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;font-family:'Open Sans',sans-serif;border:none;transition:background .15s}
    .comment-submit:hover{background:var(--red-d)}
    @media(max-width:600px){.comment-form-row{flex-direction:column}}
  .sb-all-models{display:block;margin-top:8px;padding:6px 8px;border-radius:6px;font-size:11px;font-weight:600;color:#888;text-align:center;border:1px solid var(--border);transition:background .12s,color .12s,border-color .12s}.sb-all-models:hover{background:var(--bg3);color:#ddd;border-color:#333}

/* ══ CSS columns for galGrid ══ */
@media (min-width: 1200px) { #gallery-grid { column-count: 5; column-gap: 3px; } }
@media (min-width: 900px)  and (max-width: 1199px) { #gallery-grid { column-count: 4; column-gap: 3px; } }
@media (min-width: 600px)  and (max-width: 899px)  { #gallery-grid { column-count: 3; column-gap: 3px; } }
@media (max-width: 599px)  { #gallery-grid { column-count: 2; column-gap: 2px; } }

#gallery-grid { overflow-anchor: none; }

#gallery-grid .gal-thumb {
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  float: none !important;
  width: 100% !important;
  display: block;
  margin-bottom: 3px;
  padding: 0;
  box-sizing: border-box;
  cursor: zoom-in;
}
#gallery-grid .gallery-sizer { display: none !important; }
#gallery-grid .gal-thumb-inner img { display: block; width: 100%; height: auto; vertical-align: bottom; }

/* Mobile col-toggle */
@media (max-width: 899px) { #gallery-grid.cols-1 { column-count: 1 !important; } }

/* Sidebar CLS */
html.sb-left-closed  #sidebar-left  { display: none !important; }
html.sb-right-closed #sidebar-right { display: none !important; }
html.sb-right-closed #sidebar-right.mob-open { display: flex !important; transform: translateX(0) !important; }

/* CLS — block heights */
.gal-rating-block { min-height: 76px; box-sizing: border-box; }
.gal-banner-wrap  { min-height: 108px; }
.gal-actions      { min-height: 40px; }

/* ── Gallery description block ── */
.gal-desc-wrap {
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
}
.gal-desc-inner {
  font-size: 13px;
  line-height: 1.7;
  color: #999;
  overflow: hidden;
  /* Mobile: truncate to 3 lines */
  max-height: 4.2em;
  transition: max-height .35s ease;
}
.gal-desc-inner.expanded {
  max-height: 600px;
}
/* Desktop — show slightly more lines */
@media (min-width: 700px) {
  .gal-desc-inner {
    max-height: 3.9em; /* ~2 lines */
  }
}
.gal-desc-toggle {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-top: 8px;
  background: none;
  border: none;
  color: var(--red);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  padding: 0;
  font-family: inherit;
}
.gal-desc-toggle:hover { opacity: .8; }
#gal-desc-arrow {
  transition: transform .3s ease;
}
.gal-desc-inner.expanded ~ .gal-desc-toggle #gal-desc-arrow,
.gal-desc-toggle.expanded #gal-desc-arrow {
  transform: rotate(180deg);
}

/* CLS fixes — min-height for stable blocks */
.gal-meta       { min-height: 28px; }
.gal-header     { min-height: 80px; }
.header-inner   { min-height: 58px; }
.gal-actions    { min-height: 40px; }
.gal-rating-block { min-height: 76px; }
.gal-info-row   { min-height: 56px; }

/* ── Sidebar banner ── */
.sb-banner {
  background: linear-gradient(135deg, #1a0008, #0d0d0d);
  border: 1px solid #3a0018;
  border-radius: 8px;
  padding: 16px;
  text-align: center;
}
.sb-banner p { font-size: 11px; color: #bbb; margin-bottom: 10px; line-height: 1.5; }
.sb-banner strong { color: var(--red); font-size: 13px; display: block; margin-bottom: 6px; }
.sb-banner a { display: block; background: var(--red); color: #fff; font-size: 11px; font-weight: 700; padding: 8px; border-radius: 5px; transition: background .15s; }
.sb-banner a:hover { background: var(--red-d); }

/* CSS columns for related-grid */
#related-grid { overflow-anchor: none; }
@media (min-width: 1100px) { #related-grid { column-count: 5; column-gap: 3px; } }
@media (min-width: 900px) and (max-width: 1099px) { #related-grid { column-count: 4; column-gap: 3px; } }
@media (min-width: 600px) and (max-width: 899px) { #related-grid { column-count: 3; column-gap: 3px; } }
@media (max-width: 599px) { #related-grid { column-count: 2; column-gap: 2px; } }
#related-grid .gallery-card { break-inside: avoid; -webkit-column-break-inside: avoid; float: none; width: 100%; display: block; margin-bottom: 3px; padding: 0; box-sizing: border-box; }
#related-grid .gallery-sizer { display: none; }

:root{--red:#F22E4B;--red-d:#c41f3a;--header-h:68px;--sb-w:220px;--bg:#0d0d0d;--bg2:#141414;--bg3:#1c1c1c;--border:#252525;--text:#ddd;--text-dim:#888}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--text);font-family:'Open Sans',sans-serif;font-size:16px;line-height:1.5;min-height:100vh}
body{overflow-x:clip}
a{text-decoration:none;color:inherit}img{display:block;max-width:100%}button{cursor:pointer;font-family:inherit;border:none;background:none}
.site-header{position:sticky;top:0;z-index:300;height:var(--header-h);background:#111;border-bottom:1px solid #222;display:flex;align-items:center;overflow:visible}
.header-inner{width:100%;padding:0 16px;display:flex;align-items:center;gap:6px}
.logo-link{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;margin:0 20px 0 8px}
.logo-mark{width:34px;height:34px;background:transparent;border-radius:0;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.logo-text-top{font-size:25px;font-weight:700;color:#fff;letter-spacing:-0.02em}
.logo-text-top span{color:var(--red)}
.page-body{display:flex;align-items:flex-start;min-height:calc(100vh - var(--header-h))}
.sidebar{width:var(--sb-w);flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);min-height:calc(100vh - var(--header-h));position:sticky;top:var(--header-h);height:calc(100vh - var(--header-h));overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}
.sidebar::-webkit-scrollbar{display:none}
.sidebar.right{border-right:none;border-left:1px solid var(--border)}
.sidebar.closed,.sidebar.left.closed,.sidebar.right.closed{display:none!important}
html.sb-left-closed #sidebar-left{display:none!important}
html.sb-right-closed #sidebar-right{display:none!important}
html.sb-right-closed #sidebar-right.mob-open{display:flex!important;transform:translateX(0)!important}
.main-content{flex:1;min-width:0;display:flex;flex-direction:column}.intro{order:1}.site-desc{order:5}.gallery-heading{order:2}.gallery-grid{order:3}.pagination{order:4}
.gallery-card{float:left;box-sizing:border-box;padding:0 1.5px 3px}
.gallery-card-inner{position:relative;overflow:hidden;background:#161616}
.gallery-card img{display:block;width:100%;height:auto}
.gallery-grid{position:relative;width:100%;overflow-anchor:none}
.gallery-grid::after{content:'';display:block;clear:both}
/* Above-the-fold */
.intro{padding:10px 14px;border-bottom:1px solid #1e1e1e;display:flex;align-items:center;gap:12px}
.intro-title{font-size:20px;font-weight:700;color:#fff}
#gallery-grid{overflow-anchor:none}
.gallery-card{float:none;break-inside:avoid;-webkit-column-break-inside:avoid;width:100%;display:block;margin-bottom:3px;padding:0;box-sizing:border-box}
.gallery-card-inner{position:relative;overflow:hidden;background:#161616}
.gallery-card img{display:block;width:100%;height:auto;vertical-align:bottom}
.gallery-card a{display:block}
@media(min-width:1800px){#gallery-grid{column-count:6;column-gap:3px}}
@media(min-width:1400px)and(max-width:1799px){#gallery-grid{column-count:5;column-gap:3px}}
@media(min-width:1100px)and(max-width:1399px){#gallery-grid{column-count:4;column-gap:3px}}
@media(min-width:550px)and(max-width:1099px){#gallery-grid{column-count:3;column-gap:3px}}
@media(max-width:549px){#gallery-grid{column-count:2;column-gap:2px}}

/* ── sb-toggle.active in dark mode ── */
html.dark-mode .sb-toggle.active { color: #EF4444 !important; }


/* ── Dark mode: muted red ── */
html.dark-mode { --red: #CC3333 !important; --red-d: #AA2222 !important; --accent: #CC3333 !important; --accent-d: #AA2222 !important; --text: #ddd !important; --text-dim: #888 !important; --bg: #0d0d0d !important; --bg2: #141414 !important; --bg3: #1c1c1c !important; --border: #252525 !important; }

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{min-width:320px;scrollbar-width:thin;scrollbar-color:#333 #111}body{font-family:'Open Sans',sans-serif;font-size:16px;line-height:1.5;color:#eee;background:#0d0d0d;min-height:100vh}a{text-decoration:none;color:inherit}ul{list-style:none}img{display:block;max-width:100%}button{cursor:pointer;font-family:inherit;border:none;background:none}:root{--red:#F22E4B;--red-d:#c41f3a;--header-h:68px;--sb-w:220px;--sb-gap:3px;--bg:#0d0d0d;--bg2:#141414;--bg3:#1c1c1c;--border:#252525;--text:#ccc;--text-dim:#666}.site-header{position:sticky;top:0;z-index:300;min-height:var(--header-h);height:auto;background:#111;border-bottom:1px solid #222;display:flex;align-items:center;overflow:visible}.header-inner{width:100%;padding:0 16px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.sb-toggle{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:6px;color:#bbb;transition:background .15s,color .15s;flex-shrink:0}.sb-toggle:hover{background:#1e1e1e;color:#fff}.sb-toggle.active{color:var(--red)}.logo-link{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;margin:0 20px 0 8px}.logo-mark{width:34px;height:34px;background:transparent;border-radius:0;display:flex;align-items:center;justify-content:center;flex-shrink:0}.logo-mark svg{display:block}.logo-text{display:flex;flex-direction:column;line-height:1}.logo-text-top{font-size:25px;font-weight:700;color:#fff;letter-spacing:-0.02em}.logo-text-top span{color:var(--red)}.logo-text-bot{font-size:8px;font-weight:400;letter-spacing:0.25em;color:#999;margin-top:2px}.main-nav{display:flex;align-items:center;align-content:flex-start;gap:1px;flex:1;flex-wrap:wrap}.main-nav a{display:inline-flex;align-items:center;gap:4px;font-size:14.5px;font-weight:500;color:#b0b0b0;padding:5px 8px;border-radius:6px;white-space:nowrap;position:relative;transition:background .15s,color .15s}.main-nav a svg{flex-shrink:0;opacity:.7}.main-nav a:hover{background:#1e1e1e;color:#fff}.main-nav a:hover svg{opacity:1}.nav-active{background:var(--red) !important;color:#fff !important}.nav-active:hover{background:var(--red-d) !important}.nav-active svg{opacity:1 !important}.nav-red{color:var(--red) !important}.nav-red:hover{background:#1a0012 !important}.nav-red svg{opacity:1 !important}@keyframes pulse-border{0%,100%{border-color:rgba(180,0,30,.3)}50%{border-color:rgba(180,0,30,.85)}}.header-icons{display:flex;align-items:center;gap:2px;margin-left:4px;flex-shrink:0}.hicon{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:6px;color:#999;transition:background .15s,color .15s}.hicon:hover{background:#1e1e1e;color:#fff}.hicon.active{color:var(--red)}.history-dot{display:none;position:absolute;top:5px;right:5px;width:7px;height:7px;border-radius:50%;background:var(--red);border:1.5px solid var(--bg);box-shadow:0 0 6px rgba(180,0,30,.7)}#history-btn{position:relative}#history-btn.has-history .history-dot{display:block}#history-btn.has-history{color:#eee}.mobile-history-btn.has-history .history-dot{display:block}.mobile-history-btn.has-history{color:#eee}.history-drop{display:none;position:fixed;top:var(--header-h);right:0;width:320px;background:#161616;border:1px solid var(--border);border-top:none;border-radius:0 0 0 10px;z-index:400;box-shadow:-4px 8px 24px rgba(0,0,0,.5)}.history-drop.open{display:block}.history-drop-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 8px;border-bottom:1px solid var(--border);font-size:11px;font-weight:600;color:#888;letter-spacing:.06em;text-transform:uppercase}.history-clear-btn{font-size:10px;color:#888;transition:color .15s;font-family:'Open Sans',sans-serif}.history-clear-btn:hover{color:var(--red)}.history-drop-list{max-height:420px;overflow-y:auto;padding:6px}.history-drop-list::-webkit-scrollbar{width:4px}.history-drop-list::-webkit-scrollbar-track{background:transparent}.history-drop-list::-webkit-scrollbar-thumb{background:#2a2a2a;border-radius:2px}.history-drop-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:6px;text-decoration:none;transition:background .15s}.history-drop-item:hover{background:#1e1e1e}.history-drop-thumb{width:44px;height:58px;object-fit:cover;border-radius:4px;flex-shrink:0;background:#1a1a1a}.history-drop-info{flex:1;min-width:0}.history-drop-model{font-size:12px;color:var(--red);font-weight:700;letter-spacing:.03em}.history-drop-title{font-size:12.5px;color:#eee;line-height:1.35;margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.history-drop-empty{padding:20px;text-align:center;font-size:12px;color:#888}.header-search{flex:1;max-width:300px;position:relative;display:flex;align-items:center}.header-search form{width:100%;display:flex;align-items:center;background:#181818;border:1px solid #282828;border-radius:7px;overflow:hidden;transition:border-color .15s}.header-search form:focus-within{border-color:var(--red)}.header-search-icon{display:flex;align-items:center;padding:0 0 0 11px;color:#555;flex-shrink:0;pointer-events:none}.header-search input{flex:1;padding:7px 8px;background:transparent;border:none;color:#eee;font-size:13px;font-family:'Open Sans',sans-serif;outline:none;min-width:0}.header-search input::placeholder{color:#555}.header-search-submit{display:flex;align-items:center;justify-content:center;width:34px;height:34px;background:#242424;border-left:1px solid #303030;color:#888;flex-shrink:0;transition:color .15s,background .15s;font-family:'Open Sans',sans-serif}.header-search-submit:hover{color:#fff;background:var(--red);border-color:var(--red)}@media (max-width:1024px){.header-search{display:none;pointer-events:none}}.search-drop{display:none;position:fixed;top:var(--header-h);left:0;right:0;background:#161616;border-bottom:1px solid var(--border);padding:10px 16px;z-index:400}.search-drop.open{display:block}.search-drop form{display:flex;gap:8px;max-width:500px;margin:0 auto}.search-drop input{flex:1;padding:8px 14px;background:#1e1e1e;border:1px solid var(--border);border-radius:6px;color:#fff;font-size:13px;font-family:'Open Sans',sans-serif;outline:none}.search-drop input:focus{border-color:var(--red)}.search-drop button[type=submit]{padding:8px 18px;background:var(--red);color:#fff;border-radius:6px;font-size:13px;font-weight:600;transition:background .15s}.search-drop button[type=submit]:hover{background:var(--red-d)}.link-bar{padding:10px 12px;border-bottom:1px solid var(--border);background:#0f0f0f}.link-bar-wrap{display:flex;flex-wrap:wrap;gap:6px}.link-bar-scroll{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:6px;scrollbar-width:none;-ms-overflow-style:none}.link-bar-scroll::-webkit-scrollbar{display:none}.link-bar a{display:inline-flex;align-items:center;white-space:nowrap;padding:5px 12px;border-radius:5px;font-size:12px;font-weight:500;color:#bbb;background:#181818;border:1px solid #252525;transition:background .15s,color .15s,border-color .15s;flex-shrink:0}.link-bar a:hover{background:#222;color:#fff;border-color:#333}.page-body{display:flex;align-items:flex-start;min-height:calc(100vh - var(--header-h))}.sidebar{width:var(--sb-w);flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);min-height:calc(100vh - var(--header-h));position:sticky;top:var(--header-h);align-self:flex-start;overflow-x:hidden}.sidebar.right{border-right:none;border-left:1px solid var(--border)}.sidebar.closed{display:none !important}.sidebar-inner{padding:14px;width:var(--sb-w)}.sb-section{margin-bottom:22px}.sb-title{font-size:11px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-dim);padding-bottom:8px;border-bottom:1px solid var(--border);margin-bottom:10px}.sb-nav{display:flex;flex-direction:column;gap:1px}.sb-nav a{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:6px;font-size:13px;color:#bbb;transition:background .12s,color .12s}.sb-nav a:hover{background:var(--bg3);color:#fff}.sb-nav a.active{background:#1a0012;color:var(--red)}.sb-nav .icon{width:15px;height:15px;flex-shrink:0;opacity:.5;transition:opacity .12s}.sb-nav a:hover .icon{opacity:.9}.sb-nav a.active .icon{opacity:1;stroke:var(--red)}.sb-nav .count{margin-left:auto;font-size:10px;color:#888;font-weight:600}.sb-models{display:flex;flex-direction:column}.sb-model{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid #1a1a1a;transition:color .12s}.sb-model:hover{color:#fff}.sb-model-rank{font-size:10px;color:#888;font-weight:700;width:16px;flex-shrink:0;text-align:right}.sb-model-name{font-size:13px;color:#bbb;flex:1}.sb-model:hover .sb-model-name{color:#fff}.sb-model-cnt{font-size:10px;color:#888}.sb-tags{display:flex;flex-wrap:wrap;gap:4px}.sb-tags a{font-size:12px;padding:3px 8px;background:#1a1a1a;border:1px solid var(--border);border-radius:3px;color:#888;transition:all .12s}.sb-tags a:hover{border-color:var(--red);color:var(--red);background:#160010}.sb-tags a.active{border-color:var(--red);color:var(--red);background:#160010}.sb-filters{display:flex;flex-direction:column;gap:6px}.sb-check{display:flex;align-items:center;gap:8px;font-size:12px;color:#999;cursor:pointer;padding:3px 0}.sb-check:hover{color:#bbb}.sb-check input[type=checkbox]{width:13px;height:13px;accent-color:var(--red);cursor:pointer;flex-shrink:0}.sb-check span:last-child{margin-left:auto;font-size:10px;color:#888}.sb-history{display:flex;flex-direction:column;gap:1px}.sb-empty{font-size:11px;color:#888;padding:4px 0}.sb-hist-item{display:flex;align-items:center;gap:6px;padding:5px 6px;border-radius:5px;font-size:13px;color:#888;transition:background .12s,color .12s;text-decoration:none}.sb-hist-item:hover{background:#1a1a1a;color:#eee}.sb-hist-thumb{width:28px;height:28px;object-fit:cover;border-radius:3px;flex-shrink:0;background:#222}.sb-hist-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gallery-heading{padding:8px 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border)}.gallery-heading h2{font-size:13px;font-weight:600;color:#888;letter-spacing:.06em;text-transform:uppercase;flex-shrink:0}.gallery-heading h2 span{color:var(--red);margin-left:6px}.gallery-heading-spacer{flex:1}.sb-banner{background:linear-gradient(135deg,#1a0012,#0d0d0d);border:1px solid #3a0018;border-radius:8px;padding:16px;text-align:center}.sb-banner p{font-size:13px;color:#bbb;margin-bottom:10px;line-height:1.5}.sb-banner strong{color:var(--red);font-size:16px;display:block;margin-bottom:6px}.sb-banner a{display:block;background:var(--red);color:#fff;font-size:11px;font-weight:700;padding:8px;border-radius:5px;transition:background .15s}.sb-banner a:hover{background:var(--red-d)}.main-content{flex:1;min-width:0;display:flex;flex-direction:column}.intro{order:1}.site-desc{order:5}.gallery-heading{order:2}.gallery-grid{order:3}.pagination{order:4}.intro{padding:10px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.intro-left{display:flex;flex-direction:column;flex-shrink:0}.intro-title{font-size:20px;font-weight:700;color:#fff;letter-spacing:-0.02em}.intro-sub{font-size:12px;color:#999;margin-top:2px}.intro-spacer{flex:1}@media (max-width:900px){.intro{padding:8px 10px;gap:8px}.intro-title{font-size:17px}}.sort-drop-wrap{position:relative;flex-shrink:0}.sort-drop-btn{display:flex;align-items:center;gap:6px;padding:5px 10px;border-radius:6px;font-size:12px;font-weight:500;color:#bbb;background:#181818;border:1px solid #252525;transition:background .12s,color .12s,border-color .12s;white-space:nowrap;font-family:'Open Sans',sans-serif}.sort-drop-btn:hover{background:#222;color:#eee;border-color:#333}.sort-drop-btn.open{color:var(--red);border-color:var(--red);background:#1a0012}.sort-drop-menu{display:none;position:absolute;top:calc(100%+6px);right:0;background:#161616;border:1px solid var(--border);border-radius:8px;overflow:hidden;z-index:300;min-width:130px;box-shadow:0 8px 24px rgba(0,0,0,.5)}.sort-drop-menu.open{display:block}.sort-opt{display:flex;align-items:center;gap:8px;width:100%;padding:9px 14px;font-size:13px;font-weight:500;color:#999;transition:background .12s,color .12s;text-align:left;font-family:'Open Sans',sans-serif;white-space:nowrap}.sort-opt:hover{background:#1e1e1e;color:#fff}.sort-opt.active{color:var(--red);background:#1a0012}.sort-opt svg{flex-shrink:0;opacity:.6}.sort-opt.active svg{opacity:1}.random-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;color:#999;border:1px solid #222;transition:background .12s,color .12s,border-color .12s;flex-shrink:0}.random-btn:hover{background:#1e1e1e;color:#fff;border-color:#333}.col-toggle-tb{display:none;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;color:#888;border:1px solid #222;transition:background .15s,color .15s;flex-shrink:0}.col-toggle-tb:hover{background:#1e1e1e;color:#fff}.col-toggle-tb.active{color:var(--red);border-color:var(--red)}@media (max-width:900px){.col-toggle-tb{display:flex}.intro{padding:8px 10px;gap:6px}.sort-btn{padding:5px 7px;font-size:11px}}.site-desc{padding:14px 16px;border-bottom:1px solid var(--border);background:#111}.site-desc p{font-size:12px;line-height:1.7;color:#bbb;margin-bottom:8px}.site-desc p:last-child{margin-bottom:0}.site-desc p strong{color:var(--red);font-weight:600}@media (max-width:900px){.site-desc{display:none}}.gallery-grid{position:relative;width:100%;overflow-anchor:none}body{overflow-anchor:none}.gallery-grid::after{content:'';display:block;clear:both}.gallery-sizer{float:left}.gallery-card{float:left;box-sizing:border-box;padding:0 1.5px 3px}.gallery-card-inner{position:relative;overflow:hidden;background:#161616}.gallery-card img{display:block;width:100%;height:auto;transition:transform .4s ease;filter:brightness(1)}.gallery-card:hover .gallery-card-inner img{transform:scale(1.05);filter:brightness(1)}.gc-info{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.92) 0%,transparent 75%);opacity:0;transition:opacity .2s;padding:30px 10px 10px;pointer-events:none;z-index:2}.gallery-card:hover .gc-info{opacity:1}.gc-model{font-size:11px;font-weight:700;color:#fff;background:var(--red);display:inline-block;padding:1px 6px;border-radius:3px;letter-spacing:.04em;margin-bottom:3px}.gc-title{font-size:13px;color:#fff;line-height:1.35;margin-top:2px}.gc-date{font-size:11px;color:#bbb;margin-top:4px}.gc-save{position:absolute;top:6px;right:6px;width:28px;height:28px;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.12);border-radius:6px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,background .15s,border-color .15s;z-index:3;cursor:pointer;color:#bbb}.gallery-card:hover .gc-save{opacity:1}.gc-save:hover{background:var(--red);border-color:var(--red);color:#fff}.gc-save.saved{opacity:1;background:var(--red);border-color:var(--red);color:#fff}@media (max-width:900px){.gc-save{opacity:1}}.gc-save svg{display:block;pointer-events:none}.gallery-card.banner-card{cursor:default}.gallery-card.banner-card .gallery-card-inner{background:#111;display:flex;align-items:center;justify-content:center;aspect-ratio:300 / 250;overflow:hidden}.gallery-card.banner-card img{width:100%;height:100%;object-fit:cover;filter:none !important;transition:none !important}.gallery-card.banner-card:hover .gallery-card-inner img{transform:none !important;filter:none !important}.banner-label{position:absolute;top:5px;left:5px;font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#ddd;background:rgba(0,0,0,.75);padding:2px 7px;border-radius:3px;pointer-events:none;z-index:2;border:1px solid rgba(255,255,255,.1)}.gallery-card.ad-script-card{cursor:default;display:flex;flex-direction:column;align-items:center;justify-content:center;aspect-ratio:300 / 250;overflow:hidden;position:relative}.gallery-card.ad-script-card .gallery-card-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#0f0f0f;position:relative}.gallery-card.ad-script-card:hover .gallery-card-inner{transform:none !important}.ad-script-wrap{width:300px;height:250px;flex-shrink:0;transform-origin:center center}.sb-friends{display:flex;flex-direction:column;gap:1px}.sb-friends li{list-style:none}.sb-friends li a{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;font-size:13px;color:#999;transition:background .12s,color .12s}.sb-friends li a:hover{background:var(--bg3);color:#fff}.sb-friends li a svg{flex-shrink:0;opacity:.45;transition:opacity .12s}.sb-friends li a:hover svg{opacity:1}.pagination{display:flex;gap:3px;justify-content:center;padding:28px 0 16px;clear:both}.pagination a,.pagination span{font-size:12px;font-weight:500;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);color:#999;border-radius:4px;transition:all .15s}.pagination a:hover{border-color:var(--red);color:var(--red)}.pg-active{background:var(--red) !important;color:#fff !important;border-color:var(--red) !important}.pg-dots{border:none !important;color:#333 !important}.site-footer{border-top:1px solid var(--border);margin-top:20px}.footer-banner{background:#111;padding:40px 20px;text-align:center;border-bottom:1px solid var(--border)}.footer-banner h2{font-size:26px;font-weight:300;color:#fff;margin-bottom:8px}.footer-banner h2 strong{color:var(--red);font-weight:700}.footer-banner p{font-size:13px;color:#999;margin-bottom:18px}.btn-join{display:inline-block;background:var(--red);color:#fff;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:12px 28px;transition:background .15s}.btn-join:hover{background:var(--red-d)}.footer-bottom{max-width:1200px;margin:0 auto;padding:20px 20px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.footer-logo{display:flex;align-items:center;gap:8px;text-decoration:none}.footer-nav{display:flex;gap:18px}.footer-nav a{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:#333;font-weight:500;transition:color .15s}.footer-nav a:hover{color:var(--red)}.footer-copy{font-size:12px;color:#444}.scroll-up{position:fixed;bottom:20px;right:20px;width:36px;height:36px;background:#1a1a1a;border:1px solid #333;color:#888;font-size:14px;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:all .2s;z-index:50;border-radius:4px}.scroll-up.visible{opacity:1;pointer-events:all}.scroll-up:hover{border-color:var(--red);color:var(--red)}.hamburger{display:none;flex-direction:column;gap:5px;padding:6px;flex-shrink:0;position:relative;z-index:10}.hamburger span{display:block;width:20px;height:2px;background:#888;border-radius:1px;transition:all .2s}.mobile-nav{display:none;position:fixed;top:var(--header-h);left:0;right:0;bottom:0;background:#111;z-index:290;flex-direction:column;overflow-y:auto;padding:8px 0}.mobile-nav.open{display:flex}.mobile-nav>a{display:flex;align-items:center;gap:12px;padding:13px 18px;font-size:14px;color:#bbb;border-bottom:1px solid var(--border);transition:color .15s,background .15s}.mobile-nav>a svg{flex-shrink:0;opacity:.6}.mobile-nav>a:hover{color:#fff;background:#181818}.mobile-nav>a:hover svg{opacity:1}.mobile-nav-history-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 8px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#888;border-top:1px solid var(--border);margin-top:4px}.mobile-nav-history-head span{display:flex;align-items:center;gap:6px}#mobile-nav-history{padding:0 8px 12px}.mobile-nav-hist-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:6px;text-decoration:none;transition:background .15s}.mobile-nav-hist-item:hover{background:#1a1a1a}.mobile-nav-hist-thumb{width:38px;height:50px;object-fit:cover;border-radius:4px;flex-shrink:0;background:#1a1a1a}.mobile-nav-hist-info{flex:1;min-width:0}.mobile-nav-hist-model{font-size:12px;color:var(--red);font-weight:700}.mobile-nav-hist-title{font-size:13px;color:#bbb;line-height:1.3;margin-top:2px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.mobile-nav-hist-empty{padding:12px 18px;font-size:13px;color:#888}.mob-section{border-top:1px solid var(--border)}.mob-section-head{display:flex;align-items:center;justify-content:space-between;width:100%;padding:13px 18px;font-size:12px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#999;background:none;border:none;font-family:'Open Sans',sans-serif;cursor:pointer;transition:color .15s;user-select:none}.mob-section-head span{display:flex;align-items:center;gap:8px}.mob-section-head:hover{color:#bbb}.mob-section-arrow{transition:transform .2s;flex-shrink:0}.mob-section.open .mob-section-arrow{transform:rotate(180deg)}.mob-section-body{display:none}.mob-section.open .mob-section-body{display:block}.mob-section-body ul{padding:0 0 8px}.mob-section-body ul li{list-style:none}.mob-section-body ul li a{display:flex;align-items:center;gap:12px;padding:10px 18px;font-size:14px;color:#888;border-bottom:1px solid var(--border);transition:color .15s,background .15s}.mob-section-body ul li a svg{flex-shrink:0;opacity:.5}.mob-section-body ul li a:hover{color:#fff;background:#181818}.mobile-nav-link{display:flex;align-items:center;gap:12px;padding:13px 18px;font-size:14px;color:#888;border-bottom:1px solid var(--border);transition:color .15s,background .15s}.mobile-nav-link svg{flex-shrink:0;opacity:.6}.mobile-nav-link:hover{color:#fff;background:#181818}.mobile-search-btn{display:none;flex-shrink:0}.mobile-history-btn{display:none;flex-shrink:0;position:relative}.mobile-theme-btn{display:none;flex-shrink:0}.mobile-sb-btn{display:none;flex-shrink:0}@media (max-width:1024px){.main-nav{display:none}.header-icons{display:none}.sidebar.left{display:none !important}.sb-toggle{display:none}.logo-text-bot{display:none}.logo-link{margin:0 4px;flex:1}.main-content{width:100%;min-width:0}.intro{padding:12px 10px 10px}.gallery-grid{padding:0}.gallery-card{padding:0 1px 2px}.mobile-search-btn{display:flex}.mobile-history-btn{display:flex}.mobile-theme-btn{display:flex}.hamburger{display:flex}}@media (max-width:400px){.logo-link{margin:0 2px}}.history-drop-foot{padding:6px 8px 8px;border-top:1px solid var(--border)}.history-close-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:7px;border-radius:6px;font-size:12px;font-weight:500;color:#999;font-family:'Open Sans',sans-serif;background:#1a1a1a;transition:background .15s,color .15s}.history-close-btn:hover{background:#222;color:#fff}.btn-icon-default{display:block !important}.btn-icon-close{display:none !important}.hicon.active .btn-icon-default{display:none !important}.hicon.active .btn-icon-close{display:block !important;color:var(--red)}.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.hamburger.active span{background:var(--red)}.hamburger span{transition:transform .2s,opacity .2s,background .2s}.mobile-history-btn.active .history-dot{display:none!important}
.sb-all-models{display:block;margin-top:8px;padding:6px 8px;border-radius:6px;font-size:12px;font-weight:600;color:#888;text-align:center;border:1px solid #252525;transition:background .12s,color .12s,border-color .12s;text-decoration:none}.sb-all-models:hover{background:#1c1c1c;color:#ddd;border-color:#333}
/* CLS=0: CSS columns instead of masonry */
#gallery-grid {
  display: block;
  overflow-anchor: none;
}
@media (min-width: 1800px) { #gallery-grid { column-count: 6; column-gap: 3px; } }
@media (min-width: 1400px) and (max-width: 1799px) { #gallery-grid { column-count: 5; column-gap: 3px; } }
@media (min-width: 1100px) and (max-width: 1399px) { #gallery-grid { column-count: 4; column-gap: 3px; } }
@media (min-width: 550px)  and (max-width: 1099px) { #gallery-grid { column-count: 3; column-gap: 3px; } }
@media (max-width: 549px)  { #gallery-grid { column-count: 2; column-gap: 2px; } }
@media (max-width: 899px)  { #gallery-grid.cols-1 { column-count: 1 !important; } }
#gallery-grid .gallery-card {
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  float: none;
  width: 100%;
  display: block;
  margin-bottom: 3px;
  padding: 0;
  box-sizing: border-box;
}
#gallery-grid .gallery-sizer { display: none; }
#gallery-grid .gallery-card-inner { position: relative; overflow: hidden; background: #161616; }
#gallery-grid .gallery-card img { display: block; width: 100%; height: auto; vertical-align: bottom; }
html.sb-left-closed  #sidebar-left  { display: none !important; }
html.sb-right-closed #sidebar-right { display: none !important; }

/* Fix: mob-open overrides html.sb-right-closed */
html.sb-right-closed #sidebar-right.mob-open {
  display: flex !important;
  transform: translateX(0) !important;
}

/* ══ Prev/Next ══ */
.gal-prev-next { display:flex; gap:8px; padding:16px 18px; border-top:1px solid var(--border); }
.gpn-btn { flex:1; display:flex; align-items:center; gap:10px; padding:12px 14px; border:1.5px solid #333; border-radius:8px; text-decoration:none; transition:border-color .15s, background .15s, color .15s; color:#bbb; }
.gpn-btn:hover { border-color:var(--red); background:var(--bg2); }
.gpn-next { justify-content:flex-end; text-align:right; }
.gpn-info { display:flex; flex-direction:column; gap:2px; }
.gpn-label { font-size:10px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--text-dim); }
.gpn-title { font-size:13px; font-weight:600; color:var(--text); line-height:1.3; display:-webkit-box; -webkit-line-clamp:1; -webkit-box-orient:vertical; overflow:hidden; }
.gpn-btn svg { flex-shrink:0; opacity:.5; }
.gpn-btn:hover svg { opacity:1; color:var(--red); }
@media(max-width:600px) { .gpn-title { font-size:12px; } .gpn-btn { padding:10px 10px; } }

/* ══ Sticky CTA ══ */
.sticky-cta { position:fixed; bottom:-80px; left:0; right:0; z-index:200; transition:bottom .3s ease; padding:0 16px 12px; pointer-events:none; }
.sticky-cta.visible { bottom:0; pointer-events:all; }
.sticky-cta-inner { max-width:700px; margin:0 auto; display:flex; align-items:center; gap:12px; background:#111; border:1px solid rgba(239,68,68,.4); border-radius:10px 10px 0 0; padding:12px 16px; }
.sticky-cta-text { flex:1; min-width:0; }
.sticky-cta-text strong { display:block; font-size:13px; font-weight:700; color:#fff; }
.sticky-cta-text span { font-size:11px; color:#888; }
.sticky-cta-btn { background:#EF4444; color:#fff!important; font-size:12px; font-weight:700; padding:8px 18px; border-radius:5px; text-decoration:none; white-space:nowrap; flex-shrink:0; transition:background .15s; }
.sticky-cta-btn:hover { background:#DC2626; }
.sticky-cta-close { width:28px; height:28px; display:flex; align-items:center; justify-content:center; color:#888; flex-shrink:0; transition:color .15s; border-radius:4px; }
.sticky-cta-close:hover { color:#fff; background:#1e1e1e; }
html:not(.dark-mode) .sticky-cta-inner { background:#fff; border-color:rgba(239,68,68,.3); }
html:not(.dark-mode) .sticky-cta-text strong { color:#111; }

/* ══ Share copied toast ══ */
.share-toast { position:fixed; bottom:80px; left:50%; transform:translateX(-50%) translateY(20px); background:#111; color:#fff; font-size:12px; font-weight:600; padding:8px 18px; border-radius:20px; opacity:0; pointer-events:none; transition:opacity .2s, transform .2s; z-index:500; border:1px solid #333; }
.share-toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* ══ Keyboard hint ══ */
.lb-kb-hint { position:fixed; bottom:80px; left:50%; transform:translateX(-50%); display:flex; gap:16px; opacity:0; pointer-events:none; transition:opacity .5s; z-index:11; }
.lb-kb-hint.show { opacity:1; }
.lb-kb-hint span { display:flex; align-items:center; gap:5px; font-size:11px; color:rgba(255,255,255,.6); }
.lb-kb-hint kbd { background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2); border-radius:3px; padding:2px 6px; font-size:10px; font-family:inherit; color:rgba(255,255,255,.8); }

/* Light theme fixes */
html:not(.dark-mode) .gal-more-model { border-color:#e5e5e5; }
html:not(.dark-mode) .gal-prev-next { border-color:#e5e5e5; }
html:not(.dark-mode) .gpn-btn { border-color:#e0e0e0; }
html:not(.dark-mode) .gpn-btn:hover { border-color:#EF4444; background:#f9f9f9; }

/* ── New elements: light theme fixes ── */

/* More from model */
html:not(.dark-mode) .gal-more-model { background: #fff; }
html:not(.dark-mode) .gmm-title { color: #111; }
html:not(.dark-mode) .gmm-all { color: #888; }
html:not(.dark-mode) .gmm-all:hover { color: #EF4444; }

/* Prev/Next */
html:not(.dark-mode) .gal-prev-next { background: #fff; }
html:not(.dark-mode) .gpn-btn { color: #111; background: #fff; border-color: #e0e0e0; }
html:not(.dark-mode) .gpn-btn:hover { border-color: #EF4444; background: #f9f9f9; }
html:not(.dark-mode) .gpn-label { color: #999; }
html:not(.dark-mode) .gpn-title { color: #111; }

/* Sticky CTA */
html:not(.dark-mode) .sticky-cta-inner { background: #fff; border-color: rgba(239,68,68,.3); box-shadow: 0 -2px 12px rgba(0,0,0,.08); }
html:not(.dark-mode) .sticky-cta-text strong { color: #111; }
html:not(.dark-mode) .sticky-cta-text span { color: #888; }
html:not(.dark-mode) .sticky-cta-close { color: #999; }
html:not(.dark-mode) .sticky-cta-close:hover { color: #111; background: #f0f0f0; }

/* Share toast */
html:not(.dark-mode) .share-toast { background: #111; color: #fff; border-color: #333; }

/* Keyboard hint — always dark (in lightbox) */
.lb-kb-hint { /* already dark, regardless of theme */ }

/* ── Dark theme fixes for new elements ── */

/* More from model */
html.dark-mode .gal-more-model { background: #111; border-color: #222; }
html.dark-mode .gmm-title { color: #ddd; }
html.dark-mode .gmm-title span { color: #EF4444; }
html.dark-mode .gmm-all { color: #555; }
html.dark-mode .gmm-all:hover { color: #EF4444; }
html.dark-mode .gmm-card { border: 1.5px solid #333; }
html.dark-mode .gmm-card:hover { border-color: #EF4444; }

/* Prev/Next */
html.dark-mode .gal-prev-next { background: #0d0d0d; border-color: #222; }
html.dark-mode .gpn-btn { color: #bbb; background: #161616; border: 1.5px solid #2a2a2a; }
html.dark-mode .gpn-btn:hover { border-color: #EF4444; background: #1c1c1c; }
html.dark-mode .gpn-label { color: #555; }
html.dark-mode .gpn-title { color: #ccc; }
html.dark-mode .gpn-btn:hover .gpn-label { color: #EF4444; }
html.dark-mode .gpn-btn:hover .gpn-title { color: #fff; }
html.dark-mode .gpn-btn:hover svg { color: #EF4444 !important; opacity: 1; }



/* ── gmm scroll arrows (desktop only) ── */
.gmm-scroll-wrap { position: relative; display: flex; align-items: center; gap: 8px; }
.gmm-arrow {
  display: none;
  flex-shrink: 0;
  width: 34px;
  height: 34px;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1.5px solid var(--border);
  border-radius: 50%;
  color: var(--text-dim);
  cursor: pointer;
  transition: all .15s;
  opacity: 1;
  z-index: 2;
}
.gmm-arrow:hover {
  background: var(--red);
  border-color: var(--red);
  color: #fff;
  transform: scale(1.08);
}
.gmm-arrow.hidden { opacity: 0; pointer-events: none; }

/* Scroll indicator for mobile */
.gmm-scroll-hint {
  display: none;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  color: var(--text-dim);
  margin-top: 6px;
  letter-spacing: .02em;
}
.gmm-scroll-hint-dots {
  display: flex;
  gap: 3px;
}
.gmm-scroll-hint-dots span {
  width: 18px;
  height: 3px;
  border-radius: 2px;
  background: var(--border);
}
.gmm-scroll-hint-dots span:first-child {
  background: var(--red);
  width: 28px;
}

@media(min-width:901px) {
  .gmm-arrow { display: flex; }
  .gmm-scroll { flex: 1; }
  .gmm-scroll-hint { display: none !important; }
}
@media(max-width:900px) {
  .gmm-scroll-hint { display: flex; }
}

/* Light theme */
html:not(.dark-mode) .gmm-arrow { border-color: #ddd; color: #aaa; }
html:not(.dark-mode) .gmm-arrow:hover { background: #EF4444; border-color: #EF4444; color: #fff; }

/* ── Header: scrolls with content on desktop ── */

/* ── Force white text on red buttons in light mode ── */
html:not(.dark-mode) .rev-cta-btn,
html:not(.dark-mode) .rev-cta-btn:hover,
html:not(.dark-mode) .model-more-btn,
html:not(.dark-mode) .model-more-btn:hover,
html:not(.dark-mode) .btn-join,
html:not(.dark-mode) .btn-join:hover,
html:not(.dark-mode) .btn-join-v5,
html:not(.dark-mode) a.rev-cta-btn,
html:not(.dark-mode) a.model-more-btn,
html:not(.dark-mode) a.btn-join { color: #fff !important; }

/* ── btn-join-v5 fix light mode ── */
html:not(.dark-mode) .btn-join-v5 {
  color: #EF4444 !important;
  background: transparent !important;
  border-color: #EF4444 !important;
}
html:not(.dark-mode) .btn-join-v5:hover {
  background: #EF4444 !important;
  color: #fff !important;
}

/* ===== LIGHT THEME OVERRIDE ===== */
:root {
  --accent: #EF4444;
  --accent-d: #DC2626;
  --bg: #ffffff;
  --bg2: #f8f8f8;
  --bg3: #f0f0f0;
  --border: #e5e5e5;
  --text: #111111;
  --text-dim: #888888;
  --shadow: 0 1px 3px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.1);
}

/* Scrollbar */
html { scrollbar-color: #ddd #f5f5f5; }

/* MomLover link style */
a { color: #000 !important; }
a:hover { color: #888; }
.nav-active, .nav-active a { color: #fff !important; }
.gc-model a, .gc-model { color: #fff !important; }

/* Body */
body {
  background: var(--bg) !important;
  color: #212529 !important;
}

/* Header */
.site-header {
  background: #fff !important;
  border-bottom: 1px solid var(--border) !important;
  box-shadow: var(--shadow) !important;
}

/* Logo — pill shape, bold wordmark */
.logo-link { margin: 0 16px 0 4px !important; align-items: center !important; }
.logo-text { justify-content: center !important; }
.logo-text-top { line-height: 1 !important; }
.logo-text-bot { line-height: 1 !important; margin-top: 3px !important; }
.main-nav { align-items: center !important; }
.main-nav a { align-items: center !important; line-height: 1.2 !important; }
.logo-mark {
  background: transparent !important;
  border-radius: 0 !important;
  width: auto !important; height: auto !important;
}
.logo-text-top {
  font-size: 20px !important;
  font-weight: 700 !important;
  color: #111 !important;
  letter-spacing: -0.03em !important;
}
.logo-text-top span { color: var(--accent) !important; }
.logo-text-bot {
  font-size: 8px !important;
  color: #bbb !important;
  letter-spacing: 0.2em !important;
}

/* Nav */
.sb-toggle { color: #555 !important; }
.sb-toggle:hover { background: #f3f3f3 !important; color: #111 !important; }
.sb-toggle.active { color: var(--accent) !important; }

.main-nav a {
  color: #111 !important;
  font-size: 14.5px !important;
  font-weight: 500 !important;
  padding: 5px 10px !important;
  border-radius: 3px !important;
  transition: background .15s, color .15s !important;
}
.main-nav a:hover { background: #EF4444 !important; color: #fff !important; }
.nav-active {
  background: #EF4444 !important;
  color: #fff !important;
  border-radius: 3px !important;
}
.nav-active:hover { background: #DC2626 !important; }
.nav-red { color: #EF4444 !important; }
.nav-red:hover { background: #EF4444 !important; color: #fff !important; }
.nav-discount { background: var(--red) !important; color: #ffffff !important; border: none !important; }
@keyframes pulse-border {
  0%,100%{border-color:rgba(239,68,68,.3)}
  50%{border-color:rgba(239,68,68,.85)}
}

/* Header icons */
.hicon { color: #888 !important; }
.hicon:hover { background: #f3f3f3 !important; color: #111 !important; }
.hicon.active { color: var(--accent) !important; }
.history-dot { background: var(--accent) !important; border-color: #fff !important; box-shadow: 0 0 6px rgba(239,68,68,.5) !important; }

/* Search */
.header-search form {
  background: #fff !important;
  border-color: #ddd !important;
}
.header-search form:focus-within { border-color: var(--accent) !important; }
.header-search-icon { color: #aaa !important; }
.header-search input { color: #111 !important; }
.header-search input::placeholder { color: #bbb !important; }
.header-search-submit {
  background: #fff !important;
  border-color: #ddd !important;
  color: #aaa !important;
}
.header-search-submit:hover { background: var(--accent) !important; border-color: var(--accent) !important; color: #fff !important; }

/* Search drop */
.search-drop { background: #fff !important; border-color: var(--border) !important; }
.search-drop input { background: #f5f5f5 !important; border-color: #e0e0e0 !important; color: #111 !important; }
.search-drop input:focus { border-color: var(--accent) !important; }
.search-drop button[type=submit] { background: var(--accent) !important; }
.search-drop button[type=submit]:hover { background: var(--accent-d) !important; }

/* History drop */
.history-drop { background: #fff !important; border-color: var(--border) !important; box-shadow: -4px 8px 24px rgba(0,0,0,0.12) !important; }
.history-drop-head { border-color: var(--border) !important; color: #999 !important; }
.history-clear-btn { color: #bbb !important; }
.history-clear-btn:hover { color: var(--accent) !important; }
.history-drop-list::-webkit-scrollbar-thumb { background: #ddd !important; }
.history-drop-item:hover { background: #f5f5f5 !important; }
.history-drop-thumb { background: #eee !important; }
.history-drop-model { color: var(--accent) !important; }
.history-drop-title { color: #333 !important; }
.history-drop-empty { color: #bbb !important; }
.history-drop-foot { border-color: var(--border) !important; }
.history-close-btn { background: #f3f3f3 !important; color: #888 !important; }
.history-close-btn:hover { background: #eaeaea !important; color: #111 !important; }

/* Link bar */
.link-bar { background: #fafafa !important; border-color: var(--border) !important; }
.link-bar a {
  color: #555 !important;
  background: #fff !important;
  border-color: #e5e5e5 !important;
  border-radius: 20px !important;
}
.link-bar a:hover { background: #f3f3f3 !important; color: #111 !important; border-color: #ccc !important; }

/* Sidebars */
.sidebar { background: #fafafa !important; border-color: var(--border) !important; scrollbar-color: #ddd transparent !important; }
.sidebar.right { border-color: var(--border) !important; }

.sb-title { color: #bbb !important; border-color: var(--border) !important; }

.sb-nav a { color: #555 !important; }
.sb-nav a:hover { background: #f0f0f0 !important; color: #111 !important; }
.sb-nav a.active { background: #fff0f0 !important; color: var(--accent) !important; }
.sb-nav .icon { opacity: .4 !important; }
.sb-nav a:hover .icon { opacity: .8 !important; }
.sb-nav a.active .icon { opacity: 1 !important; stroke: var(--accent) !important; }
.sb-nav .count { color: #bbb !important; }

.sb-model { border-color: #efefef !important; }
.sb-model { padding: 6px 16px !important; margin: 0 !important; transition: background .12s !important; cursor: pointer !important; }
.sb-model:hover { background: #f7f7f7 !important; color: #000 !important; border-color: transparent !important; }
.sb-model-rank { color: #ccc !important; }
.sb-model-name { color: #666 !important; }
.sb-model:hover .sb-model-name { color: #111 !important; }
.sb-model-cnt { color: #bbb !important; }

.sb-tags a { background: #f3f3f3 !important; border-color: #e5e5e5 !important; color: #888 !important; }
.sb-tags a:hover, .sb-tags a.active { border-color: var(--accent) !important; color: var(--accent) !important; background: #fff0f0 !important; }

.sb-check { color: #888 !important; }
.sb-check:hover { color: #555 !important; }
.sb-check input[type=checkbox] { accent-color: var(--accent) !important; }
.sb-check span:last-child { color: #bbb !important; }

.sb-empty { color: #bbb !important; }
.sb-hist-item { color: #aaa !important; }
.sb-hist-item:hover { background: #f0f0f0 !important; color: #555 !important; }
.sb-hist-thumb { background: #eee !important; }

.sb-banner { background: linear-gradient(135deg,#fff0f0,#fff) !important; border-color: rgba(239,68,68,0.2) !important; }
.sb-banner p { color: #777 !important; }
.sb-banner strong { color: var(--accent) !important; }
.sb-banner a { background: var(--accent) !important; }
.sb-banner a:hover { background: var(--accent-d) !important; }

.sb-friends li a { color: #777 !important; }
.sb-friends li a:hover { background: #f0f0f0 !important; color: #111 !important; }

.sb-all-models { color: #aaa !important; border-color: #e5e5e5 !important; }
.sb-all-models:hover { background: #f3f3f3 !important; color: #333 !important; border-color: #ccc !important; }

/* Gallery heading */
.gallery-heading { border-color: var(--border) !important; }
.gallery-heading h2 { color: #111 !important; }
.gallery-heading h2 span { color: var(--accent) !important; }

/* Intro / toolbar */
.intro { border-color: var(--border) !important; }
.intro-title { color: #111 !important; }
.intro-sub { color: #aaa !important; }

.sort-drop-btn { color: #555 !important; background: #f5f5f5 !important; border-color: #e0e0e0 !important; font-family: 'Open Sans', sans-serif !important; height: 32px !important; padding: 0 10px !important; box-sizing: border-box !important; }
.sort-drop-btn:hover { background: #ececec !important; color: #111 !important; border-color: #ccc !important; }
.sort-drop-btn.open { color: var(--accent) !important; border-color: var(--accent) !important; background: #fff0f0 !important; }
.sort-drop-menu { background: #fff !important; border-color: var(--border) !important; box-shadow: 0 8px 24px rgba(0,0,0,0.1) !important; }
.sort-opt { color: #777 !important; font-family: 'Open Sans', sans-serif !important; }
.sort-opt:hover { background: #f5f5f5 !important; color: #111 !important; }
.sort-opt.active { color: var(--accent) !important; background: #fff0f0 !important; }

.random-btn { color: #EF4444 !important; border: 2px solid #EF4444 !important; background: #fff !important; width: 32px !important; height: 32px !important; min-width: 32px !important; min-height: 32px !important; box-sizing: border-box !important; padding: 0 !important; border-radius: 6px !important; flex-shrink: 0 !important; }
.random-btn:hover { background: #EF4444 !important; color: #fff !important; }
.random-btn svg { stroke: currentColor !important; }
.col-toggle-tb { color: #bbb !important; border-color: #e5e5e5 !important; }
.col-toggle-tb:hover { background: #f3f3f3 !important; color: #555 !important; }
.col-toggle-tb.active { color: var(--accent) !important; border-color: var(--accent) !important; }

/* Site desc */
.site-desc { background: #fff !important; border-color: var(--border) !important; }
.site-desc p { color: #888 !important; }
.site-desc p strong { color: var(--accent) !important; }

/* Gallery cards — rounded */
#gallery-grid { column-gap: 3px !important; }
#gallery-grid .gallery-card { margin-bottom: 3px !important; }
#gallery-grid .gallery-card-inner {
  border-radius: 0 !important;
  overflow: hidden !important;
  background: #eee !important;
  box-shadow: none !important;
  transition: box-shadow .2s, transform .2s !important;
}
.gallery-card:hover .gallery-card-inner {
  box-shadow: 0 6px 20px rgba(0,0,0,0.14) !important;
}

/* Card overlay — lighter gradient on light bg */
.gc-info { background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, transparent 80%) !important; }
.gc-model { background: var(--accent) !important; border-radius: 6px !important; }
.gc-save {
  background: rgba(255,255,255,0.9) !important;
  border-color: rgba(0,0,0,0.1) !important;
  color: #555 !important;
  border-radius: 8px !important;
}
.gc-save:hover { background: var(--accent) !important; border-color: var(--accent) !important; color: #fff !important; }
.gc-save.saved { background: var(--accent) !important; border-color: var(--accent) !important; color: #fff !important; }

/* Banner card */
.gallery-card.banner-card .gallery-card-inner { background: #f3f3f3 !important; }
.banner-label { color: #555 !important; background: rgba(255,255,255,0.85) !important; border-color: rgba(0,0,0,0.1) !important; }

/* Ad card */
.gallery-card.ad-script-card .gallery-card-inner { background: #f5f5f5 !important; }

/* Pagination */
.pagination { display: flex; gap: 4px; justify-content: center; padding: 28px 0 16px; clear: both; }
.pagination a, .pagination span { font-size: 13px; font-weight: 600; width: 34px; height: 34px; display: flex; align-items: center; justify-content: center; border: 1px solid #ccc; color: #333; border-radius: 3px; transition: all .15s; background: #fff; }
.pagination a:hover { border-color: #EF4444; color: #EF4444; background: #fff; }
.pg-active { background: #EF4444 !important; color: #fff !important; border-color: #EF4444 !important; }
.pg-dots { border: none !important; color: #999 !important; background: transparent !important; font-weight: 400 !important; }

/* Footer */
.site-footer { border-color: var(--border) !important; }
.footer-banner { background: #fafafa !important; border-color: var(--border) !important; }
.footer-banner h2 { color: #111 !important; }
.footer-banner h2 strong { color: var(--accent) !important; }
.footer-banner p { color: #888 !important; }
.btn-join { background: var(--accent) !important; }
.btn-join:hover { background: var(--accent-d) !important; }
.footer-nav a { color: #bbb !important; }
.footer-nav a:hover { color: var(--accent) !important; }
.footer-copy { color: #555 !important; font-size: 12px !important; }
.footer-logo .logo-text-top { color: #111 !important; }
/* ===== CTA BANNER VARIANTS (cta-v1 ... cta-v10) =====
   Usage: <a href="#" class="cta-banner cta-v1">...</a>
   Inner structure depends on variant — see examples in right sidebar
   Works in any sidebar: left, right, any container
*/

/* Base container */
.cta-banner {
  display: block;
  text-decoration: none;
  margin: 0 2px 10px;
  border-radius: 8px;
  transition: opacity .2s, border-color .2s, box-shadow .2s;
  font-family: 'Open Sans', sans-serif;
}

/* V1: Red gradient */
.cta-v1 { background: linear-gradient(135deg, #EF4444, #c0392b); padding: 16px; }
.cta-v1:hover { opacity: .88; }
.cta-v1 .cta-label { font-size: 10px; font-weight: 700; letter-spacing: .1em; color: rgba(255,255,255,.7); text-transform: uppercase; margin-bottom: 6px; }
.cta-v1 .cta-title { font-size: 16px; font-weight: 700; color: #fff; line-height: 1.2; margin-bottom: 10px; }
.cta-v1 .cta-btn { background: #fff; color: #EF4444; font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: 7px; border-radius: 4px; text-align: center; }

/* V2: White with red left border */
.cta-v2 { background: #fff; border: 1px solid #e5e5e5; border-left: 4px solid #EF4444; padding: 14px; }
.cta-v2:hover { box-shadow: 0 2px 12px rgba(239,68,68,.15); border-color: #EF4444; }
.cta-v2 .cta-title { font-size: 15px; font-weight: 700; color: #111; margin-bottom: 4px; }
.cta-v2 .cta-sub { font-size: 12px; color: #888; margin-bottom: 10px; line-height: 1.4; }
.cta-v2 .cta-link { color: #EF4444; font-size: 12px; font-weight: 700; }

/* V3: Dark minimal */
.cta-v3 { background: #111; border: 1px solid #2a2a2a; padding: 16px; }
.cta-v3:hover { border-color: #EF4444; }
.cta-v3 .cta-label { font-size: 11px; color: #EF4444; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 8px; }
.cta-v3 .cta-title { font-size: 14px; color: #fff; font-weight: 600; line-height: 1.3; margin-bottom: 10px; }
.cta-v3 .cta-btn { background: #EF4444; color: #fff; font-size: 11px; font-weight: 700; padding: 7px; border-radius: 4px; text-align: center; letter-spacing: .05em; }

/* V4: Stats 2 columns + button */
.cta-v4 { background: #fff; border: 1px solid #ebebeb; padding: 14px; }
.cta-v4:hover { border-color: #EF4444; }
.cta-v4 .cta-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 12px; }
.cta-v4 .cta-stat { text-align: center; }
.cta-v4 .cta-stat-num { font-size: 18px; font-weight: 700; color: #EF4444; }
.cta-v4 .cta-stat-lbl { font-size: 10px; color: #aaa; }
.cta-v4 .cta-btn { background: #EF4444; color: #fff; font-size: 11px; font-weight: 700; padding: 8px; border-radius: 4px; text-align: center; letter-spacing: .06em; text-transform: uppercase; }

/* V5: Badge + text */
.cta-v5 { background: #fff; border: 1px solid #ebebeb; overflow: hidden; padding: 0; }
.cta-v5:hover { border-color: #EF4444; }
.cta-v5 .cta-head { background: #EF4444; padding: 8px 14px; display: flex; align-items: center; justify-content: space-between; }
.cta-v5 .cta-head-label { font-size: 11px; font-weight: 700; color: #fff; letter-spacing: .06em; text-transform: uppercase; }
.cta-v5 .cta-head-pct { font-size: 18px; font-weight: 900; color: #fff; }
.cta-v5 .cta-body { padding: 12px 14px; }
.cta-v5 .cta-title { font-size: 13px; font-weight: 600; color: #111; margin-bottom: 4px; }
.cta-v5 .cta-sub { font-size: 11px; color: #999; margin-bottom: 10px; }
.cta-v5 .cta-link { color: #EF4444; font-size: 12px; font-weight: 700; }

/* V6: Heart */
.cta-v6 { background: #fff5f5; border: 1px solid #ffd5d5; padding: 16px; text-align: center; }
.cta-v6:hover { border-color: #EF4444; }
.cta-v6 .cta-icon { font-size: 24px; margin-bottom: 6px; }
.cta-v6 .cta-title { font-size: 13px; font-weight: 700; color: #111; margin-bottom: 4px; }
.cta-v6 .cta-sub { font-size: 11px; color: #888; margin-bottom: 10px; }
.cta-v6 .cta-btn { background: #EF4444; color: #fff; font-size: 11px; font-weight: 700; padding: 7px; border-radius: 4px; letter-spacing: .05em; text-transform: uppercase; }

/* V7: Horizontal with icon */
.cta-v7 { background: #fff; border: 1px solid #ebebeb; padding: 12px; display: flex; align-items: center; gap: 10px; }
.cta-v7:hover { border-color: #EF4444; }
.cta-v7 .cta-icon-box { width: 36px; height: 36px; background: #EF4444; border-radius: 6px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cta-v7 .cta-title { font-size: 12px; font-weight: 700; color: #111; }
.cta-v7 .cta-link { font-size: 11px; color: #EF4444; font-weight: 600; }

/* V8: Black with yellow badge */
.cta-v8 { background: #111; padding: 16px; position: relative; overflow: hidden; }
.cta-v8:hover { opacity: .88; }
.cta-v8 .cta-badge { position: absolute; top: 10px; right: -8px; background: #FFD600; color: #111; font-size: 10px; font-weight: 900; padding: 3px 16px 3px 8px; letter-spacing: .04em; }
.cta-v8 .cta-title { font-size: 14px; font-weight: 700; color: #fff; margin-bottom: 4px; margin-top: 4px; }
.cta-v8 .cta-sub { font-size: 11px; color: #888; margin-bottom: 12px; }
.cta-v8 .cta-btn { background: #EF4444; color: #fff; font-size: 11px; font-weight: 700; padding: 7px; border-radius: 4px; text-align: center; letter-spacing: .06em; text-transform: uppercase; }

/* V9: Link row */
.cta-v9 { border-top: 1px solid #ebebeb; border-bottom: 1px solid #ebebeb; border-radius: 0; padding: 12px 4px; display: flex; align-items: center; justify-content: space-between; }
.cta-v9:hover { background: #fff5f5; }
.cta-v9 .cta-title { font-size: 12px; font-weight: 700; color: #111; }
.cta-v9 .cta-link { font-size: 11px; color: #EF4444; font-weight: 600; }

/* V10: Timer */
.cta-v10 { background: #fff; border: 1px solid #ebebeb; padding: 14px; }
.cta-v10:hover { border-color: #EF4444; }
.cta-v10 .cta-label { font-size: 10px; font-weight: 700; letter-spacing: .1em; color: #EF4444; text-transform: uppercase; margin-bottom: 6px; }
.cta-v10 .cta-timer { display: flex; gap: 4px; margin-bottom: 10px; }
.cta-v10 .cta-timer-cell { text-align: center; background: #f5f5f5; border-radius: 4px; padding: 4px 6px; flex: 1; }
.cta-v10 .cta-timer-num { font-size: 16px; font-weight: 700; color: #111; }
.cta-v10 .cta-timer-lbl { font-size: 9px; color: #aaa; }
.cta-v10 .cta-btn { background: #EF4444; color: #fff; font-size: 11px; font-weight: 700; padding: 7px; border-radius: 4px; text-align: center; letter-spacing: .06em; text-transform: uppercase; }


/* Scroll up */
.scroll-up { background: #fff !important; border-color: #e5e5e5 !important; color: #bbb !important; box-shadow: var(--shadow-md) !important; }
.scroll-up.visible { opacity: 1 !important; pointer-events: all !important; }
.scroll-up:hover { border-color: var(--accent) !important; color: var(--accent) !important; }

/* Mobile nav */
.hamburger span { background: #888 !important; }
.hamburger.active span { background: var(--accent) !important; }
.mobile-nav { background: #fff !important; }
.mobile-nav > a { color: #555 !important; border-color: var(--border) !important; }
.mobile-nav > a:hover { color: #111 !important; background: #f5f5f5 !important; }
.mobile-nav-history-head { color: #bbb !important; border-color: var(--border) !important; }
.mobile-nav-hist-item:hover { background: #f5f5f5 !important; }
.mobile-nav-hist-thumb { background: #eee !important; }
.mobile-nav-hist-model { color: var(--accent) !important; }
.mobile-nav-hist-title { color: #777 !important; }
.mobile-nav-hist-empty { color: #bbb !important; }
.mob-section { border-color: var(--border) !important; }
.mob-section-head { color: #bbb !important; font-family: 'Open Sans', sans-serif !important; }
.mob-section-head:hover { color: #888 !important; }
.mob-section-body ul li a { color: #777 !important; border-color: var(--border) !important; }
.mob-section-body ul li a:hover { color: #111 !important; background: #f5f5f5 !important; }
.mobile-nav-link { color: #777 !important; border-color: var(--border) !important; }
.mobile-nav-link:hover { color: #111 !important; background: #f5f5f5 !important; }
.mobile-nav-link.mobile-discount { color: #EF4444 !important; background: rgba(239,68,68,0.08) !important; border-left: 3px solid #EF4444 !important; font-weight: 700 !important; }
.mobile-nav-link.mobile-discount:hover { background: rgba(239,68,68,0.15) !important; }

/* Mobile sidebar */
.sidebar.right { border-color: var(--border) !important; box-shadow: -8px 0 24px rgba(0,0,0,0.1) !important; }
.sb-right-overlay { background: rgba(0,0,0,0.2) !important; }

/* Fix dark hardcoded colors */
.history-drop-list::-webkit-scrollbar-thumb { background: #ddd !important; }

/* ===== SIDEBAR MOMLOVER STYLE ===== */
.sidebar { background: #fff !important; border-color: #e0e0e0 !important; overflow-y: auto !important; max-height: calc(100vh - var(--header-h)) !important; }
.sidebar-inner { padding: 0 !important; width: 100% !important; }
.sb-section { margin-bottom: 0 !important; border-bottom: 1px solid #ebebeb !important; }
.sb-title { font-size: 11px !important; font-weight: 600 !important; letter-spacing: 0.06em !important; text-transform: uppercase !important; color: #aaa !important; padding: 12px 16px 6px !important; border-bottom: none !important; margin-bottom: 0 !important; }
.sb-nav { gap: 0 !important; }
.sb-nav a { padding: 10px 16px !important; font-size: 14px !important; font-weight: 400 !important; color: #212529 !important; border-radius: 0 !important; border-bottom: 1px solid #f2f2f2 !important; background: transparent !important; }
.sb-nav a:hover { background: #f7f7f7 !important; color: #000 !important; }
.sb-nav a.active { background: #EF4444 !important; color: #fff !important; font-weight: 600 !important; border-bottom-color: #EF4444 !important; }
.sb-nav a.active .icon { opacity: 1 !important; stroke: #fff !important; }
.sb-nav .icon { opacity: 0.3 !important; }
.sb-nav .count { color: #ccc !important; font-size: 11px !important; }
.sb-models { padding: 4px 0 !important; }
.sb-model { border-color: #f0f0f0 !important; padding: 7px 16px !important; }
.sb-model-rank { color: #ccc !important; }
.sb-model-name { color: #212529 !important; font-size: 13px !important; }
.sb-model { cursor: pointer !important; transition: background .12s !important; }
.sb-model:hover { background: #f7f7f7 !important; color: #000 !important; border-color: transparent !important; }
.sb-model:hover .sb-model-name { color: #000 !important; font-weight: 600 !important; }
.sb-model:hover .sb-model-rank { color: #EF4444 !important; }
.sb-model-cnt { color: #bbb !important; }
.sb-all-models { color: #888 !important; border-color: #e0e0e0 !important; margin: 8px 12px !important; width: calc(100% - 24px) !important; border-radius: 4px !important; font-size: 12px !important; }
.sb-all-models:hover { background: #f5f5f5 !important; color: #333 !important; border-color: #ccc !important; }
.sb-tags { padding: 6px 12px 12px !important; }
.sb-tags a { background: #f5f5f5 !important; border-color: #e5e5e5 !important; color: #555 !important; }
.sb-tags a:hover, .sb-tags a.active { border-color: #EF4444 !important; color: #EF4444 !important; background: #fff0f0 !important; }
.sb-filters { padding: 6px 16px 12px !important; }
.sb-check { color: #555 !important; }
.sb-check:hover { color: #111 !important; }
.sb-empty { color: #bbb !important; padding: 6px 16px !important; }
.sb-hist-item { padding: 6px 16px !important; color: #777 !important; }
.sb-hist-item:hover { background: #f5f5f5 !important; color: #333 !important; }
.sb-hist-thumb { background: #eee !important; }
.sb-hist-name { color: #555 !important; }
.sb-banner { background: #fff0f0 !important; border-color: rgba(239,68,68,0.2) !important; margin: 10px !important; }
.sb-banner p { color: #777 !important; }
.sb-banner strong { color: #EF4444 !important; }
.sb-friends li a { color: #555 !important; border-radius: 0 !important; padding: 9px 16px !important; border-bottom: 1px solid #f2f2f2 !important; }
.sb-friends li a:hover { background: #f7f7f7 !important; color: #111 !important; }
.gallery-heading { background: #fff !important; border-color: #e5e5e5 !important; }
.gallery-heading h2 { color: #111 !important; }
.gallery-heading h2 span { color: #EF4444 !important; }
.sidebar.right { background: #fff !important; border-color: #e0e0e0 !important; box-shadow: -4px 0 16px rgba(0,0,0,0.08) !important; }

/* Footer bottom — crisp text */
.footer-bottom { border-top: 1px solid #e5e5e5 !important; padding: 20px !important; }
.footer-nav a { color: #333 !important; font-size: 12px !important; font-weight: 500 !important; letter-spacing: .05em !important; }
.footer-nav a:hover { color: #EF4444 !important; }
.footer-copy { color: #555 !important; font-size: 12px !important; }
.footer-logo .logo-text-top { color: #111 !important; }
/* ===== CTA BANNER VARIANTS (cta-v1 ... cta-v10) =====
   Usage: <a href="#" class="cta-banner cta-v1">...</a>
   Inner structure depends on variant — see examples in right sidebar
   Works in any sidebar: left, right, any container
*/

/* Base container */
.cta-banner {
  display: block;
  text-decoration: none;
  margin: 0 2px 10px;
  border-radius: 8px;
  transition: opacity .2s, border-color .2s, box-shadow .2s;
  font-family: 'Open Sans', sans-serif;
}

/* V1: Red gradient */
.cta-v1 { background: linear-gradient(135deg, #EF4444, #c0392b); padding: 16px; }
.cta-v1:hover { opacity: .88; }
.cta-v1 .cta-label { font-size: 10px; font-weight: 700; letter-spacing: .1em; color: rgba(255,255,255,.7); text-transform: uppercase; margin-bottom: 6px; }
.cta-v1 .cta-title { font-size: 16px; font-weight: 700; color: #fff; line-height: 1.2; margin-bottom: 10px; }
.cta-v1 .cta-btn { background: #fff; color: #EF4444; font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: 7px; border-radius: 4px; text-align: center; }

/* V2: White with red left border */
.cta-v2 { background: #fff; border: 1px solid #e5e5e5; border-left: 4px solid #EF4444; padding: 14px; }
.cta-v2:hover { box-shadow: 0 2px 12px rgba(239,68,68,.15); border-color: #EF4444; }
.cta-v2 .cta-title { font-size: 15px; font-weight: 700; color: #111; margin-bottom: 4px; }
.cta-v2 .cta-sub { font-size: 12px; color: #888; margin-bottom: 10px; line-height: 1.4; }
.cta-v2 .cta-link { color: #EF4444; font-size: 12px; font-weight: 700; }

/* V3: Dark minimal */
.cta-v3 { background: #111; border: 1px solid #2a2a2a; padding: 16px; }
.cta-v3:hover { border-color: #EF4444; }
.cta-v3 .cta-label { font-size: 11px; color: #EF4444; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 8px; }
.cta-v3 .cta-title { font-size: 14px; color: #fff; font-weight: 600; line-height: 1.3; margin-bottom: 10px; }
.cta-v3 .cta-btn { background: #EF4444; color: #fff; font-size: 11px; font-weight: 700; padding: 7px; border-radius: 4px; text-align: center; letter-spacing: .05em; }

/* V4: Stats 2 columns + button */
.cta-v4 { background: #fff; border: 1px solid #ebebeb; padding: 14px; }
.cta-v4:hover { border-color: #EF4444; }
.cta-v4 .cta-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 12px; }
.cta-v4 .cta-stat { text-align: center; }
.cta-v4 .cta-stat-num { font-size: 18px; font-weight: 700; color: #EF4444; }
.cta-v4 .cta-stat-lbl { font-size: 10px; color: #aaa; }
.cta-v4 .cta-btn { background: #EF4444; color: #fff; font-size: 11px; font-weight: 700; padding: 8px; border-radius: 4px; text-align: center; letter-spacing: .06em; text-transform: uppercase; }

/* V5: Badge + text */
.cta-v5 { background: #fff; border: 1px solid #ebebeb; overflow: hidden; padding: 0; }
.cta-v5:hover { border-color: #EF4444; }
.cta-v5 .cta-head { background: #EF4444; padding: 8px 14px; display: flex; align-items: center; justify-content: space-between; }
.cta-v5 .cta-head-label { font-size: 11px; font-weight: 700; color: #fff; letter-spacing: .06em; text-transform: uppercase; }
.cta-v5 .cta-head-pct { font-size: 18px; font-weight: 900; color: #fff; }
.cta-v5 .cta-body { padding: 12px 14px; }
.cta-v5 .cta-title { font-size: 13px; font-weight: 600; color: #111; margin-bottom: 4px; }
.cta-v5 .cta-sub { font-size: 11px; color: #999; margin-bottom: 10px; }
.cta-v5 .cta-link { color: #EF4444; font-size: 12px; font-weight: 700; }

/* V6: Heart */
.cta-v6 { background: #fff5f5; border: 1px solid #ffd5d5; padding: 16px; text-align: center; }
.cta-v6:hover { border-color: #EF4444; }
.cta-v6 .cta-icon { font-size: 24px; margin-bottom: 6px; }
.cta-v6 .cta-title { font-size: 13px; font-weight: 700; color: #111; margin-bottom: 4px; }
.cta-v6 .cta-sub { font-size: 11px; color: #888; margin-bottom: 10px; }
.cta-v6 .cta-btn { background: #EF4444; color: #fff; font-size: 11px; font-weight: 700; padding: 7px; border-radius: 4px; letter-spacing: .05em; text-transform: uppercase; }

/* V7: Horizontal with icon */
.cta-v7 { background: #fff; border: 1px solid #ebebeb; padding: 12px; display: flex; align-items: center; gap: 10px; }
.cta-v7:hover { border-color: #EF4444; }
.cta-v7 .cta-icon-box { width: 36px; height: 36px; background: #EF4444; border-radius: 6px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cta-v7 .cta-title { font-size: 12px; font-weight: 700; color: #111; }
.cta-v7 .cta-link { font-size: 11px; color: #EF4444; font-weight: 600; }

/* V8: Black with yellow badge */
.cta-v8 { background: #111; padding: 16px; position: relative; overflow: hidden; }
.cta-v8:hover { opacity: .88; }
.cta-v8 .cta-badge { position: absolute; top: 10px; right: -8px; background: #FFD600; color: #111; font-size: 10px; font-weight: 900; padding: 3px 16px 3px 8px; letter-spacing: .04em; }
.cta-v8 .cta-title { font-size: 14px; font-weight: 700; color: #fff; margin-bottom: 4px; margin-top: 4px; }
.cta-v8 .cta-sub { font-size: 11px; color: #888; margin-bottom: 12px; }
.cta-v8 .cta-btn { background: #EF4444; color: #fff; font-size: 11px; font-weight: 700; padding: 7px; border-radius: 4px; text-align: center; letter-spacing: .06em; text-transform: uppercase; }

/* V9: Link row */
.cta-v9 { border-top: 1px solid #ebebeb; border-bottom: 1px solid #ebebeb; border-radius: 0; padding: 12px 4px; display: flex; align-items: center; justify-content: space-between; }
.cta-v9:hover { background: #fff5f5; }
.cta-v9 .cta-title { font-size: 12px; font-weight: 700; color: #111; }
.cta-v9 .cta-link { font-size: 11px; color: #EF4444; font-weight: 600; }

/* V10: Timer */
.cta-v10 { background: #fff; border: 1px solid #ebebeb; padding: 14px; }
.cta-v10:hover { border-color: #EF4444; }
.cta-v10 .cta-label { font-size: 10px; font-weight: 700; letter-spacing: .1em; color: #EF4444; text-transform: uppercase; margin-bottom: 6px; }
.cta-v10 .cta-timer { display: flex; gap: 4px; margin-bottom: 10px; }
.cta-v10 .cta-timer-cell { text-align: center; background: #f5f5f5; border-radius: 4px; padding: 4px 6px; flex: 1; }
.cta-v10 .cta-timer-num { font-size: 16px; font-weight: 700; color: #111; }
.cta-v10 .cta-timer-lbl { font-size: 9px; color: #aaa; }
.cta-v10 .cta-btn { background: #EF4444; color: #fff; font-size: 11px; font-weight: 700; padding: 7px; border-radius: 4px; text-align: center; letter-spacing: .06em; text-transform: uppercase; }


/* Theme toggle icon */

/* Mobile: restore original header height */
@media (max-width: 900px) {
  :root { --header-h: 58px !important; }
  .sb-toggle { width: 36px !important; height: 36px !important; }
  .hicon { width: 36px !important; height: 36px !important; }
  .logo-text-top { font-size: 20px !important; color: #111 !important; display: block !important; }
  .logo-text { display: flex !important; }
  .logo-link { flex: 1; min-width: 0; }
  /* Right sidebar — position and scroll fix */
  .sidebar.right {
    top: 58px;
    height: calc(100vh - 58px);
    overflow-y: auto !important;
    background: #fff !important;
  }
}

/* Join button V5 */
.btn-join-v5 {
  display: inline-block;
  background: transparent;
  color: #EF4444;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 12px 32px;
  border: 2px solid #EF4444;
  border-radius: 4px;
  text-decoration: none;
  transition: background .2s, color .2s;
}
.btn-join-v5:hover {
  background: #EF4444 !important;
  color: #fff !important;
}

/* ===== DARK MODE ===== */
html.dark-mode body { background: #0d0d0d !important; color: #eee !important; }
html.dark-mode .site-header { background: #111 !important; border-color: #222 !important; }
html.dark-mode .logo-text-top { color: #fff !important; }
html.dark-mode .logo-text-top span { color: #EF4444 !important; }
html.dark-mode .logo-text-bot { color: #888 !important; }
html.dark-mode .main-nav a:not(.nav-discount) { color: #bbb !important; }
html.dark-mode .main-nav a:hover { background: #EF4444 !important; color: #fff !important; }
html.dark-mode .sb-toggle { color: #bbb !important; }
html.dark-mode .sb-toggle:hover { background: #1e1e1e !important; color: #fff !important; }
html.dark-mode .hicon { color: #999 !important; }
html.dark-mode .hicon:hover { background: #1e1e1e !important; color: #fff !important; }
html.dark-mode .history-close-btn { background: #222 !important; color: #aaa !important; }
html.dark-mode .history-close-btn:hover { background: #2a2a2a !important; color: #fff !important; }
html.dark-mode .header-search form { background: #2a2a2a !important; border-color: #444 !important; }
html.dark-mode .header-search input { color: #fff !important; }
html.dark-mode .header-search input::placeholder { color: #999 !important; }
html.dark-mode .header-search-icon { color: #aaa !important; }
html.dark-mode .header-search-submit { background: #333 !important; border-color: #444 !important; color: #ccc !important; }
html.dark-mode .sidebar { background: #141414 !important; border-color: #252525 !important; overflow-y: auto !important; max-height: calc(100vh - var(--header-h)) !important; }
html.dark-mode .sb-title { color: #aaa !important; }
html.dark-mode .sb-nav a { color: #bbb !important; border-color: #1a1a1a !important; background: transparent !important; }
html.dark-mode .sb-nav a:hover { background: #1c1c1c !important; color: #fff !important; }
html.dark-mode .sb-nav a.active { background: #EF4444 !important; color: #fff !important; }
html.dark-mode .sb-section { border-color: #222 !important; }
html.dark-mode .sb-model { border-color: #1a1a1a !important; }
html.dark-mode .sb-model:hover { background: #1e1e1e !important; }
html.dark-mode .sb-model-name { color: #bbb !important; }
html.dark-mode .sb-model:hover .sb-model-name { color: #fff !important; }
html.dark-mode .sb-model-rank { color: #888 !important; }
html.dark-mode .sb-model-cnt { color: #999 !important; }
html.dark-mode .sb-tags a { background: #1a1a1a !important; border-color: #333 !important; color: #aaa !important; }
html.dark-mode .sb-tags a:hover { border-color: #EF4444 !important; color: #EF4444 !important; background: #1a0000 !important; }
html.dark-mode .sb-all-models { border-color: #333 !important; color: #aaa !important; background: transparent !important; }
html.dark-mode .sb-all-models:hover { background: #1e1e1e !important; color: #ccc !important; }
html.dark-mode .sb-friends li a { color: #bbb !important; border-color: #222 !important; }
html.dark-mode .sb-friends li a:hover { background: #1e1e1e !important; color: #fff !important; }
html.dark-mode .sb-empty { color: #999 !important; }
html.dark-mode .sb-hist-item { color: #ccc !important; }
html.dark-mode .sb-hist-item:hover { background: #1e1e1e !important; color: #eee !important; }
html.dark-mode .sb-hist-name { color: #ccc !important; }
html.dark-mode .sb-hist-thumb { background: #2a2a2a !important; }
html.dark-mode .gallery-heading { background: #111 !important; border-color: #222 !important; }
html.dark-mode .gallery-heading h2 { color: #fff !important; }
html.dark-mode .intro { border-color: #222 !important; background: #0d0d0d !important; }
html.dark-mode .intro-title { color: #fff !important; }
html.dark-mode .intro-sub { color: #999 !important; }
html.dark-mode .sort-drop-btn { background: #181818 !important; border-color: #252525 !important; color: #bbb !important; }
html.dark-mode .sort-drop-btn:hover { background: #222 !important; color: #eee !important; }
html.dark-mode .sort-drop-menu { background: #161616 !important; border-color: #252525 !important; }
html.dark-mode .sort-opt { color: #999 !important; }
html.dark-mode .sort-opt:hover { background: #1e1e1e !important; color: #fff !important; }
html.dark-mode .random-btn { background: transparent !important; border-color: #EF4444 !important; color: #EF4444 !important; }
html.dark-mode .random-btn:hover { background: #EF4444 !important; color: #fff !important; }
html.dark-mode .col-toggle-tb { border-color: #333 !important; color: #aaa !important; }
html.dark-mode .site-desc { background: #111 !important; border-color: #222 !important; }
html.dark-mode .site-desc p { color: #bbb !important; }
html.dark-mode .gallery-card-inner { background: #161616 !important; }
html.dark-mode .link-bar { background: #111 !important; border-color: #222 !important; }
html.dark-mode .link-bar a { background: #1a1a1a !important; border-color: #252525 !important; color: #bbb !important; }
html.dark-mode .link-bar a:hover { background: #222 !important; color: #fff !important; border-color: #333 !important; }
html.dark-mode .pagination a, html.dark-mode .pagination span { border-color: #333 !important; color: #aaa !important; background: #111 !important; }
html.dark-mode .pagination a:hover { border-color: #EF4444 !important; color: #EF4444 !important; }
html.dark-mode .site-footer { border-color: #222 !important; }
html.dark-mode .footer-bottom { border-color: #222 !important; background: #0d0d0d !important; }
html.dark-mode .footer-nav a { color: #aaa !important; }
html.dark-mode .footer-nav a:hover { color: #EF4444 !important; }
html.dark-mode .footer-copy { color: #888 !important; }
html.dark-mode .footer-logo .logo-text-top { color: #eee !important; }
html.dark-mode .scroll-up { background: #1a1a1a !important; border-color: #333 !important; color: #888 !important; }
html.dark-mode .history-drop { background: #161616 !important; border-color: #252525 !important; }
html.dark-mode .history-drop-head { color: #999 !important; border-color: #252525 !important; }
html.dark-mode .history-drop-item:hover { background: #1e1e1e !important; }
html.dark-mode .history-drop-title { color: #eee !important; }
html.dark-mode .history-drop-empty { color: #888 !important; }
html.dark-mode .search-drop { background: #161616 !important; border-color: #252525 !important; }
html.dark-mode .search-drop input { background: #1e1e1e !important; border-color: #252525 !important; color: #fff !important; }
html.dark-mode .mobile-nav { background: #111 !important; }
html.dark-mode .mobile-nav > a { color: #bbb !important; border-color: #222 !important; }
html.dark-mode .mobile-nav > a:hover { background: #1a1a1a !important; color: #fff !important; }
html.dark-mode .mob-section { border-color: #222 !important; }
html.dark-mode .mob-section-head { color: #bbb !important; }
html.dark-mode .mob-section-body ul li a { color: #bbb !important; border-color: #222 !important; }
html.dark-mode .mob-section-body ul li a:hover { background: #1a1a1a !important; color: #fff !important; }

/* Dark mode — footer banner V5 */
html.dark-mode .fb-v5 { background: #111 !important; border-color: #222 !important; }
html.dark-mode .fb-v5 p { color: #888 !important; }
html.dark-mode .fb-v5 h2 { color: #eee !important; }
html.dark-mode .btn-join-v5 { color: #EF4444 !important; border-color: #EF4444 !important; background: transparent !important; }
html.dark-mode .btn-join-v5:hover { background: #EF4444 !important; color: #fff !important; }
/* Dark mode — sort dropdown */
html.dark-mode .sort-drop-btn.open { background: #1a1a1a !important; border-color: #EF4444 !important; color: #EF4444 !important; }
html.dark-mode .sort-opt.active { background: #1a0000 !important; color: #EF4444 !important; }
/* Dark mode — nav count */
html.dark-mode .sb-nav .count { color: #aaa !important; }
html.dark-mode .sb-nav a.active .count { color: rgba(255,255,255,0.8) !important; }
/* Dark mode — history drop model */
html.dark-mode .history-drop-model { color: #EF4444 !important; }
/* Dark mode — search drop */
html.dark-mode .search-drop button[type=submit] { background: #EF4444 !important; color: #fff !important; }
/* Dark mode — mobile nav hist */
html.dark-mode .mobile-nav-hist-title { color: #ccc !important; }
html.dark-mode .mobile-nav-hist-empty { color: #888 !important; }

/* ===== CTA BANNERS — DARK MODE ===== */

/* V1: gradient — keep as-is, already dark */
html.dark-mode .cta-v1 { opacity: .9; }

/* V2: white → dark */
html.dark-mode .cta-v2 { background: #1a1a1a !important; border-color: #2a2a2a !important; border-left-color: #EF4444 !important; }
html.dark-mode .cta-v2:hover { box-shadow: 0 2px 12px rgba(239,68,68,.2) !important; border-color: #EF4444 !important; }
html.dark-mode .cta-v2 .cta-title { color: #eee !important; }
html.dark-mode .cta-v2 .cta-sub { color: #888 !important; }

/* V3: already dark — slightly lighter border */
html.dark-mode .cta-v3 { border-color: #333 !important; }

/* V4: white → dark */
html.dark-mode .cta-v4 { background: #1a1a1a !important; border-color: #2a2a2a !important; }
html.dark-mode .cta-v4:hover { border-color: #EF4444 !important; }
html.dark-mode .cta-v4 .cta-stat-lbl { color: #777 !important; }

/* V5: white → dark */
html.dark-mode .cta-v5 { background: #1a1a1a !important; border-color: #2a2a2a !important; }
html.dark-mode .cta-v5:hover { border-color: #EF4444 !important; }
html.dark-mode .cta-v5 .cta-title { color: #eee !important; }
html.dark-mode .cta-v5 .cta-sub { color: #888 !important; }

/* V6: pinkish → dark */
html.dark-mode .cta-v6 { background: #1a0a0a !important; border-color: #3a1515 !important; }
html.dark-mode .cta-v6:hover { border-color: #EF4444 !important; }
html.dark-mode .cta-v6 .cta-title { color: #eee !important; }
html.dark-mode .cta-v6 .cta-sub { color: #888 !important; }

/* V7: white → dark */
html.dark-mode .cta-v7 { background: #1a1a1a !important; border-color: #2a2a2a !important; }
html.dark-mode .cta-v7:hover { border-color: #EF4444 !important; }
html.dark-mode .cta-v7 .cta-title { color: #eee !important; }

/* V8: already dark — no changes */

/* V9: white borders → dark */
html.dark-mode .cta-v9 { border-color: #2a2a2a !important; }
html.dark-mode .cta-v9:hover { background: #1a0a0a !important; }
html.dark-mode .cta-v9 .cta-title { color: #eee !important; }

/* V10: white → dark */
html.dark-mode .cta-v10 { background: #1a1a1a !important; border-color: #2a2a2a !important; }
html.dark-mode .cta-v10:hover { border-color: #EF4444 !important; }
html.dark-mode .cta-v10 .cta-timer-cell { background: #242424 !important; }
html.dark-mode .cta-v10 .cta-timer-num { color: #eee !important; }
html.dark-mode .cta-v10 .cta-timer-lbl { color: #777 !important; }
html.dark-mode a { color: inherit !important; }
html.dark-mode a:hover { color: #888; }
html.dark-mode .gallery-heading h2 span { color: #EF4444 !important; }

@media(max-width:900px) {
  #gal-save-btn .btn-label,
  .comments-btn .btn-label,
  #share-btn .btn-label,
  #gal-save-btn span.btn-label,
  .comments-btn span.btn-label,
  #share-btn span.btn-label {
    display: none !important;
    visibility: hidden !important;
    width: 0 !important;
    overflow: hidden !important;
  }
  #gal-save-btn,
  .comments-btn,
  #share-btn {
    width: 36px !important;
    min-width: 36px !important;
    max-width: 36px !important;
    height: 36px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-shrink: 0 !important;
    gap: 0 !important;
  }
  #gal-save-btn svg,
  .comments-btn svg {
    flex-shrink: 0 !important;
    margin: 0 !important;
  }
  .gal-actions { gap: 6px !important; flex-wrap: nowrap !important; }
}

/* ── Gallery grid CTA block ── */
.gal-grid-cta {
  display: block;
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  width: 100%;
  margin-bottom: 3px;
  text-decoration: none;
  cursor: pointer;
}
.ggc-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: #0d0d0d;
  padding: 32px 20px;
  text-align: center;
  min-height: 280px;
  transition: background .2s;
}
.gal-grid-cta:hover .ggc-inner { background: #141414; }
.ggc-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #EF4444;
}
.ggc-title {
  font-size: 22px;
  font-weight: 800;
  color: #fff;
  line-height: 1.2;
  letter-spacing: -.02em;
}
.ggc-sub {
  font-size: 12px;
  color: #666;
  font-style: italic;
}
.ggc-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: #EF4444;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  padding: 9px 20px;
  border-radius: 4px;
  margin-top: 4px;
  letter-spacing: .04em;
}
.gal-grid-cta:hover .ggc-btn { background: #DC2626; }

/* Light theme */
html:not(.dark-mode) .ggc-inner { background: #f0f0f0; }
html:not(.dark-mode) .gal-grid-cta:hover .ggc-inner { background: #e5e5e5; }
html:not(.dark-mode) .ggc-title { color: #111; }
html:not(.dark-mode) .ggc-sub { color: #888; }

html:not(.dark-mode) .lb-cta-btn { color: #fff !important; }

/* ══ More from model ══ */
.gal-more-model { padding: 14px 18px; border-bottom: 1px solid var(--border); }
.gmm-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.gmm-title { font-size:13px; font-weight:700; color:var(--text); letter-spacing:.02em; }
.gmm-title span { color: var(--red); }
.gmm-all { font-size:12px; color:var(--text-dim); transition:color .15s; }
.gmm-all:hover { color:var(--red); }
.gmm-scroll { display:flex; gap:4px; overflow-x:auto; scrollbar-width:none; padding-bottom:2px; }
.gmm-scroll::-webkit-scrollbar { display:none; }
.gmm-card { flex-shrink:0; border-radius:5px; overflow:hidden; position:relative; cursor:pointer; height:180px; }
.gmm-card img { display:block; height:180px; width:auto; object-fit:cover; transition:transform .3s; }
.gmm-card:hover img { transform:scale(1.05); }
.gmm-card-overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,.6) 0%, transparent 50%); opacity:0; transition:opacity .2s; pointer-events:none; }
.gmm-card:hover .gmm-card-overlay { opacity:1; }

/* ── header-search adaptive shrink ── */
@media (max-width:1400px) { .header-search { max-width:240px; } }
@media (max-width:1280px) { .header-search { max-width:180px; } }
@media (max-width:1150px) { .header-search { max-width:180px; } }
@media (max-width:1060px) { .header-search { max-width:180px; } }
/* FORCE mob-open */
@media(max-width:1024px){
  #sidebar-right.mob-open{
    display:flex!important;
    transform:translateX(0)!important;
    top:58px!important;
    height:calc(100vh - 58px)!important;
    position:fixed!important;
    right:0!important;
    width:260px!important;
    z-index:280!important;
    overflow-y:auto!important;
  }
}
