/* ==========================================================================
   视觉大师 Shijuedashi — Design System
   ========================================================================== */

:root {
  --sjd-purple: #A855F7;
  --sjd-purple-dark: #7C3AED;
  --sjd-purple-light: #EDE9FE;
  --sjd-purple-bg: #F5F3FF;
  --sjd-black: #0A0A0A;
  --sjd-white: #FFFFFF;
  --sjd-gray-50: #F9FAFB;
  --sjd-gray-100: #F3F4F6;
  --sjd-gray-200: #E5E7EB;
  --sjd-gray-300: #D1D5DB;
  --sjd-gray-400: #9CA3AF;
  --sjd-gray-500: #6B7280;
  --sjd-gray-600: #4B5563;
  --sjd-gray-700: #374151;
  --sjd-gray-800: #1F2937;
  --sjd-gray-900: #111827;
  --sjd-radius: 12px;
  --sjd-radius-sm: 8px;
  --sjd-radius-lg: 16px;
  --sjd-radius-xl: 20px;
  --sjd-shadow: 0 1px 3px rgba(0,0,0,.08), 0 4px 12px rgba(0,0,0,.04);
  --sjd-shadow-lg: 0 8px 30px rgba(0,0,0,.12);
  --sjd-font: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'Noto Sans SC', sans-serif;
  --sjd-header-h: 64px;
  --sjd-container: 1440px;
  --sjd-transition: .2s ease;
  --sjd-bg: var(--sjd-white);
  --sjd-text: var(--sjd-gray-800);
  --sjd-text-muted: var(--sjd-gray-500);
  --sjd-border: var(--sjd-gray-200);

  /* 头部专用 — 始终深色，不受页面主题切换影响 */
  --sjd-header-bg: #0A0A0A;
  --sjd-header-text: rgba(255,255,255,.75);
  --sjd-header-text-active: #FFFFFF;
  --sjd-header-border: rgba(255,255,255,.06);
  --sjd-header-hover: rgba(255,255,255,.1);
}

[data-theme="dark"] {
  --sjd-bg: #0F0F0F;
  --sjd-text: #F3F4F6;
  --sjd-text-muted: #9CA3AF;
  --sjd-border: #2D2D2D;
  --sjd-gray-50: #1A1A1A;
  --sjd-gray-100: #222;
  --sjd-white: #1A1A1A;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }

body {
  font-family: var(--sjd-font);
  font-size: 14px;
  line-height: 1.6;
  color: var(--sjd-text);
  background: var(--sjd-bg);
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
ul, ol { list-style: none; }

.sjd-container {
  max-width: var(--sjd-container);
  margin: 0 auto;
  padding: 0 24px;
}

/* Header — 全站统一深色导航 */
.sjd-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--sjd-header-bg);
  height: var(--sjd-header-h);
  border-bottom: 1px solid var(--sjd-header-border);
  color: var(--sjd-header-text-active);
}

.admin-bar .sjd-header {
  top: 32px;
}
@media screen and (max-width: 782px) {
  .admin-bar .sjd-header { top: 46px; }
}

.sjd-header-inner {
  display: flex;
  align-items: center;
  height: 100%;
  gap: 24px;
}

.sjd-logo { flex-shrink: 0; color: var(--sjd-header-text-active); display: block; }
.custom-logo-link { display: block; flex-shrink: 0; }
.custom-logo-link img { max-height: 36px; width: auto; filter: brightness(0) invert(1); }
.sjd-logo-text { display: block; font-size: 18px; font-weight: 700; letter-spacing: -.02em; color: var(--sjd-header-text-active); }
.sjd-logo-url { display: block; font-size: 10px; color: rgba(255,255,255,.5); margin-top: 1px; }

.sjd-nav {
  flex: 1;
  min-width: 0;
  overflow-x: auto;
  scrollbar-width: none;
}
.sjd-nav::-webkit-scrollbar { display: none; }

.sjd-nav-menu,
.sjd-mobile-nav-menu {
  display: flex;
  align-items: center;
  gap: 2px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.sjd-nav-menu > li,
.sjd-mobile-nav-menu > li { flex-shrink: 0; }

.sjd-mobile-nav-inner .sjd-mobile-nav-menu {
  flex-direction: column;
  align-items: stretch;
  gap: 0;
}

.sjd-nav-link {
  color: var(--sjd-header-text);
  font-size: 13px;
  white-space: nowrap;
  padding: 8px 10px;
  border-radius: var(--sjd-radius-sm);
  transition: color var(--sjd-transition), background var(--sjd-transition);
}
.sjd-nav-link:hover {
  color: var(--sjd-header-text-active);
  background: var(--sjd-header-hover);
}
.sjd-nav-link.is-active {
  color: var(--sjd-header-text-active);
  position: relative;
}
.sjd-nav-link.is-active::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 10px;
  right: 10px;
  height: 2px;
  background: var(--sjd-purple);
  border-radius: 1px;
}

.sjd-header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.sjd-icon-btn {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--sjd-header-text);
  border-radius: 50%;
  transition: background var(--sjd-transition), color var(--sjd-transition);
}
.sjd-icon-btn:hover {
  background: var(--sjd-header-hover);
  color: var(--sjd-header-text-active);
}
.sjd-icon-btn svg { width: 18px; height: 18px; }

.sjd-theme-toggle .sjd-icon-sun { display: none; }
[data-theme="dark"] .sjd-theme-toggle .sjd-icon-moon { display: none; }
[data-theme="dark"] .sjd-theme-toggle .sjd-icon-sun { display: block; }

.sjd-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid rgba(255,255,255,.2);
}
.sjd-avatar img { width: 100%; height: 100%; object-fit: cover; }
.sjd-avatar--guest { display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.6); }
.sjd-avatar--guest svg { width: 18px; height: 18px; }

.sjd-mobile-toggle {
  display: none;
  flex-direction: column;
  gap: 4px;
  padding: 8px;
}
.sjd-mobile-toggle span {
  display: block;
  width: 20px;
  height: 2px;
  background: #fff;
  border-radius: 1px;
}

/* Search Overlay */
.sjd-search-overlay {
  position: fixed;
  inset: 0;
  z-index: 2000;
  background: rgba(0,0,0,.6);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 120px;
}
.sjd-search-overlay[hidden] { display: none; }

.sjd-search-modal {
  background: var(--sjd-bg);
  border-radius: var(--sjd-radius-lg);
  padding: 32px;
  width: 90%;
  max-width: 640px;
  position: relative;
  box-shadow: var(--sjd-shadow-lg);
}

.sjd-search-form {
  display: flex;
  gap: 8px;
}
.sjd-search-form input {
  flex: 1;
  padding: 14px 20px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-xl);
  font-size: 16px;
  background: var(--sjd-gray-50);
  color: var(--sjd-text);
  outline: none;
}
.sjd-search-form input:focus { border-color: var(--sjd-purple); }

.sjd-search-close {
  position: absolute;
  top: 12px;
  right: 16px;
  font-size: 24px;
  color: var(--sjd-text-muted);
}

.sjd-hot-searches {
  margin-top: 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  font-size: 13px;
  color: var(--sjd-text-muted);
}
.sjd-hot-searches a {
  padding: 4px 12px;
  background: var(--sjd-gray-100);
  border-radius: 20px;
  transition: background var(--sjd-transition);
}
.sjd-hot-searches a:hover { background: var(--sjd-purple-light); color: var(--sjd-purple-dark); }

/* Hero */
.sjd-hero {
  color: #fff;
  overflow: hidden;
}

.sjd-hero-slider {
  position: relative;
  min-height: clamp(520px, 72vh, 680px);
  overflow: visible;
  background: var(--sjd-black);
}

.sjd-hero-bg {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.sjd-hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .7s ease;
}

.sjd-hero-slide.is-active {
  opacity: 1;
  z-index: 1;
}

.sjd-hero-slide-media,
.sjd-hero-slide-img {
  width: 100%;
  height: 100%;
}

.sjd-hero-slide-media {
  position: absolute;
  inset: 0;
}

.sjd-hero-slide-img {
  object-fit: cover;
  object-position: center top;
}

.sjd-hero-slide .sjd-placeholder.sjd-hero-slide-img {
  min-height: 100%;
  background: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 100%);
}

.sjd-hero-gradient {
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(90deg, rgba(0,0,0,.72) 0%, rgba(0,0,0,.45) 42%, rgba(0,0,0,.18) 68%, rgba(0,0,0,.35) 100%),
    linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.05) 55%, rgba(0,0,0,.45) 100%);
  pointer-events: none;
}

.sjd-hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 3;
  display: flex;
  flex-direction: column;
  justify-content: center;
  pointer-events: none;
}

.sjd-hero-overlay-inner {
  width: 100%;
  max-width: var(--sjd-container);
  margin-inline: auto;
  padding-bottom: 48px;
  box-sizing: border-box;
  pointer-events: auto;
}

.sjd-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  align-items: center;
  gap: clamp(24px, 4vw, 48px);
  width: 100%;
}

.sjd-hero-content {
  justify-self: start;
  width: 100%;
  max-width: 640px;
  min-width: 0;
}

.sjd-hero-title {
  font-size: clamp(32px, 4.8vw, 56px);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -.03em;
  margin-bottom: 16px;
  white-space: pre-line;
}

.sjd-hero-subtitle {
  font-size: clamp(14px, 1.6vw, 16px);
  line-height: 1.7;
  color: rgba(255,255,255,.72);
  margin-bottom: 32px;
  max-width: 520px;
}

.sjd-hero-search {
  display: flex;
  align-items: center;
  max-width: 560px;
  padding: 5px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  margin-bottom: 20px;
  backdrop-filter: blur(8px);
}

.sjd-hero-search input {
  flex: 1;
  min-width: 0;
  padding: 12px 12px 12px 20px;
  background: transparent;
  border: none;
  color: #fff;
  font-size: 15px;
  outline: none;
}

.sjd-hero-search input::placeholder { color: rgba(255,255,255,.42); }

.sjd-hero-search button {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.55);
  color: #fff;
  border-radius: 999px;
  transition: background var(--sjd-transition);
}

.sjd-hero-search button:hover { background: rgba(0,0,0,.72); }
.sjd-hero-search button svg { width: 20px; height: 20px; }

.sjd-hot-searches--hero {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 12px;
  font-size: 13px;
  color: rgba(255,255,255,.55);
}

.sjd-hot-searches--hero a {
  background: none;
  padding: 0;
  color: rgba(255,255,255,.78);
  transition: color var(--sjd-transition);
}

.sjd-hot-searches--hero a:hover {
  background: none;
  color: #fff;
}

.sjd-hero-features {
  position: relative;
  justify-self: end;
  width: 340px;
  max-width: 100%;
  min-height: 220px;
}

.sjd-hero-feature {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  box-sizing: border-box;
  padding: 28px 32px;
  border-radius: var(--sjd-radius-lg);
  background: rgba(0,0,0,.42);
  border: 1px solid rgba(255,255,255,.1);
  backdrop-filter: blur(12px);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity .5s ease, transform .5s ease, visibility .5s;
  pointer-events: none;
}

.sjd-hero-feature.is-active {
  position: relative;
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  z-index: 1;
  pointer-events: auto;
}

.sjd-hero-feature-badge {
  display: inline-flex;
  align-self: flex-start;
  padding: 4px 12px;
  margin-bottom: 16px;
  border-radius: 999px;
  background: var(--sjd-purple-light);
  color: var(--sjd-purple-dark);
  font-size: 12px;
  font-weight: 600;
}

.sjd-hero-feature-title {
  font-size: clamp(22px, 2.4vw, 32px);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: .02em;
  margin-bottom: 8px;
  word-break: break-word;
  overflow-wrap: break-word;
}

.sjd-hero-feature-meta {
  font-size: 14px;
  line-height: 1.5;
  color: rgba(255,255,255,.72);
  margin-bottom: 20px;
  word-break: break-word;
  overflow-wrap: break-word;
}

.sjd-btn-hero {
  align-self: flex-start;
  padding: 10px 18px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.35);
  background: rgba(0,0,0,.55);
  color: #fff;
  font-size: 14px;
}

.sjd-btn-hero:hover {
  background: rgba(0,0,0,.75);
  border-color: rgba(255,255,255,.55);
}

.sjd-hero-dots-wrap {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 28px;
  z-index: 4;
  pointer-events: none;
  width: 100%;
  max-width: var(--sjd-container);
  margin-inline: auto;
  padding-inline: 24px;
  box-sizing: border-box;
}

.sjd-hero-dots {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  pointer-events: auto;
}

.sjd-hero-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,.35);
  transition: all .25s ease;
}

.sjd-hero-dot.is-active {
  width: 24px;
  border-radius: 999px;
  background: #fff;
}

.sjd-hero-dot:hover { background: rgba(255,255,255,.65); }

/* Buttons */
.sjd-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 20px;
  border-radius: var(--sjd-radius);
  font-size: 14px;
  font-weight: 500;
  transition: all var(--sjd-transition);
  cursor: pointer;
}
.sjd-btn svg { width: 16px; height: 16px; }

.sjd-btn-primary { background: var(--sjd-purple); color: #fff; }
.sjd-btn-primary:hover { background: var(--sjd-purple-dark); }

.sjd-btn-dark { background: var(--sjd-black); color: #fff; }
.sjd-btn-dark:hover { background: var(--sjd-gray-800); }

.sjd-btn-outline {
  border: 1px solid rgba(255,255,255,.3);
  color: #fff;
  background: transparent;
}
.sjd-btn-outline:hover { background: rgba(255,255,255,.1); }

.sjd-btn-load-more {
  display: block;
  margin: 32px auto 0;
  padding: 12px 32px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-xl);
  background: var(--sjd-bg);
  color: var(--sjd-text);
}
.sjd-btn-load-more:hover { border-color: var(--sjd-purple); color: var(--sjd-purple); }

/* Sections */
.sjd-section { padding: 48px 0; }
.sjd-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 24px;
}
.sjd-section-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 20px;
  font-weight: 700;
}
.sjd-sparkle { color: var(--sjd-purple); }
.sjd-sparkle svg { width: 18px; height: 18px; }

.sjd-section-link {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 13px;
  color: var(--sjd-text-muted);
  transition: color var(--sjd-transition);
}
.sjd-section-link:hover { color: var(--sjd-purple); }
.sjd-section-link svg { width: 14px; height: 14px; }

.sjd-section-header--tabs { flex-wrap: wrap; gap: 12px; }
.sjd-section-tabs { display: flex; gap: 4px; }
.sjd-tab {
  padding: 6px 16px;
  border-radius: 20px;
  font-size: 13px;
  color: var(--sjd-text-muted);
  transition: all var(--sjd-transition);
}
.sjd-tab.is-active {
  background: var(--sjd-black);
  color: #fff;
}
[data-theme="dark"] .sjd-tab.is-active { background: var(--sjd-purple); }

/* Trend Grid */
.sjd-trend-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}

.sjd-trend-tag-card {
  position: relative;
  border-radius: var(--sjd-radius);
  overflow: hidden;
  aspect-ratio: 3/4;
  display: block;
}
.sjd-trend-tag-bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, hsl(var(--trend-hue, 260), 30%, 25%), hsl(calc(var(--trend-hue, 260) + 40), 40%, 15%));
}
.sjd-trend-tag-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 16px;
  background: linear-gradient(transparent, rgba(0,0,0,.7));
  color: #fff;
}
.sjd-trend-tag-content h3 { font-size: 14px; font-weight: 600; }
.sjd-trend-tag-content p { font-size: 12px; opacity: .8; margin: 2px 0 6px; }
.sjd-trend-tag-content span { font-size: 11px; opacity: .6; }

/* Grids */
.sjd-grid { display: grid; gap: 16px; }
.sjd-grid--3 { grid-template-columns: repeat(3, 1fr); }
.sjd-grid--4 { grid-template-columns: repeat(4, 1fr); }
.sjd-grid--5 { grid-template-columns: repeat(5, 1fr); }
.sjd-grid--6 { grid-template-columns: repeat(6, 1fr); }

/* Cards */
.sjd-card {
  background: var(--sjd-bg);
  border-radius: var(--sjd-radius);
  overflow: hidden;
  border: 1px solid var(--sjd-border);
  transition: transform var(--sjd-transition), box-shadow var(--sjd-transition);
}
.sjd-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--sjd-shadow);
}

.sjd-card-image { position: relative; overflow: hidden; }
.sjd-card-img { width: 100%; aspect-ratio: 3/4; object-fit: cover; transition: transform .3s ease; }
.sjd-card:hover .sjd-card-img { transform: scale(1.03); }

.sjd-card-body { padding: 12px; }
.sjd-card-title {
  font-size: 13px;
  font-weight: 600;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.sjd-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
  font-size: 11px;
  color: var(--sjd-text-muted);
}
.sjd-card-meta span::after { content: '·'; margin-left: 6px; }
.sjd-card-meta span:last-child::after { display: none; }

.sjd-card-excerpt {
  font-size: 12px;
  color: var(--sjd-text-muted);
  margin-top: 6px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sjd-card-stats {
  display: flex;
  gap: 12px;
  margin-top: 8px;
  font-size: 11px;
  color: var(--sjd-text-muted);
}
.sjd-card-stats svg { width: 12px; height: 12px; vertical-align: -2px; }

/* Badges */
.sjd-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  padding: 3px 8px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 600;
  z-index: 2;
}
.sjd-badge--type { background: rgba(0,0,0,.6); color: #fff; backdrop-filter: blur(4px); }
.sjd-badge--pinned { background: var(--sjd-purple); color: #fff; }
.sjd-badge--featured, .sjd-badge--new { background: var(--sjd-purple); color: #fff; }
.sjd-badge--cover { background: #3B82F6; color: #fff; }
.sjd-badge--inside { background: rgba(15, 23, 42, .72); color: #fff; backdrop-filter: blur(4px); }
.sjd-badge--inline { position: static; display: inline-flex; margin-right: 6px; margin-bottom: 8px; }
.sjd-badge--hot { background: #EF4444; color: #fff; }
.sjd-badge--focus { position: static; display: inline-block; background: var(--sjd-purple); color: #fff; margin-bottom: 4px; }

/* Card Actions */
.sjd-card-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 12px;
  border-top: 1px solid var(--sjd-border);
}
.sjd-action-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  color: var(--sjd-text-muted);
  transition: color var(--sjd-transition);
}
.sjd-action-btn svg { width: 14px; height: 14px; }
.sjd-action-btn.is-active, .sjd-action-btn:hover { color: #EF4444; }
.sjd-bookmark-btn.is-active { color: var(--sjd-purple); }
.sjd-action-stat { display: flex; align-items: center; gap: 4px; font-size: 12px; color: var(--sjd-text-muted); margin-left: auto; }
.sjd-action-stat svg { width: 14px; height: 14px; }

/* Tags */
.sjd-tags { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 8px; }
.sjd-tag {
  font-size: 11px;
  padding: 2px 8px;
  background: var(--sjd-gray-100);
  border-radius: 4px;
  color: var(--sjd-text-muted);
  transition: all var(--sjd-transition);
}
.sjd-tag:hover { background: var(--sjd-purple-light); color: var(--sjd-purple-dark); }

.sjd-home-magazine-grid {
  margin-bottom: 0;
  align-items: start;
}

.sjd-home-magazine .sjd-magazine-card .sjd-card-title {
  font-size: 13px;
}

.sjd-home-magazine .sjd-magazine-card .sjd-card-actions {
  display: none;
}

/* Triple Columns */
.sjd-triple-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.sjd-prompt-list { display: flex; flex-direction: column; gap: 12px; }
.sjd-prompt-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px;
  border-radius: var(--sjd-radius-sm);
  transition: background var(--sjd-transition);
}
.sjd-prompt-item:hover { background: var(--sjd-gray-50); }
.sjd-prompt-thumb { flex-shrink: 0; width: 48px; height: 48px; border-radius: var(--sjd-radius-sm); overflow: hidden; }
.sjd-prompt-thumb-img { width: 100%; height: 100%; object-fit: cover; }
.sjd-prompt-info { flex: 1; min-width: 0; }
.sjd-prompt-info strong { display: block; font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sjd-prompt-info span { font-size: 11px; color: var(--sjd-text-muted); }

.sjd-copy-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 6px 12px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-sm);
  font-size: 12px;
  white-space: nowrap;
  transition: all var(--sjd-transition);
}
.sjd-copy-btn:hover { border-color: var(--sjd-purple); color: var(--sjd-purple); }
.sjd-copy-btn svg { width: 14px; height: 14px; }

.sjd-color-featured {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  background: var(--sjd-gray-50);
  border-radius: var(--sjd-radius);
  margin-bottom: 12px;
}
.sjd-color-featured-swatch { width: 48px; height: 48px; border-radius: var(--sjd-radius-sm); }
.sjd-color-featured-info { flex: 1; }
.sjd-color-featured-info h4 { font-size: 14px; }
.sjd-color-percent { font-size: 20px; font-weight: 700; color: var(--sjd-purple); }

.sjd-color-list li {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0;
  font-size: 13px;
  border-bottom: 1px solid var(--sjd-border);
}
.sjd-color-dot { width: 16px; height: 16px; border-radius: 50%; flex-shrink: 0; }
.sjd-color-pct { margin-left: auto; font-weight: 600; color: var(--sjd-text-muted); }

.sjd-people-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.sjd-people-item { text-align: center; }
.sjd-people-circle {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto 8px;
}
.sjd-people-circle-img { width: 100%; height: 100%; object-fit: cover; }
.sjd-people-name { display: block; font-size: 13px; font-weight: 600; }
.sjd-people-works { font-size: 11px; color: var(--sjd-text-muted); }

/* Style Grid Home */
.sjd-style-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}
.sjd-style-card-home {
  position: relative;
  border-radius: var(--sjd-radius);
  overflow: hidden;
  aspect-ratio: 16/10;
  display: block;
}
.sjd-style-card-bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, hsl(var(--style-hue, 200), 25%, 20%), hsl(calc(var(--style-hue, 200) + 30), 35%, 12%));
}
.sjd-style-card-content {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #fff;
  text-align: center;
  padding: 12px;
}
.sjd-style-icon { font-size: 24px; margin-bottom: 6px; }
.sjd-style-card-content h3 { font-size: 13px; font-weight: 600; }
.sjd-style-card-content p { font-size: 11px; opacity: .7; }
.sjd-style-card-content span { font-size: 10px; opacity: .5; margin-top: 4px; }

.sjd-library-tags { display: flex; gap: 12px; }
.sjd-library-tag {
  padding: 12px 24px;
  background: var(--sjd-gray-100);
  border-radius: var(--sjd-radius);
  font-weight: 500;
  transition: all var(--sjd-transition);
}
.sjd-library-tag:hover { background: var(--sjd-purple-light); color: var(--sjd-purple-dark); }

/* Page Layout */
.sjd-page { padding: 32px 0 64px; }
.sjd-page-hero {
  display: flex;
  gap: 32px;
  align-items: flex-start;
  margin-bottom: 32px;
  padding: 24px 0;
}
.sjd-page-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 8px;
}
.sjd-page-desc { color: var(--sjd-text-muted); margin-bottom: 12px; }
.sjd-page-stats { display: flex; gap: 24px; font-size: 13px; color: var(--sjd-text-muted); }
.sjd-page-stats strong { color: var(--sjd-text); font-size: 16px; }

form.sjd-page-search,
.sjd-search-form-bar {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 16px;
  max-width: 480px;
}
form.sjd-page-search input,
.sjd-search-form-bar input {
  flex: 1;
  min-width: 0;
  padding: 12px 20px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-xl);
  background: var(--sjd-gray-50);
  color: var(--sjd-text);
  outline: none;
}
form.sjd-page-search input:focus,
.sjd-search-form-bar input:focus { border-color: var(--sjd-purple); }

.sjd-page-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 32px;
}
.sjd-page-layout--triple {
  grid-template-columns: 220px 1fr 260px;
}

/* Sidebar — 栏目页左侧栏统一样式 */
.sjd-sidebar {
  position: sticky;
  top: calc(var(--sjd-header-h) + 24px);
  align-self: start;
}

.sjd-sidebar-section {
  margin-bottom: 24px;
}

.sjd-sidebar-section:last-child {
  margin-bottom: 0;
}

.sjd-sidebar-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--sjd-text);
  margin-bottom: 10px;
}

.sjd-sidebar-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
}

.sjd-sidebar-section-head .sjd-sidebar-label {
  margin-bottom: 0;
}

.sjd-sidebar-more {
  font-size: 12px;
  color: var(--sjd-purple);
  white-space: nowrap;
}

.sjd-sidebar-more:hover {
  color: var(--sjd-purple-dark);
}

.sjd-sidebar-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.sjd-sidebar-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 9px 12px;
  border-radius: var(--sjd-radius-sm);
  font-size: 13px;
  color: var(--sjd-text-muted);
  transition: background var(--sjd-transition), color var(--sjd-transition);
  text-align: left;
}

.sjd-sidebar-item:hover {
  background: var(--sjd-gray-50);
  color: var(--sjd-text);
}

.sjd-sidebar-item.is-active {
  background: var(--sjd-purple-bg);
  color: var(--sjd-purple-dark);
  font-weight: 500;
}

.sjd-sidebar-name {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sjd-sidebar-count {
  margin-left: auto;
  font-size: 12px;
  color: var(--sjd-text-muted);
  opacity: .75;
  flex-shrink: 0;
}

.sjd-sidebar-item.is-active .sjd-sidebar-count {
  color: var(--sjd-purple-dark);
  opacity: 1;
}

.sjd-sidebar-icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.sjd-sidebar-footer-btn {
  width: 100%;
  margin-top: 12px;
  justify-content: center;
  gap: 8px;
}

.sjd-sidebar-footer-btn svg {
  width: 14px;
  height: 14px;
}

.sjd-sidebar-cta {
  padding: 20px;
  background: var(--sjd-purple-bg);
  border-radius: var(--sjd-radius);
  margin-top: 24px;
}
.sjd-sidebar-cta h4 { font-size: 14px; margin-bottom: 4px; }
.sjd-sidebar-cta p { font-size: 12px; color: var(--sjd-text-muted); margin-bottom: 12px; }

.sjd-widget {
  padding: 20px;
  background: var(--sjd-gray-50);
  border-radius: var(--sjd-radius);
  margin-bottom: 16px;
}
.sjd-widget h4 { font-size: 14px; margin-bottom: 12px; }

.sjd-hot-list li {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0;
  font-size: 13px;
  border-bottom: 1px solid var(--sjd-border);
}
.sjd-hot-rank {
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--sjd-purple-light);
  color: var(--sjd-purple-dark);
  border-radius: 4px;
  font-size: 11px;
  font-weight: 700;
}

/* Filter Bar */
.sjd-filter-bar { margin-bottom: 24px; }
.sjd-filter-tabs { display: flex; gap: 4px; margin-bottom: 12px; }
.sjd-filter-tab {
  padding: 6px 16px;
  border-radius: 20px;
  font-size: 13px;
  color: var(--sjd-text-muted);
}
.sjd-filter-tab.is-active { background: var(--sjd-black); color: #fff; }

.sjd-filter-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.sjd-filter-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 8px 14px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius);
  font-size: 13px;
  background: var(--sjd-bg);
  transition: border-color var(--sjd-transition);
}
.sjd-filter-btn:hover { border-color: var(--sjd-purple); }

.sjd-filter-dropdown {
  position: relative;
  flex-shrink: 0;
}

.sjd-filter-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  z-index: 30;
  min-width: 168px;
  max-width: min(240px, 90vw);
  max-height: 280px;
  overflow-y: auto;
  margin: 0;
  padding: 6px;
  list-style: none;
  background: var(--sjd-bg);
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius);
  box-shadow: var(--sjd-shadow);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-4px);
  transition: opacity var(--sjd-transition), transform var(--sjd-transition), visibility var(--sjd-transition);
}

.sjd-filter-dropdown.is-open .sjd-filter-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}

.sjd-filter-menu a {
  display: block;
  padding: 8px 12px;
  border-radius: var(--sjd-radius-sm);
  font-size: 13px;
  color: var(--sjd-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sjd-filter-menu a:hover {
  background: var(--sjd-gray-50);
}

.sjd-filter-dropdown.is-open .sjd-filter-btn {
  border-color: var(--sjd-purple);
  color: var(--sjd-purple-dark);
}

.sjd-view-toggle { margin-left: auto; display: flex; gap: 4px; }
.sjd-view-btn {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--sjd-radius-sm);
  color: var(--sjd-text-muted);
}
.sjd-view-btn.is-active { background: var(--sjd-black); color: #fff; }
.sjd-view-btn svg { width: 16px; height: 16px; }

/* Masonry */
.sjd-masonry {
  columns: 4;
  column-gap: 16px;
}
.sjd-masonry-item {
  break-inside: avoid;
  margin-bottom: 16px;
  border-radius: var(--sjd-radius);
  overflow: hidden;
  position: relative;
}
.sjd-masonry-image { position: relative; overflow: hidden; }
.sjd-masonry-img { width: 100%; border-radius: var(--sjd-radius); }
.sjd-masonry-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(transparent 55%, rgba(0, 0, 0, .62));
  opacity: 0;
  transition: opacity var(--sjd-transition);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 12px;
  pointer-events: none;
}

.sjd-masonry-overlay .sjd-tags {
  pointer-events: auto;
}

.sjd-masonry-item:hover .sjd-masonry-overlay { opacity: 1; }

.sjd-masonry-bookmark {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, .88);
  color: var(--sjd-text);
  box-shadow: 0 2px 8px rgba(0, 0, 0, .12);
}

.sjd-masonry-bookmark svg {
  width: 14px;
  height: 14px;
}

.sjd-masonry-bookmark.is-active {
  color: var(--sjd-purple);
}

.sjd-masonry-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  padding: 10px 4px 4px;
  font-size: 12px;
  color: var(--sjd-text-muted);
}

.sjd-masonry-author {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.sjd-masonry-avatar {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  flex-shrink: 0;
}
.sjd-masonry-likes { display: flex; align-items: center; gap: 4px; }
.sjd-masonry-likes svg { width: 12px; height: 12px; }

/* Trend Cards (large) */
.sjd-trend-masonry {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.sjd-page-trends .sjd-trend-masonry {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.sjd-page-trends .sjd-trend-card--large .sjd-trend-info h3 {
  font-size: 14px;
}
.sjd-trend-card--large .sjd-card-image { aspect-ratio: 3/4; }
.sjd-trend-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(transparent 50%, rgba(0,0,0,.7));
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 16px;
  color: #fff;
}
.sjd-trend-info h3 { font-size: 16px; font-weight: 700; }
.sjd-trend-bookmark {
  position: absolute;
  top: 12px;
  right: 12px;
  color: #fff;
}
.sjd-trend-bookmark svg { width: 20px; height: 20px; }

/* Trends Page Banner */
.sjd-page-trends { padding-top: 24px; }

.sjd-trends-banner {
  margin-bottom: 32px;
  padding: 28px 32px;
  border-radius: var(--sjd-radius-lg);
  background: linear-gradient(135deg, #f3efff 0%, #f8f6ff 45%, #faf9fc 100%);
  border: 1px solid rgba(168, 85, 247, .08);
}

.sjd-trends-banner-inner {
  display: grid;
  grid-template-columns: minmax(200px, 260px) minmax(0, 1fr);
  gap: clamp(20px, 3vw, 40px);
  align-items: center;
}

.sjd-trends-banner-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 700;
  line-height: 1.2;
  color: var(--sjd-text);
}

.sjd-trends-banner-title .sjd-sparkle {
  display: inline-flex;
  color: var(--sjd-purple);
}

.sjd-trends-banner-title .sjd-sparkle svg {
  width: 20px;
  height: 20px;
}

.sjd-trends-banner-desc {
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.65;
  color: var(--sjd-text-muted);
  max-width: 240px;
}

.sjd-trends-top-list {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
  min-width: 0;
}

.sjd-trends-top-card {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  padding: 12px;
  background: #fff;
  border-radius: var(--sjd-radius-lg);
  box-shadow: 0 1px 3px rgba(15, 23, 42, .05);
  transition: box-shadow var(--sjd-transition), transform var(--sjd-transition);
}

.sjd-trends-top-card:hover {
  box-shadow: 0 6px 20px rgba(15, 23, 42, .08);
  transform: translateY(-1px);
}

.sjd-trends-top-thumb {
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  border-radius: 10px;
  overflow: hidden;
  background: var(--sjd-gray-100);
}

.sjd-trends-top-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sjd-trends-top-body {
  min-width: 0;
  flex: 1;
}

.sjd-trends-top-name {
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--sjd-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sjd-trends-top-rank {
  font-weight: 600;
  color: var(--sjd-gray-400);
  margin-right: 4px;
}

.sjd-trends-top-cn {
  display: block;
  margin-top: 2px;
  font-size: 11px;
  line-height: 1.4;
  color: var(--sjd-text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sjd-trends-top-heat {
  display: block;
  margin-top: 4px;
  font-size: 11px;
  color: var(--sjd-gray-400);
}

/* People Page */
.sjd-page-layout--people {
  grid-template-columns: 220px minmax(0, 1fr);
  align-items: start;
}

.sjd-sidebar-range { margin-top: 8px; }

.sjd-range-track {
  padding: 8px 0;
}

.sjd-range-input {
  width: 100%;
  accent-color: var(--sjd-purple);
}

.sjd-range-labels {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  color: var(--sjd-text-muted);
}

.sjd-sidebar-reset {
  width: 100%;
  margin-top: 16px;
  border-color: var(--sjd-border);
  color: var(--sjd-text-muted);
}

.sjd-sidebar-reset:hover {
  border-color: var(--sjd-purple);
  color: var(--sjd-purple);
}

.sjd-people-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: clamp(24px, 4vw, 40px);
  align-items: center;
  padding: 28px 32px;
  border-radius: var(--sjd-radius-lg);
  background: linear-gradient(135deg, #f3efff 0%, #f8f6ff 45%, #faf9fc 100%);
  border: 1px solid rgba(168, 85, 247, .08);
  overflow: hidden;
}

.sjd-people-hero-intro .sjd-page-title {
  font-size: clamp(24px, 3vw, 32px);
  margin-bottom: 10px;
}

.sjd-people-hero-intro .sjd-page-desc {
  max-width: 520px;
  line-height: 1.7;
  margin-bottom: 16px;
}

.sjd-people-hero-featured {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.sjd-featured-people,
.sjd-page-people .sjd-featured-person {
  margin-bottom: 0;
}

.sjd-featured-person {
  flex-shrink: 0;
  border-radius: var(--sjd-radius);
  overflow: hidden;
  position: relative;
  background: var(--sjd-gray-100);
  box-shadow: var(--sjd-shadow);
  transition: transform var(--sjd-transition), box-shadow var(--sjd-transition);
}

.sjd-featured-person:hover {
  transform: translateY(-2px);
  box-shadow: var(--sjd-shadow-lg);
}

.sjd-featured-person-img { width: 100%; aspect-ratio: 3/4; object-fit: cover; display: block; }
.sjd-featured-person-info {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 28px 10px 10px;
  background: linear-gradient(transparent, rgba(0,0,0,.75));
  color: #fff;
}
.sjd-featured-person-info h3 { font-size: 13px; font-weight: 600; margin-bottom: 2px; }
.sjd-featured-person-info span { font-size: 11px; opacity: .85; }

.sjd-people-toolbar {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.sjd-people-toolbar-title {
  font-size: 15px;
  font-weight: 700;
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-shrink: 0;
  margin: 0;
}

.sjd-people-toolbar-count {
  font-size: 13px;
  font-weight: 500;
  color: var(--sjd-text-muted);
}

.sjd-people-toolbar .sjd-alpha-bar {
  flex: 1;
  display: flex;
  flex-wrap: nowrap;
  gap: 2px;
  overflow-x: auto;
  min-width: 0;
  padding: 2px 0;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}

.sjd-people-toolbar .sjd-alpha-bar::-webkit-scrollbar { display: none; }

.sjd-people-sort {
  flex-shrink: 0;
  margin-left: auto;
}

.sjd-people-sort select {
  padding: 8px 32px 8px 12px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius);
  background: var(--sjd-bg);
  color: var(--sjd-text);
  font-size: 13px;
  outline: none;
  cursor: pointer;
}

.sjd-people-sort select:focus { border-color: var(--sjd-purple); }

.sjd-alpha-link {
  min-width: 28px;
  height: 28px;
  padding: 0 4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: none;
  border-radius: var(--sjd-radius-sm);
  font-size: 12px;
  font-weight: 500;
  color: var(--sjd-text-muted);
  background: transparent;
  cursor: pointer;
  flex-shrink: 0;
  transition: all var(--sjd-transition);
}

.sjd-alpha-link:hover,
.sjd-alpha-link.is-active {
  background: var(--sjd-purple);
  color: #fff;
}

.sjd-people-scroll {
  position: relative;
  margin-bottom: 24px;
}

.sjd-people-scroll-track {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-snap-type: x proximity;
  scroll-behavior: smooth;
  padding: 4px 52px 8px 4px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.sjd-people-scroll-track::-webkit-scrollbar { display: none; }

.sjd-people-scroll-btn {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--sjd-border);
  border-radius: 50%;
  background: var(--sjd-bg);
  color: var(--sjd-text-muted);
  box-shadow: var(--sjd-shadow);
  cursor: pointer;
  transition: all var(--sjd-transition);
}

.sjd-people-scroll-btn:hover {
  border-color: var(--sjd-purple);
  color: var(--sjd-purple);
}

.sjd-people-scroll-btn svg {
  width: 18px;
  height: 18px;
}

.sjd-people-card {
  flex: 0 0 118px;
  scroll-snap-align: start;
  text-align: center;
  padding: 14px 10px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius);
  background: var(--sjd-bg);
  transition: border-color var(--sjd-transition), box-shadow var(--sjd-transition);
}

.sjd-people-card:hover,
.sjd-people-card.is-selected {
  border-color: var(--sjd-purple);
  box-shadow: 0 0 0 1px var(--sjd-purple-light);
}

.sjd-people-card-link {
  display: block;
  color: inherit;
}

.sjd-people-avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto 10px;
  background: var(--sjd-gray-100);
}

.sjd-avatar-img { width: 100%; height: 100%; object-fit: cover; }

.sjd-people-card .sjd-card-title {
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 4px;
  line-height: 1.3;
}

.sjd-people-role {
  font-size: 11px;
  color: var(--sjd-text-muted);
  line-height: 1.4;
  margin-bottom: 8px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sjd-people-count-pill {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 500;
  color: var(--sjd-purple-dark);
  background: var(--sjd-purple-bg);
}

.sjd-people-panel {
  padding: 24px;
  background: var(--sjd-gray-50);
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-lg);
  margin-top: 8px;
}

.sjd-people-panel-top {
  display: grid;
  grid-template-columns: 132px minmax(0, 1fr) 200px;
  gap: 20px;
  align-items: start;
}

.sjd-people-panel--single .sjd-people-panel-top {
  grid-template-columns: 152px minmax(0, 1fr) 220px;
  gap: 24px;
}

.sjd-people-panel-nav {
  min-width: 0;
}

.sjd-people-panel-main {
  min-width: 0;
}

.sjd-people-panel-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.sjd-people-panel-nav-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  padding: 8px 10px;
  border-radius: var(--sjd-radius-sm);
  font-size: 12px;
  line-height: 1.3;
  color: var(--sjd-text-muted);
  transition: all var(--sjd-transition);
}

.sjd-people-panel-nav-link span {
  min-width: 0;
}

.sjd-people-panel-nav-link em {
  font-style: normal;
  font-size: 10px;
  opacity: .65;
  flex-shrink: 0;
}

.sjd-people-panel-nav-link:hover,
.sjd-people-panel-nav-link.is-active {
  background: var(--sjd-purple-bg);
  color: var(--sjd-purple-dark);
  font-weight: 500;
}

.sjd-people-panel-profile {
  display: grid;
  grid-template-columns: 160px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}

.sjd-people-panel--preview .sjd-people-panel-profile {
  grid-template-columns: 140px minmax(0, 1fr);
}

.sjd-people-panel-photo {
  align-self: start;
}

.sjd-people-panel-photo .sjd-profile-img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  border-radius: var(--sjd-radius);
  display: block;
}

.sjd-people-panel-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 10px;
}

.sjd-people-panel-head-text {
  min-width: 0;
  flex: 1;
}

.sjd-people-panel-info h2,
.sjd-people-panel-title {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 2px;
  line-height: 1.25;
}

.sjd-people-panel--preview .sjd-people-panel-title {
  font-size: 18px;
}

.sjd-real-name {
  font-size: 13px;
  color: var(--sjd-text-muted);
  margin-bottom: 4px;
}

.sjd-people-panel-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.sjd-btn-sm {
  padding: 8px 14px;
  font-size: 12px;
  white-space: nowrap;
}

.sjd-people-social {
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--sjd-border);
  border-radius: 50%;
  font-size: 10px;
  font-weight: 700;
  color: var(--sjd-text-muted);
  flex-shrink: 0;
}

.sjd-profile-meta {
  font-size: 12px;
  color: var(--sjd-text-muted);
  margin-bottom: 8px;
  line-height: 1.5;
}

.sjd-profile-bio {
  font-size: 12px;
  line-height: 1.65;
  color: var(--sjd-text);
  margin-bottom: 12px;
}

.sjd-people-panel--preview .sjd-profile-bio {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sjd-profile-bio p { margin-bottom: 0; }

.sjd-profile-stats--panel {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 0;
}

.sjd-people-panel--single .sjd-profile-stats--panel {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  margin-bottom: 16px;
}

.sjd-profile-stats--panel .sjd-stat-box {
  min-width: 0;
  padding: 10px 8px;
  text-align: center;
  background: var(--sjd-bg);
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-sm);
}

.sjd-profile-stats--panel .sjd-stat-box strong {
  display: block;
  font-size: 18px;
  line-height: 1.2;
}

.sjd-profile-stats--panel .sjd-stat-box span {
  display: block;
  font-size: 10px;
  color: var(--sjd-text-muted);
  margin-top: 2px;
}

.sjd-people-panel-works .sjd-section-header { margin-bottom: 16px; }

.sjd-people-panel-works .sjd-visual-card .sjd-card-actions { display: none; }

.sjd-people-panel-brands {
  padding: 14px;
  background: var(--sjd-bg);
  border-radius: var(--sjd-radius);
  border: 1px solid var(--sjd-border);
  align-self: start;
  min-width: 0;
}

.sjd-people-panel--preview .sjd-people-panel-brands {
  align-self: stretch;
  display: flex;
  flex-direction: column;
}

.sjd-people-panel--single .sjd-people-panel-works,
.sjd-people-panel--single .sjd-people-panel-magazine {
  margin-top: 28px;
  padding-top: 28px;
  border-top: 1px solid var(--sjd-border);
}

.sjd-people-panel-brands h4 {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 12px;
}

.sjd-brand-rank {
  list-style: none;
  margin: 0 0 12px;
  padding: 0;
}

.sjd-brand-rank li {
  display: grid;
  grid-template-columns: 24px 1fr auto;
  gap: 8px;
  align-items: center;
  padding: 8px 0;
  font-size: 12px;
  border-bottom: 1px solid var(--sjd-border);
}

.sjd-brand-rank-num {
  font-weight: 700;
  color: var(--sjd-purple);
}

.sjd-brand-rank-name { font-weight: 500; }

.sjd-brand-rank-count {
  font-size: 11px;
  color: var(--sjd-text-muted);
}

.sjd-brand-rank-empty {
  font-size: 12px;
  color: var(--sjd-text-muted);
  margin-bottom: 12px;
}

#sjd-people-preview.is-loading {
  opacity: .55;
  pointer-events: none;
}

.sjd-people-panel--single {
  margin-top: 0;
  background: var(--sjd-gray-50);
}

.sjd-single-people .sjd-people-panel-title {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 700;
  margin-bottom: 4px;
}

.sjd-single-people .sjd-people-panel-actions .sjd-card-actions {
  padding: 0;
  border: none;
  gap: 8px;
}

.sjd-single-people .sjd-people-panel-magazine {
  margin-top: 32px;
  padding-top: 32px;
  border-top: 1px solid var(--sjd-border);
}

.sjd-single-people .sjd-people-panel-magazine .sjd-section-header,
.sjd-single-people .sjd-people-panel-works .sjd-section-header {
  margin-bottom: 16px;
}

.sjd-single-people [id^="sjd-people-"] {
  scroll-margin-top: calc(var(--sjd-header-h) + 24px);
}

.sjd-single-people .sjd-people-panel-nav {
  position: sticky;
  top: calc(var(--sjd-header-h) + 24px);
  align-self: start;
}

.admin-bar .sjd-single-people .sjd-people-panel-nav {
  top: calc(var(--sjd-header-h) + 56px);
}

.sjd-single-people .sjd-people-panel-brands {
  position: sticky;
  top: calc(var(--sjd-header-h) + 24px);
}

.admin-bar .sjd-single-people .sjd-people-panel-brands {
  top: calc(var(--sjd-header-h) + 56px);
}

/* Magazine Page */
.sjd-page-magazine { padding-top: 24px; }

.sjd-page-layout--magazine {
  grid-template-columns: 220px minmax(0, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
  align-items: start;
}

.sjd-page-content--magazine .sjd-filter-bar {
  margin-bottom: 16px;
}

.sjd-sidebar--magazine .sjd-sidebar-title {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 16px;
  line-height: 1.35;
}

.sjd-sidebar--magazine .sjd-sidebar-title a {
  color: var(--sjd-text);
  transition: color var(--sjd-transition);
}

.sjd-sidebar--magazine .sjd-sidebar-title a:hover {
  color: var(--sjd-purple);
}

.sjd-sidebar--magazine .sjd-sidebar-item {
  width: 100%;
  text-align: left;
  text-decoration: none;
}

.sjd-magazine-term-header {
  margin-bottom: 24px;
  padding: 24px 28px;
  border-radius: var(--sjd-radius-lg);
  background: linear-gradient(135deg, #f3efff 0%, #f8f6ff 45%, #faf9fc 100%);
  border: 1px solid rgba(168, 85, 247, .08);
}

.sjd-magazine-term-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-bottom: 18px;
  font-size: 12px;
  color: var(--sjd-text-muted);
}

.sjd-magazine-term-breadcrumb a {
  color: var(--sjd-text-muted);
  transition: color var(--sjd-transition);
}

.sjd-magazine-term-breadcrumb a:hover {
  color: var(--sjd-purple);
}

.sjd-magazine-term-header-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 140px;
  gap: clamp(20px, 3vw, 32px);
  align-items: center;
}

.sjd-magazine-term-eyebrow {
  margin: 0 0 8px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--sjd-purple);
}

.sjd-magazine-term-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 8px;
  font-size: clamp(24px, 2.8vw, 32px);
  font-weight: 700;
  line-height: 1.2;
}

.sjd-magazine-term-title .sjd-sparkle {
  color: var(--sjd-purple);
  display: inline-flex;
}

.sjd-magazine-term-title .sjd-sparkle svg {
  width: 20px;
  height: 20px;
}

.sjd-magazine-term-count {
  margin: 0;
  font-size: 14px;
  color: var(--sjd-text-muted);
}

.sjd-magazine-term-desc {
  margin: 10px 0 0;
  max-width: 560px;
  font-size: 13px;
  line-height: 1.65;
  color: var(--sjd-text-muted);
}

.sjd-magazine-term-back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 16px;
  font-size: 13px;
  font-weight: 600;
  color: var(--sjd-purple);
}

.sjd-magazine-term-back svg {
  width: 14px;
  height: 14px;
  transform: rotate(180deg);
}

.sjd-magazine-term-back:hover {
  color: var(--sjd-purple-dark);
}

.sjd-magazine-term-featured {
  position: relative;
  display: block;
  aspect-ratio: 3 / 4;
  border-radius: var(--sjd-radius);
  overflow: hidden;
  box-shadow: var(--sjd-shadow-lg);
  transition: transform var(--sjd-transition), box-shadow var(--sjd-transition);
}

.sjd-magazine-term-featured:hover {
  transform: translateY(-4px) scale(1.02);
  box-shadow: 0 16px 36px rgba(15, 23, 42, .14);
}

.sjd-magazine-term-featured-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sjd-magazine-term-featured-label {
  position: absolute;
  top: 8px;
  left: 8px;
  padding: 4px 8px;
  border-radius: 4px;
  background: var(--sjd-purple);
  color: #fff;
  font-size: 10px;
  font-weight: 600;
}

.sjd-page-magazine-term .sjd-magazine-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

/* Region taxonomy archive */
.sjd-page-region {
  padding: 24px 0 56px;
}

.sjd-page-layout--region {
  grid-template-columns: 220px minmax(0, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
  align-items: start;
}

.sjd-sidebar--region .sjd-sidebar-title {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 16px;
}

.sjd-sidebar--region .sjd-sidebar-item {
  width: 100%;
  text-align: left;
  text-decoration: none;
}

.sjd-region-nav-item.is-active {
  background: var(--sjd-purple-bg);
  color: var(--sjd-purple-dark);
  font-weight: 600;
}

.sjd-region-column-link {
  gap: 8px;
}

.sjd-region-column-icon {
  flex-shrink: 0;
  width: 18px;
  text-align: center;
  font-size: 14px;
  line-height: 1;
}

.sjd-region-term-header {
  margin-bottom: 24px;
  padding: 24px 28px;
  border-radius: var(--sjd-radius-lg);
  background: linear-gradient(135deg, #eff6ff 0%, #f5f9ff 45%, #fafbfd 100%);
  border: 1px solid rgba(59, 130, 246, .1);
}

.sjd-region-term-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-bottom: 18px;
  font-size: 12px;
  color: var(--sjd-text-muted);
}

.sjd-region-term-breadcrumb a {
  color: var(--sjd-text-muted);
  transition: color var(--sjd-transition);
}

.sjd-region-term-breadcrumb a:hover {
  color: var(--sjd-purple);
}

.sjd-region-term-header-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 140px;
  gap: clamp(20px, 3vw, 32px);
  align-items: center;
}

.sjd-region-term-eyebrow {
  margin: 0 0 8px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #2563EB;
}

.sjd-region-term-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 8px;
  font-size: clamp(24px, 2.8vw, 32px);
  font-weight: 700;
  line-height: 1.2;
}

.sjd-region-term-title .sjd-sparkle {
  color: var(--sjd-purple);
  display: inline-flex;
}

.sjd-region-term-title .sjd-sparkle svg {
  width: 20px;
  height: 20px;
}

.sjd-region-term-count {
  margin: 0;
  font-size: 14px;
  color: var(--sjd-text-muted);
}

.sjd-region-term-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 20px;
  margin-top: 14px;
  font-size: 13px;
  color: var(--sjd-text-muted);
}

.sjd-region-term-stats strong {
  color: var(--sjd-text);
  font-size: 15px;
  margin-right: 4px;
}

.sjd-region-term-desc {
  margin: 12px 0 0;
  max-width: 620px;
  font-size: 13px;
  line-height: 1.65;
  color: var(--sjd-text-muted);
}

.sjd-region-term-featured {
  position: relative;
  display: block;
  aspect-ratio: 3 / 4;
  border-radius: var(--sjd-radius);
  overflow: hidden;
  box-shadow: var(--sjd-shadow-lg);
  transition: transform var(--sjd-transition), box-shadow var(--sjd-transition);
}

.sjd-region-term-featured:hover {
  transform: translateY(-4px) scale(1.02);
  box-shadow: 0 16px 36px rgba(15, 23, 42, .14);
}

.sjd-region-term-featured-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sjd-region-term-featured-label {
  position: absolute;
  top: 8px;
  left: 8px;
  padding: 4px 8px;
  border-radius: 4px;
  background: #2563EB;
  color: #fff;
  font-size: 10px;
  font-weight: 600;
}

.sjd-region-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 20px;
}

.sjd-region-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid var(--sjd-border);
  background: var(--sjd-bg);
  font-size: 13px;
  color: var(--sjd-text-muted);
  transition: border-color var(--sjd-transition), background var(--sjd-transition), color var(--sjd-transition);
}

.sjd-region-tab:hover {
  border-color: var(--sjd-purple);
  color: var(--sjd-text);
}

.sjd-region-tab.is-active {
  background: var(--sjd-black);
  border-color: var(--sjd-black);
  color: #fff;
}

.sjd-region-tab-count {
  font-size: 11px;
  opacity: .85;
}

.sjd-region-grid {
  margin-bottom: 28px;
}

.sjd-region-media-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(168px, 1fr));
  gap: clamp(14px, 1.6vw, 20px);
}

.sjd-region-section {
  margin-bottom: 36px;
}

.sjd-region-section:last-child {
  margin-bottom: 12px;
}

.sjd-region-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--sjd-border);
}

.sjd-region-section-title {
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.3;
}

.sjd-region-section-more {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 13px;
  font-weight: 600;
  color: var(--sjd-purple);
}

.sjd-region-section-more svg {
  width: 14px;
  height: 14px;
}

.sjd-region-section-more:hover {
  color: var(--sjd-purple-dark);
}

.sjd-people-grid--region {
  grid-template-columns: repeat(auto-fill, minmax(108px, 1fr));
  gap: 12px;
  align-items: start;
}

.sjd-people-grid--region .sjd-people-card {
  flex: none;
  width: auto;
  height: auto;
}

.sjd-people-card--portrait {
  padding: 0;
  text-align: left;
  overflow: hidden;
  border-radius: var(--sjd-radius-lg);
}

.sjd-people-card--portrait .sjd-people-card-link {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: inherit;
}

.sjd-people-card--portrait .sjd-people-card-image {
  position: relative;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: var(--sjd-gray-100);
}

.sjd-people-card--portrait .sjd-people-card-image .sjd-card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: auto;
}

.sjd-people-card--portrait .sjd-card-body {
  padding: 12px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.sjd-people-card--portrait .sjd-card-title {
  font-size: 13px;
  font-weight: 700;
  margin: 0;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sjd-people-card--portrait .sjd-people-role {
  margin: 0;
  font-size: 11px;
  line-height: 1.45;
  -webkit-line-clamp: 2;
}

.sjd-people-card--portrait .sjd-people-count-pill {
  margin-top: auto;
  align-self: flex-start;
}

.sjd-page-region .sjd-pagination {
  margin-top: 8px;
  margin-bottom: 8px;
}

.sjd-region-empty {
  padding: 56px 24px;
  text-align: center;
  border: 1px dashed var(--sjd-border);
  border-radius: var(--sjd-radius-lg);
}

.sjd-region-empty .sjd-btn {
  margin-top: 16px;
}

.sjd-magazine-toolbar {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--sjd-border);
}

.sjd-magazine-toolbar-title {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.3;
}

.sjd-magazine-toolbar-count {
  font-size: 13px;
  font-weight: 600;
  color: var(--sjd-purple);
}

.sjd-magazine-toolbar-hint {
  font-size: 12px;
  color: var(--sjd-text-muted);
  white-space: nowrap;
}

.sjd-magazine-banner {
  margin-bottom: 28px;
  padding: 28px 32px;
  border-radius: var(--sjd-radius-lg);
  background: linear-gradient(135deg, #f3efff 0%, #f8f6ff 45%, #faf9fc 100%);
  border: 1px solid rgba(168, 85, 247, .08);
}

.sjd-magazine-banner-inner {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: clamp(20px, 3vw, 36px);
  align-items: center;
}

.sjd-magazine-banner-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 700;
  line-height: 1.2;
}

.sjd-magazine-banner-title .sjd-sparkle { color: var(--sjd-purple); display: inline-flex; }
.sjd-magazine-banner-title .sjd-sparkle svg { width: 20px; height: 20px; }

.sjd-magazine-banner-desc {
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.65;
  color: var(--sjd-text-muted);
  max-width: 280px;
}

.sjd-magazine-banner-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 24px;
  margin-top: 16px;
  font-size: 13px;
  color: var(--sjd-text-muted);
}

.sjd-magazine-banner-stats strong {
  color: var(--sjd-text);
  font-size: 16px;
  margin-right: 4px;
}

.sjd-magazine-cover-stack {
  position: relative;
  height: 220px;
  min-width: 0;
}

.sjd-magazine-cover-item {
  position: absolute;
  top: 50%;
  width: 120px;
  aspect-ratio: 3 / 4;
  border-radius: var(--sjd-radius);
  overflow: hidden;
  box-shadow: var(--sjd-shadow-lg);
  transform: translateY(-50%) rotate(calc((var(--mag-index) - 2) * 4deg)) translateX(calc(var(--mag-index) * 56px));
  transition: transform var(--sjd-transition), z-index var(--sjd-transition);
  z-index: calc(var(--mag-index) + 1);
}

.sjd-magazine-cover-item:hover {
  transform: translateY(calc(-50% - 6px)) rotate(0deg) translateX(calc(var(--mag-index) * 56px)) scale(1.03);
  z-index: 10;
}

.sjd-magazine-cover-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sjd-magazine-popular { margin-bottom: 28px; }

.sjd-magazine-popular-scroll {
  position: relative;
}

.sjd-magazine-popular-track {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-snap-type: x proximity;
  padding: 4px 48px 8px 4px;
  scrollbar-width: none;
}

.sjd-magazine-popular-track::-webkit-scrollbar { display: none; }

.sjd-magazine-popular-card {
  flex: 0 0 180px;
  scroll-snap-align: start;
  color: inherit;
}

.sjd-magazine-popular-bg {
  position: relative;
  aspect-ratio: 16 / 10;
  border-radius: var(--sjd-radius);
  overflow: hidden;
  margin-bottom: 8px;
}

.sjd-magazine-popular-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sjd-magazine-popular-overlay {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, .35);
}

.sjd-magazine-popular-logo {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: .12em;
  color: #fff;
  text-shadow: 0 2px 8px rgba(0,0,0,.35);
}

.sjd-magazine-popular-info strong {
  display: block;
  font-size: 13px;
  margin-bottom: 2px;
}

.sjd-magazine-popular-info span {
  font-size: 11px;
  color: var(--sjd-text-muted);
}

.sjd-magazine-scroll-btn {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid var(--sjd-border);
  background: var(--sjd-bg);
  box-shadow: var(--sjd-shadow);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.sjd-magazine-scroll-btn svg { width: 18px; height: 18px; }

.sjd-magazine-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(168px, 1fr));
  gap: clamp(14px, 1.6vw, 20px);
  margin-bottom: 32px;
}

.sjd-magazine-empty {
  grid-column: 1 / -1;
  padding: 48px 24px;
  text-align: center;
  border: 1px dashed var(--sjd-border);
  border-radius: var(--sjd-radius-lg);
  color: var(--sjd-text-muted);
  font-size: 14px;
}

.sjd-magazine-load-more {
  display: block;
  width: 100%;
  max-width: 320px;
  margin: 0 auto 40px;
}

.sjd-page-magazine .sjd-magazine-card {
  border-radius: var(--sjd-radius-lg);
  border-color: rgba(15, 23, 42, .08);
  box-shadow: 0 1px 2px rgba(15, 23, 42, .04);
}

.sjd-page-magazine .sjd-magazine-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(15, 23, 42, .08);
  border-color: rgba(168, 85, 247, .18);
}

.sjd-magazine-card-image {
  aspect-ratio: 3 / 4;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, var(--sjd-gray-50) 0%, var(--sjd-gray-100) 100%);
}

.sjd-magazine-card-image .sjd-card-img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  aspect-ratio: auto;
  object-fit: contain;
  object-position: center center;
}

.sjd-magazine-card:hover .sjd-card-img {
  transform: none;
}

.sjd-magazine-card-badges {
  position: absolute;
  inset: 8px 8px auto 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  z-index: 2;
}

.sjd-magazine-card-badges .sjd-badge {
  position: static;
  padding: 4px 8px;
  font-size: 10px;
  letter-spacing: .02em;
}

.sjd-page-magazine .sjd-magazine-card .sjd-card-body {
  padding: 12px 12px 0;
}

.sjd-page-magazine .sjd-magazine-card .sjd-card-title {
  font-size: 13px;
  font-weight: 700;
  line-height: 1.45;
  min-height: 2.9em;
}

.sjd-magazine-card-meta {
  margin-top: 6px;
  font-size: 11px;
  line-height: 1.5;
}

.sjd-page-magazine .sjd-magazine-card .sjd-card-actions {
  padding: 10px 12px;
  margin-top: 0;
}

.sjd-magazine-footer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 24px;
  padding-top: 8px;
  border-top: 1px solid var(--sjd-border);
}

.sjd-magazine-topic-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.sjd-magazine-topic-card {
  display: flex;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius);
  background: var(--sjd-bg);
  color: inherit;
  transition: border-color var(--sjd-transition), box-shadow var(--sjd-transition);
}

.sjd-magazine-topic-card:hover {
  border-color: var(--sjd-purple-light);
  box-shadow: var(--sjd-shadow);
}

.sjd-magazine-topic-text {
  flex: 1;
  min-width: 0;
}

.sjd-magazine-topic-text h3 {
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 4px;
  line-height: 1.35;
}

.sjd-magazine-topic-text p {
  font-size: 11px;
  color: var(--sjd-text-muted);
  line-height: 1.5;
  margin-bottom: 6px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sjd-magazine-topic-text span {
  font-size: 10px;
  color: var(--sjd-purple-dark);
}

.sjd-magazine-topic-thumb {
  flex-shrink: 0;
  width: 72px;
  height: 72px;
  border-radius: var(--sjd-radius-sm);
  overflow: hidden;
}

.sjd-magazine-topic-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sjd-magazine-hot-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.sjd-magazine-hot-item {
  display: grid;
  grid-template-columns: 24px 48px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--sjd-border);
  color: inherit;
}

.sjd-magazine-hot-rank {
  font-weight: 700;
  color: var(--sjd-purple);
  font-size: 13px;
}

.sjd-magazine-hot-thumb {
  width: 48px;
  height: 48px;
  border-radius: var(--sjd-radius-sm);
  overflow: hidden;
}

.sjd-magazine-hot-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sjd-magazine-hot-body strong {
  display: block;
  font-size: 12px;
  line-height: 1.35;
}

.sjd-magazine-hot-body span {
  display: block;
  font-size: 11px;
  color: var(--sjd-text-muted);
  margin-top: 2px;
}

.sjd-magazine-hot-item em {
  font-style: normal;
  font-size: 11px;
  color: var(--sjd-text-muted);
  white-space: nowrap;
}

/* Brand Campaign Page */
.sjd-page-brand { padding-top: 24px; }

.sjd-page-layout--brand {
  grid-template-columns: 220px minmax(0, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
  align-items: start;
}

.sjd-sidebar--brand .sjd-brand-sidebar-checks {
  max-height: 220px;
  overflow-y: auto;
  scrollbar-width: thin;
}

.sjd-brand-sidebar-search-wrap {
  margin-bottom: 10px;
}

.sjd-brand-sidebar-search {
  width: 100%;
  padding: 9px 12px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius);
  background: var(--sjd-bg);
  font-size: 13px;
  color: var(--sjd-text);
}

.sjd-brand-sidebar-checks {
  max-height: 220px;
  overflow-y: auto;
  scrollbar-width: thin;
}

.sjd-brand-check-box,
.sjd-brand-season-radio {
  width: 14px;
  height: 14px;
  border: 1px solid var(--sjd-border);
  border-radius: 3px;
  flex-shrink: 0;
  background: var(--sjd-bg);
}

.sjd-brand-season-radio {
  border-radius: 50%;
}

.sjd-brand-banner {
  margin-bottom: 28px;
  padding: 28px 32px;
  border-radius: var(--sjd-radius-lg);
  background: linear-gradient(135deg, #f3efff 0%, #f8f6ff 45%, #faf9fc 100%);
  border: 1px solid rgba(168, 85, 247, .08);
}

.sjd-brand-banner-inner {
  display: grid;
  grid-template-columns: minmax(240px, 320px) minmax(0, 1fr);
  gap: clamp(20px, 3vw, 36px);
  align-items: center;
}

.sjd-brand-banner-head {
  min-width: 0;
}

.sjd-brand-banner-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 700;
  line-height: 1.2;
}

.sjd-brand-banner-title .sjd-sparkle { color: var(--sjd-purple); display: inline-flex; }

.sjd-brand-banner-desc {
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.65;
  color: var(--sjd-text-muted);
  max-width: 320px;
}

.sjd-brand-banner-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 24px;
  margin-top: 16px;
  font-size: 13px;
  color: var(--sjd-text-muted);
}

.sjd-brand-banner-stats strong {
  color: var(--sjd-text);
  font-size: 16px;
  margin-right: 4px;
}

.sjd-brand-banner-search {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 18px;
  max-width: 100%;
}

.sjd-brand-banner-search input {
  flex: 1;
  min-width: 0;
  padding: 11px 16px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-xl);
  background: var(--sjd-bg);
  font-size: 14px;
}

.sjd-brand-banner-search .sjd-btn-dark {
  width: 42px;
  height: 42px;
  padding: 0;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.sjd-brand-featured {
  position: relative;
  display: block;
  min-height: 240px;
  border-radius: var(--sjd-radius-lg);
  overflow: hidden;
  color: #fff;
  box-shadow: 0 10px 30px rgba(15, 23, 42, .12);
}

.sjd-brand-featured-media {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.sjd-brand-featured-media img,
.sjd-brand-featured-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sjd-brand-featured-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg, rgba(0, 0, 0, .08) 0%, rgba(0, 0, 0, .72) 100%);
}

.sjd-brand-featured-body {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 240px;
  padding: 24px;
  max-width: 100%;
}

.sjd-brand-featured-label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  opacity: .9;
}

.sjd-brand-featured-body strong {
  display: block;
  margin-top: 6px;
  font-size: clamp(16px, 1.8vw, 22px);
  line-height: 1.3;
  max-width: 100%;
}

.sjd-brand-featured-body em {
  display: block;
  margin-top: 4px;
  font-style: normal;
  font-size: 12px;
  opacity: .85;
}

.sjd-brand-featured-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 14px;
  padding: 8px 14px;
  width: fit-content;
  max-width: 100%;
  white-space: nowrap;
  font-size: 13px;
  font-weight: 600;
  line-height: 1;
  border-radius: 999px;
  background: rgba(255, 255, 255, .16);
  backdrop-filter: blur(6px);
}

.sjd-brand-featured-cta svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

.sjd-brand-popular { margin-bottom: 24px; }

.sjd-brand-popular-scroll,
.sjd-horizontal-scroll {
  position: relative;
}

.sjd-brand-popular-track {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 4px;
  scrollbar-width: none;
}

.sjd-brand-popular-track::-webkit-scrollbar { display: none; }

.sjd-brand-popular-card {
  flex: 0 0 min(180px, 42vw);
  scroll-snap-align: start;
  color: inherit;
}

.sjd-brand-popular-bg {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--sjd-radius-lg);
  overflow: hidden;
  background: var(--sjd-gray-100);
}

.sjd-brand-popular-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sjd-brand-popular-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.05) 0%, rgba(0,0,0,.55) 100%);
}

.sjd-brand-popular-logo {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 12px;
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  letter-spacing: .04em;
}

.sjd-brand-popular-info {
  padding: 8px 2px 0;
}

.sjd-brand-popular-info strong {
  display: block;
  font-size: 13px;
}

.sjd-brand-popular-info span {
  font-size: 11px;
  color: var(--sjd-text-muted);
}

.sjd-horizontal-scroll-btn,
.sjd-magazine-scroll-btn {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--sjd-border);
  background: var(--sjd-bg);
  box-shadow: var(--sjd-shadow);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.sjd-brand-grid { margin-bottom: 24px; }

.sjd-brand-card-image { aspect-ratio: 3 / 4; }

.sjd-brand-card-badges {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 2;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.sjd-brand-card-badges .sjd-badge { position: static; }

.sjd-page-brand .sjd-btn-load-more {
  display: block;
  width: 100%;
  max-width: 280px;
  margin: 0 auto 40px;
}

.sjd-brand-footer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 24px;
  padding-top: 8px;
  border-top: 1px solid var(--sjd-border);
}

.sjd-brand-theme-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.sjd-brand-theme-card {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 14px 16px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius);
  background: var(--sjd-bg);
  color: inherit;
  transition: border-color var(--sjd-transition), box-shadow var(--sjd-transition);
}

.sjd-brand-theme-card:hover {
  border-color: var(--sjd-purple);
  box-shadow: 0 4px 14px rgba(124, 58, 237, .08);
}

.sjd-brand-theme-card strong { font-size: 14px; }
.sjd-brand-theme-card span { font-size: 11px; color: var(--sjd-text-muted); }

.sjd-brand-hot-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.sjd-brand-hot-item {
  display: grid;
  grid-template-columns: 24px 52px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius);
  color: inherit;
  transition: border-color var(--sjd-transition);
}

.sjd-brand-hot-item:hover { border-color: var(--sjd-purple); }

.sjd-brand-hot-rank {
  font-size: 14px;
  font-weight: 700;
  color: var(--sjd-gray-400);
  text-align: center;
}

.sjd-brand-hot-thumb {
  width: 52px;
  height: 52px;
  border-radius: 8px;
  overflow: hidden;
  background: var(--sjd-gray-100);
}

.sjd-brand-hot-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sjd-brand-hot-body strong {
  display: block;
  font-size: 13px;
  line-height: 1.35;
}

.sjd-brand-hot-body span {
  display: block;
  font-size: 11px;
  color: var(--sjd-text-muted);
  margin-top: 2px;
}

.sjd-brand-hot-item em {
  font-style: normal;
  font-size: 11px;
  color: var(--sjd-text-muted);
  white-space: nowrap;
}

.sjd-brand-grid.sjd-list-view {
  grid-template-columns: 1fr;
}

.sjd-brand-grid.sjd-list-view .sjd-brand-card .sjd-card-link {
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  gap: 16px;
}

.sjd-brand-grid.sjd-list-view .sjd-brand-card-image {
  aspect-ratio: 3 / 4;
}

/* Prompt Library Page */
.sjd-page-layout--prompt {
  grid-template-columns: 220px minmax(0, 1fr) 280px;
  gap: clamp(20px, 2.5vw, 32px);
}

.sjd-prompt-model-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: color-mix(in srgb, var(--model-color, var(--sjd-purple)) 14%, transparent);
  color: var(--model-color, var(--sjd-purple));
  font-size: 10px;
  font-weight: 700;
  flex-shrink: 0;
}

.sjd-prompt-banner {
  margin-bottom: 24px;
  padding: 28px 32px;
  border-radius: var(--sjd-radius-lg);
  background: linear-gradient(135deg, #f3efff 0%, #f8f6ff 45%, #faf9fc 100%);
  border: 1px solid rgba(168, 85, 247, .08);
  overflow: hidden;
}

.sjd-prompt-banner-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 380px);
  gap: clamp(20px, 3vw, 36px);
  align-items: center;
}

.sjd-prompt-banner-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 700;
  line-height: 1.2;
}

.sjd-prompt-banner-title .sjd-sparkle {
  color: var(--sjd-purple);
  display: inline-flex;
}

.sjd-prompt-banner-title .sjd-sparkle svg {
  width: 20px;
  height: 20px;
}

.sjd-prompt-banner-desc {
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.65;
  color: var(--sjd-text-muted);
  max-width: 520px;
}

.sjd-prompt-banner-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 24px;
  margin-top: 16px;
  font-size: 13px;
  color: var(--sjd-text-muted);
}

.sjd-prompt-banner-stats strong {
  color: var(--sjd-text);
  font-size: 16px;
  margin-right: 4px;
}

.sjd-prompt-banner-search {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 18px;
  max-width: 100%;
}

.sjd-prompt-banner-search input {
  flex: 1;
  min-width: 0;
  padding: 11px 16px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-xl);
  background: var(--sjd-bg);
  font-size: 14px;
}

.sjd-prompt-banner-search .sjd-btn-dark {
  width: 42px;
  height: 42px;
  padding: 0;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.sjd-prompt-banner-side {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(120px, 160px);
  gap: 12px;
  align-items: stretch;
  min-height: 180px;
}

.sjd-prompt-quick-links {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.sjd-prompt-quick-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: var(--sjd-radius);
  background: rgba(255, 255, 255, .82);
  border: 1px solid rgba(168, 85, 247, .08);
  color: inherit;
  transition: border-color var(--sjd-transition), box-shadow var(--sjd-transition);
}

.sjd-prompt-quick-link:hover {
  border-color: var(--sjd-purple);
  box-shadow: 0 4px 14px rgba(124, 58, 237, .08);
}

.sjd-prompt-quick-link-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.sjd-prompt-quick-link-body strong {
  font-size: 12px;
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sjd-prompt-quick-link-body em {
  font-style: normal;
  font-size: 11px;
  color: var(--sjd-text-muted);
}

.sjd-prompt-banner-visual {
  position: relative;
  border-radius: var(--sjd-radius-lg);
  overflow: hidden;
  box-shadow: 0 12px 32px rgba(15, 23, 42, .14);
}

.sjd-prompt-banner-visual-link {
  display: block;
  height: 100%;
}

.sjd-prompt-banner-visual-img {
  width: 100%;
  height: 100%;
  min-height: 180px;
  object-fit: cover;
  display: block;
}

.sjd-page-content--prompt .sjd-filter-bar {
  margin-bottom: 20px;
}

.sjd-prompt-grid {
  margin-bottom: 8px;
}

.sjd-prompt-grid.sjd-list-view {
  grid-template-columns: 1fr;
}

.sjd-prompt-grid.sjd-list-view .sjd-prompt-card .sjd-card-link {
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  gap: 16px;
}

.sjd-prompt-grid.sjd-list-view .sjd-prompt-card-image {
  aspect-ratio: 3 / 4;
}

.sjd-prompt-load-wrap {
  display: flex;
  justify-content: center;
  margin-top: 24px;
}

.sjd-prompt-load-more {
  min-width: 220px;
}

.sjd-prompt-card-badges {
  position: absolute;
  top: 8px;
  left: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  z-index: 2;
}

.sjd-prompt-card-badges .sjd-badge {
  position: static;
}

.sjd-prompt-card-footer {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--sjd-border);
  font-size: 11px;
  color: var(--sjd-text-muted);
}

.sjd-prompt-card-author {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  flex: 1;
}

.sjd-prompt-card-author .sjd-prompt-card-avatar {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  flex-shrink: 0;
}

.sjd-prompt-card-time {
  white-space: nowrap;
}

.sjd-prompt-card-views {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-left: auto;
  white-space: nowrap;
}

.sjd-prompt-card-views svg {
  width: 12px;
  height: 12px;
}

.sjd-prompt-widget-hot,
.sjd-prompt-widget-tags,
.sjd-prompt-widget-guide {
  background: var(--sjd-bg);
  border: 1px solid var(--sjd-border);
}

.sjd-prompt-hot-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.sjd-prompt-hot-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--sjd-border);
  color: inherit;
}

.sjd-prompt-hot-item:last-child {
  border-bottom: none;
}

.sjd-prompt-hot-thumb {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: var(--sjd-radius-sm);
  overflow: hidden;
}

.sjd-prompt-hot-thumb-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sjd-prompt-hot-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
  flex: 1;
}

.sjd-prompt-hot-info strong {
  font-size: 12px;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sjd-prompt-hot-score {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: #EF4444;
}

.sjd-prompt-hot-score svg {
  width: 12px;
  height: 12px;
}

.sjd-prompt-tag-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.sjd-prompt-tag-pill {
  display: inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--sjd-gray-50);
  font-size: 11px;
  color: var(--sjd-text-muted);
  transition: background var(--sjd-transition), color var(--sjd-transition);
}

a.sjd-prompt-tag-pill:hover {
  background: var(--sjd-purple-light);
  color: var(--sjd-purple-dark);
}

.sjd-prompt-widget-guide {
  background: linear-gradient(160deg, rgba(124, 58, 237, .08) 0%, rgba(124, 58, 237, .02) 100%);
  border-color: rgba(124, 58, 237, .12);
}

.sjd-prompt-guide-btn {
  width: 100%;
  justify-content: center;
}

/* Photo Style Page */
.sjd-page-layout--photo-style {
  grid-template-columns: 220px minmax(0, 1fr) 280px;
  gap: clamp(20px, 2.5vw, 32px);
}

.sjd-sidebar--photo-style .sjd-photo-style-icon,
.sjd-sidebar--library .sjd-library-icon {
  width: 22px;
  text-align: center;
}

.sjd-photo-style-hot-mini {
  list-style: none;
  margin: 0;
  padding: 0;
}

.sjd-photo-style-hot-mini-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--sjd-border);
  color: inherit;
}

.sjd-photo-style-hot-mini-item:last-child {
  border-bottom: none;
}

.sjd-photo-style-hot-mini-thumb {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: var(--sjd-radius-sm);
  overflow: hidden;
}

.sjd-photo-style-hot-mini-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sjd-photo-style-hot-mini-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.sjd-photo-style-hot-mini-info strong {
  font-size: 12px;
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sjd-photo-style-hot-mini-info em {
  font-style: normal;
  font-size: 11px;
  color: var(--sjd-text-muted);
}

.sjd-photo-style-banner {
  margin-bottom: 24px;
}

.sjd-photo-style-banner-head {
  margin-bottom: 20px;
  padding: 28px 32px;
  border-radius: var(--sjd-radius-lg);
  background: linear-gradient(135deg, #f3efff 0%, #f8f6ff 45%, #faf9fc 100%);
  border: 1px solid rgba(168, 85, 247, .08);
}

.sjd-photo-style-banner-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 700;
  line-height: 1.2;
}

.sjd-photo-style-banner-title .sjd-sparkle {
  color: var(--sjd-purple);
  display: inline-flex;
}

.sjd-photo-style-banner-title .sjd-sparkle svg {
  width: 20px;
  height: 20px;
}

.sjd-photo-style-banner-desc {
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.65;
  color: var(--sjd-text-muted);
  max-width: 640px;
}

.sjd-photo-style-banner-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 24px;
  margin-top: 16px;
  font-size: 13px;
  color: var(--sjd-text-muted);
}

.sjd-photo-style-banner-stats strong {
  color: var(--sjd-text);
  font-size: 16px;
  margin-right: 4px;
}

.sjd-photo-style-banner-search {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 18px;
  max-width: 100%;
}

.sjd-photo-style-banner-search input {
  flex: 1;
  min-width: 0;
  padding: 11px 16px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-xl);
  background: var(--sjd-bg);
  font-size: 14px;
}

.sjd-photo-style-banner-search .sjd-btn-dark {
  width: 42px;
  height: 42px;
  padding: 0;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.sjd-photo-style-featured {
  position: relative;
  border-radius: var(--sjd-radius-lg);
  overflow: hidden;
  background: var(--sjd-black);
  box-shadow: 0 12px 32px rgba(15, 23, 42, .14);
}

.sjd-photo-style-featured-slide {
  display: none;
  grid-template-columns: minmax(0, 1.05fr) minmax(280px, 1fr);
  min-height: 280px;
  color: #fff;
}

.sjd-photo-style-featured-slide.is-active {
  display: grid;
}

.sjd-photo-style-featured-media {
  position: relative;
  min-height: 280px;
}

.sjd-photo-style-featured-img {
  width: 100%;
  height: 100%;
  min-height: 280px;
  object-fit: cover;
  display: block;
}

.sjd-photo-style-featured-body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(24px, 4vw, 40px);
  background: linear-gradient(180deg, rgba(10, 10, 10, .92) 0%, rgba(10, 10, 10, .98) 100%);
}

.sjd-photo-style-featured-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .72;
}

.sjd-photo-style-featured-body h2 {
  margin-top: 8px;
  font-size: clamp(22px, 2.4vw, 30px);
  line-height: 1.25;
}

.sjd-photo-style-featured-body p {
  margin-top: 12px;
  font-size: 13px;
  line-height: 1.7;
  color: rgba(255, 255, 255, .72);
  max-width: 420px;
}

.sjd-photo-style-featured-cta {
  margin-top: 20px;
  width: fit-content;
  gap: 8px;
}

.sjd-photo-style-featured-cta svg {
  width: 14px;
  height: 14px;
}

.sjd-photo-style-featured-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, .14);
  color: #fff;
  backdrop-filter: blur(6px);
  z-index: 2;
}

.sjd-photo-style-featured-nav svg {
  width: 16px;
  height: 16px;
}

.sjd-photo-style-featured-prev {
  left: 12px;
}

.sjd-photo-style-featured-prev svg {
  transform: rotate(180deg);
}

.sjd-photo-style-featured-next {
  right: 12px;
}

.sjd-photo-style-featured-dots {
  position: absolute;
  left: 50%;
  bottom: 14px;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 2;
}

.sjd-photo-style-featured-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .35);
}

.sjd-photo-style-featured-dot.is-active {
  background: #fff;
  transform: scale(1.15);
}

.sjd-page-photo-style .sjd-filter-tab.is-active {
  background: var(--sjd-purple);
  color: #fff;
}

.sjd-photo-style-grid {
  margin-bottom: 8px;
}

.sjd-photo-style-grid.sjd-list-view {
  grid-template-columns: 1fr;
}

.sjd-photo-style-grid.sjd-list-view .sjd-style-card .sjd-card-link {
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  gap: 16px;
}

.sjd-photo-style-grid.sjd-list-view .sjd-style-card-image {
  aspect-ratio: 3 / 4;
}

.sjd-style-card-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 6px;
  font-size: 11px;
  color: var(--sjd-text-muted);
}

.sjd-style-card-stats span:not(:last-child)::after {
  content: '·';
  margin-left: 8px;
}

.sjd-style-card-footer {
  display: flex;
  align-items: center;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--sjd-border);
}

.sjd-style-card-author {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--sjd-text-muted);
  min-width: 0;
}

.sjd-style-card-avatar {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  flex-shrink: 0;
}

.sjd-style-card-verified {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--sjd-purple-light);
  color: var(--sjd-purple-dark);
  font-size: 9px;
  font-weight: 700;
}

.sjd-photo-style-load-wrap {
  display: flex;
  justify-content: center;
  margin-top: 24px;
}

.sjd-photo-style-load-more {
  min-width: 220px;
  gap: 8px;
}

.sjd-photo-style-load-more svg {
  width: 14px;
  height: 14px;
  transform: rotate(90deg);
}

.sjd-photo-style-widget-tool,
.sjd-photo-style-widget-compare,
.sjd-photo-style-widget-tags {
  background: var(--sjd-bg);
  border: 1px solid var(--sjd-border);
}

.sjd-photo-style-tool-list {
  margin: 0 0 16px;
  padding-left: 18px;
  font-size: 13px;
  color: var(--sjd-text-muted);
}

.sjd-photo-style-tool-list li {
  padding: 4px 0;
}

.sjd-photo-style-tool-btn {
  width: 100%;
  justify-content: center;
}

.sjd-photo-style-widget-tool {
  background: linear-gradient(160deg, rgba(124, 58, 237, .08) 0%, rgba(124, 58, 237, .02) 100%);
  border-color: rgba(124, 58, 237, .12);
}

.sjd-photo-style-compare-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.sjd-photo-style-compare-slot {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 88px;
  border: 1px dashed var(--sjd-border);
  border-radius: var(--sjd-radius);
  background: var(--sjd-gray-50);
  color: var(--sjd-text-muted);
  font-size: 24px;
}

.sjd-photo-style-compare-start {
  width: 100%;
  justify-content: center;
}

.sjd-photo-style-tag-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.sjd-photo-style-tag-pill {
  display: inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--sjd-gray-50);
  font-size: 11px;
  color: var(--sjd-text-muted);
  transition: background var(--sjd-transition), color var(--sjd-transition);
}

a.sjd-photo-style-tag-pill:hover {
  background: var(--sjd-purple-light);
  color: var(--sjd-purple-dark);
}

/* Color Trends Page */
.sjd-page-layout--color {
  grid-template-columns: 220px minmax(0, 1fr) 280px;
  gap: clamp(20px, 2.5vw, 32px);
}

.sjd-color-hue-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
  border: 1px solid rgba(0, 0, 0, .08);
}

.sjd-color-banner {
  margin-bottom: 24px;
}

.sjd-color-banner-head {
  margin-bottom: 20px;
  padding: 28px 32px;
  border-radius: var(--sjd-radius-lg);
  background: linear-gradient(135deg, #f3efff 0%, #f8f6ff 45%, #faf9fc 100%);
  border: 1px solid rgba(168, 85, 247, .08);
}

.sjd-color-banner-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 700;
  line-height: 1.2;
}

.sjd-color-banner-title .sjd-sparkle {
  color: var(--sjd-purple);
  display: inline-flex;
}

.sjd-color-banner-title .sjd-sparkle svg {
  width: 20px;
  height: 20px;
}

.sjd-color-banner-desc {
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.65;
  color: var(--sjd-text-muted);
  max-width: 640px;
}

.sjd-color-banner-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 24px;
  margin-top: 16px;
  font-size: 13px;
  color: var(--sjd-text-muted);
}

.sjd-color-banner-stats strong {
  color: var(--sjd-text);
  font-size: 16px;
  margin-right: 4px;
}

.sjd-color-banner-search {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 18px;
  max-width: 100%;
}

.sjd-color-banner-search input {
  flex: 1;
  min-width: 0;
  padding: 11px 16px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-xl);
  background: var(--sjd-bg);
  font-size: 14px;
}

.sjd-color-banner-search .sjd-btn-dark {
  width: 42px;
  height: 42px;
  padding: 0;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.sjd-color-featured-carousel {
  position: relative;
  border-radius: var(--sjd-radius-lg);
  overflow: hidden;
  box-shadow: 0 12px 32px rgba(15, 23, 42, .14);
}

.sjd-color-featured-slide {
  display: none;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 360px);
  min-height: 280px;
  background: linear-gradient(135deg, var(--color-accent, #6B5BD6) 0%, color-mix(in srgb, var(--color-accent, #6B5BD6) 72%, #111827) 100%);
  color: #fff;
}

.sjd-color-featured-slide.is-active {
  display: grid;
}

.sjd-color-featured-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(24px, 4vw, 40px);
}

.sjd-color-featured-eyebrow {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .06em;
  opacity: .82;
}

.sjd-color-featured-content h2 {
  margin-top: 10px;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.25;
}

.sjd-color-featured-en {
  margin-top: 8px;
  font-size: 13px;
  opacity: .88;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.sjd-color-featured-desc {
  margin-top: 12px;
  font-size: 13px;
  line-height: 1.7;
  color: rgba(255, 255, 255, .78);
  max-width: 520px;
}

.sjd-color-featured-cta {
  margin-top: 20px;
  width: fit-content;
  gap: 8px;
  color: #fff;
  border-color: rgba(255, 255, 255, .42);
}

.sjd-color-featured-cta:hover {
  background: rgba(255, 255, 255, .12);
}

.sjd-color-featured-cta svg {
  width: 14px;
  height: 14px;
}

.sjd-color-featured-media {
  position: relative;
  min-height: 280px;
}

.sjd-color-featured-img {
  width: 100%;
  height: 100%;
  min-height: 280px;
  object-fit: cover;
  display: block;
}

.sjd-color-featured-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, .16);
  color: #fff;
  backdrop-filter: blur(6px);
  z-index: 2;
}

.sjd-color-featured-nav svg {
  width: 16px;
  height: 16px;
}

.sjd-color-featured-prev {
  left: 12px;
}

.sjd-color-featured-prev svg {
  transform: rotate(180deg);
}

.sjd-color-featured-next {
  right: 12px;
}

.sjd-color-featured-dots {
  position: absolute;
  left: 50%;
  bottom: 14px;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 2;
}

.sjd-color-featured-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .35);
}

.sjd-color-featured-dot.is-active {
  background: #fff;
  transform: scale(1.15);
}

.sjd-page-color .sjd-filter-tab.is-active {
  background: var(--sjd-purple);
  color: #fff;
}

.sjd-color-grid {
  margin-bottom: 8px;
}

.sjd-color-load-wrap {
  display: flex;
  justify-content: center;
  margin-top: 24px;
}

.sjd-color-load-more {
  min-width: 220px;
  gap: 8px;
}

.sjd-color-load-more svg {
  width: 14px;
  height: 14px;
  transform: rotate(90deg);
}

.sjd-color-widget-report,
.sjd-color-widget-hot,
.sjd-color-widget-palettes {
  background: var(--sjd-bg);
  border: 1px solid var(--sjd-border);
}

.sjd-color-report-card {
  display: grid;
  gap: 12px;
}

.sjd-color-report-thumb {
  border-radius: var(--sjd-radius);
  overflow: hidden;
}

.sjd-color-report-img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  display: block;
}

.sjd-color-report-body strong {
  display: block;
  font-size: 14px;
  margin-bottom: 4px;
}

.sjd-color-report-body p {
  font-size: 12px;
  color: var(--sjd-text-muted);
  margin-bottom: 12px;
}

.sjd-color-report-btn {
  width: 100%;
  justify-content: center;
}

.sjd-color-widget-report {
  background: linear-gradient(160deg, rgba(124, 58, 237, .08) 0%, rgba(124, 58, 237, .02) 100%);
  border-color: rgba(124, 58, 237, .12);
}

.sjd-color-hot-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.sjd-color-hot-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--sjd-border);
  color: inherit;
}

.sjd-color-hot-item:last-child {
  border-bottom: none;
}

.sjd-color-hot-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  flex-shrink: 0;
  border: 1px solid rgba(0, 0, 0, .08);
}

.sjd-color-hot-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  flex: 1;
}

.sjd-color-hot-info strong {
  font-size: 12px;
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sjd-color-hot-info em {
  font-style: normal;
  font-size: 11px;
  color: var(--sjd-text-muted);
}

.sjd-color-palette-desc {
  font-size: 12px;
  color: var(--sjd-text-muted);
  margin-bottom: 12px;
}

.sjd-color-palette-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.sjd-color-palette-row {
  display: flex;
  gap: 8px;
}

.sjd-color-palette-dot {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid rgba(0, 0, 0, .08);
  flex-shrink: 0;
}

/* Single detail — sidebar + main (gallery + panel) */
.sjd-single-page-layout {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
  align-items: start;
}

.sjd-single-page-main {
  min-width: 0;
}

.sjd-sidebar--single .sjd-sidebar-title {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 16px;
  line-height: 1.35;
}

.sjd-sidebar--single .sjd-sidebar-title a {
  color: var(--sjd-text);
  transition: color var(--sjd-transition);
}

.sjd-sidebar--single .sjd-sidebar-title a:hover {
  color: var(--sjd-purple);
}

.sjd-sidebar--single .sjd-sidebar-item {
  width: 100%;
  text-align: left;
  text-decoration: none;
}

/* Detail single — shared two-column layout */
.sjd-detail-layout,
.sjd-magazine-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, 1fr);
  gap: clamp(28px, 4vw, 48px);
  align-items: start;
}

.sjd-detail-media,
.sjd-magazine-media {
  position: sticky;
  top: calc(var(--sjd-header-h) + 24px);
}

.admin-bar .sjd-detail-media,
.admin-bar .sjd-magazine-media {
  top: calc(var(--sjd-header-h) + 56px);
}

.sjd-detail-image,
.sjd-magazine-image {
  border-radius: var(--sjd-radius-lg);
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

.sjd-detail-image .sjd-detail-gallery-main,
.sjd-detail-image .sjd-magazine-slider-main,
.sjd-magazine-image .sjd-detail-gallery-main,
.sjd-magazine-image .sjd-magazine-slider-main {
  border-radius: var(--sjd-radius-lg);
  box-shadow: var(--sjd-shadow-lg);
}

.sjd-detail-panel,
.sjd-magazine-detail,
.sjd-visual-detail,
.sjd-brand-detail,
.sjd-prompt-detail {
  min-width: 0;
  padding: clamp(20px, 2.5vw, 24px);
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-lg);
  background: var(--sjd-bg);
}

.sjd-detail-panel .sjd-single-content {
  max-width: none;
}

.sjd-detail-gallery--empty {
  border-radius: var(--sjd-radius-lg);
  overflow: hidden;
  background: var(--sjd-gray-100);
  box-shadow: var(--sjd-shadow-lg);
}

.sjd-detail-gallery--empty .sjd-detail-gallery-slide-img {
  width: 100%;
  display: block;
}

/* Detail gallery slider (shared) */
.sjd-detail-gallery,
.sjd-magazine-slider {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.sjd-detail-gallery-main,
.sjd-magazine-slider-main {
  position: relative;
  aspect-ratio: 3 / 4;
  background: var(--sjd-gray-100);
  border-radius: inherit;
  overflow: hidden;
  cursor: zoom-in;
}

.sjd-detail-gallery-track,
.sjd-magazine-slider-track {
  position: relative;
  width: 100%;
  height: 100%;
}

.sjd-detail-gallery-slide,
.sjd-magazine-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity .55s ease, visibility .55s ease;
  z-index: 0;
}

.sjd-detail-gallery-slide.is-active,
.sjd-magazine-slide.is-active {
  opacity: 1;
  visibility: visible;
  z-index: 1;
}

.sjd-detail-gallery-slide-img,
.sjd-magazine-slide-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sjd-detail-gallery-nav,
.sjd-magazine-slider-nav {
  position: absolute;
  top: 50%;
  z-index: 4;
  width: 40px;
  height: 40px;
  margin-top: -20px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(255, 255, 255, .9);
  color: var(--sjd-text);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 2px 12px rgba(0, 0, 0, .18);
  opacity: 0;
  -webkit-appearance: none;
  appearance: none;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition: opacity var(--sjd-transition), background var(--sjd-transition), color var(--sjd-transition), transform var(--sjd-transition);
}

.sjd-detail-gallery-main:hover .sjd-detail-gallery-nav,
.sjd-detail-gallery-main:focus-within .sjd-detail-gallery-nav,
.sjd-detail-gallery.is-fullscreen .sjd-detail-gallery-nav,
.sjd-magazine-slider-main:hover .sjd-magazine-slider-nav,
.sjd-magazine-slider-main:focus-within .sjd-magazine-slider-nav,
.sjd-magazine-slider.is-fullscreen .sjd-magazine-slider-nav {
  opacity: 1;
}

.sjd-detail-gallery-nav:hover,
.sjd-magazine-slider-nav:hover {
  background: #fff;
  color: var(--sjd-purple);
  transform: scale(1.06);
}

.sjd-detail-gallery-nav svg,
.sjd-magazine-slider-nav svg {
  width: 18px;
  height: 18px;
}

.sjd-detail-gallery-prev,
.sjd-magazine-slider-prev { left: 12px; }

.sjd-detail-gallery-prev svg,
.sjd-magazine-slider-prev svg { transform: rotate(180deg); }

.sjd-detail-gallery-next,
.sjd-magazine-slider-next { right: 12px; }

.sjd-detail-gallery-count,
.sjd-magazine-slider-count {
  position: absolute;
  right: 12px;
  bottom: 12px;
  z-index: 4;
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 500;
  color: #fff;
  background: rgba(0, 0, 0, .5);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  pointer-events: none;
}

.sjd-detail-gallery-fs,
.sjd-magazine-slider-fs {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 5;
  width: 36px;
  height: 36px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(0, 0, 0, .45);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition: background var(--sjd-transition), transform var(--sjd-transition);
}

.sjd-detail-gallery-fs:hover,
.sjd-magazine-slider-fs:hover {
  background: rgba(0, 0, 0, .65);
  transform: scale(1.05);
}

.sjd-detail-gallery-fs svg,
.sjd-magazine-slider-fs svg {
  width: 18px;
  height: 18px;
}

.sjd-detail-gallery-fs--close,
.sjd-magazine-slider-fs--close {
  top: max(12px, env(safe-area-inset-top, 0px));
  right: max(12px, env(safe-area-inset-right, 0px));
  width: 44px;
  height: 44px;
  background: rgba(255, 255, 255, .15);
}

.sjd-detail-gallery-fs--close[hidden],
.sjd-magazine-slider-fs--close[hidden] { display: none; }

.sjd-detail-gallery.is-fullscreen .sjd-detail-gallery-fs[data-gallery-fs-open],
.sjd-detail-gallery.is-fullscreen .sjd-detail-gallery-fs[data-magazine-fs-open],
.sjd-magazine-slider.is-fullscreen .sjd-magazine-slider-fs[data-magazine-fs-open] {
  display: none;
}

.sjd-detail-gallery.is-fullscreen,
.sjd-magazine-slider.is-fullscreen {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  height: 100dvh;
  min-height: -webkit-fill-available;
  z-index: 2147483646;
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 10px;
  padding: max(8px, env(safe-area-inset-top, 0px)) max(8px, env(safe-area-inset-right, 0px)) max(8px, env(safe-area-inset-bottom, 0px)) max(8px, env(safe-area-inset-left, 0px));
  background: #000;
  border-radius: 0;
  outline: none;
  transform: translateZ(0);
  overscroll-behavior: contain;
  box-sizing: border-box;
}

.sjd-detail-gallery.is-fs-portal,
.sjd-magazine-slider.is-fs-portal { margin: 0; }

.sjd-detail-gallery.is-fullscreen .sjd-detail-gallery-main,
.sjd-magazine-slider.is-fullscreen .sjd-magazine-slider-main {
  position: relative;
  flex: none;
  min-height: 0;
  height: 100%;
  aspect-ratio: unset;
  max-height: none;
  border-radius: 0;
  box-shadow: none;
  cursor: default;
  background: #000;
  overflow: hidden;
}

.sjd-detail-gallery.is-fullscreen .sjd-detail-gallery-track,
.sjd-magazine-slider.is-fullscreen .sjd-magazine-slider-track {
  position: absolute;
  inset: 0;
}

.sjd-detail-gallery.is-fullscreen .sjd-detail-gallery-slide,
.sjd-magazine-slider.is-fullscreen .sjd-magazine-slide {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 56px;
  box-sizing: border-box;
}

.sjd-detail-gallery.is-fullscreen .sjd-detail-gallery-slide-img,
.sjd-magazine-slider.is-fullscreen .sjd-magazine-slide-img {
  width: auto !important;
  height: auto !important;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: center;
}

.sjd-detail-gallery.is-fullscreen .sjd-detail-gallery-nav,
.sjd-magazine-slider.is-fullscreen .sjd-magazine-slider-nav {
  width: 44px;
  height: 44px;
  margin-top: 0;
  opacity: 1;
  z-index: 6;
  background: rgba(0, 0, 0, .45);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, .25);
  box-shadow: 0 2px 10px rgba(0, 0, 0, .35);
}

.sjd-detail-gallery.is-fullscreen .sjd-detail-gallery-nav svg,
.sjd-magazine-slider.is-fullscreen .sjd-magazine-slider-nav svg {
  width: 20px;
  height: 20px;
  stroke: #fff;
}

.sjd-detail-gallery.is-fullscreen .sjd-detail-gallery-nav:hover,
.sjd-magazine-slider.is-fullscreen .sjd-magazine-slider-nav:hover {
  background: rgba(0, 0, 0, .7);
  color: #fff;
}

.sjd-detail-gallery.is-fullscreen .sjd-detail-gallery-count,
.sjd-magazine-slider.is-fullscreen .sjd-magazine-slider-count {
  top: max(12px, env(safe-area-inset-top, 0px));
  bottom: auto;
  right: max(12px, env(safe-area-inset-right, 0px));
  font-size: 14px;
  padding: 6px 14px;
  z-index: 6;
}

.sjd-detail-gallery.is-fullscreen .sjd-detail-gallery-fs--close,
.sjd-magazine-slider.is-fullscreen .sjd-magazine-slider-fs--close {
  z-index: 7;
  background: rgba(0, 0, 0, .5);
  border: 1px solid rgba(255, 255, 255, .2);
}

.sjd-detail-gallery.is-fullscreen .sjd-detail-gallery-thumbs,
.sjd-magazine-slider.is-fullscreen .sjd-magazine-slider-thumbs {
  flex-shrink: 0;
  width: 100%;
  max-width: 100%;
  justify-content: center;
  padding: 4px 8px 2px;
  box-sizing: border-box;
}

.sjd-detail-gallery.is-fullscreen .sjd-detail-gallery-thumb,
.sjd-magazine-slider.is-fullscreen .sjd-magazine-slider-thumb {
  border-color: rgba(255, 255, 255, .3);
  opacity: .75;
}

.sjd-detail-gallery.is-fullscreen .sjd-detail-gallery-thumb.is-active,
.sjd-magazine-slider.is-fullscreen .sjd-magazine-slider-thumb.is-active {
  border-color: var(--sjd-purple);
  opacity: 1;
}

body.sjd-detail-gallery-fullscreen-open,
body.sjd-magazine-fullscreen-open {
  overflow: hidden;
  overscroll-behavior: none;
}

.sjd-detail-gallery-thumbs,
.sjd-magazine-slider-thumbs {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 2px 2px 6px;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}

.sjd-detail-gallery-thumbs::-webkit-scrollbar,
.sjd-magazine-slider-thumbs::-webkit-scrollbar { height: 4px; }

.sjd-detail-gallery-thumbs::-webkit-scrollbar-thumb,
.sjd-magazine-slider-thumbs::-webkit-scrollbar-thumb {
  background: var(--sjd-gray-300);
  border-radius: 4px;
}

.sjd-detail-gallery-thumb,
.sjd-magazine-slider-thumb {
  flex: 0 0 clamp(56px, 14vw, 72px);
  aspect-ratio: 3 / 4;
  padding: 0;
  border: 2px solid transparent;
  border-radius: var(--sjd-radius-sm);
  overflow: hidden;
  background: var(--sjd-gray-100);
  cursor: pointer;
  scroll-snap-align: start;
  opacity: .72;
  transition: border-color var(--sjd-transition), opacity var(--sjd-transition), transform var(--sjd-transition);
}

.sjd-detail-gallery-thumb:hover,
.sjd-magazine-slider-thumb:hover { opacity: 1; }

.sjd-detail-gallery-thumb.is-active,
.sjd-magazine-slider-thumb.is-active {
  border-color: var(--sjd-purple);
  opacity: 1;
  transform: translateY(-2px);
}

.sjd-detail-gallery-thumb-img,
.sjd-magazine-slider-thumb-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sjd-detail-gallery-count em,
.sjd-magazine-slider-count em {
  font-style: normal;
  font-weight: 700;
}

.sjd-detail-image > .sjd-single-img,
.sjd-magazine-image > .sjd-single-img,
.sjd-magazine-image > img {
  width: 100%;
  display: block;
  border-radius: var(--sjd-radius-lg);
  box-shadow: var(--sjd-shadow-lg);
}

.sjd-magazine-detail { min-width: 0; }

.sjd-magazine-header h1 {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 700;
  line-height: 1.25;
  margin-bottom: 10px;
}

.sjd-magazine-badges { margin-bottom: 4px; }

.sjd-magazine-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  margin-bottom: 10px;
  font-size: 13px;
  color: var(--sjd-text-muted);
}

.sjd-magazine-subtitle {
  font-size: 14px;
  color: var(--sjd-text-muted);
  margin-bottom: 16px;
}

.sjd-related-people {
  margin-bottom: 16px;
}

.sjd-related-people-label {
  font-size: 12px;
  font-weight: 500;
  color: var(--sjd-text-muted);
  margin: 0 0 8px;
  letter-spacing: 0.02em;
}

.sjd-magazine-header .sjd-related-people .sjd-tags--people,
.sjd-visual-header .sjd-related-people .sjd-tags--people,
.sjd-brand-header .sjd-related-people .sjd-tags--people {
  margin-bottom: 0;
}

.sjd-magazine-meta-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

@media (max-width: 640px) {
  .sjd-magazine-meta-grid {
    grid-template-columns: 1fr;
  }
}

.sjd-magazine-meta-item {
  padding: 14px 16px;
  background: var(--sjd-gray-50);
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius);
}

.sjd-magazine-meta-item span {
  display: block;
  font-size: 11px;
  color: var(--sjd-text-muted);
  margin-bottom: 4px;
}

.sjd-magazine-meta-item strong {
  display: block;
  font-size: 14px;
  font-weight: 600;
}

.sjd-magazine-content {
  max-width: none;
  margin-bottom: 24px;
}

.sjd-magazine-actions {
  padding-top: 24px;
  border-top: 1px solid var(--sjd-border);
}

.sjd-magazine-actions .sjd-card-actions {
  padding: 0;
  border: none;
}

.sjd-magazine-related {
  margin-top: 56px;
  padding-top: 32px;
  border-top: 1px solid var(--sjd-border);
}

.sjd-magazine-related h2 {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 24px;
}

.sjd-single-magazine .sjd-grid--4 .sjd-magazine-card .sjd-card-actions {
  flex-wrap: wrap;
  gap: 8px;
}

/* Color */
.sjd-color-swatch {
  aspect-ratio: 16 / 10;
  border-radius: var(--sjd-radius) var(--sjd-radius) 0 0;
  position: relative;
}

.sjd-color-like {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px;
  background: rgba(0, 0, 0, .42);
  color: #fff;
  border-radius: 20px;
  font-size: 11px;
  backdrop-filter: blur(4px);
}

.sjd-color-like svg {
  width: 12px;
  height: 12px;
}

.sjd-color-card .sjd-card-body {
  padding: 14px;
}

.sjd-color-en {
  font-size: 12px;
  color: var(--sjd-text-muted);
  margin-top: 2px;
}

.sjd-color-values {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  font-size: 11px;
  color: var(--sjd-text-muted);
  margin-top: 6px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.sjd-color-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.sjd-color-tag {
  display: inline-flex;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 600;
}

.sjd-color-tag--featured {
  background: var(--sjd-purple-light);
  color: var(--sjd-purple-dark);
}

.sjd-color-tag--rising {
  background: rgba(34, 197, 94, .12);
  color: #15803D;
}

.sjd-color-tag--falling {
  background: rgba(239, 68, 68, .12);
  color: #B91C1C;
}

.sjd-color-apply-dots {
  display: flex;
  gap: 6px;
  margin-top: 10px;
}

.sjd-color-apply-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 1px solid rgba(0, 0, 0, .08);
}

.sjd-color-examples {
  margin-top: 12px;
}

.sjd-color-examples-label {
  display: block;
  font-size: 10px;
  color: var(--sjd-text-muted);
  margin-bottom: 6px;
}

.sjd-color-examples-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.sjd-color-example-thumb {
  display: block;
  border-radius: var(--sjd-radius-sm);
  overflow: hidden;
  aspect-ratio: 1;
}

.sjd-color-example-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Color trend — single detail */
.sjd-color-detail-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 1.05fr);
  gap: clamp(28px, 4vw, 48px);
  align-items: start;
}

.sjd-color-detail-media {
  position: sticky;
  top: calc(var(--sjd-header-h) + 24px);
  min-width: 0;
}

.admin-bar .sjd-color-detail-media {
  top: calc(var(--sjd-header-h) + 56px);
}

.sjd-color-detail-swatch {
  position: relative;
  min-height: 280px;
  border-radius: var(--sjd-radius-lg);
  overflow: hidden;
  box-shadow: var(--sjd-shadow-lg);
  display: flex;
  align-items: flex-end;
}

.sjd-color-detail-swatch.is-light { color: #111827; }
.sjd-color-detail-swatch.is-dark { color: #fff; }

.sjd-color-detail-trend-badge {
  position: absolute;
  top: 16px;
  right: 16px;
  padding: 10px 14px;
  border-radius: var(--sjd-radius);
  background: rgba(0, 0, 0, .28);
  backdrop-filter: blur(8px);
  text-align: right;
  line-height: 1.2;
}

.sjd-color-detail-swatch.is-light .sjd-color-detail-trend-badge {
  background: rgba(255, 255, 255, .72);
}

.sjd-color-detail-trend-badge strong {
  display: block;
  font-size: 22px;
  font-weight: 700;
}

.sjd-color-detail-trend-badge span {
  display: block;
  margin-top: 2px;
  font-size: 11px;
  opacity: .85;
}

.sjd-color-detail-swatch-body {
  width: 100%;
  padding: clamp(20px, 3vw, 28px);
}

.sjd-color-detail-hex {
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 700;
  letter-spacing: .04em;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  line-height: 1.1;
}

.sjd-color-detail-rgb {
  margin-top: 8px;
  font-size: 13px;
  opacity: .88;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.sjd-color-detail-copy-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}

.sjd-color-detail-copy {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  font-size: 12px;
  border-radius: var(--sjd-radius-sm);
  background: rgba(0, 0, 0, .22);
  border: 1px solid rgba(255, 255, 255, .24);
  color: inherit;
}

.sjd-color-detail-swatch.is-light .sjd-color-detail-copy {
  background: rgba(255, 255, 255, .55);
  border-color: rgba(17, 24, 39, .12);
}

.sjd-color-detail-copy:hover {
  border-color: currentColor;
}

.sjd-color-detail-copy svg {
  width: 14px;
  height: 14px;
}

.sjd-color-detail-image {
  margin-top: 16px;
  border-radius: var(--sjd-radius-lg);
  overflow: hidden;
  background: var(--sjd-gray-100);
  box-shadow: var(--sjd-shadow);
}

.sjd-color-detail-img {
  width: 100%;
  display: block;
}

.sjd-color-detail-examples {
  margin-top: 20px;
}

.sjd-color-detail-examples h3 {
  font-size: 13px;
  font-weight: 600;
  color: var(--sjd-text-muted);
  margin-bottom: 10px;
}

.sjd-color-detail-examples-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.sjd-color-detail-example {
  display: block;
  border-radius: var(--sjd-radius-sm);
  overflow: hidden;
  aspect-ratio: 1;
  background: var(--sjd-gray-100);
}

.sjd-color-detail-example-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--sjd-transition);
}

.sjd-color-detail-example:hover .sjd-color-detail-example-img {
  transform: scale(1.04);
}

.sjd-color-detail-info {
  min-width: 0;
}

.sjd-color-detail-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.sjd-color-detail-header h1 {
  font-size: clamp(24px, 3vw, 34px);
  font-weight: 700;
  line-height: 1.25;
  margin-bottom: 8px;
}

.sjd-color-detail-en {
  font-size: 14px;
  color: var(--sjd-text-muted);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  margin-bottom: 14px;
}

.sjd-color-detail-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  margin-bottom: 24px;
  font-size: 13px;
  color: var(--sjd-text-muted);
}

.sjd-color-detail-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}

.sjd-color-detail-meta-item {
  padding: 14px 16px;
  background: var(--sjd-gray-50);
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius);
}

.sjd-color-detail-meta-item span {
  display: block;
  font-size: 11px;
  color: var(--sjd-text-muted);
  margin-bottom: 4px;
}

.sjd-color-detail-meta-item strong {
  display: block;
  font-size: 15px;
  font-weight: 600;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.sjd-color-detail-apply {
  margin-bottom: 24px;
}

.sjd-color-detail-apply h3 {
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 10px;
}

.sjd-color-detail-apply-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.sjd-color-detail-apply-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: var(--sjd-gray-50);
  border: 1px solid var(--sjd-border);
  border-radius: 999px;
  font-size: 13px;
}

.sjd-color-detail-apply-chip i {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}

.sjd-color-detail-header .sjd-tags {
  margin-top: 0;
  margin-bottom: 20px;
}

.sjd-color-detail-excerpt {
  font-size: 15px;
  line-height: 1.7;
  color: var(--sjd-text-muted);
  margin-bottom: 20px;
}

.sjd-color-detail-content {
  max-width: none;
  margin-bottom: 24px;
  line-height: 1.8;
}

.sjd-color-detail-actions {
  margin-top: 8px;
  padding-top: 24px;
  border-top: 1px solid var(--sjd-border);
}

.sjd-color-detail-actions .sjd-card-actions {
  padding: 0;
  border: none;
}

.sjd-color-detail-related {
  margin-top: 56px;
  padding-top: 32px;
  border-top: 1px solid var(--sjd-border);
}

.sjd-color-detail-related h2 {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 24px;
}

.sjd-single-color .sjd-color-card .sjd-color-like {
  pointer-events: auto;
}

.sjd-color-trend {
  margin-top: 10px;
  font-size: 12px;
  font-weight: 600;
}

.sjd-trend-up { color: #16A34A; }
.sjd-trend-down { color: #DC2626; }
.sjd-trend-flat { color: var(--sjd-text-muted); }

/* Brand */
.sjd-brand-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  letter-spacing: .1em;
  text-shadow: 0 2px 8px rgba(0,0,0,.5);
}

/* Prompt */
.sjd-prompt-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 11px;
  color: var(--sjd-text-muted);
  margin-top: 4px;
}

.sjd-prompt-meta span:not(:last-child)::after {
  content: '·';
  margin-left: 8px;
}

.sjd-prompt-like {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px;
  background: rgba(0, 0, 0, .5);
  color: #fff;
  border-radius: 20px;
  font-size: 11px;
  backdrop-filter: blur(4px);
}

.sjd-prompt-like svg {
  width: 12px;
  height: 12px;
}
.sjd-prompt-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}
.sjd-prompt-block {
  margin: 24px 0;
  padding: 20px;
  background: var(--sjd-gray-50);
  border-radius: var(--sjd-radius);
}
.sjd-prompt-code {
  background: var(--sjd-gray-100);
  padding: 16px;
  border-radius: var(--sjd-radius-sm);
  font-size: 13px;
  line-height: 1.6;
  overflow-x: auto;
  margin: 12px 0;
  white-space: pre-wrap;
  word-break: break-word;
}

/* Breadcrumb */
.sjd-breadcrumb { margin-bottom: 20px; font-size: 13px; line-height: 1.4; }
.sjd-breadcrumb-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2px 0;
  list-style: none;
  margin: 0;
  padding: 0;
}
.sjd-breadcrumb-item { display: flex; align-items: center; color: var(--sjd-text-muted); }
.sjd-breadcrumb-item a {
  color: var(--sjd-text-muted);
  transition: color var(--sjd-transition);
}
.sjd-breadcrumb-item a:hover { color: var(--sjd-purple); }
.sjd-breadcrumb-item.is-current { color: var(--sjd-text); font-weight: 500; }
.sjd-breadcrumb-sep {
  display: flex;
  align-items: center;
  margin: 0 6px;
  color: var(--sjd-text-muted);
  opacity: 0.45;
}
.sjd-breadcrumb-sep svg { width: 12px; height: 12px; }

/* Single */
.sjd-single { padding: 32px 0 64px; }
.sjd-single-header { margin-bottom: 24px; }
.sjd-single-header h1 { font-size: 28px; font-weight: 700; margin-bottom: 8px; }
.sjd-single-meta { display: flex; gap: 12px; font-size: 13px; color: var(--sjd-text-muted); margin-bottom: 12px; }
.sjd-single-image { margin-bottom: 24px; border-radius: var(--sjd-radius-lg); overflow: hidden; }
.sjd-single-img { width: 100%; }
.sjd-single-content { font-size: 16px; line-height: 1.8; max-width: 720px; }
.sjd-single-content p { margin-bottom: 16px; }

.sjd-single-back {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-bottom: 24px;
  font-size: 13px;
  color: var(--sjd-text-muted);
  transition: color var(--sjd-transition);
}

.sjd-single-back svg {
  width: 16px;
  height: 16px;
  transform: rotate(180deg);
}

.sjd-single-back:hover { color: var(--sjd-purple); }

.sjd-visual-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, 1fr);
  gap: clamp(28px, 4vw, 48px);
  align-items: start;
}

.sjd-visual-media {
  position: sticky;
  top: calc(var(--sjd-header-h) + 24px);
}

.admin-bar .sjd-visual-media {
  top: calc(var(--sjd-header-h) + 56px);
}

.sjd-visual-image {
  border-radius: var(--sjd-radius-lg);
  overflow: hidden;
  background: var(--sjd-gray-100);
  box-shadow: var(--sjd-shadow-lg);
}

.sjd-visual-image .sjd-single-img,
.sjd-visual-image img {
  width: 100%;
  display: block;
}

.sjd-visual-detail {
  min-width: 0;
}

.sjd-visual-header h1 {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 700;
  line-height: 1.25;
  margin-bottom: 12px;
}

.sjd-visual-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  margin-bottom: 20px;
  font-size: 13px;
  color: var(--sjd-text-muted);
}

.sjd-visual-meta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 20px;
}

.sjd-visual-meta-item {
  padding: 14px 16px;
  background: var(--sjd-gray-50);
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius);
}

.sjd-visual-meta-item span {
  display: block;
  font-size: 11px;
  color: var(--sjd-text-muted);
  margin-bottom: 4px;
}

.sjd-visual-meta-item strong {
  display: block;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.4;
  color: var(--sjd-text);
}

.sjd-visual-header .sjd-tags,
.sjd-brand-header .sjd-tags {
  margin-top: 0;
  margin-bottom: 24px;
}

.sjd-visual-content {
  max-width: none;
  margin-bottom: 24px;
  color: var(--sjd-text);
}

.sjd-visual-prompt {
  margin-top: 0;
}

.sjd-visual-actions {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--sjd-border);
}

.sjd-visual-actions .sjd-card-actions {
  padding: 0;
  border: none;
}

.sjd-detail-related,
.sjd-visual-related {
  margin-top: 56px;
  padding-top: 32px;
  border-top: 1px solid var(--sjd-border);
}

.sjd-detail-related h2,
.sjd-visual-related h2 {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 24px;
}

.sjd-detail-panel h1,
.sjd-prompt-detail-header h1 {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 700;
  line-height: 1.25;
  margin-bottom: 12px;
}

.sjd-prompt-detail-stats {
  margin-bottom: 20px;
}

.sjd-detail-actions,
.sjd-magazine-actions,
.sjd-visual-actions,
.sjd-brand-actions,
.sjd-prompt-detail-actions {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--sjd-border);
}

.sjd-detail-actions .sjd-card-actions,
.sjd-magazine-actions .sjd-card-actions,
.sjd-visual-actions .sjd-card-actions,
.sjd-prompt-detail-actions .sjd-card-actions {
  padding: 0;
  border: none;
}

.sjd-prompt-content {
  margin-bottom: 20px;
}

.sjd-visual-related h2 {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 24px;
}

.sjd-single-visual .sjd-grid--4 .sjd-visual-card .sjd-card-actions {
  display: none;
}

.sjd-people-profile {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 32px;
  margin-bottom: 48px;
}
.sjd-profile-img { width: 100%; border-radius: var(--sjd-radius-lg); }
.sjd-profile-stats { display: flex; gap: 16px; margin: 16px 0; }
.sjd-stat-box {
  text-align: center;
  padding: 12px 20px;
  background: var(--sjd-gray-50);
  border-radius: var(--sjd-radius);
}
.sjd-stat-box strong { display: block; font-size: 20px; }
.sjd-stat-box span { font-size: 11px; color: var(--sjd-text-muted); }

/* Library Tabs & Page */
.sjd-page-layout--library {
  grid-template-columns: 220px minmax(0, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
}

.sjd-library-icon {
  width: 22px;
  text-align: center;
}

.sjd-library-filter-groups {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.sjd-library-filter-group {
  border: none;
}

.sjd-library-filter-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 12px;
  border-radius: var(--sjd-radius-sm);
  font-size: 13px;
  font-weight: 600;
  color: var(--sjd-text);
  cursor: pointer;
  list-style: none;
  transition: background var(--sjd-transition);
}

.sjd-library-filter-summary:hover {
  background: var(--sjd-gray-50);
}

.sjd-library-filter-summary::-webkit-details-marker {
  display: none;
}

.sjd-library-filter-plus {
  color: var(--sjd-text-muted);
  font-size: 14px;
  line-height: 1;
  font-weight: 400;
}

.sjd-library-filter-list {
  margin: 0 0 4px;
  padding: 0 0 0 8px;
}

.sjd-library-collection-links .sjd-sidebar-item {
  color: var(--sjd-text-muted);
}

.sjd-library-collection-previews {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.sjd-library-collection-thumb {
  display: block;
  border-radius: var(--sjd-radius-sm);
  overflow: hidden;
  aspect-ratio: 1;
}

.sjd-library-collection-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sjd-library-banner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: clamp(20px, 3vw, 32px);
  margin-bottom: 24px;
  padding: 28px 32px;
  border-radius: var(--sjd-radius-lg);
  background: linear-gradient(135deg, #f3efff 0%, #f8f6ff 45%, #faf9fc 100%);
  border: 1px solid rgba(168, 85, 247, .08);
}

.sjd-library-banner-title {
  font-size: clamp(24px, 2.6vw, 32px);
  font-weight: 700;
  line-height: 1.2;
}

.sjd-library-banner-desc {
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.65;
  color: var(--sjd-text-muted);
  max-width: 560px;
}

.sjd-library-banner-search {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 18px;
  max-width: 100%;
}

.sjd-library-banner-search input {
  flex: 1;
  min-width: 0;
  padding: 12px 16px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-xl);
  background: var(--sjd-bg);
  font-size: 14px;
}

.sjd-library-banner-search .sjd-btn-primary {
  width: 44px;
  height: 44px;
  padding: 0;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.sjd-library-hot-searches {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-top: 14px;
  font-size: 12px;
}

.sjd-library-hot-searches > span {
  color: var(--sjd-text-muted);
}

.sjd-library-hot-searches a {
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--sjd-bg);
  border: 1px solid var(--sjd-border);
  color: var(--sjd-text-muted);
}

.sjd-library-hot-searches a:hover {
  border-color: var(--sjd-purple);
  color: var(--sjd-purple-dark);
}

.sjd-library-featured {
  position: relative;
  border-radius: var(--sjd-radius-lg);
  overflow: hidden;
  min-height: 280px;
  box-shadow: 0 12px 32px rgba(15, 23, 42, .14);
}

.sjd-library-featured-slide {
  display: none;
  position: relative;
  min-height: 280px;
  color: #fff;
}

.sjd-library-featured-slide.is-active {
  display: block;
}

.sjd-library-featured-media {
  position: absolute;
  inset: 0;
}

.sjd-library-featured-img {
  width: 100%;
  height: 100%;
  min-height: 280px;
  object-fit: cover;
  display: block;
}

.sjd-library-featured-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(10, 10, 10, .72) 0%, rgba(10, 10, 10, .28) 55%, rgba(10, 10, 10, .08) 100%);
}

.sjd-library-featured-body {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 280px;
  padding: 28px;
  max-width: 72%;
}

.sjd-library-featured-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .82;
}

.sjd-library-featured-body h2 {
  margin-top: 8px;
  font-size: clamp(20px, 2.2vw, 28px);
  line-height: 1.25;
}

.sjd-library-featured-body p {
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.65;
  color: rgba(255, 255, 255, .78);
}

.sjd-library-featured-cta {
  margin-top: 16px;
  width: fit-content;
  gap: 8px;
  color: #fff;
  border-color: rgba(255, 255, 255, .42);
}

.sjd-library-featured-cta svg {
  width: 14px;
  height: 14px;
}

.sjd-library-featured-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, .16);
  color: #fff;
  backdrop-filter: blur(6px);
  z-index: 2;
}

.sjd-library-featured-nav svg {
  width: 16px;
  height: 16px;
}

.sjd-library-featured-prev { left: 12px; }
.sjd-library-featured-prev svg { transform: rotate(180deg); }
.sjd-library-featured-next { right: 12px; }

.sjd-library-featured-dots {
  position: absolute;
  left: 28px;
  bottom: 14px;
  display: flex;
  gap: 8px;
  z-index: 2;
}

.sjd-library-featured-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .35);
}

.sjd-library-featured-dot.is-active {
  background: #fff;
}

.sjd-library-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.sjd-library-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 0;
  overflow-x: auto;
  flex: 1;
  min-width: 0;
}

.sjd-library-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  border-radius: var(--sjd-radius);
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
  border: 1px solid var(--sjd-border);
  background: var(--sjd-bg);
  transition: all var(--sjd-transition);
}

.sjd-library-tab-icon {
  font-size: 14px;
  line-height: 1;
}

.sjd-library-tab.is-active {
  background: var(--sjd-purple);
  color: #fff;
  border-color: var(--sjd-purple);
}

.sjd-library-palette {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.sjd-library-palette-swatches {
  display: flex;
  gap: 6px;
}

.sjd-library-palette-dot {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1px solid rgba(0, 0, 0, .08);
  flex-shrink: 0;
}

.sjd-library-palette-more {
  font-size: 12px;
  color: var(--sjd-purple);
  white-space: nowrap;
}

.sjd-page-library .sjd-filter-bar .sjd-view-toggle {
  display: none;
}

.sjd-library-view-toggle {
  display: flex;
  justify-content: flex-end;
  gap: 4px;
  margin: -8px 0 16px;
}

.sjd-library-masonry.sjd-view-grid {
  columns: unset;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.sjd-library-masonry.sjd-view-grid .sjd-masonry-item {
  margin-bottom: 0;
}

.sjd-library-masonry.sjd-view-compact {
  columns: 5;
}

.sjd-library-masonry.sjd-list-view {
  columns: unset;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.sjd-library-masonry.sjd-list-view .sjd-masonry-link {
  display: grid;
  grid-template-columns: 160px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
}

.sjd-library-load-wrap {
  display: flex;
  justify-content: center;
  margin-top: 24px;
}

/* AI Analysis Page */
.sjd-page-layout--ai {
  grid-template-columns: minmax(0, 1fr) 280px;
  gap: clamp(20px, 2.5vw, 32px);
}

.sjd-ai-banner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: clamp(20px, 3vw, 32px);
  margin-bottom: 28px;
  padding: 28px 32px;
  border-radius: var(--sjd-radius-lg);
  background: linear-gradient(135deg, #f3efff 0%, #f8f6ff 45%, #faf9fc 100%);
  border: 1px solid rgba(168, 85, 247, .08);
}

.sjd-ai-banner-title {
  font-size: clamp(24px, 2.6vw, 32px);
  font-weight: 700;
  line-height: 1.2;
}

.sjd-ai-banner-desc {
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.65;
  color: var(--sjd-text-muted);
  max-width: 560px;
}

.sjd-ai-banner-actions {
  margin-top: 18px;
}

.sjd-ai-banner-search {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 18px;
  max-width: 100%;
}

.sjd-ai-banner-search input {
  flex: 1;
  min-width: 0;
  padding: 12px 16px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-xl);
  background: var(--sjd-bg);
  font-size: 14px;
}

.sjd-ai-upload-btn {
  white-space: nowrap;
  flex-shrink: 0;
  cursor: pointer;
}

.sjd-ai-upload-note {
  margin-top: 8px;
  font-size: 11px;
  color: var(--sjd-text-muted);
}

.sjd-ai-featured {
  position: relative;
  border-radius: var(--sjd-radius-lg);
  overflow: hidden;
  min-height: 280px;
  box-shadow: 0 12px 32px rgba(15, 23, 42, .14);
}

.sjd-ai-featured-slide {
  display: none;
  position: relative;
  min-height: 280px;
  color: #fff;
}

.sjd-ai-featured-slide.is-active {
  display: block;
}

.sjd-ai-featured-media {
  position: absolute;
  inset: 0;
}

.sjd-ai-featured-img {
  width: 100%;
  height: 100%;
  min-height: 280px;
  object-fit: cover;
  display: block;
}

.sjd-ai-featured-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(10, 10, 10, .78) 0%, rgba(10, 10, 10, .32) 55%, rgba(10, 10, 10, .12) 100%);
}

.sjd-ai-featured-body {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 280px;
  padding: 28px;
  max-width: 78%;
}

.sjd-ai-featured-body h2 {
  font-size: clamp(20px, 2.2vw, 28px);
  line-height: 1.25;
}

.sjd-ai-featured-body p {
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.65;
  color: rgba(255, 255, 255, .78);
}

.sjd-ai-featured-cta {
  margin-top: 16px;
  width: fit-content;
  gap: 8px;
  color: #fff;
  border-color: rgba(255, 255, 255, .42);
}

.sjd-ai-featured-cta svg {
  width: 14px;
  height: 14px;
}

.sjd-ai-featured-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, .16);
  color: #fff;
  backdrop-filter: blur(6px);
  z-index: 2;
}

.sjd-ai-featured-nav svg {
  width: 16px;
  height: 16px;
}

.sjd-ai-featured-prev { left: 12px; }
.sjd-ai-featured-prev svg { transform: rotate(180deg); }
.sjd-ai-featured-next { right: 12px; }

.sjd-ai-featured-dots {
  position: absolute;
  left: 28px;
  bottom: 14px;
  display: flex;
  gap: 8px;
  z-index: 2;
}

.sjd-ai-featured-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .35);
}

.sjd-ai-featured-dot.is-active {
  background: #fff;
}

.sjd-ai-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}

.sjd-ai-section-head h2 {
  font-size: 18px;
  font-weight: 700;
}

.sjd-ai-section-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 13px;
  color: var(--sjd-purple);
}

.sjd-ai-section-link svg {
  width: 14px;
  height: 14px;
}

.sjd-ai-tools,
.sjd-ai-cases,
.sjd-ai-hot-searches,
.sjd-ai-process,
.sjd-ai-all-cases {
  margin-bottom: 28px;
}

.sjd-ai-tools-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
}

.sjd-ai-tool-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  padding: 16px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius);
  background: var(--sjd-bg);
  text-align: left;
  transition: border-color var(--sjd-transition), box-shadow var(--sjd-transition);
}

.sjd-ai-tool-card:hover,
.sjd-ai-tool-card.is-active {
  border-color: var(--sjd-purple);
  box-shadow: 0 4px 14px rgba(124, 58, 237, .08);
}

.sjd-ai-tool-card.is-active {
  background: var(--sjd-purple-bg);
}

.sjd-ai-tool-icon {
  font-size: 22px;
  line-height: 1;
}

.sjd-ai-tool-card strong {
  font-size: 13px;
}

.sjd-ai-tool-card p {
  font-size: 11px;
  line-height: 1.55;
  color: var(--sjd-text-muted);
}

.sjd-ai-cases-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 16px;
}

.sjd-analysis-card-image .sjd-analysis-tool-badge {
  top: 8px;
  left: 8px;
}

.sjd-analysis-card-footer {
  display: flex;
  align-items: center;
  margin-top: 8px;
  font-size: 11px;
  color: var(--sjd-text-muted);
}

.sjd-analysis-likes {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.sjd-analysis-likes svg {
  width: 12px;
  height: 12px;
}

.sjd-ai-refresh-btn {
  font-size: 13px;
  color: var(--sjd-purple);
}

.sjd-ai-hot-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.sjd-ai-hot-tag {
  padding: 8px 14px;
  border-radius: 999px;
  background: var(--sjd-gray-50);
  border: 1px solid var(--sjd-border);
  font-size: 13px;
  color: var(--sjd-text-muted);
}

.sjd-ai-hot-tag:hover {
  border-color: var(--sjd-purple);
  color: var(--sjd-purple-dark);
}

.sjd-ai-process-track {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  padding: 20px 24px;
  border-radius: var(--sjd-radius-lg);
  background: var(--sjd-gray-50);
  border: 1px solid var(--sjd-border);
}

.sjd-ai-process-step {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: var(--sjd-radius);
  background: var(--sjd-bg);
  border: 1px solid var(--sjd-border);
}

.sjd-ai-process-icon {
  font-size: 18px;
}

.sjd-ai-process-step strong {
  font-size: 13px;
}

.sjd-ai-process-arrow {
  color: var(--sjd-text-muted);
  font-size: 16px;
}

.sjd-ai-load-wrap {
  display: flex;
  justify-content: center;
  margin-top: 24px;
}

.sjd-ai-widget-stats,
.sjd-ai-widget-tips {
  background: var(--sjd-bg);
  border: 1px solid var(--sjd-border);
}

.sjd-ai-stats-list {
  list-style: none;
  margin: 0 0 16px;
  padding: 0;
}

.sjd-ai-stats-list li {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 10px 0;
  border-bottom: 1px solid var(--sjd-border);
}

.sjd-ai-stats-list li:last-child {
  border-bottom: none;
}

.sjd-ai-stats-list strong {
  font-size: 18px;
}

.sjd-ai-stats-list span {
  font-size: 12px;
  color: var(--sjd-text-muted);
}

.sjd-ai-report-btn,
.sjd-ai-guide-btn {
  width: 100%;
  justify-content: center;
}

.sjd-ai-widget-stats {
  background: linear-gradient(160deg, rgba(124, 58, 237, .08) 0%, rgba(124, 58, 237, .02) 100%);
  border-color: rgba(124, 58, 237, .12);
}

.sjd-ai-tips-list {
  margin: 0 0 16px;
  padding-left: 18px;
  font-size: 13px;
  color: var(--sjd-text-muted);
}

.sjd-ai-tips-list li {
  padding: 4px 0;
}

/* AI Analysis Detail */
.sjd-single-ai {
  padding: 24px 0 64px;
  background: var(--sjd-gray-50);
}

.sjd-ai-detail-layout {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) 280px;
  gap: clamp(20px, 2.5vw, 28px);
  align-items: start;
}

.sjd-ai-detail-sidebar {
  position: sticky;
  top: calc(var(--sjd-header-h) + 24px);
}

.admin-bar .sjd-ai-detail-sidebar {
  top: calc(var(--sjd-header-h) + 56px);
}

.sjd-ai-detail-widget {
  padding: 18px;
  margin-bottom: 16px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius);
  background: var(--sjd-bg);
}

.sjd-ai-detail-widget-title {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 12px;
}

.sjd-ai-detail-widget-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 12px;
}

.sjd-ai-detail-widget-head .sjd-ai-detail-widget-title {
  margin-bottom: 0;
}

.sjd-ai-detail-widget-link {
  font-size: 12px;
  color: var(--sjd-purple);
}

.sjd-ai-detail-tools {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.sjd-ai-detail-tool {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: var(--sjd-radius-sm);
  font-size: 13px;
  color: var(--sjd-text-muted);
  transition: background var(--sjd-transition), color var(--sjd-transition);
}

.sjd-ai-detail-tool:hover {
  background: var(--sjd-gray-50);
  color: var(--sjd-text);
}

.sjd-ai-detail-tool.is-active {
  background: var(--sjd-purple-bg);
  color: var(--sjd-purple-dark);
  font-weight: 600;
  box-shadow: inset 3px 0 0 var(--sjd-purple);
}

.sjd-ai-detail-tool-icon {
  font-size: 16px;
  line-height: 1;
}

.sjd-ai-detail-upload {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 24px 16px;
  margin-bottom: 16px;
  border: 1.5px dashed var(--sjd-gray-300);
  border-radius: var(--sjd-radius);
  background: var(--sjd-bg);
  text-align: center;
}

.sjd-ai-detail-upload-icon {
  font-size: 28px;
  line-height: 1;
}

.sjd-ai-detail-upload strong {
  font-size: 13px;
}

.sjd-ai-detail-upload p,
.sjd-ai-detail-upload span {
  font-size: 11px;
  color: var(--sjd-text-muted);
}

.sjd-ai-detail-history {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.sjd-ai-detail-history-item {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sjd-ai-detail-history-thumb {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: var(--sjd-radius-sm);
  overflow: hidden;
  background: var(--sjd-gray-100);
}

.sjd-ai-detail-history-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sjd-ai-detail-history-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.sjd-ai-detail-history-body strong {
  font-size: 12px;
  font-weight: 600;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sjd-ai-detail-history-body span {
  font-size: 11px;
  color: var(--sjd-text-muted);
}

.sjd-ai-detail-history-empty,
.sjd-ai-detail-similar-empty {
  font-size: 12px;
  color: var(--sjd-text-muted);
}

.sjd-ai-detail-main {
  min-width: 0;
}

.sjd-ai-detail-hero {
  display: grid;
  grid-template-columns: minmax(280px, 42%) minmax(0, 1fr);
  gap: 20px;
  margin-bottom: 24px;
}

.sjd-ai-detail-media {
  min-width: 0;
}

.sjd-ai-detail-image {
  position: relative;
  border-radius: var(--sjd-radius-lg);
  overflow: hidden;
  background: var(--sjd-gray-100);
  box-shadow: var(--sjd-shadow);
}

.sjd-ai-detail-img {
  width: 100%;
  height: auto;
  display: block;
  vertical-align: middle;
}

.sjd-ai-detail-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(0, 0, 0, .55);
  color: #fff;
  font-size: 11px;
  backdrop-filter: blur(4px);
}

.sjd-ai-detail-media-actions {
  position: absolute;
  top: 12px;
  right: 12px;
  display: flex;
  gap: 8px;
}

.sjd-ai-detail-action {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .92);
  color: var(--sjd-text);
  font-size: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .12);
}

.sjd-ai-detail-action svg {
  width: 14px;
  height: 14px;
}

.sjd-ai-detail-action.is-active {
  color: var(--sjd-purple-dark);
}

.sjd-ai-detail-results {
  padding: 22px 24px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-lg);
  background: var(--sjd-bg);
}

.sjd-ai-detail-results-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--sjd-border);
}

.sjd-ai-detail-results-head h1 {
  font-size: 18px;
  font-weight: 700;
}

.sjd-ai-detail-confidence {
  flex-shrink: 0;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(34, 197, 94, .12);
  color: #15803d;
  font-size: 12px;
  font-weight: 600;
}

.sjd-ai-detail-block {
  margin-bottom: 18px;
}

.sjd-ai-detail-block:last-child {
  margin-bottom: 0;
}

.sjd-ai-detail-block h3 {
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 10px;
}

.sjd-ai-detail-block p {
  font-size: 13px;
  line-height: 1.7;
  color: var(--sjd-text-muted);
}

.sjd-ai-detail-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.sjd-ai-detail-tag {
  padding: 6px 12px;
  border-radius: 999px;
  background: var(--sjd-purple-bg);
  color: var(--sjd-purple-dark);
  font-size: 12px;
}

.sjd-ai-detail-tags--muted .sjd-ai-detail-tag {
  background: var(--sjd-gray-50);
  color: var(--sjd-text-muted);
  border: 1px solid var(--sjd-border);
}

.sjd-ai-detail-swatches {
  display: flex;
  gap: 8px;
  margin-bottom: 10px;
}

.sjd-ai-detail-swatch {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--swatch-color);
  border: 1px solid rgba(0, 0, 0, .08);
}

.sjd-ai-detail-inline-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 8px;
  font-size: 12px;
  color: var(--sjd-purple);
}

.sjd-ai-detail-inline-link svg {
  width: 12px;
  height: 12px;
}

.sjd-ai-detail-block--split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 120px;
  gap: 16px;
  align-items: center;
}

.sjd-ai-detail-dl {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.sjd-ai-detail-dl div {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 8px;
  font-size: 12px;
}

.sjd-ai-detail-dl dt {
  color: var(--sjd-text-muted);
}

.sjd-ai-detail-dl dd {
  font-weight: 500;
}

.sjd-ai-detail-dl--grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 16px;
}

.sjd-ai-detail-dl--grid div {
  grid-template-columns: 1fr;
  gap: 2px;
}

.sjd-ai-detail-composition-diagram {
  position: relative;
  width: 120px;
  height: 120px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-sm);
  background: var(--sjd-gray-50);
}

.sjd-ai-detail-grid-line {
  position: absolute;
  background: var(--sjd-gray-200);
}

.sjd-ai-detail-grid-line--v1,
.sjd-ai-detail-grid-line--v2 {
  top: 0;
  bottom: 0;
  width: 1px;
}

.sjd-ai-detail-grid-line--v1 { left: 33.33%; }
.sjd-ai-detail-grid-line--v2 { left: 66.66%; }

.sjd-ai-detail-grid-line--h1,
.sjd-ai-detail-grid-line--h2 {
  left: 0;
  right: 0;
  height: 1px;
}

.sjd-ai-detail-grid-line--h1 { top: 33.33%; }
.sjd-ai-detail-grid-line--h2 { top: 66.66%; }

.sjd-ai-detail-figure {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  opacity: .65;
}

.sjd-ai-detail-camera {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.sjd-ai-detail-camera div {
  padding: 10px;
  border-radius: var(--sjd-radius-sm);
  background: var(--sjd-gray-50);
  text-align: center;
}

.sjd-ai-detail-camera span {
  display: block;
  font-size: 11px;
  color: var(--sjd-text-muted);
  margin-bottom: 4px;
}

.sjd-ai-detail-camera strong {
  font-size: 13px;
}

.sjd-ai-detail-prompt .sjd-prompt-code {
  margin-bottom: 12px;
}

.sjd-ai-detail-quick-tools {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.sjd-ai-detail-quick-tool {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-sm);
  font-size: 13px;
  text-align: left;
  transition: border-color var(--sjd-transition), background var(--sjd-transition);
}

.sjd-ai-detail-quick-tool:hover {
  border-color: var(--sjd-purple);
  background: var(--sjd-purple-bg);
}

.sjd-ai-detail-quick-tool-icon {
  font-size: 16px;
}

.sjd-ai-detail-keywords {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.sjd-ai-detail-keyword {
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--sjd-gray-50);
  border: 1px solid var(--sjd-border);
  font-size: 12px;
  color: var(--sjd-text-muted);
}

.sjd-ai-detail-keywords-toggle {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  width: 100%;
  margin-top: 4px;
  font-size: 12px;
  color: var(--sjd-purple);
}

.sjd-ai-detail-keywords-toggle svg {
  width: 12px;
  height: 12px;
  transition: transform var(--sjd-transition);
}

.sjd-ai-detail-keywords-toggle[aria-expanded="true"] svg {
  transform: rotate(90deg);
}

.sjd-ai-detail-similar-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.sjd-ai-detail-similar-item {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sjd-ai-detail-similar-thumb {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: var(--sjd-radius-sm);
  overflow: hidden;
  background: var(--sjd-gray-100);
}

.sjd-ai-detail-similar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sjd-ai-detail-similar-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.sjd-ai-detail-similar-body strong {
  font-size: 12px;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sjd-ai-detail-similar-body span {
  font-size: 11px;
  color: var(--sjd-purple);
}

.sjd-ai-detail-similar-row {
  padding: 20px 24px;
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-lg);
  background: var(--sjd-bg);
}

.sjd-ai-detail-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}

.sjd-ai-detail-section-head h2 {
  font-size: 16px;
  font-weight: 700;
}

.sjd-ai-detail-similar-track {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 4px;
}

.sjd-ai-detail-similar-card {
  flex: 0 0 120px;
  scroll-snap-align: start;
}

.sjd-ai-detail-similar-card-img {
  width: 120px;
  height: 120px;
  object-fit: cover;
  border-radius: var(--sjd-radius-sm);
  margin-bottom: 6px;
}

.sjd-ai-detail-similar-card span {
  display: block;
  font-size: 11px;
  line-height: 1.35;
  color: var(--sjd-text-muted);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sjd-single-ai .sjd-breadcrumbs {
  margin-bottom: 16px;
}

/* Footer */
.sjd-footer {
  background: var(--sjd-black);
  color: rgba(255,255,255,.8);
  padding: 48px 0 24px;
}
.sjd-footer-features {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-bottom: 32px;
}
.sjd-footer-feature h4 { font-size: 14px; color: #fff; margin: 8px 0 4px; }
.sjd-footer-feature p { font-size: 12px; color: rgba(255,255,255,.5); }
.sjd-footer-feature-icon { font-size: 24px; }
.sjd-footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,.1);
  font-size: 12px;
  color: rgba(255,255,255,.4);
}
.sjd-footer-brand strong { display: block; color: #fff; font-size: 14px; }

/* Search & 404 */
.sjd-search-page {
  padding: 28px 0 56px;
}

.sjd-search-page .sjd-page-layout--search {
  display: grid;
}

.sjd-search-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px 32px;
  margin-bottom: 28px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--sjd-border);
}

.sjd-search-header-text {
  min-width: 0;
}

.sjd-search-header h1 {
  font-size: clamp(22px, 3vw, 30px);
  font-weight: 700;
  line-height: 1.25;
  margin: 0 0 8px;
}

.sjd-search-header span { color: var(--sjd-purple); }

.sjd-search-count {
  margin: 0;
  font-size: 14px;
  color: var(--sjd-text-muted);
}

.sjd-search-header .sjd-search-form-bar {
  margin: 0;
  margin-top: 0;
  max-width: min(100%, 420px);
  flex: 1 1 320px;
}

.sjd-search-input-wrap {
  flex: 1;
  min-width: 0;
}

.sjd-search-form-bar input {
  width: 100%;
  padding: 13px 18px;
  font-size: 15px;
  background: var(--sjd-bg);
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-xl);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
}

.sjd-search-form-bar input:focus {
  border-color: var(--sjd-purple);
  outline: none;
  box-shadow: 0 0 0 3px var(--sjd-purple-light);
}

.sjd-search-submit {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  min-height: 48px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
}

.sjd-search-submit svg {
  width: 20px;
  height: 20px;
}

.sjd-page-layout--search {
  grid-template-columns: 240px minmax(0, 1fr);
  gap: 28px;
  align-items: start;
}

.sjd-search-sidebar {
  position: sticky;
  top: calc(var(--sjd-header-h, 64px) + 20px);
  align-self: start;
}

.sjd-search-sidebar-panel {
  padding: 18px 16px;
  background: var(--sjd-gray-50);
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-lg);
}

.sjd-search-sidebar .sjd-sidebar-title {
  font-size: 14px;
  font-weight: 700;
  margin: 0 0 12px;
  color: var(--sjd-text);
  text-transform: none;
  letter-spacing: 0;
}

.sjd-hot-search-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-height: min(420px, calc(100vh - var(--sjd-header-h, 64px) - 120px));
  overflow-y: auto;
  scrollbar-width: thin;
}

.sjd-hot-search-item {
  display: block;
  padding: 9px 12px;
  border-radius: var(--sjd-radius);
  background: var(--sjd-bg);
  border: 1px solid var(--sjd-border);
  font-size: 13px;
  font-weight: 500;
  line-height: 1.35;
  color: var(--sjd-text);
  transition: border-color var(--sjd-transition), background var(--sjd-transition), color var(--sjd-transition);
}

.sjd-hot-search-item:hover {
  border-color: var(--sjd-purple);
  background: var(--sjd-purple-light);
  color: var(--sjd-purple-dark);
}

.sjd-hot-search-item.is-active {
  border-color: var(--sjd-purple);
  background: var(--sjd-purple-light);
  color: var(--sjd-purple-dark);
  font-weight: 600;
}

.sjd-search-sidebar-empty {
  margin: 0;
  font-size: 13px;
  color: var(--sjd-text-muted);
}

.sjd-search-content {
  min-width: 0;
}

.sjd-search-dimensions {
  display: block;
  margin-bottom: 20px;
}

.sjd-search-dimensions-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--sjd-text-muted);
  margin-bottom: 10px;
}

.sjd-search-dim-tags {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  width: 100%;
}

.sjd-search-dim-tag {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  font-size: 12px;
  padding: 6px 12px;
}

.sjd-search-dim-tag.is-active {
  background: var(--sjd-purple);
  color: #fff;
  border-color: var(--sjd-purple);
}

.sjd-search-results-panel {
  padding: 20px;
  background: var(--sjd-bg);
  border: 1px solid var(--sjd-border);
  border-radius: var(--sjd-radius-lg);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
}

.sjd-grid--search {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  align-items: start;
}

.sjd-grid--search .sjd-card {
  height: auto;
}

.sjd-grid--search .sjd-card:not(.sjd-people-card--portrait) {
  height: 100%;
}

.sjd-grid--search .sjd-card-link {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.sjd-grid--search .sjd-card-image,
.sjd-grid--search .sjd-magazine-card-image,
.sjd-grid--search .sjd-people-card-image {
  aspect-ratio: 3 / 4;
}

.sjd-grid--search .sjd-card-body {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.sjd-grid--search .sjd-people-card:not(.sjd-people-card--portrait) {
  flex: none;
  width: auto;
  height: auto;
  text-align: center;
}

.sjd-grid--search .sjd-magazine-card .sjd-card-title,
.sjd-grid--search .sjd-visual-card .sjd-card-title {
  font-size: 14px;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sjd-search-empty {
  padding: 56px 24px;
  text-align: center;
}

.sjd-search-empty .sjd-no-results {
  padding: 0 0 8px;
  margin: 0;
  font-size: 16px;
  color: var(--sjd-text);
}

.sjd-search-empty-hint {
  margin: 0;
  font-size: 14px;
  color: var(--sjd-text-muted);
}

.sjd-search-results-panel .sjd-pagination {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--sjd-border);
}

/* 风格标签归档（首页热门趋势落地页） */
.sjd-page-style-tag {
  padding: 32px 0 48px;
}

.sjd-page-layout--style-tag {
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 36px;
  align-items: start;
}

.sjd-style-tag-header {
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--sjd-border);
}

.sjd-style-tag-eyebrow {
  margin: 0 0 8px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--sjd-purple);
}

.sjd-style-tag-title {
  margin: 0 0 6px;
  font-size: clamp(26px, 3.5vw, 34px);
  font-weight: 700;
  line-height: 1.2;
}

.sjd-style-tag-subtitle {
  margin: 0 0 10px;
  font-size: 16px;
  color: var(--sjd-text-muted);
}

.sjd-style-tag-count {
  margin: 0;
  font-size: 14px;
  color: var(--sjd-text-muted);
}

.sjd-style-tag-desc {
  margin: 12px 0 0;
  max-width: 720px;
  font-size: 14px;
  line-height: 1.6;
  color: var(--sjd-text-muted);
}

.sjd-style-tag-sidebar .sjd-sidebar-title {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 12px;
  text-transform: none;
  letter-spacing: 0;
}

.sjd-style-tag-nav {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.sjd-style-tag-nav-item {
  display: block;
  padding: 10px 12px;
  border-radius: var(--sjd-radius);
  border: 1px solid var(--sjd-border);
  background: var(--sjd-gray-50);
  transition: border-color var(--sjd-transition), background var(--sjd-transition);
}

.sjd-style-tag-nav-item:hover {
  border-color: var(--sjd-purple);
  background: var(--sjd-purple-light);
}

.sjd-style-tag-nav-item.is-active {
  border-color: var(--sjd-purple);
  background: var(--sjd-purple-light);
  box-shadow: 0 0 0 1px var(--sjd-purple);
}

.sjd-style-tag-nav-name {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: var(--sjd-text);
}

.sjd-style-tag-nav-cn {
  display: block;
  margin-top: 2px;
  font-size: 12px;
  color: var(--sjd-text-muted);
}

.sjd-style-tag-nav-item em {
  display: block;
  margin-top: 6px;
  font-size: 11px;
  font-style: normal;
  color: var(--sjd-gray-400);
}

.sjd-style-tag-all-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 16px;
  font-size: 13px;
  font-weight: 600;
  color: var(--sjd-purple);
}

.sjd-style-tag-all-link:hover {
  color: var(--sjd-purple-dark);
}

.sjd-style-tag-content {
  min-width: 0;
}

.sjd-style-tag-content .sjd-btn-load-more {
  margin-top: 28px;
}

.sjd-style-tag-empty {
  padding: 48px 24px;
  text-align: center;
  background: var(--sjd-gray-50);
  border: 1px dashed var(--sjd-border);
  border-radius: var(--sjd-radius-lg);
}

.sjd-style-tag-empty .sjd-btn {
  margin-top: 16px;
}

.sjd-404-inner { text-align: center; padding: 80px 0; }
.sjd-404-inner h1 { font-size: 80px; font-weight: 700; color: var(--sjd-purple); }
.sjd-404-inner p { font-size: 18px; color: var(--sjd-text-muted); margin: 16px 0 32px; }

.sjd-no-results { text-align: center; padding: 48px; color: var(--sjd-text-muted); grid-column: 1 / -1; }
.sjd-placeholder { background: var(--sjd-gray-200); aspect-ratio: 3/4; border-radius: var(--sjd-radius); }

.sjd-pagination { display: flex; justify-content: center; gap: 4px; margin-top: 32px; }
.sjd-pagination .page-numbers {
  padding: 8px 14px;
  border-radius: var(--sjd-radius-sm);
  font-size: 13px;
}
.sjd-pagination .current { background: var(--sjd-purple); color: #fff; }

.sjd-guide-list { font-size: 13px; color: var(--sjd-text-muted); margin-bottom: 16px; }
.sjd-guide-list li { padding: 4px 0; }

/* Mobile Nav */
.sjd-mobile-nav {
  position: fixed;
  top: var(--sjd-header-h);
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 999;
  background: var(--sjd-header-bg);
  color: var(--sjd-header-text-active);
  padding: 16px 24px 32px;
  overflow-y: auto;
  border-top: 1px solid var(--sjd-header-border);
}
.admin-bar .sjd-mobile-nav { top: calc(var(--sjd-header-h) + 32px); }
@media screen and (max-width: 782px) {
  .admin-bar .sjd-mobile-nav { top: calc(var(--sjd-header-h) + 46px); }
}
.sjd-mobile-nav[hidden] { display: none; }
.sjd-mobile-nav-link {
  display: block;
  padding: 14px 12px;
  font-size: 15px;
  color: var(--sjd-header-text);
  border-bottom: 1px solid var(--sjd-header-border);
  border-radius: var(--sjd-radius-sm);
  transition: color var(--sjd-transition), background var(--sjd-transition);
}
.sjd-mobile-nav-link:hover {
  color: var(--sjd-header-text-active);
  background: var(--sjd-header-hover);
}
.sjd-mobile-nav-link.is-active {
  color: var(--sjd-header-text-active);
  background: rgba(168, 85, 247, .15);
  border-left: 3px solid var(--sjd-purple);
}
body.sjd-nav-open { overflow: hidden; }

/* Responsive */
@media (max-width: 1200px) {
  .sjd-trends-banner-inner {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .sjd-trends-banner-desc {
    max-width: none;
  }

  .sjd-trends-top-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .sjd-hero-inner {
    grid-template-columns: minmax(0, 1fr) 300px;
  }

  .sjd-hero-features {
    width: 300px;
  }

  .sjd-grid--5, .sjd-grid--6 { grid-template-columns: repeat(4, 1fr); }
  .sjd-trend-grid, .sjd-style-grid { grid-template-columns: repeat(3, 1fr); }
  .sjd-page-trends .sjd-trend-masonry { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .sjd-masonry { columns: 3; }
  .sjd-page-layout--triple,
  .sjd-page-layout--prompt,
  .sjd-page-layout--photo-style,
  .sjd-page-layout--color,
  .sjd-page-layout--library { grid-template-columns: 200px 1fr; }
  .sjd-page-layout--ai { grid-template-columns: 1fr; }
  .sjd-ai-detail-layout { grid-template-columns: 200px minmax(0, 1fr); }
  .sjd-ai-detail-sidebar--right { display: none; }
  .sjd-ai-detail-hero { grid-template-columns: minmax(240px, 38%) minmax(0, 1fr); }
  .sjd-ai-detail-camera { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .sjd-sidebar--right,
  .sjd-sidebar--prompt-right,
  .sjd-sidebar--photo-style-right,
  .sjd-sidebar--color-right,
  .sjd-sidebar--ai { display: none; }
  .sjd-prompt-banner-inner { grid-template-columns: 1fr; }
  .sjd-prompt-banner-side { grid-template-columns: 1fr; }
  .sjd-photo-style-featured-slide.is-active { grid-template-columns: 1fr; }
  .sjd-color-featured-slide.is-active { grid-template-columns: 1fr; }
}

@media (max-width: 992px) {
  .sjd-trends-top-list {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: 4px;
    -webkit-overflow-scrolling: touch;
  }

  .sjd-trends-top-card {
    flex: 0 0 min(240px, 78vw);
    scroll-snap-align: start;
  }

  .sjd-hero-inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .sjd-hero-features {
    justify-self: stretch;
    width: 100%;
    min-height: 200px;
  }

  .sjd-hero-overlay {
    justify-content: flex-end;
  }
  .sjd-triple-grid { grid-template-columns: 1fr; }
  .sjd-page-layout,
  .sjd-page-layout--search,
  .sjd-page-layout--style-tag { grid-template-columns: 1fr; }
  .sjd-search-sidebar,
  .sjd-style-tag-sidebar { position: static; }
  .sjd-search-header {
    flex-direction: column;
    align-items: stretch;
  }
  .sjd-search-header .sjd-search-form-bar {
    max-width: none;
    flex: 1 1 auto;
    width: 100%;
  }
  .sjd-grid--search {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .sjd-sidebar { position: static; }
  .sjd-grid--4, .sjd-grid--5 { grid-template-columns: repeat(3, 1fr); }
  .sjd-masonry { columns: 2; }
  .sjd-trend-masonry { grid-template-columns: repeat(2, 1fr); }
  .sjd-page-trends .sjd-trend-masonry { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .sjd-footer-features { grid-template-columns: repeat(2, 1fr); }
  .sjd-prompt-layout { grid-template-columns: 1fr; }
  .sjd-visual-layout:not(.sjd-detail-layout) { grid-template-columns: 1fr; }
  .sjd-visual-media:not(.sjd-detail-media) { position: static; }
  .sjd-color-detail-layout { grid-template-columns: 1fr; }
  .sjd-color-detail-media { position: static; }
  .sjd-color-detail-examples-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sjd-single-page-layout { grid-template-columns: 1fr; }
  .sjd-sidebar--single { display: none; }
  .sjd-detail-layout,
  .sjd-magazine-layout { grid-template-columns: 1fr; }
  .sjd-detail-media,
  .sjd-magazine-media { position: static; }
  .sjd-magazine-banner-inner { grid-template-columns: 1fr; }
  .sjd-brand-banner-inner { grid-template-columns: 1fr; }
  .sjd-prompt-banner-inner { grid-template-columns: 1fr; }
  .sjd-prompt-banner-side {
    grid-template-columns: 1fr;
    min-height: auto;
  }
  .sjd-prompt-banner-visual { min-height: 220px; }
  .sjd-page-layout--prompt { grid-template-columns: 1fr; }
  .sjd-page-layout--photo-style { grid-template-columns: 1fr; }
  .sjd-page-layout--color { grid-template-columns: 1fr; }
  .sjd-page-layout--library { grid-template-columns: 1fr; }
  .sjd-page-layout--ai { grid-template-columns: 1fr; }
  .sjd-ai-detail-layout { grid-template-columns: 1fr; }
  .sjd-ai-detail-sidebar { position: static; display: none; }
  .sjd-ai-detail-hero { grid-template-columns: 1fr; }
  .sjd-ai-detail-block--split { grid-template-columns: 1fr; }
  .sjd-ai-detail-composition-diagram { width: 100%; max-width: 160px; }
  .sjd-ai-detail-camera { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sjd-ai-banner { grid-template-columns: 1fr; }
  .sjd-ai-tools-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sjd-ai-cases-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sjd-library-banner { grid-template-columns: 1fr; }
  .sjd-library-toolbar { flex-direction: column; align-items: stretch; }
  .sjd-library-masonry.sjd-view-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sjd-photo-style-featured-slide.is-active { grid-template-columns: 1fr; }
  .sjd-color-featured-slide.is-active { grid-template-columns: 1fr; }
  .sjd-brand-footer-grid,
  .sjd-magazine-footer-grid { grid-template-columns: 1fr; }
  .sjd-page-layout--brand { grid-template-columns: 1fr; }
  .sjd-page-layout--magazine { grid-template-columns: 1fr; }
  .sjd-sidebar--magazine { display: none; }
  .sjd-page-layout--region { grid-template-columns: 1fr; }
  .sjd-sidebar--region { display: none; }
  .sjd-region-term-header-inner { grid-template-columns: 1fr; }
  .sjd-region-term-featured {
    max-width: 160px;
    justify-self: start;
  }
  .sjd-region-grid,
  .sjd-region-media-grid,
  .sjd-grid--search { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sjd-people-grid--region { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .sjd-magazine-banner-inner { grid-template-columns: 1fr; }
  .sjd-magazine-toolbar {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }
  .sjd-magazine-term-header-inner {
    grid-template-columns: 1fr;
  }
  .sjd-magazine-term-featured {
    max-width: 160px;
    justify-self: start;
  }
  .sjd-magazine-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }
  .sjd-magazine-cover-stack { height: 180px; margin-top: 12px; }
  .sjd-magazine-footer-grid { grid-template-columns: 1fr; }
  .sjd-magazine-topic-list { grid-template-columns: 1fr; }
  .sjd-people-profile { grid-template-columns: 1fr; }
  .sjd-people-hero { grid-template-columns: 1fr; }
  .sjd-people-hero-featured { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .sjd-people-panel-top { grid-template-columns: 1fr; }
  .sjd-people-panel-profile { grid-template-columns: 120px minmax(0, 1fr); }
  .sjd-people-panel-photo { max-width: 120px; }
  .sjd-people-panel-nav ul {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
  }
  .sjd-profile-stats--panel,
  .sjd-people-panel--single .sjd-profile-stats--panel {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .sjd-single-people .sjd-people-panel-nav,
  .sjd-single-people .sjd-people-panel-brands { position: static; }
}

@media (max-width: 768px) {
  .sjd-nav { display: none; }
  .sjd-mobile-toggle { display: flex; }
  .sjd-grid--3, .sjd-grid--4, .sjd-grid--5, .sjd-grid--6 { grid-template-columns: repeat(2, 1fr); }
  .sjd-trend-grid, .sjd-style-grid { grid-template-columns: repeat(2, 1fr); }
  .sjd-masonry { columns: 2; }
  .sjd-trend-masonry { grid-template-columns: 1fr; }
  .sjd-page-trends .sjd-trend-masonry { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sjd-footer-features { grid-template-columns: 1fr; }
  .sjd-footer-bottom { flex-direction: column; gap: 8px; text-align: center; }
  .sjd-hero-slider { min-height: 640px; }
  .sjd-trends-banner {
    padding: 20px 16px;
  }
  .sjd-hero-overlay {
    justify-content: flex-end;
  }
  .sjd-hero-feature { padding: 22px 24px; }
  .sjd-hero-dots-wrap { bottom: 20px; }
  .sjd-section { padding: 32px 0; }
  .sjd-people-hero-featured { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sjd-people-toolbar { flex-direction: column; align-items: stretch; }
  .sjd-people-toolbar .sjd-alpha-bar { width: 100%; }
  .sjd-people-sort { margin-left: 0; width: 100%; }
  .sjd-people-sort select { width: 100%; }
  .sjd-people-scroll-btn { width: 36px; height: 36px; }
}

@media (max-width: 480px) {
  .sjd-grid--search { grid-template-columns: 1fr; }
  .sjd-search-results-panel { padding: 16px; }
  .sjd-grid--3, .sjd-grid--4, .sjd-grid--5, .sjd-grid--6 { grid-template-columns: 1fr; }
  .sjd-people-card { flex-basis: 108px; }
  .sjd-masonry { columns: 1; }
  .sjd-people-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}
