﻿.gc-forge-studio-card {
  background: linear-gradient(135deg, rgba(230,57,70,0.12), rgba(67,97,238,0.1), rgba(245,158,11,0.05));
  border-color: rgba(245,158,11,0.24);
}
.gc-composer-forge-link {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid var(--gc-border);
  border-radius: 999px;
  color: var(--gc-text-secondary);
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
}
.gc-composer-forge-link:hover {
  color: var(--gc-text-primary);
  border-color: var(--gc-accent);
}
/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
  LoreBurst Community v9 - Commercial-Grade Design System
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€ Design Tokens â”€â”€ */
:root {
  --gc-bg: #07080c;
  --gc-surface: #10141b;
  --gc-surface-hover: #17202a;
  --gc-surface-raised: #1b2631;
  --gc-surface-overlay: #22303d;
  --gc-border: rgba(247,240,223,0.1);
  --gc-border-light: rgba(247,240,223,0.16);
  --gc-text: #f7f0df;
  --gc-text-secondary: #a9b0bd;
  --gc-text-tertiary: #747d8d;
  --gc-accent: #ff5a3d;
  --gc-accent-hover: #ff765f;
  --gc-accent-dark: #ce3c28;
  --gc-accent-subtle: rgba(255,90,61,.12);
  --gc-accent2: #24d6c9;
  --gc-hover: rgba(231,233,234,.03);
  --gc-hover-strong: rgba(231,233,234,.08);
  --gc-like: #ff5a3d;
  --gc-like-bg: rgba(255,90,61,.12);
  --gc-repost: #22c55e;
  --gc-repost-bg: rgba(34,197,94,.1);
  --gc-bookmark: #24d6c9;
  --gc-bookmark-bg: rgba(36,214,201,.12);
  --gc-warning: #ffd166;
  --gc-error: #ef4444;
  --gc-success: #22c55e;
  --gc-link: #24d6c9;
  /* Spacing */
  --gc-sp-1: 4px; --gc-sp-2: 8px; --gc-sp-3: 12px; --gc-sp-4: 16px;
  --gc-sp-5: 20px; --gc-sp-6: 24px; --gc-sp-7: 32px; --gc-sp-8: 48px;
  /* Typography */
  --gc-fs-xs: 12px; --gc-fs-sm: 13px; --gc-fs-base: 15px;
  --gc-fs-md: 16px; --gc-fs-lg: 18px; --gc-fs-xl: 20px;
  --gc-fs-2xl: 24px; --gc-fs-3xl: 32px;
  --gc-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  /* Radius */
  --gc-radius-sm: 8px; --gc-radius-md: 12px; --gc-radius-lg: 16px;
  --gc-radius-xl: 20px; --gc-radius-full: 9999px;
  /* Shadows */
  --gc-shadow-sm: 0 1px 3px rgba(0,0,0,.4);
  --gc-shadow-md: 0 4px 16px rgba(0,0,0,.5);
  --gc-shadow-lg: 0 8px 32px rgba(0,0,0,.6);
  --gc-shadow-glow: 0 0 20px rgba(255,90,61,.22);
  /* Transitions */
  --gc-transition: 150ms ease;
  --gc-transition-slow: 250ms ease;
}

/* â”€â”€ Base â”€â”€ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
.gc-app { font-family: var(--gc-font); color: var(--gc-text); background: var(--gc-bg); min-height: 100vh; line-height: 1.5; -webkit-font-smoothing: antialiased; }
.gc-app a { color: inherit; text-decoration: none; }
.gc-app button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
.gc-app input, .gc-app textarea, .gc-app select { font-family: inherit; color: var(--gc-text); background: var(--gc-bg); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-sm); padding: var(--gc-sp-2) var(--gc-sp-3); font-size: var(--gc-fs-base); outline: none; transition: border-color var(--gc-transition); }
.gc-app input:focus, .gc-app textarea:focus, .gc-app select:focus { border-color: var(--gc-accent); }
.gc-app img { max-width: 100%; display: block; }

/* â”€â”€ Layout Grid â”€â”€ */
.gc-layout { display: grid; grid-template-columns: 275px minmax(0, 600px) 350px; max-width: 1280px; margin: 0 auto; min-height: calc(100vh - var(--gmn-topbar-h, 38px)); gap: 0; }

/* â”€â”€ Left Sidebar â”€â”€ */
.gc-sidebar { position: sticky; top: var(--gmn-topbar-h, 38px); height: calc(100vh - var(--gmn-topbar-h, 38px)); overflow-y: auto; overflow-x: hidden; padding: var(--gc-sp-3) var(--gc-sp-3) var(--gc-sp-3) var(--gc-sp-4); display: flex; flex-direction: column; border-right: 1px solid var(--gc-border); scrollbar-width: thin; }
.gc-logo { display: flex; align-items: center; gap: var(--gc-sp-3); padding: var(--gc-sp-3) var(--gc-sp-3); margin-bottom: var(--gc-sp-2); text-decoration: none; }
.gc-logo-icon { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; }
.gc-logo-icon svg { width: 36px; height: 36px; }
.gc-logo-text { font-size: var(--gc-fs-xl); font-weight: 800; background: linear-gradient(135deg, var(--gc-accent), var(--gc-accent2)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; letter-spacing: -.5px; }
.gc-nav { flex: 1; display: flex; flex-direction: column; gap: var(--gc-sp-1); }
.gc-nav-item { display: flex; align-items: center; gap: var(--gc-sp-5); padding: var(--gc-sp-3) var(--gc-sp-3); border-radius: var(--gc-radius-full); font-size: var(--gc-fs-xl); transition: background var(--gc-transition); position: relative; white-space: nowrap; }
.gc-nav-item:hover { background: var(--gc-hover-strong); }
.gc-nav-item.active { font-weight: 700; }
.gc-nav-item svg { width: 26px; height: 26px; flex-shrink: 0; }
.gc-nav-item .gc-nav-label { font-size: var(--gc-fs-xl); }
.gc-nav-badge { position: absolute; top: 4px; left: 18px; background: var(--gc-accent); color: #fff; font-size: 11px; font-weight: 700; min-width: 18px; height: 18px; border-radius: var(--gc-radius-full); display: flex; align-items: center; justify-content: center; padding: 0 5px; }
.gc-compose-btn { width: 90%; padding: var(--gc-sp-4); border-radius: var(--gc-radius-full); background: var(--gc-accent); color: #fff; font-size: 17px; font-weight: 700; border: none; margin-top: var(--gc-sp-4); transition: background var(--gc-transition), box-shadow var(--gc-transition); cursor: pointer; text-align: center; }
.gc-compose-btn:hover { background: var(--gc-accent-hover); box-shadow: var(--gc-shadow-glow); }
.gc-compose-icon { display: none; }
.gc-compose-full { display: inline-flex; align-items: center; gap: 8px; }
.gc-sidebar-user { display: flex; align-items: center; gap: var(--gc-sp-3); padding: var(--gc-sp-3); border-radius: var(--gc-radius-full); margin-top: auto; transition: background var(--gc-transition); cursor: pointer; }
.gc-sidebar-user:hover { background: var(--gc-hover-strong); }
.gc-sidebar-user-info { flex: 1; min-width: 0; }
.gc-sidebar-user-name { font-weight: 700; font-size: var(--gc-fs-base); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gc-sidebar-user-handle { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gc-sidebar-user .gc-dots { color: var(--gc-text-secondary); font-size: var(--gc-fs-xl); }

/* â”€â”€ Main Content Area â”€â”€ */
.gc-main { border-right: 1px solid var(--gc-border); min-height: calc(100vh - var(--gmn-topbar-h, 38px)); overflow-y: visible; }
.gc-view-header { position: sticky; top: 0; z-index: 10; background: rgba(0,0,0,.65); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); padding: var(--gc-sp-3) var(--gc-sp-4); display: flex; align-items: center; gap: var(--gc-sp-4); border-bottom: 1px solid var(--gc-border); min-height: 53px; }
.gc-view-header h2 { font-size: var(--gc-fs-xl); font-weight: 700; flex: 1; }
.gc-view-header .gc-view-subtitle { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); margin-top: 2px; }
.gc-back-btn { display: flex; align-items: center; gap: var(--gc-sp-2); color: var(--gc-text); background: none; border: none; font-size: var(--gc-fs-base); padding: var(--gc-sp-2); border-radius: var(--gc-radius-full); transition: background var(--gc-transition); cursor: pointer; }
.gc-back-btn:hover { background: var(--gc-hover-strong); }
.gc-back-btn svg { width: 20px; height: 20px; }
.gc-view-desc { padding: var(--gc-sp-3) var(--gc-sp-4); color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); border-bottom: 1px solid var(--gc-border); }

/* â”€â”€ Tabs â”€â”€ */
.gc-tabs { display: flex; border-bottom: 1px solid var(--gc-border); }
.gc-tab { flex: 1; text-align: center; padding: var(--gc-sp-4) 0; font-size: var(--gc-fs-base); font-weight: 500; color: var(--gc-text-secondary); cursor: pointer; position: relative; transition: background var(--gc-transition), color var(--gc-transition); }
.gc-tab:hover { background: var(--gc-hover); color: var(--gc-text); }
.gc-tab.active { color: var(--gc-text); font-weight: 700; }
.gc-tab.active::after { content: ''; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 56px; height: 4px; background: var(--gc-accent); border-radius: 2px; }

/* â”€â”€ Right Sidebar â”€â”€ */
.gc-right { position: sticky; top: var(--gmn-topbar-h, 38px); height: calc(100vh - var(--gmn-topbar-h, 38px)); overflow-y: auto; overflow-x: hidden; padding: var(--gc-sp-3) var(--gc-sp-6); display: flex; flex-direction: column; gap: var(--gc-sp-4); scrollbar-width: thin; }
.gc-search-wrapper { position: relative; margin-bottom: var(--gc-sp-2); }
.gc-search-input { width: 100%; background: var(--gc-surface); border: 1px solid transparent; border-radius: var(--gc-radius-full); padding: var(--gc-sp-3) var(--gc-sp-4) var(--gc-sp-3) 44px; font-size: var(--gc-fs-base); color: var(--gc-text); transition: border-color var(--gc-transition), background var(--gc-transition); }
.gc-search-input:focus { border-color: var(--gc-accent); background: var(--gc-bg); }
.gc-search-wrapper .gc-search-icon { position: absolute; left: var(--gc-sp-4); top: 50%; transform: translateY(-50%); color: var(--gc-text-secondary); pointer-events: none; }
.gc-search-wrapper .gc-search-icon svg { width: 18px; height: 18px; }
.gc-search-results { position: absolute; top: 100%; left: 0; right: 0; background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-md); margin-top: var(--gc-sp-1); box-shadow: var(--gc-shadow-lg); z-index: 100; display: none; max-height: 400px; overflow-y: auto; }
.gc-search-result { display: flex; align-items: center; gap: var(--gc-sp-3); padding: var(--gc-sp-3) var(--gc-sp-4); cursor: pointer; transition: background var(--gc-transition); }
.gc-search-result:hover { background: var(--gc-hover-strong); }
.gc-search-result-name { font-weight: 700; font-size: var(--gc-fs-base); }
.gc-search-result-bio { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); }
.gc-search-empty { padding: var(--gc-sp-4); text-align: center; color: var(--gc-text-secondary); }

/* Right sidebar cards */
.gc-card { background: var(--gc-surface); border-radius: var(--gc-radius-lg); margin-bottom: var(--gc-sp-4); overflow: hidden; border: 1px solid var(--gc-border); box-shadow: var(--gc-shadow-sm); transition: border-color var(--gc-transition); }
.gc-card:hover { border-color: var(--gc-border-light); }
.gc-card-header { padding: var(--gc-sp-4); font-size: var(--gc-fs-xl); font-weight: 800; }
.gc-card-item { padding: var(--gc-sp-3) var(--gc-sp-4); transition: background var(--gc-transition); cursor: pointer; }
.gc-card-item:hover { background: var(--gc-hover-strong); }
.gc-card-footer { padding: var(--gc-sp-4); }
.gc-card-footer a { color: var(--gc-accent); font-size: var(--gc-fs-base); }
.gc-card-footer a:hover { text-decoration: underline; }

/* Trending card */
.gc-trending-card .gc-card-header { font-size: var(--gc-fs-xl); font-weight: 800; }
.gc-trending-item { display: flex; align-items: flex-start; gap: 10px; padding: 10px 14px; border-radius: 8px; transition: background var(--gc-transition); text-decoration: none; color: inherit; }
.gc-trending-item:hover { background: var(--gc-hover-strong); }
.gc-trending-num { flex-shrink: 0; width: 20px; color: var(--gc-text-secondary); font-size: 13px; font-weight: 600; text-align: right; padding-top: 2px; }
.gc-trending-info { flex: 1; min-width: 0; }
.gc-trending-name { display: block; font-weight: 700; font-size: var(--gc-fs-base); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 1px; }
.gc-trending-meta { display: block; font-size: 12px; color: var(--gc-text-secondary); }
.gc-trending-label { font-size: var(--gc-fs-xs); color: var(--gc-text-tertiary); }
.gc-trending-name { font-weight: 700; font-size: var(--gc-fs-base); margin: 2px 0; }
.gc-trending-meta { font-size: var(--gc-fs-xs); color: var(--gc-text-secondary); }
.gc-trending-stats { display: flex; align-items: center; gap: var(--gc-sp-1); color: var(--gc-text-secondary); font-size: var(--gc-fs-xs); }

/* Suggestions card */
.gc-suggest-card .gc-card-header { font-size: var(--gc-fs-xl); font-weight: 800; }
.gc-suggest-item { display: flex; align-items: center; gap: var(--gc-sp-3); padding: var(--gc-sp-3) var(--gc-sp-4); }
.gc-suggest-info { flex: 1; min-width: 0; }
.gc-suggest-name { font-weight: 700; font-size: var(--gc-fs-base); display: block; }
.gc-suggest-name:hover { text-decoration: underline; }
.gc-suggest-bio { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Guest CTA card */
.gc-guest-cta { background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-lg); padding: var(--gc-sp-6); text-align: center; }
.gc-guest-cta h3 { font-size: var(--gc-fs-2xl); font-weight: 800; margin-bottom: var(--gc-sp-2); }
.gc-guest-cta p { color: var(--gc-text-secondary); font-size: var(--gc-fs-base); margin-bottom: var(--gc-sp-5); }
.gc-guest-cta .gc-btn { width: 100%; margin-bottom: var(--gc-sp-3); }

/* Footer */
.gc-right-footer { color: var(--gc-text-tertiary); font-size: var(--gc-fs-xs); padding: var(--gc-sp-3) 0; }
.gc-right-footer a { color: var(--gc-text-tertiary); }
.gc-right-footer a:hover { text-decoration: underline; }

/* â”€â”€ Buttons â”€â”€ */
.gc-btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--gc-sp-2); padding: var(--gc-sp-2) var(--gc-sp-4); border-radius: var(--gc-radius-full); font-size: var(--gc-fs-base); font-weight: 700; cursor: pointer; border: none; transition: all var(--gc-transition); white-space: nowrap; }
.gc-btn-accent { background: var(--gc-accent); color: #fff; }
.gc-btn-accent:hover { background: var(--gc-accent-hover); }
.gc-btn-outline { background: transparent; color: var(--gc-text); border: 1px solid var(--gc-border); }
.gc-btn-outline:hover { background: var(--gc-hover-strong); border-color: var(--gc-text-secondary); }
.gc-btn-ghost { background: transparent; color: var(--gc-text-secondary); }
.gc-btn-ghost:hover { background: var(--gc-hover-strong); color: var(--gc-text); }
.gc-btn-primary { background: var(--gc-accent); color: #fff; }
.gc-btn-primary:hover { background: var(--gc-accent-hover); }
.gc-btn-danger { background: var(--gc-error); color: #fff; }
.gc-btn-danger:hover { opacity: .9; }
.gc-btn-sm { padding: var(--gc-sp-1) var(--gc-sp-3); font-size: var(--gc-fs-sm); }
.gc-btn-xs { padding: 2px var(--gc-sp-2); font-size: var(--gc-fs-xs); }
.gc-btn-lg { padding: var(--gc-sp-3) var(--gc-sp-6); font-size: var(--gc-fs-md); }
.gc-btn:disabled { opacity: .5; cursor: not-allowed; }
.gc-btn svg { width: 18px; height: 18px; }

/* â”€â”€ Verified Badge â”€â”€ */
.gc-verified { display: inline-flex; align-items: center; justify-content: center; margin-left: var(--gc-sp-1); vertical-align: middle; flex-shrink: 0; }
.gc-verified svg { width: 18px; height: 18px; }

/* â”€â”€ Avatar â”€â”€ */
.gc-avatar { border-radius: var(--gc-radius-full); overflow: hidden; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-weight: 700; color: #fff; background: var(--gc-surface-raised); }
.gc-avatar img { width: 100%; height: 100%; object-fit: cover; }
.gc-avatar-initials { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; }

/* â”€â”€ Posts â”€â”€ */
.gc-post { display: flex; gap: var(--gc-sp-3); padding: var(--gc-sp-3) var(--gc-sp-4); border-bottom: 1px solid var(--gc-border); transition: background var(--gc-transition); cursor: pointer; }
.gc-post:hover { background: var(--gc-hover); }
.gc-post-avatar-col { flex-shrink: 0; padding-top: 2px; }
.gc-post-body { flex: 1; min-width: 0; }
.gc-post-header { display: flex; align-items: center; gap: var(--gc-sp-1); flex-wrap: wrap; }
.gc-post-name { font-weight: 700; font-size: var(--gc-fs-base); }
.gc-post-name:hover { text-decoration: underline; }
.gc-post-handle { color: var(--gc-text-secondary); font-size: var(--gc-fs-base); }
.gc-post-dot { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); }
.gc-post-time { color: var(--gc-text-secondary); font-size: var(--gc-fs-base); }
.gc-post-time:hover { text-decoration: underline; }
.gc-post-more { margin-left: auto; opacity: 0; padding: var(--gc-sp-1); border-radius: var(--gc-radius-full); transition: opacity var(--gc-transition), background var(--gc-transition); color: var(--gc-text-secondary); }
.gc-post:hover .gc-post-more { opacity: 1; }
.gc-post-more:hover { background: rgba(239,68,68,.1); color: var(--gc-error); }
.gc-post-more svg { width: 18px; height: 18px; }
.gc-post-text { margin-top: var(--gc-sp-1); font-size: var(--gc-fs-base); line-height: 1.55; word-wrap: break-word; white-space: pre-wrap; }
.gc-post-text a { color: var(--gc-link); }
.gc-post-text a:hover { text-decoration: underline; }
.gc-post-series { display: inline-flex; align-items: center; gap: var(--gc-sp-1); margin-top: var(--gc-sp-2); padding: var(--gc-sp-1) var(--gc-sp-3); background: var(--gc-accent-subtle); color: var(--gc-accent); border-radius: var(--gc-radius-full); font-size: var(--gc-fs-sm); font-weight: 500; transition: background var(--gc-transition); }
.gc-post-series:hover { background: rgba(67,97,238,.2); }
.gc-post-series svg { width: 14px; height: 14px; }

/* Post Media Grid */
.gc-post-media { margin-top: var(--gc-sp-3); border-radius: var(--gc-radius-lg); overflow: hidden; border: 1px solid var(--gc-border); }
.gc-post-media-grid { display: grid; gap: 2px; }
.gc-post-media-grid.gc-media-1 { grid-template-columns: 1fr; }
.gc-post-media-grid.gc-media-2 { grid-template-columns: 1fr 1fr; }
.gc-post-media-grid.gc-media-3 { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; }
.gc-post-media-grid.gc-media-3 .gc-media-item:first-child { grid-row: 1 / 3; }
.gc-post-media-grid.gc-media-4 { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; }
.gc-media-item { position: relative; overflow: hidden; cursor: pointer; }
.gc-media-item img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--gc-transition-slow); }
.gc-media-item:hover img { transform: scale(1.02); }
.gc-post-media-grid.gc-media-1 .gc-media-item { max-height: 510px; }
.gc-post-media-grid:not(.gc-media-1) .gc-media-item { height: 200px; }

/* Post Actions */
.gc-post-actions { display: flex; justify-content: space-between; margin-top: var(--gc-sp-3); max-width: 425px; }
.gc-action { display: flex; align-items: center; gap: var(--gc-sp-1); padding: var(--gc-sp-2); border-radius: var(--gc-radius-full); color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); transition: all var(--gc-transition); background: none; border: none; cursor: pointer; }
.gc-action svg { width: 18px; height: 18px; transition: transform .2s cubic-bezier(.34,1.56,.64,1); }
.gc-action span { min-width: 1ch; transition: color var(--gc-transition); }

/* Comment action */
.gc-comment-btn:hover { color: var(--gc-accent); background: var(--gc-accent-subtle); }
.gc-comment-btn:hover svg { transform: scale(1.15); }

/* Repost action */
.gc-repost-btn:hover { color: var(--gc-repost); background: var(--gc-repost-bg); }
.gc-repost-btn.active { color: var(--gc-repost); }
.gc-repost-btn:hover svg { transform: scale(1.15); }
.gc-repost-btn.active svg { animation: gc-pop .3s ease; }

/* Like action */
.gc-like-btn:hover { color: var(--gc-like); background: var(--gc-like-bg); }
.gc-like-btn.active { color: var(--gc-like); }
.gc-like-btn:hover svg { transform: scale(1.15); }
.gc-like-btn.active svg { animation: gc-heartPop .45s ease; }

/* Bookmark action */
.gc-bookmark-btn:hover { color: var(--gc-bookmark); background: var(--gc-bookmark-bg); }
.gc-bookmark-btn.active { color: var(--gc-bookmark); }
.gc-bookmark-btn:hover svg { transform: scale(1.15); }
.gc-bookmark-btn.active svg { animation: gc-pop .3s ease; }

/* Share action */
.gc-share-btn:hover { color: var(--gc-accent); background: var(--gc-accent-subtle); }
.gc-share-btn.shared { color: var(--gc-success); }

/* â”€â”€ Comments Section â”€â”€ */
.gc-comments-section { border-top: 1px solid var(--gc-border); margin-top: var(--gc-sp-3); padding-top: var(--gc-sp-3); }
.gc-comment { display: flex; gap: var(--gc-sp-2); padding: var(--gc-sp-2) 0; }
.gc-comment-body { flex: 1; min-width: 0; }
.gc-comment-header { display: flex; align-items: center; gap: var(--gc-sp-2); }
.gc-comment-name { font-weight: 700; font-size: var(--gc-fs-sm); }
.gc-comment-time { color: var(--gc-text-secondary); font-size: var(--gc-fs-xs); }
.gc-comment-text { font-size: var(--gc-fs-base); margin-top: 2px; word-wrap: break-word; }
.gc-comment-form { display: flex; gap: var(--gc-sp-2); align-items: flex-start; margin-top: var(--gc-sp-3); padding-top: var(--gc-sp-3); border-top: 1px solid var(--gc-border); }
.gc-comment-input { flex: 1; resize: none; border: 1px solid var(--gc-border); border-radius: var(--gc-radius-lg); padding: var(--gc-sp-2) var(--gc-sp-3); font-size: var(--gc-fs-sm); background: var(--gc-bg); color: var(--gc-text); min-height: 36px; }
.gc-comment-input:focus { border-color: var(--gc-accent); }

/* â”€â”€ Composer â”€â”€ */
.gc-composer { display: flex; gap: var(--gc-sp-3); padding: var(--gc-sp-3) var(--gc-sp-4); border-bottom: 1px solid var(--gc-border); }
.gc-composer-body { flex: 1; }
.gc-composer-textarea { width: 100%; border: none; background: transparent; color: var(--gc-text); font-size: var(--gc-fs-xl); resize: none; min-height: 52px; outline: none; line-height: 1.4; padding: var(--gc-sp-2) 0; }
.gc-composer-textarea::placeholder { color: var(--gc-text-tertiary); }
.gc-composer-toolbar { display: flex; align-items: center; justify-content: space-between; padding-top: var(--gc-sp-3); border-top: 1px solid var(--gc-border); margin-top: var(--gc-sp-2); }
.gc-composer-tools { display: flex; align-items: center; gap: var(--gc-sp-1); }
.gc-composer-tool-btn { width: 34px; height: 34px; display: flex; align-items: center; justify-content: center; border-radius: var(--gc-radius-full); color: var(--gc-accent); transition: background var(--gc-transition); cursor: pointer; border: none; background: none; }
.gc-composer-tool-btn:hover { background: var(--gc-accent-subtle); }
.gc-composer-tool-btn svg { width: 20px; height: 20px; }
.gc-composer-right { display: flex; align-items: center; gap: var(--gc-sp-3); }
/* Character count ring */
.gc-char-ring { width: 30px; height: 30px; position: relative; }
.gc-char-ring svg { width: 30px; height: 30px; transform: rotate(-90deg); }
.gc-char-ring circle { fill: none; stroke-width: 2; }
.gc-char-ring .gc-char-bg { stroke: var(--gc-border); }
.gc-char-ring .gc-char-fill { stroke: var(--gc-accent); transition: stroke-dashoffset .3s; }
.gc-char-ring.gc-char-warn .gc-char-fill { stroke: var(--gc-warning); }
.gc-char-ring.gc-char-over .gc-char-fill { stroke: var(--gc-error); }
.gc-char-ring .gc-char-count { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); font-size: 9px; color: var(--gc-text-secondary); }
.gc-composer-select { background: var(--gc-bg); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-full); padding: var(--gc-sp-1) var(--gc-sp-3); font-size: var(--gc-fs-sm); color: var(--gc-text-secondary); }
.gc-post-submit { padding: var(--gc-sp-2) var(--gc-sp-5); border-radius: var(--gc-radius-full); background: var(--gc-accent); color: #fff; font-size: var(--gc-fs-base); font-weight: 700; border: none; cursor: pointer; transition: opacity var(--gc-transition); }
.gc-post-submit:disabled { opacity: .5; cursor: not-allowed; }
.gc-post-submit:not(:disabled):hover { background: var(--gc-accent-hover); }
/* Image preview in composer */
.gc-composer-images { display: flex; gap: var(--gc-sp-2); margin-top: var(--gc-sp-2); flex-wrap: wrap; }
.gc-composer-img-preview { position: relative; width: 80px; height: 80px; border-radius: var(--gc-radius-sm); overflow: hidden; border: 1px solid var(--gc-border); }
.gc-composer-img-preview img { width: 100%; height: 100%; object-fit: cover; }
.gc-composer-img-remove { position: absolute; top: 2px; right: 2px; width: 22px; height: 22px; border-radius: 50%; background: rgba(0,0,0,.75); color: #fff; display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: 14px; border: none; }
.gc-composer-upload-row { display: flex; align-items: center; gap: 8px; margin-top: 6px; }
.gc-composer-upload-btn { display: flex; align-items: center; gap: 4px; background: none; border: 1px solid var(--gc-border); border-radius: var(--gc-radius-full); padding: 4px 12px; font-size: 13px; color: var(--gc-accent); cursor: pointer; transition: background .15s; }
.gc-composer-upload-btn:hover { background: var(--gc-accent-subtle); }
.gc-composer-upload-preview { position: relative; margin-top: 8px; }
.gc-composer-upload-preview img { max-height: 200px; border-radius: var(--gc-radius-sm); border: 1px solid var(--gc-border); }
.gc-composer-upload-preview .gc-remove-upload { position: absolute; top: 4px; right: 4px; width: 24px; height: 24px; border-radius: 50%; background: rgba(0,0,0,.7); color: #fff; border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 16px; }
.gc-composer-upload-row { display: flex; align-items: center; gap: 8px; margin-top: 6px; }
.gc-composer-upload-btn { display: flex; align-items: center; gap: 4px; background: none; border: 1px solid var(--gc-border); border-radius: var(--gc-radius-full); padding: 4px 12px; font-size: 13px; color: var(--gc-accent); cursor: pointer; transition: background .15s; }
.gc-composer-upload-btn:hover { background: var(--gc-accent-subtle); }
.gc-composer-upload-preview { position: relative; margin-top: 8px; }
.gc-composer-upload-preview img { max-height: 200px; border-radius: var(--gc-radius-sm); border: 1px solid var(--gc-border); }
.gc-composer-upload-preview .gc-remove-upload { position: absolute; top: 4px; right: 4px; width: 24px; height: 24px; border-radius: 50%; background: rgba(0,0,0,.7); color: #fff; border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 16px; }

/* â”€â”€ Profile â”€â”€ */
.gc-profile-banner { height: 200px; background: linear-gradient(135deg, var(--gc-surface) 0%, #16213e 50%, #1a1030 100%); position: relative; }
.gc-profile-banner img { width: 100%; height: 100%; object-fit: cover; }
.gc-profile-info { padding: 0 var(--gc-sp-4); }
.gc-profile-avatar-row { display: flex; align-items: flex-end; justify-content: space-between; margin-top: -48px; margin-bottom: var(--gc-sp-3); position: relative; z-index: 2; }
.gc-profile-avatar-row .gc-avatar { width: 96px; height: 96px; border: 4px solid var(--gc-bg); font-size: var(--gc-fs-3xl); border-radius: 50%; box-shadow: 0 2px 8px rgba(0,0,0,.3); }
.gc-profile-actions { display: flex; gap: var(--gc-sp-2); padding-top: 48px; }
.gc-profile-name { font-size: var(--gc-fs-xl); font-weight: 800; display: flex; align-items: center; gap: var(--gc-sp-1); }
.gc-profile-handle { color: var(--gc-text-secondary); font-size: var(--gc-fs-base); margin-bottom: var(--gc-sp-3); }
.gc-profile-bio { margin-bottom: var(--gc-sp-3); font-size: var(--gc-fs-base); line-height: 1.5; }
.gc-profile-bio a { color: var(--gc-link); }
.gc-profile-meta { display: flex; flex-wrap: wrap; gap: var(--gc-sp-3) var(--gc-sp-4); margin-bottom: var(--gc-sp-3); color: var(--gc-text-secondary); font-size: var(--gc-fs-base); }
.gc-profile-meta-item { display: flex; align-items: center; gap: var(--gc-sp-1); }
.gc-profile-meta-item svg { width: 18px; height: 18px; }
.gc-profile-meta-item a { color: var(--gc-link); }
.gc-profile-meta-item a:hover { text-decoration: underline; }
.gc-profile-stats { display: flex; gap: var(--gc-sp-5); margin-bottom: var(--gc-sp-3); font-size: var(--gc-fs-base); }
.gc-profile-stats strong { color: var(--gc-text); }
.gc-profile-stats span { color: var(--gc-text-secondary); cursor: pointer; }
.gc-profile-stats span:hover { text-decoration: underline; }
.gc-profile-tabs { border-bottom: 1px solid var(--gc-border); }
/* Avatar upload overlay */
.gc-avatar-upload { position: relative; cursor: pointer; }
.gc-avatar-upload-overlay { position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,.5); border-radius: 50%; display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity var(--gc-transition); }
.gc-avatar-upload:hover .gc-avatar-upload-overlay { opacity: 1; }
.gc-avatar-upload-overlay svg { width: 24px; height: 24px; color: #fff; }
.gc-banner-upload { position: absolute; top: 0; left: 0; right: 0; bottom: 0; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.gc-banner-upload-overlay { background: rgba(0,0,0,.4); border-radius: 50%; width: 44px; height: 44px; display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity var(--gc-transition); }
.gc-banner-upload:hover .gc-banner-upload-overlay { opacity: 1; }
.gc-banner-upload-overlay svg { width: 22px; height: 22px; color: #fff; }

/* â”€â”€ Messages â”€â”€ */
.gc-convo { display: flex; align-items: center; gap: var(--gc-sp-3); padding: var(--gc-sp-4); border-bottom: 1px solid var(--gc-border); transition: background var(--gc-transition); cursor: pointer; text-decoration: none; }
.gc-convo:hover { background: var(--gc-hover); }
.gc-convo-info { flex: 1; min-width: 0; }
.gc-convo-header { display: flex; justify-content: space-between; align-items: baseline; }
.gc-convo-name { font-weight: 700; font-size: var(--gc-fs-base); }
.gc-convo-time { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); }
.gc-convo-preview { color: var(--gc-text-secondary); font-size: var(--gc-fs-base); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gc-convo-unread { color: var(--gc-text); font-weight: 600; }
.gc-convo-badge { background: var(--gc-accent); color: #fff; font-size: var(--gc-fs-xs); font-weight: 700; min-width: 20px; height: 20px; display: flex; align-items: center; justify-content: center; border-radius: var(--gc-radius-full); padding: 0 6px; }
.gc-dm-header { border-bottom: 1px solid var(--gc-border); }
.gc-dm-messages { flex: 1; overflow-y: auto; padding: var(--gc-sp-4); display: flex; flex-direction: column; gap: var(--gc-sp-2); max-height: calc(100vh - 160px); }
.gc-dm-msg { display: flex; flex-direction: column; max-width: 80%; }
.gc-dm-mine { align-self: flex-end; }
.gc-dm-theirs { align-self: flex-start; }
.gc-dm-bubble { padding: var(--gc-sp-3) var(--gc-sp-4); border-radius: var(--gc-radius-lg); font-size: var(--gc-fs-base); line-height: 1.4; word-wrap: break-word; }
.gc-dm-mine .gc-dm-bubble { background: var(--gc-accent); color: #fff; border-bottom-right-radius: var(--gc-sp-1); }
.gc-dm-theirs .gc-dm-bubble { background: var(--gc-surface-raised); border-bottom-left-radius: var(--gc-sp-1); }
.gc-dm-time { font-size: var(--gc-fs-xs); color: var(--gc-text-tertiary); margin-top: 2px; padding: 0 var(--gc-sp-1); }
.gc-dm-mine .gc-dm-time { text-align: right; }
.gc-dm-input-row { display: flex; gap: var(--gc-sp-2); padding: var(--gc-sp-3) var(--gc-sp-4); border-top: 1px solid var(--gc-border); align-items: flex-end; }
.gc-dm-input { flex: 1; resize: none; border: 1px solid var(--gc-border); border-radius: var(--gc-radius-xl); padding: var(--gc-sp-3) var(--gc-sp-4); font-size: var(--gc-fs-base); background: var(--gc-surface); color: var(--gc-text); max-height: 120px; }
.gc-dm-input:focus { border-color: var(--gc-accent); }
.gc-dm-send { width: 40px; height: 40px; border-radius: 50%; background: var(--gc-accent); color: #fff; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background var(--gc-transition); }
.gc-dm-send:hover { background: var(--gc-accent-hover); }
.gc-dm-send svg { width: 18px; height: 18px; }

/* â”€â”€ Notifications â”€â”€ */
.gc-notif { display: flex; gap: var(--gc-sp-3); padding: var(--gc-sp-3) var(--gc-sp-4); border-bottom: 1px solid var(--gc-border); cursor: pointer; transition: background var(--gc-transition); }
.gc-notif:hover { background: var(--gc-hover); }
.gc-notif-unread { background: var(--gc-accent-subtle); }
.gc-notif-unread:hover { background: rgba(29,155,240,.15); }
.gc-notif-icon { width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.gc-notif-icon svg { width: 22px; height: 22px; }
.gc-notif-like .gc-notif-icon { color: var(--gc-like); }
.gc-notif-repost .gc-notif-icon { color: var(--gc-repost); }
.gc-notif-follow .gc-notif-icon { color: var(--gc-accent); }
.gc-notif-body { display: flex; align-items: center; gap: var(--gc-sp-2); flex: 1; min-width: 0; }
.gc-notif-text { flex: 1; }
.gc-notif-text p { font-size: var(--gc-fs-base); }
.gc-notif-time { color: var(--gc-text-secondary); font-size: var(--gc-fs-xs); display: block; margin-top: 2px; }

/* â”€â”€ Polls â”€â”€ */
.gc-poll-card { background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-lg); padding: var(--gc-sp-5); margin-bottom: var(--gc-sp-4); }
.gc-poll-series { color: var(--gc-accent); font-size: var(--gc-fs-sm); font-weight: 600; margin-bottom: var(--gc-sp-1); }
.gc-poll-question { font-size: var(--gc-fs-lg); font-weight: 700; margin-bottom: var(--gc-sp-2); }
.gc-poll-meta { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); margin-bottom: var(--gc-sp-4); }
.gc-poll-options { display: flex; flex-direction: column; gap: var(--gc-sp-2); }
.gc-poll-option { position: relative; border: 1px solid var(--gc-border); border-radius: var(--gc-radius-sm); padding: var(--gc-sp-3) var(--gc-sp-4); overflow: hidden; display: flex; align-items: center; justify-content: space-between; min-height: 44px; transition: border-color var(--gc-transition); }
.gc-poll-option:hover { border-color: var(--gc-text-secondary); }
.gc-poll-option.gc-voted { border-color: var(--gc-accent); }
.gc-poll-bar { position: absolute; left: 0; top: 0; height: 100%; background: var(--gc-accent-subtle); border-radius: var(--gc-radius-sm); transition: width .5s ease; z-index: 0; }
.gc-voted .gc-poll-bar { background: rgba(29,155,240,.2); }
.gc-poll-opt-text { position: relative; z-index: 1; font-size: var(--gc-fs-base); font-weight: 500; }
.gc-poll-opt-pct { position: relative; z-index: 1; font-weight: 700; font-size: var(--gc-fs-base); color: var(--gc-text-secondary); }
.gc-poll-vote-btn { position: relative; z-index: 1; background: var(--gc-accent); color: #fff; border: none; border-radius: var(--gc-radius-full); padding: var(--gc-sp-1) var(--gc-sp-3); font-size: var(--gc-fs-sm); font-weight: 600; cursor: pointer; transition: background var(--gc-transition); }
.gc-poll-vote-btn:hover { background: var(--gc-accent-hover); }
.gc-poll-total { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); margin-top: var(--gc-sp-3); }
.gc-expired { color: var(--gc-error); font-weight: 600; }

/* â”€â”€ Events â”€â”€ */
.gc-event-card { display: block; background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-lg); padding: var(--gc-sp-5); margin-bottom: var(--gc-sp-4); transition: border-color var(--gc-transition), background var(--gc-transition); cursor: pointer; }
.gc-event-card:hover { border-color: var(--gc-accent); background: var(--gc-surface-hover); }
.gc-event-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--gc-sp-3); }
.gc-event-type { font-size: var(--gc-fs-sm); font-weight: 600; }
.gc-event-live { color: var(--gc-success); font-weight: 700; }
.gc-event-upcoming { color: var(--gc-accent); font-weight: 600; }
.gc-event-title { font-size: var(--gc-fs-lg); font-weight: 700; margin-bottom: var(--gc-sp-2); }
.gc-event-desc { color: var(--gc-text-secondary); font-size: var(--gc-fs-base); margin-bottom: var(--gc-sp-3); line-height: 1.4; }
.gc-event-prize { color: var(--gc-warning); font-weight: 600; margin-bottom: var(--gc-sp-2); font-size: var(--gc-fs-sm); }
.gc-event-series { color: var(--gc-accent); font-size: var(--gc-fs-sm); margin-bottom: var(--gc-sp-3); }
.gc-event-footer { display: flex; justify-content: space-between; color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); padding-top: var(--gc-sp-3); border-top: 1px solid var(--gc-border); }
.gc-event-detail-card { background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-lg); padding: var(--gc-sp-6); margin: var(--gc-sp-4); }
.gc-event-type-lg { font-size: var(--gc-fs-xl); margin-bottom: var(--gc-sp-3); }
.gc-event-detail-desc { color: var(--gc-text-secondary); margin: var(--gc-sp-4) 0; line-height: 1.6; font-size: var(--gc-fs-base); }
.gc-event-prize-lg { color: var(--gc-warning); font-weight: 700; font-size: var(--gc-fs-md); margin-bottom: var(--gc-sp-3); }
.gc-event-series-lg { color: var(--gc-accent); margin-bottom: var(--gc-sp-3); }
.gc-event-dates { display: flex; flex-wrap: wrap; gap: var(--gc-sp-4); color: var(--gc-text-secondary); margin: var(--gc-sp-4) 0; font-size: var(--gc-fs-base); }
.gc-event-entry-count { font-weight: 700; margin-bottom: var(--gc-sp-4); }
.gc-entered-tag { color: var(--gc-success); font-weight: 700; }
.gc-section-title { font-size: var(--gc-fs-lg); font-weight: 700; margin: var(--gc-sp-5) var(--gc-sp-4) var(--gc-sp-3); }
.gc-entrants { display: flex; flex-wrap: wrap; gap: var(--gc-sp-3); padding: 0 var(--gc-sp-4); }
.gc-entrant { display: flex; align-items: center; gap: var(--gc-sp-2); font-size: var(--gc-fs-sm); }

/* â”€â”€ Q&A â”€â”€ */
.gc-qa-card { display: block; background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-lg); padding: var(--gc-sp-5); margin-bottom: var(--gc-sp-4); cursor: pointer; transition: border-color var(--gc-transition), background var(--gc-transition); }
.gc-qa-card:hover { border-color: var(--gc-accent); background: var(--gc-surface-hover); }
.gc-qa-status { margin-bottom: var(--gc-sp-2); }
.gc-qa-title { font-size: var(--gc-fs-lg); font-weight: 700; margin-bottom: var(--gc-sp-2); }
.gc-qa-desc { color: var(--gc-text-secondary); font-size: var(--gc-fs-base); margin-bottom: var(--gc-sp-3); }
.gc-qa-series { color: var(--gc-accent); font-size: var(--gc-fs-sm); margin-bottom: var(--gc-sp-2); }
.gc-qa-meta { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); }
.gc-qa-detail-header { padding: var(--gc-sp-5); border-bottom: 1px solid var(--gc-border); }
.gc-qa-ask-form { padding: var(--gc-sp-4); border-bottom: 1px solid var(--gc-border); display: flex; flex-direction: column; gap: var(--gc-sp-3); }
.gc-qa-questions { padding: var(--gc-sp-4); }
.gc-qa-question { background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-md); padding: var(--gc-sp-4); margin-bottom: var(--gc-sp-3); }
.gc-qa-question.gc-answered { border-left: 3px solid var(--gc-accent); }
.gc-qa-q-header { display: flex; align-items: center; gap: var(--gc-sp-2); margin-bottom: var(--gc-sp-2); }
.gc-qa-q-text { font-size: var(--gc-fs-base); margin-bottom: var(--gc-sp-3); }
.gc-qa-answer { background: var(--gc-accent-subtle); border-radius: var(--gc-radius-sm); padding: var(--gc-sp-3); margin-bottom: var(--gc-sp-3); }
.gc-qa-answer-label { color: var(--gc-accent); font-weight: 700; font-size: var(--gc-fs-sm); margin-bottom: var(--gc-sp-1); }
.gc-qa-q-actions { display: flex; gap: var(--gc-sp-2); }
.gc-qa-upvote-btn { display: flex; align-items: center; gap: var(--gc-sp-1); padding: var(--gc-sp-1) var(--gc-sp-3); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-full); font-size: var(--gc-fs-sm); color: var(--gc-text-secondary); cursor: pointer; transition: all var(--gc-transition); background: none; }
.gc-qa-upvote-btn:hover { border-color: var(--gc-accent); color: var(--gc-accent); }
.gc-qa-upvote-btn.gc-upvoted { border-color: var(--gc-accent); color: var(--gc-accent); background: var(--gc-accent-subtle); }

/* â”€â”€ Badges â”€â”€ */
.gc-badges-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: var(--gc-sp-4); padding: 0 var(--gc-sp-4); }
.gc-badge-card { background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-md); padding: var(--gc-sp-5); text-align: center; transition: border-color var(--gc-transition), transform var(--gc-transition); }
.gc-badge-card:hover { border-color: var(--gc-accent); transform: translateY(-2px); }
.gc-badge-earned { border-color: var(--gc-accent); }
.gc-badge-locked { opacity: .5; }
.gc-badge-icon { font-size: 40px; margin-bottom: var(--gc-sp-2); }
.gc-badge-name { font-weight: 700; font-size: var(--gc-fs-base); margin-bottom: var(--gc-sp-1); }
.gc-badge-type, .gc-badge-desc { color: var(--gc-text-secondary); font-size: var(--gc-fs-xs); }
.gc-badge-date { color: var(--gc-text-tertiary); font-size: var(--gc-fs-xs); margin-top: var(--gc-sp-2); }
.gc-badge-check { color: var(--gc-success); font-weight: 700; font-size: var(--gc-fs-sm); margin-top: var(--gc-sp-2); }
.gc-badge-lock { color: var(--gc-text-tertiary); margin-top: var(--gc-sp-2); }
.gc-badge-lock svg { width: 18px; height: 18px; }
.gc-title-section { padding: 0 var(--gc-sp-4) var(--gc-sp-5); margin-bottom: var(--gc-sp-4); border-bottom: 1px solid var(--gc-border); }
.gc-title-form { display: flex; gap: var(--gc-sp-3); }
.gc-title-input { flex: 1; border: 1px solid var(--gc-border); border-radius: var(--gc-radius-sm); padding: var(--gc-sp-2) var(--gc-sp-3); background: var(--gc-bg); color: var(--gc-text); font-size: var(--gc-fs-base); }
.gc-leaderboard-link { text-align: center; padding: var(--gc-sp-6) 0; }
.gc-mt { margin-top: var(--gc-sp-6); }
.gc-badges-all .gc-badge-card { min-height: 140px; display: flex; flex-direction: column; align-items: center; justify-content: center; }

/* â”€â”€ Early Access â”€â”€ */
.gc-ea-card { background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-lg); padding: var(--gc-sp-5); margin: 0 var(--gc-sp-4) var(--gc-sp-4); }
.gc-ea-series { color: var(--gc-accent); font-size: var(--gc-fs-sm); font-weight: 600; margin-bottom: var(--gc-sp-1); }
.gc-ea-title { font-size: var(--gc-fs-lg); font-weight: 700; margin-bottom: var(--gc-sp-2); }
.gc-ea-countdown { color: var(--gc-warning); font-weight: 600; margin-bottom: var(--gc-sp-3); font-size: var(--gc-fs-sm); }
.gc-ea-public { color: var(--gc-success); font-weight: 600; margin-bottom: var(--gc-sp-3); font-size: var(--gc-fs-sm); }

/* â”€â”€ Leaderboard â”€â”€ */
.gc-leaderboard { padding: 0 var(--gc-sp-4); }
.gc-lb-row { display: flex; align-items: center; gap: var(--gc-sp-4); padding: var(--gc-sp-4); border-bottom: 1px solid var(--gc-border); }
.gc-lb-rank { font-size: var(--gc-fs-2xl); width: 40px; text-align: center; flex-shrink: 0; }
.gc-lb-info { flex: 1; }
.gc-lb-name { font-weight: 700; font-size: var(--gc-fs-base); }
.gc-lb-stats { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); margin-top: 2px; }
.gc-custom-title { color: var(--gc-accent); font-size: var(--gc-fs-sm); font-weight: 500; margin-left: var(--gc-sp-2); }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   THE FORGE
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-forge-toolbar { padding: var(--gc-sp-4); border-bottom: 1px solid var(--gc-border); }
.gc-forge-genres-bar { display: flex; gap: var(--gc-sp-2); overflow-x: auto; padding-bottom: var(--gc-sp-3); scrollbar-width: thin; }
.gc-forge-genre-btn { padding: var(--gc-sp-2) var(--gc-sp-4); border-radius: var(--gc-radius-full); background: var(--gc-surface); border: 1px solid var(--gc-border); color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); font-weight: 500; white-space: nowrap; cursor: pointer; transition: all var(--gc-transition); }
.gc-forge-genre-btn:hover { border-color: var(--gc-text-secondary); color: var(--gc-text); }
.gc-forge-genre-btn.active { background: var(--gc-accent); border-color: var(--gc-accent); color: #fff; }
.gc-forge-sort-bar { display: flex; gap: var(--gc-sp-3); align-items: center; padding-top: var(--gc-sp-2); }
.gc-forge-select { background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-sm); padding: var(--gc-sp-2) var(--gc-sp-3); font-size: var(--gc-fs-sm); color: var(--gc-text); cursor: pointer; }
.gc-forge-search-input { flex: 1; background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-sm); padding: var(--gc-sp-2) var(--gc-sp-3); font-size: var(--gc-fs-sm); color: var(--gc-text); }

/* Forge Grid */
.gc-forge-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--gc-sp-4); padding: var(--gc-sp-4); }
.gc-forge-card { background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-lg); overflow: hidden; cursor: pointer; transition: border-color var(--gc-transition), transform var(--gc-transition), box-shadow var(--gc-transition); }
.gc-forge-card:hover { border-color: var(--gc-accent); transform: translateY(-3px); box-shadow: var(--gc-shadow-md); }
.gc-forge-cover { width: 100%; height: 180px; object-fit: cover; background: var(--gc-surface-raised); }
.gc-forge-cover-ph { display: flex; align-items: center; justify-content: center; font-size: var(--gc-fs-3xl); font-weight: 800; color: var(--gc-text-secondary); background: linear-gradient(135deg, var(--gc-surface), var(--gc-surface-raised)); }
.gc-forge-card-body { padding: var(--gc-sp-4); }
.gc-forge-genre-tag { display: inline-block; padding: 2px var(--gc-sp-2); background: var(--gc-accent-subtle); color: var(--gc-accent); border-radius: var(--gc-radius-full); font-size: var(--gc-fs-xs); font-weight: 600; margin-bottom: var(--gc-sp-2); }
.gc-forge-card-title { font-size: var(--gc-fs-md); font-weight: 700; margin-bottom: var(--gc-sp-1); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.gc-forge-card-author { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); margin-bottom: var(--gc-sp-2); }
.gc-forge-card-synopsis { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; margin-bottom: var(--gc-sp-3); }
.gc-forge-card-stats { display: flex; flex-wrap: wrap; gap: var(--gc-sp-3); color: var(--gc-text-tertiary); font-size: var(--gc-fs-xs); margin-bottom: var(--gc-sp-2); }
.gc-forge-card-stats span { display: flex; align-items: center; gap: 3px; }
.gc-forge-card-stats svg { width: 14px; height: 14px; }
.gc-forge-type-tag { display: inline-block; padding: 2px var(--gc-sp-2); border-radius: var(--gc-radius-full); font-size: var(--gc-fs-xs); font-weight: 600; }
.gc-forge-type-short-story { background: rgba(124,58,237,.15); color: #a78bfa; }
.gc-forge-type-serial { background: var(--gc-accent-subtle); color: var(--gc-accent); }
.gc-forge-type-novella { background: rgba(236,72,153,.15); color: #f472b6; }

/* Forge Featured */
.gc-forge-featured-section { padding: var(--gc-sp-4); border-bottom: 1px solid var(--gc-border); }
.gc-forge-featured-section h3 { font-size: var(--gc-fs-lg); font-weight: 700; margin-bottom: var(--gc-sp-4); }
.gc-forge-featured-row { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: var(--gc-sp-4); }

/* Forge Story Detail */
.gc-forge-detail-header { display: flex; gap: var(--gc-sp-6); padding: var(--gc-sp-5); flex-wrap: wrap; }
.gc-forge-detail-cover { width: 280px; height: 380px; object-fit: cover; border-radius: var(--gc-radius-lg); flex-shrink: 0; background: var(--gc-surface-raised); }
.gc-forge-detail-cover.gc-forge-cover-ph { display: flex; align-items: center; justify-content: center; font-size: 72px; font-weight: 800; color: var(--gc-text-tertiary); }
.gc-forge-detail-meta { flex: 1; min-width: 0; }
.gc-forge-detail-title { font-size: var(--gc-fs-2xl); font-weight: 800; margin-bottom: var(--gc-sp-2); }
.gc-forge-status { display: inline-block; padding: var(--gc-sp-1) var(--gc-sp-3); border-radius: var(--gc-radius-full); font-size: var(--gc-fs-xs); font-weight: 700; margin-bottom: var(--gc-sp-3); }
.gc-ongoing { background: var(--gc-accent-subtle); color: var(--gc-accent); }
.gc-completed { background: rgba(0,186,124,.15); color: var(--gc-success); }
.gc-draft { background: rgba(113,118,123,.15); color: var(--gc-text-secondary); }
.gc-forge-detail-author { color: var(--gc-text-secondary); font-size: var(--gc-fs-base); margin-bottom: var(--gc-sp-3); }
.gc-forge-detail-author:hover { text-decoration: underline; color: var(--gc-text); }
.gc-forge-detail-tags { display: flex; gap: var(--gc-sp-2); flex-wrap: wrap; margin-bottom: var(--gc-sp-3); }
.gc-forge-detail-stats { display: flex; flex-wrap: wrap; gap: var(--gc-sp-4); color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); margin-bottom: var(--gc-sp-4); }
.gc-forge-detail-stats span { display: flex; align-items: center; gap: var(--gc-sp-1); }
.gc-forge-detail-stats svg { width: 16px; height: 16px; }
.gc-forge-detail-actions { display: flex; gap: var(--gc-sp-3); flex-wrap: wrap; }
.gc-forge-synopsis { padding: var(--gc-sp-5); border-bottom: 1px solid var(--gc-border); }
.gc-forge-synopsis h3 { font-size: var(--gc-fs-md); font-weight: 700; margin-bottom: var(--gc-sp-2); }
.gc-forge-synopsis p { color: var(--gc-text-secondary); line-height: 1.6; }

/* Forge Chapters list */
.gc-forge-chapters { padding: var(--gc-sp-5); }
.gc-forge-chapters h3 { font-size: var(--gc-fs-lg); font-weight: 700; margin-bottom: var(--gc-sp-4); }
.gc-forge-chapter-row { display: flex; align-items: center; gap: var(--gc-sp-3); padding: var(--gc-sp-3) var(--gc-sp-4); border-radius: var(--gc-radius-sm); transition: background var(--gc-transition); cursor: pointer; }
.gc-forge-chapter-row:hover { background: var(--gc-hover-strong); }
.gc-forge-ch-read { color: var(--gc-text-secondary); }
.gc-forge-ch-num { width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; border-radius: var(--gc-radius-full); background: var(--gc-surface-raised); font-size: var(--gc-fs-sm); font-weight: 700; flex-shrink: 0; }
.gc-forge-ch-title { flex: 1; font-weight: 500; }
.gc-forge-ch-words { color: var(--gc-text-tertiary); font-size: var(--gc-fs-sm); }
.gc-forge-ch-draft { background: rgba(113,118,123,.15); color: var(--gc-text-secondary); padding: 2px var(--gc-sp-2); border-radius: var(--gc-radius-full); font-size: var(--gc-fs-xs); }
.gc-forge-ch-checkmark { color: var(--gc-success); font-weight: 700; }

/* Forge Reader */
.gc-forge-reader { max-width: 680px; margin: 0 auto; padding: var(--gc-sp-6) var(--gc-sp-4); }
.gc-forge-reader-header { margin-bottom: var(--gc-sp-6); }
.gc-forge-reader-story { color: var(--gc-accent); font-size: var(--gc-fs-sm); }
.gc-forge-reader-story:hover { text-decoration: underline; }
.gc-forge-reader-title { font-size: var(--gc-fs-2xl); font-weight: 800; margin: var(--gc-sp-2) 0; }
.gc-forge-reader-meta { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); display: flex; gap: var(--gc-sp-3); }
.gc-forge-reader-image { width: 100%; border-radius: var(--gc-radius-lg); margin-bottom: var(--gc-sp-6); }
.gc-forge-reader-content { font-size: 18px; line-height: 1.8; color: var(--gc-text); }
.gc-forge-reader-content p { margin-bottom: 1.2em; }
.gc-forge-reader-content strong { font-weight: 700; }
.gc-forge-reader-content em { font-style: italic; }
.gc-forge-reader-content hr.gc-forge-scene-break { border: none; text-align: center; margin: 2em 0; }
.gc-forge-reader-content hr.gc-forge-scene-break::after { content: '* * *'; color: var(--gc-text-secondary); letter-spacing: 1em; }
.gc-forge-reader-content h2.gc-forge-ch-heading { font-size: var(--gc-fs-xl); margin: 1.5em 0 .5em; }
.gc-forge-reader-content h3.gc-forge-ch-heading { font-size: var(--gc-fs-lg); margin: 1.2em 0 .4em; }
.gc-forge-reader-nav { display: flex; justify-content: space-between; align-items: center; gap: var(--gc-sp-4); padding: var(--gc-sp-6) 0; border-top: 1px solid var(--gc-border); margin-top: var(--gc-sp-6); }
.gc-forge-end-msg { color: var(--gc-text-secondary); font-style: italic; }
.gc-forge-reader-comments { border-top: 1px solid var(--gc-border); padding-top: var(--gc-sp-6); }
.gc-forge-reader-comments h3 { font-size: var(--gc-fs-lg); font-weight: 700; margin-bottom: var(--gc-sp-4); display: flex; align-items: center; gap: var(--gc-sp-2); }
.gc-forge-reader-comments h3 svg { width: 20px; height: 20px; }
.gc-forge-comment-form { margin-bottom: var(--gc-sp-5); }
.gc-forge-comment-input { width: 100%; border: 1px solid var(--gc-border); border-radius: var(--gc-radius-md); padding: var(--gc-sp-3); background: var(--gc-bg); color: var(--gc-text); font-size: var(--gc-fs-base); resize: vertical; min-height: 48px; margin-bottom: var(--gc-sp-2); }
.gc-forge-comment-input:focus { border-color: var(--gc-accent); }
.gc-forge-comment { display: flex; gap: var(--gc-sp-3); padding: var(--gc-sp-3) 0; border-bottom: 1px solid var(--gc-border); }
.gc-forge-comment-body { flex: 1; }
.gc-forge-comment-body strong { font-size: var(--gc-fs-sm); }
.gc-forge-comment-body .gc-time { color: var(--gc-text-secondary); font-size: var(--gc-fs-xs); }
.gc-forge-comment-body p { margin-top: var(--gc-sp-1); font-size: var(--gc-fs-base); line-height: 1.4; }
.gc-empty-sm { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); font-style: italic; }

/* Forge Write/Edit */
.gc-forge-form { padding: var(--gc-sp-5); }
.gc-forge-label { display: block; font-weight: 600; font-size: var(--gc-fs-sm); color: var(--gc-text-secondary); margin-bottom: var(--gc-sp-2); margin-top: var(--gc-sp-4); }
.gc-forge-label:first-child { margin-top: 0; }
.gc-forge-input { width: 100%; background: var(--gc-bg); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-sm); padding: var(--gc-sp-3); font-size: var(--gc-fs-base); color: var(--gc-text); }
.gc-forge-input:focus { border-color: var(--gc-accent); }
.gc-forge-textarea { width: 100%; background: var(--gc-bg); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-sm); padding: var(--gc-sp-3); font-size: var(--gc-fs-base); color: var(--gc-text); min-height: 100px; resize: vertical; }
.gc-forge-textarea:focus { border-color: var(--gc-accent); }
.gc-forge-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gc-sp-4); }
.gc-forge-form-actions { display: flex; align-items: center; gap: var(--gc-sp-4); margin-top: var(--gc-sp-5); }
.gc-forge-hint { font-weight: 400; color: var(--gc-text-tertiary); }
.gc-forge-content-editor { width: 100%; background: var(--gc-bg); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-sm); padding: var(--gc-sp-4); font-size: var(--gc-fs-base); color: var(--gc-text); min-height: 400px; resize: vertical; line-height: 1.8; font-family: 'Georgia', serif; }
.gc-forge-content-editor:focus { border-color: var(--gc-accent); }
.gc-forge-ch-wordcount { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); margin-top: var(--gc-sp-2); }
.gc-forge-checkbox { display: flex; align-items: center; gap: var(--gc-sp-2); font-size: var(--gc-fs-sm); cursor: pointer; }
.gc-forge-checkbox input { accent-color: var(--gc-accent); }

/* Forge Edit page */
.gc-forge-edit-header { display: flex; justify-content: space-between; align-items: center; padding-bottom: var(--gc-sp-4); border-bottom: 1px solid var(--gc-border); }
.gc-forge-edit-actions { display: flex; gap: var(--gc-sp-2); }
.gc-forge-edit-meta { display: flex; gap: var(--gc-sp-3); flex-wrap: wrap; padding: var(--gc-sp-4) 0; }
.gc-forge-chapters-edit { margin-top: var(--gc-sp-4); }
.gc-forge-chapters-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--gc-sp-4); }
.gc-forge-ch-edit-row { display: flex; align-items: center; gap: var(--gc-sp-3); padding: var(--gc-sp-3); border-bottom: 1px solid var(--gc-border); }
.gc-forge-ch-edit-row .gc-forge-ch-title { flex: 1; }
.gc-forge-story-link { padding-top: var(--gc-sp-5); text-align: center; }
.gc-forge-story-link .gc-link { color: var(--gc-accent); }
.gc-forge-story-link .gc-link:hover { text-decoration: underline; }

/* Forge My Stories */
.gc-forge-my-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--gc-sp-4); padding: var(--gc-sp-4); }
.gc-forge-my-card { background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-lg); padding: var(--gc-sp-5); }
.gc-forge-my-card-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: var(--gc-sp-3); }
.gc-forge-my-card-header h3 { font-size: var(--gc-fs-md); font-weight: 700; }
.gc-forge-my-card-meta { display: flex; gap: var(--gc-sp-3); flex-wrap: wrap; margin-bottom: var(--gc-sp-3); font-size: var(--gc-fs-sm); color: var(--gc-text-secondary); }
.gc-forge-my-card-stats { display: flex; gap: var(--gc-sp-4); color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); margin-bottom: var(--gc-sp-3); }
.gc-forge-my-card-stats span { display: flex; align-items: center; gap: var(--gc-sp-1); }
.gc-forge-my-card-stats svg { width: 14px; height: 14px; }
.gc-forge-my-card-actions { display: flex; gap: var(--gc-sp-2); }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   REVIEWS & RATINGS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-reviews-section { padding: var(--gc-sp-5); }
.gc-reviews-section h3 { font-size: var(--gc-fs-lg); font-weight: 700; margin-bottom: var(--gc-sp-4); display: flex; align-items: center; gap: var(--gc-sp-2); }
.gc-reviews-section h3 svg { width: 20px; height: 20px; }
.gc-review-stats-box { display: flex; gap: var(--gc-sp-6); padding: var(--gc-sp-5); background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-lg); margin-bottom: var(--gc-sp-5); }
.gc-review-stats-summary { text-align: center; min-width: 100px; }
.gc-review-avg { font-size: var(--gc-fs-3xl); font-weight: 800; color: var(--gc-text); }
.gc-review-total { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); margin-top: var(--gc-sp-1); }
.gc-review-stats-bars { flex: 1; }
.gc-review-bar-row { display: flex; align-items: center; gap: var(--gc-sp-2); margin-bottom: 6px; }
.gc-review-bar-label { font-size: var(--gc-fs-sm); color: var(--gc-text-secondary); width: 36px; text-align: right; display: flex; align-items: center; gap: 3px; justify-content: flex-end; }
.gc-review-bar-label svg { width: 12px; height: 12px; }
.gc-review-bar-track { flex: 1; height: 8px; background: var(--gc-surface-raised); border-radius: 4px; overflow: hidden; }
.gc-review-bar-fill { height: 100%; background: var(--gc-accent); border-radius: 4px; transition: width .5s ease; }
.gc-review-bar-count { font-size: var(--gc-fs-xs); color: var(--gc-text-tertiary); width: 24px; }
.gc-reviews-empty { padding: var(--gc-sp-5); text-align: center; color: var(--gc-text-secondary); background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-lg); }

/* Review form */
.gc-review-form { background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-lg); padding: var(--gc-sp-5); margin-bottom: var(--gc-sp-5); }
.gc-review-form h4 { font-size: var(--gc-fs-md); font-weight: 700; margin-bottom: var(--gc-sp-4); }
.gc-review-form-stars { margin-bottom: var(--gc-sp-4); }
.gc-review-form-stars label { display: block; font-size: var(--gc-fs-sm); color: var(--gc-text-secondary); margin-bottom: var(--gc-sp-2); }
.gc-review-form .gc-input { width: 100%; background: var(--gc-bg); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-sm); padding: var(--gc-sp-3); font-size: var(--gc-fs-base); color: var(--gc-text); margin-bottom: var(--gc-sp-3); }
.gc-review-form .gc-textarea { min-height: 80px; resize: vertical; }
.gc-review-form .gc-input:focus { border-color: var(--gc-accent); }
.gc-review-form-actions { display: flex; gap: var(--gc-sp-3); }
.gc-review-login-prompt { padding: var(--gc-sp-4); text-align: center; color: var(--gc-text-secondary); }
.gc-review-login-prompt a { color: var(--gc-accent); }
.gc-review-login-prompt a:hover { text-decoration: underline; }

/* Star widget */
.gc-star-widget { display: inline-flex; gap: 2px; }
.gc-star { cursor: default; font-size: 18px; transition: transform .15s ease; }
.gc-star svg { width: 20px; height: 20px; }
.gc-star-filled { color: var(--gc-warning); }
.gc-star-empty { color: var(--gc-border); }
.gc-star-interactive .gc-star { cursor: pointer; }
.gc-star-interactive .gc-star:hover { transform: scale(1.2); }
.gc-review-stars-mini { display: inline-flex; align-items: center; gap: 2px; color: var(--gc-warning); }
.gc-review-stars-mini svg { width: 13px; height: 13px; }
.gc-review-stars-inline { display: inline-flex; align-items: center; gap: var(--gc-sp-1); color: var(--gc-warning); }
.gc-review-stars-inline svg { width: 16px; height: 16px; }

/* Review cards */
.gc-review-card { padding: var(--gc-sp-4); border-bottom: 1px solid var(--gc-border); }
.gc-review-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--gc-sp-2); }
.gc-review-author { font-weight: 700; font-size: var(--gc-fs-base); color: var(--gc-text); }
.gc-review-author:hover { text-decoration: underline; }
.gc-review-date { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); }
.gc-review-rating { margin-bottom: var(--gc-sp-2); }
.gc-review-title { font-weight: 700; font-size: var(--gc-fs-base); margin-bottom: var(--gc-sp-1); }
.gc-review-body { color: var(--gc-text-secondary); font-size: var(--gc-fs-base); line-height: 1.5; margin-bottom: var(--gc-sp-2); }
.gc-review-actions { display: flex; gap: var(--gc-sp-3); }
.gc-review-helpful-btn { display: flex; align-items: center; gap: var(--gc-sp-1); }
.gc-review-helpful-btn svg { width: 14px; height: 14px; }
.gc-helpful-active { color: var(--gc-accent); }
.gc-select-sm { background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-sm); padding: var(--gc-sp-1) var(--gc-sp-2); font-size: var(--gc-fs-sm); color: var(--gc-text); }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   GROUPS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-groups-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--gc-sp-4); padding: var(--gc-sp-4); }
.gc-group-card { background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-lg); overflow: hidden; cursor: pointer; transition: border-color var(--gc-transition), transform var(--gc-transition); }
.gc-group-card:hover { border-color: var(--gc-accent); transform: translateY(-2px); }
.gc-group-cover { height: 120px; background: linear-gradient(135deg, #1a1a2e, #0f3460); }
.gc-group-cover img { width: 100%; height: 100%; object-fit: cover; }
.gc-group-card-body { padding: var(--gc-sp-4); }
.gc-group-card-name { font-size: var(--gc-fs-md); font-weight: 700; margin-bottom: var(--gc-sp-1); }
.gc-group-card-desc { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); line-height: 1.4; margin-bottom: var(--gc-sp-3); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.gc-group-card-meta { display: flex; justify-content: space-between; align-items: center; color: var(--gc-text-tertiary); font-size: var(--gc-fs-xs); }
.gc-group-badge { padding: 2px var(--gc-sp-2); border-radius: var(--gc-radius-full); font-size: var(--gc-fs-xs); font-weight: 600; }
.gc-group-badge-public { background: var(--gc-accent-subtle); color: var(--gc-accent); }
.gc-group-badge-private { background: rgba(113,118,123,.15); color: var(--gc-text-secondary); }

/* Group Detail */
.gc-group-detail-banner { height: 200px; background: linear-gradient(135deg, #1a1a2e, #16213e, #0f3460); position: relative; }
.gc-group-detail-banner img { width: 100%; height: 100%; object-fit: cover; }
.gc-group-detail-info { padding: var(--gc-sp-5); border-bottom: 1px solid var(--gc-border); }
.gc-group-detail-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: var(--gc-sp-2); }
.gc-group-detail-name { font-size: var(--gc-fs-2xl); font-weight: 800; }
.gc-group-detail-desc { color: var(--gc-text-secondary); font-size: var(--gc-fs-base); margin-bottom: var(--gc-sp-3); line-height: 1.5; }
.gc-group-detail-stats { display: flex; gap: var(--gc-sp-4); color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); }
.gc-group-members-bar { display: flex; gap: var(--gc-sp-3); padding: var(--gc-sp-3) var(--gc-sp-5); border-bottom: 1px solid var(--gc-border); overflow-x: auto; }
.gc-group-member-chip { display: flex; align-items: center; gap: var(--gc-sp-2); padding: var(--gc-sp-1) var(--gc-sp-3); background: var(--gc-surface); border-radius: var(--gc-radius-full); font-size: var(--gc-fs-sm); white-space: nowrap; cursor: pointer; }
.gc-group-member-chip:hover { background: var(--gc-surface-hover); }
.gc-group-member-role { font-size: var(--gc-fs-xs); color: var(--gc-accent); font-weight: 600; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   BOOKMARKS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-bookmarks-tabs { border-bottom: 1px solid var(--gc-border); }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   TOAST NOTIFICATIONS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-toast-container { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%); z-index: 10000; display: flex; flex-direction: column; gap: var(--gc-sp-3); align-items: center; pointer-events: none; }
.gc-toast { display: flex; align-items: center; gap: var(--gc-sp-3); padding: var(--gc-sp-3) var(--gc-sp-5); background: var(--gc-accent); color: #fff; border-radius: var(--gc-radius-sm); font-size: var(--gc-fs-base); font-weight: 500; box-shadow: var(--gc-shadow-lg); pointer-events: auto; animation: gc-toastIn .3s ease, gc-toastOut .3s ease 2.7s forwards; min-width: 200px; max-width: 420px; }
.gc-toast-success { background: var(--gc-success); }
.gc-toast-error { background: var(--gc-error); }
.gc-toast-info { background: var(--gc-accent); }
.gc-toast svg { width: 20px; height: 20px; flex-shrink: 0; }
.gc-toast-msg { flex: 1; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   HOVER CARD
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-hover-card { position: absolute; z-index: 1000; width: 300px; background: var(--gc-surface); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-lg); padding: var(--gc-sp-4); box-shadow: var(--gc-shadow-lg); animation: gc-fadeIn .15s ease; pointer-events: auto; }
.gc-hover-card-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: var(--gc-sp-3); }
.gc-hover-card-name { font-weight: 800; font-size: var(--gc-fs-base); display: flex; align-items: center; gap: var(--gc-sp-1); }
.gc-hover-card-handle { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); }
.gc-hover-card-bio { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); margin-bottom: var(--gc-sp-3); line-height: 1.4; }
.gc-hover-card-stats { display: flex; gap: var(--gc-sp-4); font-size: var(--gc-fs-sm); }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   MODALS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-modal, .gc-modal-overlay { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,.65); z-index: 5000; align-items: flex-start; justify-content: center; padding-top: 5vh; overflow-y: auto; }
.gc-modal-content, .gc-modal-inner { background: var(--gc-bg); border-radius: var(--gc-radius-lg); width: 100%; max-width: 580px; max-height: 90vh; overflow-y: auto; }
.gc-modal-header { display: flex; align-items: center; gap: var(--gc-sp-3); padding: var(--gc-sp-3) var(--gc-sp-4); border-bottom: 1px solid var(--gc-border); position: sticky; top: 0; background: var(--gc-bg); z-index: 1; }
.gc-modal-header h3 { flex: 1; font-size: var(--gc-fs-xl); font-weight: 700; }
.gc-modal-close { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 22px; transition: background var(--gc-transition); color: var(--gc-text); }
.gc-modal-close:hover { background: var(--gc-hover-strong); }
.gc-forge-modal-wide { max-width: 750px; }
.gc-edit-form { padding: var(--gc-sp-5); }
.gc-edit-form .gc-form-label { display: block; font-weight: 600; font-size: var(--gc-fs-sm); color: var(--gc-text-secondary); margin-bottom: var(--gc-sp-4); }
.gc-edit-form .gc-form-label input, .gc-edit-form .gc-form-label textarea { width: 100%; margin-top: var(--gc-sp-2); background: var(--gc-bg); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-sm); padding: var(--gc-sp-3); font-size: var(--gc-fs-base); color: var(--gc-text); }
.gc-edit-form .gc-form-label textarea { min-height: 80px; resize: vertical; }
.gc-edit-form .gc-form-label input:focus, .gc-edit-form .gc-form-label textarea:focus { border-color: var(--gc-accent); }

/* Mobile More Sheet */
.gc-more-sheet { display: none; position: fixed; bottom: 0; left: 0; right: 0; background: var(--gc-surface); border-top-left-radius: var(--gc-radius-xl); border-top-right-radius: var(--gc-radius-xl); z-index: 6000; padding: var(--gc-sp-4) 0; box-shadow: var(--gc-shadow-lg); animation: gc-slideUp .25s ease; }
.gc-more-sheet.active { display: block; }
.gc-more-sheet-handle { width: 36px; height: 4px; background: var(--gc-border); border-radius: 2px; margin: 0 auto var(--gc-sp-4); }
.gc-more-sheet-items { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--gc-sp-2); padding: 0 var(--gc-sp-4); }
.gc-more-sheet-item { display: flex; flex-direction: column; align-items: center; gap: var(--gc-sp-2); padding: var(--gc-sp-3); border-radius: var(--gc-radius-md); color: var(--gc-text); font-size: var(--gc-fs-sm); cursor: pointer; transition: background var(--gc-transition); }
.gc-more-sheet-item:hover { background: var(--gc-hover-strong); }
.gc-more-sheet-item svg { width: 24px; height: 24px; }
.gc-more-sheet-overlay { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,.5); z-index: 5999; }
.gc-more-sheet-overlay.active { display: block; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   PREMIUM PROMPTS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-premium-prompt { text-align: center; padding: var(--gc-sp-6); }
.gc-premium-prompt p { color: var(--gc-text-secondary); margin-bottom: var(--gc-sp-4); }
.gc-premium-prompt-card { background: linear-gradient(135deg, rgba(29,155,240,.1), rgba(124,58,237,.1)); border: 1px solid var(--gc-border); border-radius: var(--gc-radius-lg); padding: var(--gc-sp-5); margin: var(--gc-sp-4); position: relative; }
.gc-premium-prompt-card h3 { font-size: var(--gc-fs-lg); margin-bottom: var(--gc-sp-2); }
.gc-premium-prompt-card p { color: var(--gc-text-secondary); margin-bottom: var(--gc-sp-4); font-size: var(--gc-fs-base); }
.gc-premium-prompt-dismiss { position: absolute; top: var(--gc-sp-3); right: var(--gc-sp-3); color: var(--gc-text-secondary); font-size: var(--gc-fs-xl); background: none; border: none; cursor: pointer; width: 30px; height: 30px; display: flex; align-items: center; justify-content: center; border-radius: 50%; }
.gc-premium-prompt-dismiss:hover { background: var(--gc-hover-strong); }
.gc-premium-tag { background: linear-gradient(135deg, var(--gc-accent), #7c3aed); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; font-weight: 700; font-size: var(--gc-fs-sm); }
.gc-premium-inline { color: var(--gc-text-secondary); font-size: var(--gc-fs-sm); padding: var(--gc-sp-3) 0; }
.gc-premium-inline a { color: var(--gc-accent); }
.gc-premium-inline a:hover { text-decoration: underline; }
.gc-premium-gate { text-align: center; padding: var(--gc-sp-8); }
.gc-premium-gate h2 { margin-bottom: var(--gc-sp-3); display: flex; align-items: center; justify-content: center; gap: var(--gc-sp-2); }
.gc-premium-gate p { color: var(--gc-text-secondary); margin-bottom: var(--gc-sp-5); }
.gc-premium-gate svg { width: 24px; height: 24px; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   ANIMATIONS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
@keyframes gc-heartPop {
  0% { transform: scale(1); }
  15% { transform: scale(1.35); }
  30% { transform: scale(.9); }
  45% { transform: scale(1.15); }
  60% { transform: scale(.95); }
  75% { transform: scale(1.05); }
  100% { transform: scale(1); }
}
@keyframes gc-pop {
  0% { transform: scale(1); }
  50% { transform: scale(1.25); }
  100% { transform: scale(1); }
}
@keyframes gc-fadeIn {
  from { opacity: 0; transform: translateY(4px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes gc-slideUp {
  from { transform: translateY(100%); }
  to { transform: translateY(0); }
}
@keyframes gc-toastIn {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes gc-toastOut {
  from { opacity: 1; }
  to { opacity: 0; transform: translateY(10px); }
}
@keyframes gc-shimmer {
  0% { background-position: -400px 0; }
  100% { background-position: 400px 0; }
}
@keyframes gc-spin {
  to { transform: rotate(360deg); }
}
@keyframes gc-postFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Post enter animation */
.gc-post { animation: gc-postFadeIn .3s ease; }

/* Follow button transition */
.gc-follow-btn { min-width: 100px; transition: all var(--gc-transition); }
.gc-follow-btn.following { background: transparent; color: var(--gc-text); border: 1px solid var(--gc-border); }
.gc-follow-btn.following:hover { border-color: var(--gc-error); color: var(--gc-error); background: rgba(239,68,68,.1); }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   LOADING / SKELETON
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-loading { text-align: center; padding: var(--gc-sp-6); color: var(--gc-text-secondary); }
.gc-loading-spinner { width: 24px; height: 24px; border: 3px solid var(--gc-border); border-top-color: var(--gc-accent); border-radius: 50%; animation: gc-spin .7s linear infinite; margin: 0 auto var(--gc-sp-3); }
.gc-skeleton-post { display: flex; gap: var(--gc-sp-3); padding: var(--gc-sp-3) var(--gc-sp-4); border-bottom: 1px solid var(--gc-border); }
.gc-skeleton-avatar { width: 40px; height: 40px; border-radius: 50%; background: linear-gradient(90deg, var(--gc-surface) 25%, var(--gc-surface-raised) 50%, var(--gc-surface) 75%); background-size: 400px 100%; animation: gc-shimmer 1.2s ease-in-out infinite; flex-shrink: 0; }
.gc-skeleton-body { flex: 1; }
.gc-skeleton-line { height: 14px; border-radius: 4px; background: linear-gradient(90deg, var(--gc-surface) 25%, var(--gc-surface-raised) 50%, var(--gc-surface) 75%); background-size: 400px 100%; animation: gc-shimmer 1.2s ease-in-out infinite; margin-bottom: var(--gc-sp-2); }
.gc-skeleton-line:nth-child(1) { width: 40%; }
.gc-skeleton-line:nth-child(2) { width: 90%; }
.gc-skeleton-line:nth-child(3) { width: 70%; }
.gc-skeleton-card { height: 200px; border-radius: var(--gc-radius-lg); background: linear-gradient(90deg, var(--gc-surface) 25%, var(--gc-surface-raised) 50%, var(--gc-surface) 75%); background-size: 400px 100%; animation: gc-shimmer 1.2s ease-in-out infinite; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   EMPTY STATES
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-empty { text-align: center; padding: var(--gc-sp-8) var(--gc-sp-6); }
.gc-empty-enhanced { padding: var(--gc-sp-8) var(--gc-sp-6); }
.gc-empty-icon { color: var(--gc-text-tertiary); margin-bottom: var(--gc-sp-4); }
.gc-empty-icon svg { width: 48px; height: 48px; }
.gc-empty h3 { font-size: var(--gc-fs-xl); font-weight: 800; margin-bottom: var(--gc-sp-2); }
.gc-empty p { color: var(--gc-text-secondary); font-size: var(--gc-fs-base); margin-bottom: var(--gc-sp-5); max-width: 340px; margin-left: auto; margin-right: auto; line-height: 1.5; }
.gc-empty-actions { display: flex; gap: var(--gc-sp-3); justify-content: center; }
.gc-error { text-align: center; padding: var(--gc-sp-6); color: var(--gc-error); }
.gc-link { color: var(--gc-accent); cursor: pointer; }
.gc-link:hover { text-decoration: underline; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   LOAD MORE / INFINITE SCROLL
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-load-more { display: block; width: 100%; padding: var(--gc-sp-4); text-align: center; color: var(--gc-accent); font-size: var(--gc-fs-base); font-weight: 700; background: none; border: none; border-bottom: 1px solid var(--gc-border); cursor: pointer; transition: background var(--gc-transition); }
.gc-load-more:hover { background: var(--gc-hover); }
.gc-load-more:disabled { color: var(--gc-text-secondary); }
.gc-scroll-sentinel { height: 1px; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   LOGIN PAGE
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-login-page { display: flex; align-items: center; justify-content: center; min-height: 100vh; padding: var(--gc-sp-6); }
.gc-login-hero { text-align: center; max-width: 440px; }
.gc-login-title { font-size: 42px; font-weight: 800; background: linear-gradient(135deg, var(--gc-accent), #7c3aed); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; margin-bottom: var(--gc-sp-4); }
.gc-login-subtitle { color: var(--gc-text-secondary); font-size: var(--gc-fs-lg); line-height: 1.5; margin-bottom: var(--gc-sp-7); }
.gc-login-actions { display: flex; flex-direction: column; gap: var(--gc-sp-3); }
.gc-login-actions .gc-btn-lg { padding: var(--gc-sp-4); font-size: var(--gc-fs-lg); }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   RESPONSIVE
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* Tablet */
@media (max-width: 1100px) {
  .gc-layout { grid-template-columns: 72px minmax(0, 1fr) 300px; }
  .gc-sidebar { padding: var(--gc-sp-2); align-items: center; }
  .gc-logo-text { display: none; }
  .gc-nav-label { display: none; }
  .gc-nav-item { justify-content: center; padding: var(--gc-sp-3); width: 50px; height: 50px; }
  .gc-compose-btn { width: 50px; height: 50px; padding: 0; font-size: 0; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
  .gc-compose-full { display: none; }
  .gc-compose-icon { display: block; font-size: 26px; }
  .gc-sidebar-user-info { display: none; }
  .gc-sidebar-user .gc-dots { display: none; }
  .gc-sidebar-user { justify-content: center; }
}

/* Smaller tablet */
@media (max-width: 1000px) {
  .gc-layout { grid-template-columns: 72px minmax(0, 1fr); }
  .gc-right { display: none; }
}

/* Mobile */
@media (max-width: 680px) {
  .gc-layout { grid-template-columns: 1fr; }
  .gc-sidebar { display: none; }
  .gc-main { border: none; padding-bottom: 60px; }
  .gc-forge-detail-header { flex-direction: column; }
  .gc-forge-detail-cover { width: 100%; height: 250px; }
  .gc-forge-grid { grid-template-columns: 1fr; }
  .gc-groups-grid { grid-template-columns: 1fr; }
  .gc-review-stats-box { flex-direction: column; }
  .gc-forge-row { grid-template-columns: 1fr; }
  .gc-event-detail-card { margin: var(--gc-sp-2); padding: var(--gc-sp-4); }
}

/* Mobile bottom nav */
.gc-mobile-nav { display: none; position: fixed; bottom: 0; left: 0; right: 0; background: var(--gc-bg); border-top: 1px solid var(--gc-border); z-index: 100; padding: var(--gc-sp-1) 0 env(safe-area-inset-bottom, 0); justify-content: space-around; align-items: center; }
.gc-mobile-nav-inner { display: flex; justify-content: space-around; align-items: center; }
.gc-mobile-nav a { display: flex; flex-direction: column; align-items: center; gap: 2px; padding: var(--gc-sp-2) var(--gc-sp-3); color: var(--gc-text-secondary); font-size: 10px; position: relative; transition: color var(--gc-transition); }
.gc-mobile-nav a.active { color: var(--gc-text); }
.gc-mobile-nav a svg { width: 24px; height: 24px; }
.gc-mobile-nav .gc-mob-badge { position: absolute; top: 2px; right: 4px; width: 8px; height: 8px; background: var(--gc-accent); border-radius: 50%; }

@media (max-width: 680px) {
  .gc-mobile-nav { display: flex; }
}

/* Image lightbox */
.gc-lightbox { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,.9); z-index: 10000; display: flex; align-items: center; justify-content: center; cursor: pointer; animation: gc-fadeIn .2s ease; }
.gc-lightbox img { max-width: 90vw; max-height: 90vh; object-fit: contain; border-radius: var(--gc-radius-sm); }
.gc-lightbox-close { position: absolute; top: 16px; right: 16px; width: 40px; height: 40px; border-radius: 50%; background: rgba(0,0,0,.75); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 24px; cursor: pointer; border: none; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   CUSTOM SCROLLBAR
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-app ::-webkit-scrollbar { width: 8px; }
.gc-app ::-webkit-scrollbar-track { background: transparent; }
.gc-app ::-webkit-scrollbar-thumb { background: var(--gc-border); border-radius: 4px; }
.gc-app ::-webkit-scrollbar-thumb:hover { background: var(--gc-text-tertiary); }
.gc-app { scrollbar-width: thin; scrollbar-color: var(--gc-border) transparent; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   ACCESSIBILITY
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-app *:focus-visible { outline: 2px solid var(--gc-accent); outline-offset: 2px; border-radius: var(--gc-radius-sm); }
@media (prefers-reduced-motion: reduce) {
  .gc-app *, .gc-app *::before, .gc-app *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   UTILITY
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-hidden { display: none !important; }
.gc-sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

/* â”€â”€ Post Image â”€â”€ */
.gc-post-image { margin: 12px 0 0; border-radius: 16px; overflow: hidden; }
.gc-post-image img { width: 100%; max-height: 520px; object-fit: cover; display: block; border-radius: 16px; border: 1px solid var(--gc-border); }
.gc-group-post-img { width: 100%; max-height: 400px; object-fit: cover; border-radius: 12px; margin: 8px 0; }


/* â”€â”€ Premium Prompt v2: Subtle inline banner (not paywall) â”€â”€ */
.gc-premium-prompt {
  margin: 0 0 16px;
  padding: 0;
}
.gc-premium-prompt-card {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  background: var(--gc-surface);
  border: 1px solid var(--gc-border);
  border-radius: 12px;
  font-size: 0.88rem;
  color: var(--gc-muted);
  transition: border-color 0.2s;
}
.gc-premium-prompt-card:hover {
  border-color: var(--gc-accent);
}
.gc-premium-prompt-card h3 {
  display: none;
}
.gc-premium-prompt-card p {
  margin: 0;
  flex: 1;
  font-size: 0.85rem;
  line-height: 1.4;
}
.gc-premium-prompt-card .gc-btn-accent {
  white-space: nowrap;
  padding: 6px 16px;
  font-size: 0.8rem;
  border-radius: 20px;
  flex-shrink: 0;
}
.gc-premium-prompt-dismiss {
  display: none;
}


/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   PRESTIGE VOTING SYSTEM
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-prestige-box {
  margin: 1rem 0;
  padding: 1rem 1.5rem;
  background: linear-gradient(135deg, rgba(255,215,0,0.08), rgba(255,140,0,0.05));
  border: 1px solid rgba(255,215,0,0.2);
  border-radius: 12px;
  text-align: center;
}
.gc-prestige-label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #999;
  margin-bottom: 0.25rem;
}
.gc-prestige-score {
  font-size: 2rem;
  font-weight: 800;
  color: #888;
}
.gc-prestige-score.gc-prestige-pos { color: #ffd700; }
.gc-prestige-score.gc-prestige-neg { color: #ff5a3d; }
.gc-prestige-votes {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  margin-top: 0.5rem;
}
.gc-prestige-btn {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.15);
  background: rgba(255,255,255,0.05);
  color: #999;
  font-size: 1rem;
  cursor: pointer;
  transition: all 0.2s;
  display: flex; align-items: center; justify-content: center;
}
.gc-prestige-btn:hover { background: rgba(255,255,255,0.1); color: #fff; }
.gc-prestige-up.gc-prestige-active { background: rgba(255,215,0,0.2); color: #ffd700; border-color: rgba(255,215,0,0.4); }
.gc-prestige-down.gc-prestige-active { background: rgba(230,57,70,0.2); color: #ff5a3d; border-color: rgba(230,57,70,0.4); }
.gc-prestige-count { font-size: 0.8rem; color: #777; }
.gc-prestige-premium { font-size: 0.8rem; color: #888; margin-top: 0.5rem; }
.gc-prestige-premium a { color: #ffd700; text-decoration: underline; }

/* Prestige Leaderboard */
.gc-prestige-table { display: flex; flex-direction: column; gap: 0; }
.gc-prestige-row {
  display: grid;
  grid-template-columns: 50px 1fr 70px 80px 70px 70px;
  align-items: center;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  text-decoration: none;
  color: inherit;
  transition: background 0.15s;
}
.gc-prestige-row:hover { background: rgba(255,255,255,0.03); }
.gc-prestige-row.gc-prestige-header {
  font-weight: 600;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #888;
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
.gc-prestige-rank { text-align: center; font-weight: 700; font-size: 1.2rem; }
.gc-prestige-author { display: flex; align-items: center; gap: 0.5rem; }
.gc-prestige-pts { font-weight: 700; color: #ffd700; text-align: center; }
.gc-prestige-stories, .gc-prestige-likes, .gc-prestige-reads { text-align: center; color: #999; }
@media (max-width: 640px) {
  .gc-prestige-row { grid-template-columns: 40px 1fr 60px 60px; }
  .gc-prestige-likes, .gc-prestige-reads { display: none; }
}


/* ==========================================================
   GUEST LANDING PAGE â€” Immersive community splash
   ========================================================== */

.gc-landing {
  position: fixed;
  inset: 0;
  z-index: 10001;
  background: #050510;
  color: #e7e9ea;
  overflow-y: auto;
  overflow-x: hidden;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  -webkit-font-smoothing: antialiased;
}

/* â”€â”€ Animated Background â”€â”€ */
.gc-landing-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  background: radial-gradient(ellipse at 20% 50%, rgba(29,155,240,0.08) 0%, transparent 50%),
              radial-gradient(ellipse at 80% 20%, rgba(124,58,237,0.08) 0%, transparent 50%),
              radial-gradient(ellipse at 50% 80%, rgba(230,57,70,0.06) 0%, transparent 50%),
              #050510;
}

.gc-landing-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.5;
  animation: gc-orb-float 20s ease-in-out infinite;
}
.gc-landing-orb-1 {
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(29,155,240,0.3), transparent 70%);
  top: -10%; left: -5%;
  animation-delay: 0s;
  animation-duration: 25s;
}
.gc-landing-orb-2 {
  width: 350px; height: 350px;
  background: radial-gradient(circle, rgba(124,58,237,0.25), transparent 70%);
  top: 20%; right: -8%;
  animation-delay: -5s;
  animation-duration: 22s;
}
.gc-landing-orb-3 {
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(230,57,70,0.2), transparent 70%);
  bottom: 10%; left: 15%;
  animation-delay: -10s;
  animation-duration: 28s;
}
.gc-landing-orb-4 {
  width: 250px; height: 250px;
  background: radial-gradient(circle, rgba(29,155,240,0.15), transparent 70%);
  bottom: -5%; right: 20%;
  animation-delay: -15s;
  animation-duration: 18s;
}

@keyframes gc-orb-float {
  0%, 100% { transform: translate(0, 0) scale(1); }
  25% { transform: translate(30px, -40px) scale(1.1); }
  50% { transform: translate(-20px, 20px) scale(0.95); }
  75% { transform: translate(40px, 30px) scale(1.05); }
}

.gc-landing-grid {
  position: absolute;
  inset: 0;
  background-image: 
    linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
}

/* â”€â”€ Hero Section â”€â”€ */
.gc-landing-hero {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 12vh 24px 4vh;
  max-width: 720px;
  margin: 0 auto;
  animation: gc-landing-fadein 1s ease-out;
}

@keyframes gc-landing-fadein {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}

.gc-landing-logo-wrap {
  position: relative;
  margin-bottom: 2rem;
}

.gc-landing-logo-glow {
  position: absolute;
  inset: -20px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(29,155,240,0.3), rgba(124,58,237,0.15), transparent 70%);
  animation: gc-logo-pulse 4s ease-in-out infinite;
}

@keyframes gc-logo-pulse {
  0%, 100% { transform: scale(1); opacity: 0.5; }
  50% { transform: scale(1.2); opacity: 0.8; }
}

.gc-landing-logo {
  position: relative;
  z-index: 1;
  filter: drop-shadow(0 0 30px rgba(29,155,240,0.4));
}

.gc-landing-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 20px;
  border-radius: 100px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.6);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-bottom: 2rem;
  backdrop-filter: blur(10px);
}

.gc-landing-title {
  font-size: clamp(2.8rem, 7vw, 5rem);
  font-weight: 900;
  line-height: 1.05;
  margin: 0 0 1.5rem;
  color: #fff;
  letter-spacing: -2px;
}

.gc-landing-title-accent {
  background: linear-gradient(135deg, #ff5a3d 0%, #7c3aed 40%, #ff5a3d 80%, #ff6b35 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  background-size: 200% 200%;
  animation: gc-gradient-shift 6s ease-in-out infinite;
}

@keyframes gc-gradient-shift {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

.gc-landing-subtitle {
  font-size: clamp(1rem, 2.5vw, 1.25rem);
  line-height: 1.7;
  color: rgba(255,255,255,0.55);
  max-width: 540px;
  margin: 0 0 2.5rem;
}

/* â”€â”€ CTA Buttons â”€â”€ */
.gc-landing-cta {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
}

.gc-landing-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 32px;
  border-radius: 100px;
  font-size: 1.05rem;
  font-weight: 700;
  text-decoration: none;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
  border: none;
  position: relative;
  overflow: hidden;
}

.gc-landing-btn-primary {
  background: linear-gradient(135deg, #ff5a3d, #24d6c9);
  color: #fff;
  box-shadow: 0 4px 24px rgba(29,155,240,0.35), 0 0 0 0 rgba(29,155,240,0);
}
.gc-landing-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(29,155,240,0.5), 0 0 60px rgba(29,155,240,0.15);
}
.gc-landing-btn-primary:active {
  transform: translateY(0);
}

.gc-landing-btn-outline {
  background: rgba(255,255,255,0.04);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.15);
  backdrop-filter: blur(10px);
}
.gc-landing-btn-outline:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.3);
  transform: translateY(-2px);
}

/* â”€â”€ Feature Cards â”€â”€ */
.gc-landing-features {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 20px;
  max-width: 960px;
  margin: 0 auto;
  padding: 2rem 24px 4rem;
}

.gc-landing-feature {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 20px;
  padding: 28px 24px;
  text-align: left;
  backdrop-filter: blur(10px);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  animation: gc-feature-in 0.8s ease-out backwards;
  animation-delay: var(--delay, 0s);
}

@keyframes gc-feature-in {
  from { opacity: 0; transform: translateY(40px); }
  to { opacity: 1; transform: translateY(0); }
}

.gc-landing-feature:hover {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.12);
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(0,0,0,0.3);
}

.gc-landing-feature-icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
}
.gc-landing-fi-blue {
  background: rgba(29,155,240,0.12);
  color: #ff5a3d;
}
.gc-landing-fi-purple {
  background: rgba(124,58,237,0.12);
  color: #7c3aed;
}
.gc-landing-fi-red {
  background: rgba(230,57,70,0.12);
  color: #ff5a3d;
}
.gc-landing-fi-gold {
  background: rgba(255,170,0,0.12);
  color: #ffaa00;
}

.gc-landing-feature h3 {
  font-size: 1.15rem;
  font-weight: 700;
  margin: 0 0 8px;
  color: #fff;
}

.gc-landing-feature p {
  font-size: 0.92rem;
  line-height: 1.6;
  color: rgba(255,255,255,0.45);
  margin: 0;
}

/* â”€â”€ Social Proof / Stats â”€â”€ */
.gc-landing-social {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 40px;
  padding: 3rem 24px;
  max-width: 600px;
  margin: 0 auto;
  animation: gc-landing-fadein 1s ease-out 0.5s backwards;
}

.gc-landing-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.gc-landing-stat-num {
  font-size: 2rem;
  font-weight: 900;
  background: linear-gradient(135deg, #ff5a3d, #7c3aed);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.gc-landing-stat-label {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.4);
  font-weight: 500;
}

.gc-landing-stat-divider {
  width: 1px;
  height: 40px;
  background: rgba(255,255,255,0.1);
}

/* â”€â”€ Bottom Links â”€â”€ */
.gc-landing-bottom {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 2rem 24px 4rem;
  animation: gc-landing-fadein 1s ease-out 0.7s backwards;
}

.gc-landing-bottom-text {
  font-size: 1rem;
  color: rgba(255,255,255,0.4);
  margin: 0 0 1rem;
}

.gc-landing-link {
  color: #ff5a3d;
  text-decoration: none;
  font-weight: 600;
}
.gc-landing-link:hover {
  text-decoration: underline;
}

.gc-landing-bottom-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  font-size: 0.85rem;
}

.gc-landing-bottom-links a {
  color: rgba(255,255,255,0.3);
  text-decoration: none;
  transition: color 0.2s;
}
.gc-landing-bottom-links a:hover {
  color: rgba(255,255,255,0.7);
}
.gc-landing-bottom-links span {
  color: rgba(255,255,255,0.15);
}

/* â”€â”€ Mobile Responsive â”€â”€ */
@media (max-width: 768px) {
  .gc-landing-hero {
    padding: 8vh 20px 3vh;
  }
  .gc-landing-title {
    letter-spacing: -1px;
  }
  .gc-landing-features {
    grid-template-columns: 1fr;
    padding: 1rem 16px 3rem;
  }
  .gc-landing-social {
    gap: 24px;
  }
  .gc-landing-stat-num {
    font-size: 1.6rem;
  }
  .gc-landing-cta {
    flex-direction: column;
    width: 100%;
    padding: 0 20px;
  }
  .gc-landing-btn {
    justify-content: center;
    width: 100%;
  }
}

@media (max-width: 480px) {
  .gc-landing-hero {
    padding: 6vh 16px 2vh;
  }
  .gc-landing-badge {
    font-size: 0.65rem;
    letter-spacing: 2px;
  }
  .gc-landing-feature {
    padding: 22px 20px;
  }
}


/* Topbar always visible — managed inline by community-feed.js on /community routes */


/* â”€â”€ Upload & Composer Upgrades â”€â”€ */
.gc-upload-label { cursor: pointer; display: inline-flex; align-items: center; }
.gc-composer-preview { position: relative; margin: 8px 0; }
.gc-composer-preview .gc-composer-image-remove {
  position: absolute; top: 8px; right: 8px;
  background: rgba(0,0,0,0.7); color: #fff; border: none;
  width: 28px; height: 28px; border-radius: 50%;
  font-size: 16px; cursor: pointer; display: flex;
  align-items: center; justify-content: center;
}
.gc-composer-preview .gc-composer-image-remove:hover { background: #ff5a3d; }
.gc-hashtag-btn, .gc-mention-btn {
  font-size: 16px !important; font-weight: 700;
  min-width: 28px; display: flex; align-items: center; justify-content: center;
}
.gc-hashtag { color: var(--gc-accent); font-weight: 500; }
.gc-mention { color: var(--gc-accent); font-weight: 500; cursor: pointer; }
.gc-mention:hover { text-decoration: underline; }

/* â”€â”€ Admin Badge â”€â”€ */
.gc-admin-badge { display: inline-flex; align-items: center; margin-left: 2px; vertical-align: middle; }
.gc-admin-badge svg { filter: drop-shadow(0 0 3px rgba(255,215,0,0.5)); }

/* â”€â”€ Profile Avatar Fix â”€â”€ */
.gc-profile-avatar-wrap {
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
.gc-profile-avatar-row {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  padding: 0 16px;
}
.gc-profile-banner {
  height: 180px;
}

/* â”€â”€ Edit Profile Modal â”€â”€ */
.gc-edit-banner-section { position: relative; height: 150px; background: linear-gradient(135deg, #1a1a2e, #0f3460); border-radius: var(--gc-radius-lg) var(--gc-radius-lg) 0 0; overflow: hidden; cursor: pointer; }
.gc-edit-banner-section img { width: 100%; height: 100%; object-fit: cover; }
.gc-edit-banner-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.5); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 14px; font-weight: 600; opacity: 0; transition: opacity .2s; }
.gc-edit-banner-section:hover .gc-edit-banner-overlay { opacity: 1; }
.gc-edit-avatar-section { display: flex; align-items: center; gap: 16px; padding: 0 20px; margin-top: -36px; position: relative; z-index: 2; }
.gc-edit-avatar-preview { position: relative; width: 80px; height: 80px; border-radius: 50%; border: 4px solid var(--gc-bg); overflow: hidden; cursor: pointer; background: var(--gc-bg2); flex-shrink: 0; }
.gc-edit-avatar-preview img { width: 100%; height: 100%; object-fit: cover; }
.gc-edit-avatar-preview .gc-avatar { width: 100%; height: 100%; font-size: 28px; }
.gc-edit-avatar-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.5); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 11px; font-weight: 600; opacity: 0; transition: opacity .2s; border-radius: 50%; }
.gc-edit-avatar-preview:hover .gc-edit-avatar-overlay { opacity: 1; }
.gc-edit-avatar-label { font-size: 13px; color: var(--gc-text-secondary); }

/* â”€â”€ Forge Cover Upload â”€â”€ */
.gc-forge-cover-upload label:hover { background: var(--gc-bg2); }


/* ================================================
   COMMUNITY BROWSE PAGE -- Flagship Series Grid
   ================================================ */
.gc-browse-page { max-width: 1200px; margin: 0 auto; padding: 0 1rem; }
.gc-browse-header { margin-bottom: 1.5rem; }
.gc-browse-title { font-size: 1.75rem; font-weight: 800; color: var(--gc-text); margin: 0 0 4px; }
.gc-browse-subtitle { color: var(--gc-secondary); font-size: 14px; margin: 0 0 1.25rem; }
.gc-browse-search-row { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin-bottom: 1rem; }
.gc-browse-search-wrap { flex: 1; min-width: 200px; }
.gc-browse-search {
  width: 100%; padding: 10px 16px; border-radius: 12px;
  border: 1.5px solid var(--gc-border); background: var(--gc-card);
  color: var(--gc-text); font-size: 15px; outline: none;
  transition: border-color 0.2s;
}
.gc-browse-search:focus { border-color: var(--gc-accent); }
.gc-browse-controls { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.gc-browse-select {
  padding: 8px 12px; border-radius: 10px; border: 1.5px solid var(--gc-border);
  background: var(--gc-card); color: var(--gc-text); font-size: 13px; cursor: pointer;
}
.gc-browse-select:focus { border-color: var(--gc-accent); outline: none; }
.gc-browse-view-toggle { display: flex; border: 1.5px solid var(--gc-border); border-radius: 10px; overflow: hidden; }
.gc-browse-view-btn {
  padding: 6px 10px; background: transparent; border: none; color: var(--gc-secondary);
  cursor: pointer; display: flex; align-items: center; transition: all 0.15s;
}
.gc-browse-view-btn.active { background: var(--gc-accent); color: #000; }
.gc-browse-view-btn:hover:not(.active) { background: rgba(255,255,255,0.05); }

/* Genre chips */
.gc-browse-chips {
  display: flex; flex-wrap: wrap; gap: 6px; padding: 8px 0;
  max-height: 200px; overflow-y: auto;
}
.gc-browse-subchip {
  padding: 5px 14px; border-radius: 20px; border: 1.5px solid var(--gc-border);
  background: transparent; color: var(--gc-text); font-size: 12px; cursor: pointer;
  white-space: nowrap; transition: all 0.15s;
}
.gc-browse-subchip:hover { border-color: var(--gc-accent); color: var(--gc-accent); }
.gc-browse-subchip.active {
  background: var(--gc-accent); color: #000; border-color: var(--gc-accent); font-weight: 600;
}
.gc-browse-count { color: var(--gc-secondary); font-size: 13px; margin-bottom: 1rem; }

/* Series card grid */
.gc-browse-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1.25rem;
}
.gc-browse-grid.gc-browse-list-mode { grid-template-columns: 1fr; }
.gc-browse-grid.gc-browse-list-mode .gc-browse-card { flex-direction: row; height: 140px; }
.gc-browse-grid.gc-browse-list-mode .gc-browse-card-img { width: 100px; min-height: 140px; flex-shrink: 0; aspect-ratio: auto; }
.gc-browse-grid.gc-browse-list-mode .gc-browse-card-info { padding: 14px 18px; }

.gc-browse-card {
  display: flex; flex-direction: column; border-radius: 14px;
  background: var(--gc-card); overflow: hidden; cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s; border: 1px solid var(--gc-border);
}
.gc-browse-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.3); }
.gc-browse-card-img { position: relative; width: 100%; aspect-ratio: 3/4; overflow: hidden; }
.gc-browse-cover { width: 100%; height: 100%; object-fit: cover; display: block; }
.gc-browse-cover-ph {
  width: 100%; height: 100%; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #1a1a2e, #16213e); font-size: 3rem; font-weight: 700;
  color: var(--gc-accent); text-shadow: 0 0 20px rgba(255,140,0,0.3);
}
.gc-browse-badges { position: absolute; top: 8px; left: 8px; display: flex; flex-direction: column; gap: 4px; }
.gc-browse-badge {
  padding: 3px 10px; border-radius: 6px; font-size: 11px; font-weight: 700;
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
}
.gc-browse-badge-trend { background: rgba(0,200,80,0.85); color: #fff; }
.gc-browse-badge-new { background: rgba(255,140,0,0.9); color: #fff; }
.gc-browse-card-info { padding: 12px; flex: 1; display: flex; flex-direction: column; }
.gc-browse-card-title {
  font-size: 14px; font-weight: 700; color: var(--gc-text); margin: 0 0 4px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.gc-browse-card-author { font-size: 12px; color: var(--gc-secondary); margin: 0 0 6px; }
.gc-browse-card-meta { display: flex; gap: 10px; align-items: center; font-size: 12px; color: var(--gc-secondary); margin-top: auto; }
.gc-browse-rating { color: var(--gc-accent); font-weight: 600; }
.gc-browse-load-btn { display: block; margin: 2rem auto; }

/* ================================================
   EMOJI PICKER
   ================================================ */
.gc-emoji-picker {
  position: fixed; z-index: 10000; background: var(--gc-card); border: 1.5px solid var(--gc-border);
  border-radius: 14px; padding: 8px; display: grid; grid-template-columns: repeat(8, 1fr);
  gap: 2px; box-shadow: 0 8px 24px rgba(0,0,0,0.4); max-width: 340px;
}
.gc-emoji-btn {
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  background: transparent; border: none; border-radius: 8px; font-size: 20px; cursor: pointer;
  transition: background 0.15s;
}
.gc-emoji-btn:hover { background: rgba(255,255,255,0.1); transform: scale(1.2); }
.gc-emoji-trigger {
  background: transparent !important; border: none; color: var(--gc-secondary); cursor: pointer;
  font-size: 18px; padding: 4px 8px; border-radius: 8px; transition: background 0.15s;
  line-height: 1;
}
.gc-emoji-trigger:hover { background: rgba(255,255,255,0.1); }

/* ================================================
   POST EDITING / PINNED
   ================================================ */
.gc-edited { font-size: 11px; color: var(--gc-secondary); font-style: italic; }
.gc-edit-btn, .gc-pin-btn { opacity:0.5; transition: opacity 0.15s; }
.gc-edit-btn:hover, .gc-pin-btn:hover { opacity:1; }
.gc-edit-btn svg, .gc-pin-btn svg { width: 16px; height: 16px; }
.gc-pin-btn[data-pinned="1"] { opacity:1; color: var(--gc-accent); }
.gc-post.gc-pinned { border-left: 3px solid var(--gc-accent); }
.gc-pinned-label { font-size: 11px; color: var(--gc-accent); font-weight: 600; margin-bottom: 4px; }

/* ================================================
   COMMENT REACTIONS
   ================================================ */
.gc-reaction-row { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px; }
.gc-reaction-pill {
  display: inline-flex; align-items: center; gap: 3px; padding: 2px 8px;
  border-radius: 12px; border: 1px solid var(--gc-border); background: rgba(255,255,255,0.05);
  color: var(--gc-text); font-size: 13px; cursor: pointer; transition: border-color 0.15s;
}
.gc-reaction-pill:hover { border-color: var(--gc-accent); }

/* ================================================
   FORGE AUTHOR ANALYTICS
   ================================================ */
.gc-analytics-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 12px; margin-bottom: 2rem;
}
.gc-analytics-card {
  background: var(--gc-card); border: 1px solid var(--gc-border); border-radius: 14px;
  padding: 1.25rem; text-align: center;
}
.gc-analytics-num { font-size: 2rem; font-weight: 800; color: var(--gc-accent); line-height: 1.2; }
.gc-analytics-label { font-size: 12px; color: var(--gc-secondary); margin-top: 4px; }
.gc-analytics-stories { display: flex; flex-direction: column; gap: 8px; margin-bottom: 2rem; }
.gc-analytics-story-row {
  display: flex; gap: 16px; align-items: center; padding: 10px 14px;
  background: var(--gc-card); border-radius: 10px; cursor: pointer;
  border: 1px solid var(--gc-border); transition: border-color 0.15s;
}
.gc-analytics-story-row:hover { border-color: var(--gc-accent); }
.gc-analytics-story-title { flex: 1; font-weight: 600; color: var(--gc-text); }
.gc-analytics-readers { display: flex; flex-direction: column; gap: 6px; }
.gc-analytics-reader { display: flex; gap: 10px; align-items: center; font-size: 13px; }

/* Mobile responsive for browse */
@media (max-width: 768px) {
  .gc-browse-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 0.75rem; }
  .gc-browse-search-row { flex-direction: column; }
  .gc-browse-controls { width: 100%; justify-content: space-between; }
  .gc-analytics-grid { grid-template-columns: repeat(2, 1fr); }
  .gc-browse-title { font-size: 1.4rem; }
}
@media (max-width: 480px) {
  .gc-browse-grid { grid-template-columns: repeat(2, 1fr); gap: 0.5rem; }
  .gc-browse-card-title { font-size: 12px; }
  .gc-browse-card-info { padding: 8px; }
}


/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   THE FORGE â€” WRITER'S STUDIO STYLES (March 2026)
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€ Book Banner Preview â”€â”€ */
.gc-forge-book-banner {
  position: relative;
  width: 100%;
  height: 200px;
  background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
  background-size: cover;
  background-position: center;
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 24px;
  transition: background-image 0.3s ease;
}
.gc-forge-banner-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.3) 60%, transparent 100%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 24px;
}
.gc-forge-banner-title {
  font-size: 28px;
  font-weight: 800;
  color: #fff;
  text-shadow: 0 2px 8px rgba(0,0,0,0.5);
  letter-spacing: -0.5px;
  line-height: 1.2;
}
.gc-forge-banner-author {
  font-size: 14px;
  color: rgba(255,255,255,0.7);
  margin-top: 4px;
}

/* â”€â”€ Studio Form â”€â”€ */
.gc-forge-studio { max-width: 680px; margin: 0 auto; }
.gc-forge-field-group { margin-bottom: 20px; }
.gc-forge-field-group .gc-forge-label { margin-bottom: 6px; display: block; font-weight: 600; font-size: 14px; color: #ccc; }
.gc-required { color: #ef4444; }
.gc-forge-hint { font-size: 12px; color: #888; display: block; margin-top: 4px; }
.gc-forge-title-input { font-size: 20px !important; font-weight: 700; padding: 14px 16px !important; }
.gc-forge-textarea-footer { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.gc-forge-char-count { font-size: 12px; color: #666; white-space: nowrap; margin-top: 4px; }

/* â”€â”€ Cover Image Upload â”€â”€ */
.gc-forge-cover-upload {
  border: 2px dashed #444;
  border-radius: 12px;
  min-height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s;
  overflow: hidden;
  position: relative;
}
.gc-forge-cover-upload:hover,
.gc-forge-dragover { border-color: #e6a817 !important; background: rgba(230,168,23,0.05); }
.gc-forge-cover-prompt {
  text-align: center;
  padding: 32px;
  color: #888;
}
.gc-forge-cover-prompt svg { opacity: 0.4; margin: 0 auto 12px; display: block; }
.gc-forge-cover-text { font-size: 16px; font-weight: 600; color: #aaa; margin: 0 0 4px; }
.gc-forge-cover-subtext { font-size: 13px; color: #666; margin: 0; }
.gc-forge-cover-preview {
  width: 100%;
  height: 200px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.gc-forge-cover-preview img {
  max-width: 100%;
  max-height: 200px;
  object-fit: contain;
  border-radius: 8px;
}
.gc-forge-cover-remove {
  position: absolute;
  top: 8px;
  right: 8px;
  background: rgba(239,68,68,0.9);
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 4px 12px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
}
.gc-forge-cover-remove:hover { background: #dc2626; }
.gc-forge-cover-url-toggle { margin-top: 8px; }
.gc-forge-link-btn {
  background: none;
  border: none;
  color: #e6a817;
  cursor: pointer;
  font-size: 13px;
  padding: 0;
  text-decoration: underline;
}
.gc-forge-link-btn:hover { color: #f0c040; }

/* â”€â”€ Type description â”€â”€ */
.gc-forge-type-desc {
  font-size: 13px;
  color: #888;
  font-style: italic;
  margin-top: -8px;
  margin-bottom: 16px;
  min-height: 18px;
}

/* â”€â”€ Writing Tips â”€â”€ */
.gc-forge-tips {
  background: rgba(230,168,23,0.06);
  border: 1px solid rgba(230,168,23,0.2);
  border-radius: 10px;
  margin-bottom: 24px;
  overflow: hidden;
}
.gc-forge-tips-toggle {
  padding: 14px 18px;
  font-weight: 600;
  font-size: 14px;
  color: #e6a817;
  cursor: pointer;
  list-style: none;
}
.gc-forge-tips-toggle::-webkit-details-marker { display: none; }
.gc-forge-tips-content { padding: 0 18px 16px; }
.gc-forge-tip {
  font-size: 13px;
  color: #bbb;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  line-height: 1.5;
}
.gc-forge-tip:last-child { border: none; }
.gc-forge-tip strong { color: #e6a817; }

/* â”€â”€ Formatting Toolbar â”€â”€ */
.gc-forge-toolbar {
  display: flex;
  align-items: center;
  gap: 2px;
  background: #1a1a2e;
  border: 1px solid #333;
  border-bottom: none;
  border-radius: 8px 8px 0 0;
  padding: 6px 8px;
  flex-wrap: wrap;
}
.gc-forge-tb-btn {
  background: transparent;
  border: 1px solid transparent;
  color: #ccc;
  cursor: pointer;
  padding: 6px 10px;
  border-radius: 6px;
  font-size: 14px;
  font-family: Georgia, serif;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  transition: all 0.15s;
}
.gc-forge-tb-btn:hover { background: rgba(230,168,23,0.15); color: #e6a817; border-color: rgba(230,168,23,0.3); }
.gc-forge-tb-btn strong { font-weight: 900; }
.gc-forge-tb-btn em { font-style: italic; font-weight: 400; }
.gc-forge-tb-sep { width: 1px; height: 20px; background: #333; margin: 0 6px; }
.gc-forge-tb-upload { color: #888; }
.gc-forge-tb-upload:hover { color: #e6a817; }

/* Editor with toolbar */
.gc-forge-toolbar + .gc-forge-content-editor {
  border-radius: 0 0 8px 8px !important;
  border-top: 1px solid #333 !important;
  min-height: 350px;
}

/* â”€â”€ Chapter Stats â”€â”€ */
.gc-forge-ch-stats {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  font-size: 13px;
  color: #888;
}
.gc-forge-ch-readtime { color: #e6a817; }

/* â”€â”€ Chapter Image â”€â”€ */
.gc-forge-ch-image-area { margin-bottom: 16px; }
.gc-forge-ch-img-preview {
  width: 100%;
  max-height: 160px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #111;
  border-radius: 8px;
  position: relative;
  overflow: hidden;
  margin-bottom: 8px;
}
.gc-forge-ch-img-preview img { max-width: 100%; max-height: 160px; object-fit: contain; }

/* â”€â”€ Forge content rendering upgrades â”€â”€ */
.gc-forge-quote {
  border-left: 3px solid #e6a817;
  padding: 8px 16px;
  margin: 12px 0;
  color: #ccc;
  background: rgba(230,168,23,0.05);
  border-radius: 0 6px 6px 0;
  font-style: italic;
}
.gc-forge-li { color: #ddd; margin-left: 20px; list-style: disc; line-height: 1.7; }
.gc-forge-code { background: #1e1e2e; color: #e6a817; padding: 2px 6px; border-radius: 4px; font-family: monospace; font-size: 0.9em; }
.gc-forge-ch-heading.gc-h2 { font-size: 24px; margin: 24px 0 12px; }
.gc-forge-ch-heading.gc-h3 { font-size: 20px; margin: 20px 0 10px; }
.gc-forge-ch-heading.gc-h4 { font-size: 17px; margin: 16px 0 8px; }

/* â”€â”€ Large create button â”€â”€ */
.gc-btn-lg { padding: 14px 32px !important; font-size: 16px !important; }

/* â”€â”€ Responsive â”€â”€ */
@media (max-width: 600px) {
  .gc-forge-book-banner { height: 150px; }
  .gc-forge-banner-title { font-size: 20px; }
  .gc-forge-toolbar { padding: 4px; gap: 1px; }
  .gc-forge-tb-btn { padding: 5px 7px; min-width: 28px; height: 28px; font-size: 13px; }
}


/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   FORGE STRUCTURE PLANNER STYLES (March 2026)
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€ Structure Planner Container â”€â”€ */
.gc-forge-structure {
  background: rgba(255,255,255,0.03);
  border: 1px solid #333;
  border-radius: 12px;
  padding: 20px;
  margin-bottom: 24px;
}
.gc-forge-struct-header {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 16px;
  color: #e6a817;
  margin-bottom: 8px;
}
.gc-forge-struct-header svg { stroke: #e6a817; }
.gc-forge-struct-desc {
  font-size: 13px;
  color: #888;
  margin-bottom: 16px;
  line-height: 1.5;
}

/* â”€â”€ Season Blocks â”€â”€ */
.gc-forge-season-block, .gc-forge-volume-block {
  background: rgba(0,0,0,0.2);
  border: 1px solid #2a2a3e;
  border-radius: 10px;
  padding: 14px;
  margin-bottom: 12px;
}
.gc-forge-season-header, .gc-forge-volume-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.gc-forge-season-header strong, .gc-forge-volume-header strong {
  color: #e6a817;
  font-size: 14px;
  min-width: 80px;
}

/* â”€â”€ Episode / Entry Rows â”€â”€ */
.gc-forge-episode-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.gc-forge-ep-num {
  font-size: 13px;
  color: #888;
  min-width: 50px;
  font-weight: 600;
}

/* â”€â”€ Inline Inputs â”€â”€ */
.gc-forge-input-inline {
  flex: 1;
  font-size: 13px !important;
  padding: 8px 12px !important;
  min-width: 0;
}
.gc-forge-input-sm {
  width: 80px !important;
  font-size: 14px !important;
  text-align: center;
  padding: 8px !important;
}
.gc-forge-label-sm {
  font-size: 12px !important;
  margin-bottom: 4px !important;
}

/* â”€â”€ Add/Remove Buttons â”€â”€ */
.gc-forge-struct-add {
  background: rgba(230,168,23,0.1);
  border: 1px dashed rgba(230,168,23,0.3);
  color: #e6a817;
  padding: 10px 18px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  margin-top: 8px;
  transition: all 0.2s;
  display: inline-block;
}
.gc-forge-struct-add:hover {
  background: rgba(230,168,23,0.2);
  border-color: #e6a817;
}
.gc-forge-struct-add-sm {
  background: none;
  border: none;
  color: #e6a817;
  padding: 4px 12px;
  cursor: pointer;
  font-size: 12px;
  margin-top: 4px;
  opacity: 0.7;
}
.gc-forge-struct-add-sm:hover { opacity: 1; }
.gc-forge-struct-remove, .gc-forge-struct-remove-sm {
  background: rgba(239,68,68,0.15);
  border: 1px solid rgba(239,68,68,0.3);
  color: #ef4444;
  cursor: pointer;
  border-radius: 6px;
  font-size: 14px;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  flex-shrink: 0;
}
.gc-forge-struct-remove:hover, .gc-forge-struct-remove-sm:hover {
  background: rgba(239,68,68,0.3);
}
.gc-forge-struct-remove-sm {
  width: 24px;
  height: 24px;
  font-size: 12px;
}
.gc-forge-struct-count {
  font-size: 12px;
  color: #888;
  margin-left: 12px;
}

/* â”€â”€ Volume Chapters â”€â”€ */
.gc-forge-volume-chapters {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.06);
}

/* â”€â”€ Structure Names List â”€â”€ */
.gc-forge-struct-names {
  margin-top: 10px;
  max-height: 300px;
  overflow-y: auto;
}

/* â”€â”€ First Content Editor â”€â”€ */
.gc-forge-first-editor {
  min-height: 200px !important;
  border-radius: 0 0 8px 8px !important;
}
.gc-forge-toolbar-mini {
  margin-top: 0;
}

/* â”€â”€ Responsive â”€â”€ */
@media (max-width: 600px) {
  .gc-forge-structure { padding: 12px; }
  .gc-forge-season-header, .gc-forge-volume-header { flex-direction: column; align-items: flex-start; }
  .gc-forge-episode-row { flex-wrap: wrap; }
  .gc-forge-ep-num { min-width: 40px; }
}

/* Shake modal when backdrop clicked during active writing */
@keyframes gc-modal-shake {
  0%,100% { transform: translateX(0); }
  20%     { transform: translateX(-6px); }
  40%     { transform: translateX(6px); }
  60%     { transform: translateX(-4px); }
  80%     { transform: translateX(4px); }
}
.gc-modal-shake .gc-modal-content,
.gc-modal-shake .gc-forge-modal-wide {
  animation: gc-modal-shake 0.35s ease;
}

/* â”€â”€ PREMIUM POLISH â”€â”€ */

/* Follow button states */
.gc-follow-btn-idle {
  background: transparent;
  border: 1.5px solid var(--gc-accent);
  color: var(--gc-accent);
  font-weight: 600;
  transition: all .15s;
  white-space: nowrap;
}
.gc-follow-btn-idle:hover {
  background: var(--gc-accent);
  color: #fff;
}
.gc-follow-btn-active {
  background: var(--gc-accent-subtle);
  border: 1.5px solid var(--gc-accent);
  color: var(--gc-accent);
  font-weight: 600;
  white-space: nowrap;
}
.gc-follow-btn-active:hover {
  background: rgba(230,57,70,0.25);
}

/* Who to follow - suggest item polish */
.gc-suggest-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  transition: background .15s;
  border-radius: 0;
}
.gc-suggest-item:hover { background: var(--gc-hover); }
.gc-suggest-item:last-child { border-bottom: none; }
.gc-suggest-info { flex: 1; min-width: 0; }
.gc-suggest-name {
  font-weight: 700;
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 3px;
  color: var(--gc-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-decoration: none;
}
.gc-suggest-name:hover { text-decoration: underline; }
.gc-suggest-bio {
  color: var(--gc-text-secondary);
  font-size: 12px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: 1px;
}

/* Sidebar card title */
.gc-card-title {
  font-size: 18px;
  font-weight: 800;
  padding: 14px 14px 10px;
  border-bottom: 1px solid var(--gc-border);
  margin: 0;
}

/* Feed welcome empty state */
.gc-feed-welcome {
  padding: 48px 32px !important;
  text-align: center;
}
.gc-feed-welcome-icon {
  width: 60px; height: 60px;
  background: var(--gc-accent-subtle);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px;
  color: var(--gc-accent);
}
.gc-feed-welcome h3 {
  font-size: 20px;
  font-weight: 800;
  margin-bottom: 8px;
}
.gc-feed-welcome p {
  color: var(--gc-text-secondary);
  font-size: 14px;
  line-height: 1.6;
  max-width: 300px;
  margin: 0 auto 20px;
}
.gc-feed-welcome-actions {
  display: flex;
  gap: 8px;
  justify-content: center;
  flex-wrap: wrap;
}

/* Composer focus glow */
.gc-composer:focus-within {
  border-bottom: 1px solid var(--gc-accent) !important;
}
.gc-composer-textarea:focus {
  outline: none;
}

/* Char count color shift */
.gc-composer-count.near { color: #f0a500; }
.gc-composer-count.over { color: var(--gc-accent); font-weight: 700; }

/* Trending card link decoration */
.gc-trending-item { text-decoration: none; color: inherit; }
.gc-trending-item:hover .gc-trending-name { color: var(--gc-accent); }

/* gc-card subtle header separator */
.gc-trending-card .gc-card-title,
.gc-suggest-card .gc-card-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Avatar ring on hover within suggestions */
.gc-suggest-item .gc-avatar {
  transition: box-shadow .15s;
}
.gc-suggest-item:hover .gc-avatar {
  box-shadow: 0 0 0 2px var(--gc-accent);
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   MODERATOR BADGE â€” Shield with emerald glow
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-mod-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  background: linear-gradient(135deg, #059669 0%, #10B981 50%, #34D399 100%);
  color: #fff;
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 2px 7px 2px 5px;
  border-radius: 4px;
  margin-left: 6px;
  vertical-align: middle;
  box-shadow: 0 0 8px rgba(16,185,129,0.5), 0 0 16px rgba(5,150,105,0.3);
  animation: mod-glow 2.5s ease-in-out infinite alternate;
  position: relative;
}
.gc-mod-badge svg {
  width: 12px;
  height: 12px;
  fill: #fff;
  flex-shrink: 0;
}
@keyframes mod-glow {
  from { box-shadow: 0 0 6px rgba(16,185,129,0.4), 0 0 12px rgba(5,150,105,0.2); }
  to   { box-shadow: 0 0 14px rgba(16,185,129,0.7), 0 0 28px rgba(5,150,105,0.4); }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   PREMIUM BADGE â€” Gold glow upgrade
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.gc-verified {
  position: relative;
}
.gc-verified svg {
  filter: drop-shadow(0 0 4px rgba(255,215,0,0.5));
  animation: premium-glow 2s ease-in-out infinite alternate;
}
@keyframes premium-glow {
  from { filter: drop-shadow(0 0 3px rgba(255,215,0,0.4)); }
  to   { filter: drop-shadow(0 0 8px rgba(255,165,0,0.6)); }
}

/* ===== Feed Mode Tabs (Following / Explore) ===== */
.gc-feed-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  margin: 0 -1.5rem;
  padding: 0 1.5rem;
}
.gc-feed-tab {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 16px;
  background: none;
  border: none;
  color: rgba(255,255,255,0.5);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  position: relative;
  transition: color 0.2s, background 0.15s;
  font-family: inherit;
}
.gc-feed-tab:hover {
  color: rgba(255,255,255,0.8);
  background: rgba(255,255,255,0.04);
}
.gc-feed-tab.active {
  color: #fff;
}
.gc-feed-tab.active::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 56px;
  height: 3px;
  background: linear-gradient(90deg, #6366f1, #8b5cf6);
  border-radius: 3px 3px 0 0;
}
.gc-feed-tab svg {
  opacity: 0.7;
  flex-shrink: 0;
}
.gc-feed-tab.active svg {
  opacity: 1;
}

/* Feed hint banner */
.gc-feed-hint {
  padding: 10px 16px;
  margin: 0 0 12px 0;
  background: rgba(99, 102, 241, 0.08);
  border: 1px solid rgba(99, 102, 241, 0.15);
  border-radius: 10px;
  color: rgba(255,255,255,0.7);
  font-size: 13px;
  text-align: center;
}

/* Mobile: tighter tabs */
@media (max-width: 640px) {
  .gc-feed-tabs {
    margin: 0 -1rem;
    padding: 0 1rem;
  }
  .gc-feed-tab {
    padding: 12px 8px;
    font-size: 14px;
    gap: 6px;
  }
}

/* â”€â”€ Avatar Preset Picker â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.gc-avatar-picker-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.7); z-index: 10001;
  display: flex; align-items: center; justify-content: center;
  animation: fadeIn 0.15s ease;
}
.gc-avatar-picker-panel {
  background: #1a1a2e; border-radius: 16px;
  width: 92vw; max-width: 680px; max-height: 85vh;
  display: flex; flex-direction: column; overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}
.gc-avatar-picker-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 20px; border-bottom: 1px solid rgba(255,255,255,0.06);
  color: #eee;
}
.gc-avatar-picker-cats {
  display: flex; gap: 6px; padding: 12px 16px;
  overflow-x: auto; flex-shrink: 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  scrollbar-width: thin;
}
.gc-avatar-picker-cats::-webkit-scrollbar { height: 4px; }
.gc-avatar-picker-cats::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 4px; }
.gc-picker-cat-btn {
  background: rgba(255,255,255,0.06); color: #aaa;
  border: 1px solid rgba(255,255,255,0.08); border-radius: 20px;
  padding: 6px 14px; font-size: 13px; cursor: pointer;
  white-space: nowrap; transition: all 0.15s;
}
.gc-picker-cat-btn:hover { background: rgba(255,255,255,0.12); color: #fff; }
.gc-picker-cat-active {
  background: linear-gradient(135deg, #6366f1, #8b5cf6) !important;
  color: #fff !important; border-color: #7c3aed !important;
}
.gc-avatar-picker-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(72px, 1fr));
  gap: 10px; padding: 16px; overflow-y: auto; flex: 1;
}
.gc-picker-avatar-cell {
  aspect-ratio: 1; border-radius: 12px; overflow: hidden;
  cursor: pointer; border: 2px solid transparent;
  transition: all 0.15s; position: relative;
}
.gc-picker-avatar-cell:hover {
  border-color: #7c3aed; transform: scale(1.08);
  box-shadow: 0 4px 16px rgba(124,58,237,0.3);
}
.gc-picker-avatar-cell img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.gc-btn-outline {
  background: transparent; border: 1px solid rgba(255,255,255,0.2);
  color: #bbb; cursor: pointer; transition: all 0.15s;
}
.gc-btn-outline:hover {
  background: rgba(255,255,255,0.08); color: #fff;
  border-color: rgba(255,255,255,0.3);
}
@media (max-width: 600px) {
  .gc-avatar-picker-panel { width: 98vw; max-height: 90vh; border-radius: 12px; }
  .gc-avatar-picker-grid { grid-template-columns: repeat(auto-fill, minmax(60px, 1fr)); gap: 8px; padding: 12px; }
  .gc-picker-cat-btn { font-size: 12px; padding: 5px 10px; }
}

/* ==========================================================
   MARKETPLACE STYLES
   ========================================================== */

/* Header Actions */
.gc-mkp-header-actions { display: flex; gap: 8px; flex-wrap: wrap; }

/* Category Buttons */
.gc-mkp-cats { display: flex; gap: 8px; flex-wrap: wrap; margin: 16px 0; }
.gc-mkp-cat-btn {
  padding: 8px 16px; border-radius: 20px; border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04); color: #bbb; cursor: pointer;
  font-size: 13px; transition: all 0.15s; white-space: nowrap;
}
.gc-mkp-cat-btn:hover { background: rgba(124,58,237,0.15); color: #fff; border-color: rgba(124,58,237,0.4); }
.gc-mkp-cat-active { background: #7c3aed; color: #fff; border-color: #7c3aed; }

/* Toolbar */
.gc-mkp-toolbar { display: flex; gap: 12px; margin-bottom: 20px; align-items: center; }
.gc-mkp-search { flex: 1; }
.gc-mkp-search input { width: 100%; }

/* Grid */
.gc-mkp-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 20px; margin-bottom: 24px;
}

/* Cards */
.gc-mkp-card {
  background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px; overflow: hidden; cursor: pointer;
  transition: all 0.2s; display: flex; flex-direction: column;
}
.gc-mkp-card:hover {
  border-color: rgba(124,58,237,0.4); transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.3);
}
.gc-mkp-card-img { height: 180px; overflow: hidden; background: rgba(255,255,255,0.02); display: flex; align-items: center; justify-content: center; }
.gc-mkp-card-img img { width: 100%; height: 100%; object-fit: cover; }
.gc-mkp-card-placeholder { font-size: 48px; opacity: 0.3; }
.gc-mkp-card-body { padding: 16px; flex: 1; display: flex; flex-direction: column; gap: 6px; }
.gc-mkp-card-cat { font-size: 11px; color: #7c3aed; text-transform: uppercase; letter-spacing: 0.5px; font-weight: 600; }
.gc-mkp-card-title { font-size: 16px; font-weight: 600; color: #fff; margin: 0; line-height: 1.3; }
.gc-mkp-card-seller { font-size: 13px; color: #888; }
.gc-mkp-card-footer { display: flex; justify-content: space-between; align-items: center; margin-top: auto; padding-top: 8px; }
.gc-mkp-price { font-size: 18px; font-weight: 700; color: #10b981; }
.gc-mkp-card-meta { font-size: 12px; color: #666; }

/* Stars */
.gc-mkp-stars { color: #f59e0b; letter-spacing: 1px; }
.gc-mkp-rating-val { color: #f59e0b; font-weight: 600; font-size: 13px; }
.gc-mkp-rating-count { color: #888; font-size: 12px; }
.gc-mkp-no-rating { color: #666; font-size: 12px; font-style: italic; }

/* Pagination */
.gc-mkp-pagination { display: flex; gap: 6px; justify-content: center; margin: 20px 0; }
.gc-mkp-page-btn {
  padding: 6px 12px; border-radius: 6px; border: 1px solid rgba(255,255,255,0.12);
  background: transparent; color: #bbb; cursor: pointer; transition: all 0.15s;
}
.gc-mkp-page-btn:hover { background: rgba(124,58,237,0.15); color: #fff; }
.gc-mkp-page-active { background: #7c3aed; color: #fff; border-color: #7c3aed; }

/* Detail Page */
.gc-mkp-detail { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; margin: 24px 0; }
.gc-mkp-detail-hero { border-radius: 12px; overflow: hidden; background: rgba(255,255,255,0.02); display: flex; align-items: center; justify-content: center; min-height: 300px; }
.gc-mkp-detail-img { width: 100%; height: auto; max-height: 500px; object-fit: cover; }
.gc-mkp-detail-placeholder { font-size: 72px; opacity: 0.3; }
.gc-mkp-detail-info { display: flex; flex-direction: column; gap: 12px; }
.gc-mkp-detail-cat { font-size: 12px; color: #7c3aed; text-transform: uppercase; letter-spacing: 0.5px; font-weight: 600; }
.gc-mkp-detail-title { font-size: 28px; font-weight: 700; color: #fff; margin: 0; }
.gc-mkp-detail-seller { font-size: 14px; color: #bbb; cursor: pointer; display: flex; align-items: center; gap: 8px; }
.gc-mkp-detail-seller:hover { color: #7c3aed; }
.gc-mkp-avatar-sm { width: 24px; height: 24px; border-radius: 50%; }
.gc-mkp-detail-rating { font-size: 14px; }
.gc-mkp-detail-stats { font-size: 13px; color: #888; }
.gc-mkp-detail-price { font-size: 32px; font-weight: 700; color: #10b981; }
.gc-mkp-detail-actions { margin: 8px 0; }
.gc-mkp-detail-desc { margin-top: 16px; }
.gc-mkp-detail-desc h3, .gc-mkp-detail-preview h3 { font-size: 16px; color: #bbb; margin: 0 0 8px; }
.gc-mkp-desc-body, .gc-mkp-preview-body { color: #ccc; line-height: 1.6; font-size: 14px; }
.gc-mkp-file-info { font-size: 13px; color: #888; padding: 8px 12px; background: rgba(255,255,255,0.04); border-radius: 8px; }
.gc-mkp-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.gc-mkp-tag { padding: 4px 10px; border-radius: 12px; background: rgba(124,58,237,0.15); color: #a78bfa; font-size: 12px; }

/* Reviews */
.gc-mkp-reviews { margin-top: 32px; }
.gc-mkp-reviews h2 { color: #fff; margin-bottom: 16px; }
.gc-mkp-review-form { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 12px; padding: 20px; margin-bottom: 24px; display: flex; flex-direction: column; gap: 12px; }
.gc-mkp-review-form h3 { margin: 0; color: #bbb; font-size: 15px; }
.gc-mkp-review-stars { display: flex; gap: 4px; }
.gc-mkp-star-btn { background: none; border: none; color: #f59e0b; font-size: 24px; cursor: pointer; padding: 0; transition: transform 0.1s; }
.gc-mkp-star-btn:hover { transform: scale(1.2); }
.gc-mkp-review-list { display: flex; flex-direction: column; gap: 16px; }
.gc-mkp-review { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.06); border-radius: 10px; padding: 16px; }
.gc-mkp-review-header { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin-bottom: 8px; }
.gc-mkp-review-header strong { color: #fff; }
.gc-mkp-review-date { font-size: 12px; color: #666; }
.gc-mkp-review-title { font-weight: 600; color: #ddd; margin-bottom: 4px; }
.gc-mkp-review-body { color: #bbb; font-size: 14px; line-height: 1.5; }
.gc-mkp-helpful-btn { background: none; border: 1px solid rgba(255,255,255,0.1); border-radius: 6px; color: #888; font-size: 12px; padding: 4px 10px; cursor: pointer; margin-top: 8px; display: inline-flex; align-items: center; gap: 4px; }
.gc-mkp-helpful-btn:hover { color: #f87171; border-color: rgba(248,113,113,0.3); }

/* Sell Form */
.gc-mkp-sell-form { max-width: 680px; margin: 0 auto; }
.gc-mkp-sell-form .gc-form-group { margin-bottom: 16px; }
.gc-mkp-sell-form label { display: block; margin-bottom: 6px; color: #bbb; font-size: 14px; font-weight: 500; }

/* Dashboard */
.gc-mkp-stripe-card { padding: 20px; border-radius: 12px; margin-bottom: 24px; border: 1px solid rgba(255,255,255,0.08); }
.gc-mkp-stripe-ok { background: rgba(16,185,129,0.08); border-color: rgba(16,185,129,0.2); }
.gc-mkp-stripe-warn { background: rgba(245,158,11,0.08); border-color: rgba(245,158,11,0.2); }
.gc-mkp-stripe-card h3 { margin: 0 0 8px; color: #fff; }
.gc-mkp-stripe-status { color: #bbb; margin-bottom: 12px; font-size: 14px; }

.gc-mkp-stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 16px; margin-bottom: 28px; }
.gc-mkp-stat-card { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 10px; padding: 20px; text-align: center; }
.gc-mkp-stat-value { font-size: 28px; font-weight: 700; color: #fff; }
.gc-mkp-stat-label { font-size: 13px; color: #888; margin-top: 4px; }

.gc-mkp-payout-section { margin-bottom: 28px; }
.gc-mkp-payout-section h3 { color: #fff; margin-bottom: 12px; }
.gc-mkp-payout-balance { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; padding: 16px; background: rgba(255,255,255,0.03); border-radius: 10px; }
.gc-mkp-payout-balance span { color: #bbb; }
.gc-mkp-payout-balance strong { font-size: 24px; color: #10b981; }

.gc-mkp-payout-history h4 { color: #bbb; margin: 16px 0 8px; }
.gc-mkp-payout-row { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 8px; padding: 10px 12px; border-bottom: 1px solid rgba(255,255,255,0.05); color: #bbb; font-size: 13px; }
.gc-mkp-payout-completed { color: #10b981; }
.gc-mkp-payout-pending { color: #f59e0b; }
.gc-mkp-payout-failed { color: #ef4444; }

.gc-mkp-top-listings, .gc-mkp-recent-orders { margin-bottom: 28px; }
.gc-mkp-top-listings h3, .gc-mkp-recent-orders h3 { color: #fff; margin-bottom: 12px; }
.gc-mkp-top-row, .gc-mkp-order-row {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap: 8px;
  padding: 10px 12px; border-bottom: 1px solid rgba(255,255,255,0.05);
  color: #bbb; font-size: 13px; align-items: center;
}
.gc-mkp-top-title { color: #7c3aed; cursor: pointer; }
.gc-mkp-top-title:hover { text-decoration: underline; }

.gc-mkp-order-completed { color: #10b981; }
.gc-mkp-order-refunded { color: #ef4444; }
.gc-mkp-order-pending { color: #f59e0b; }

.gc-mkp-dash-actions { margin-top: 24px; }

/* Orders List */
.gc-mkp-order-list { display: flex; flex-direction: column; gap: 16px; }
.gc-mkp-order-card {
  display: flex; gap: 16px; background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08); border-radius: 12px;
  padding: 16px; align-items: flex-start;
}
.gc-mkp-order-img { width: 80px; height: 80px; border-radius: 8px; overflow: hidden; flex-shrink: 0; }
.gc-mkp-order-img img { width: 100%; height: 100%; object-fit: cover; }
.gc-mkp-order-info { flex: 1; }
.gc-mkp-order-info h3 { margin: 0 0 8px; color: #7c3aed; cursor: pointer; font-size: 16px; }
.gc-mkp-order-info h3:hover { text-decoration: underline; }
.gc-mkp-order-meta { display: flex; gap: 12px; flex-wrap: wrap; font-size: 13px; color: #888; align-items: center; margin-bottom: 10px; }
.gc-mkp-order-status { padding: 2px 8px; border-radius: 4px; font-size: 11px; font-weight: 600; text-transform: uppercase; }

/* Seller Page */
.gc-mkp-seller-page { margin-top: 16px; }
.gc-mkp-seller-header { display: flex; gap: 24px; align-items: center; margin-bottom: 32px; padding: 24px; background: rgba(255,255,255,0.03); border-radius: 16px; }
.gc-mkp-seller-avatar { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; }
.gc-mkp-seller-avatar-placeholder { width: 80px; height: 80px; border-radius: 50%; background: rgba(124,58,237,0.15); display: flex; align-items: center; justify-content: center; font-size: 36px; }
.gc-mkp-seller-info h1 { margin: 0 0 8px; color: #fff; font-size: 24px; }
.gc-mkp-seller-info p { color: #bbb; margin: 0 0 8px; font-size: 14px; }
.gc-mkp-seller-stats { color: #888; font-size: 13px; }

/* Not Seller */
.gc-mkp-not-seller { text-align: center; padding: 60px 20px; }
.gc-mkp-not-seller h3 { color: #fff; font-size: 22px; margin-bottom: 8px; }
.gc-mkp-not-seller p { color: #888; margin-bottom: 20px; }

/* Responsive */
@media (max-width: 768px) {
  .gc-mkp-detail { grid-template-columns: 1fr; }
  .gc-mkp-detail-hero { min-height: 200px; }
  .gc-mkp-detail-title { font-size: 22px; }
  .gc-mkp-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .gc-mkp-seller-header { flex-direction: column; text-align: center; }
  .gc-mkp-top-row, .gc-mkp-order-row { grid-template-columns: 1fr 1fr; }
  .gc-mkp-payout-row { grid-template-columns: 1fr 1fr; }
}

/* Community v8 fiction-first refresh */
:root {
  --gc-bg: #090a0e;
  --gc-surface: #11131a;
  --gc-surface-hover: #181b25;
  --gc-surface-raised: #1b1f2b;
  --gc-border: rgba(255,255,255,0.1);
  --gc-border-light: rgba(255,255,255,0.16);
  --gc-text: #f4f1ea;
  --gc-text-secondary: #b2adbf;
  --gc-text-tertiary: #777286;
  --gc-accent: #d84a4f;
  --gc-accent2: #2f7dd1;
  --gc-warning: #d9a441;
  --gc-shadow-md: 0 16px 40px rgba(0,0,0,.32);
  --gc-shadow-lg: 0 22px 70px rgba(0,0,0,.48);
}

.gc-app { background:
  radial-gradient(circle at 18% 0%, rgba(216,74,79,.16), transparent 34%),
  radial-gradient(circle at 82% 4%, rgba(47,125,209,.14), transparent 32%),
  linear-gradient(180deg, #090a0e 0%, #0d0f15 52%, #090a0e 100%);
}
.gc-layout { grid-template-columns: 250px minmax(0, 740px) 330px; max-width: 1360px; column-gap: 18px; padding: 0 14px; }
.gc-main { border-right: 0; }
.gc-sidebar, .gc-right { border: 0; }
.gc-sidebar-inner { min-height: 100%; display: flex; flex-direction: column; }
.gc-nav-item { font-size: 17px; padding: 11px 13px; gap: 14px; }
.gc-nav-item .gc-nav-label { font-size: 17px; }
.gc-compose-btn { width: 100%; box-shadow: 0 12px 30px rgba(216,74,79,.2); }
.gc-search-box, .gc-search-input { background: rgba(255,255,255,.055); border-color: var(--gc-border); }
.gc-card { background: rgba(17,19,26,.82); border: 1px solid var(--gc-border); box-shadow: var(--gc-shadow-md); backdrop-filter: blur(12px); }
.gc-card-title, .gc-card-header { letter-spacing: -.02em; }

.gc-view-header { top: 0; background: rgba(9,10,14,.72); border: 1px solid var(--gc-border); border-top: 0; border-radius: 0 0 18px 18px; box-shadow: 0 16px 42px rgba(0,0,0,.18); }
.gc-view-header h2 { font-size: 22px; letter-spacing: -.02em; }
.gc-view-subtitle { color: var(--gc-text-secondary); }
.gc-kicker { display: inline-flex; align-items: center; width: fit-content; min-height: 24px; padding: 3px 9px; border-radius: 999px; background: rgba(216,74,79,.14); border: 1px solid rgba(216,74,79,.26); color: #ffb4b8; font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }

.gc-community-hero, .gc-discovery-band { margin: 14px 0 0; padding: 22px; border: 1px solid var(--gc-border); border-radius: 18px; background:
  linear-gradient(135deg, rgba(216,74,79,.18), rgba(47,125,209,.14)),
  linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow: var(--gc-shadow-md); overflow: hidden; }
.gc-community-hero { display: grid; grid-template-columns: 1fr auto; gap: 18px; align-items: end; }
.gc-community-hero h1, .gc-discovery-band h1 { margin: 8px 0 6px; font-size: 30px; line-height: 1.05; letter-spacing: -.04em; color: var(--gc-text); }
.gc-community-hero p { max-width: 560px; color: var(--gc-text-secondary); font-size: 15px; line-height: 1.6; }
.gc-community-hero-actions { display: flex; gap: 9px; flex-wrap: wrap; justify-content: flex-end; }
.gc-discovery-band { display: flex; justify-content: space-between; gap: 18px; align-items: end; }
.gc-discovery-pills { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.gc-discovery-pills span { padding: 7px 10px; border-radius: 999px; color: var(--gc-text-secondary); background: rgba(0,0,0,.22); border: 1px solid var(--gc-border); font-size: 12px; font-weight: 700; }

.gc-composer { margin: 14px 0 12px; background: rgba(17,19,26,.9); border: 1px solid var(--gc-border-light); border-radius: 18px; box-shadow: var(--gc-shadow-md); overflow: hidden; }
.gc-composer-textarea { min-height: 92px; font-size: 16px; line-height: 1.55; background: rgba(0,0,0,.14) !important; border-radius: 14px !important; }
.gc-composer-toolbar { border-top: 1px solid var(--gc-border); padding-top: 10px; }
.gc-composer-forge-link { background: rgba(47,125,209,.12); border-color: rgba(47,125,209,.34); color: #bdd8ff; }
.gc-composer-forge-link:hover { background: rgba(47,125,209,.2); }

.gc-post-modern { position: relative; margin: 12px 0; padding: 16px; border: 1px solid var(--gc-border); border-radius: 18px; background: rgba(17,19,26,.86); box-shadow: 0 12px 34px rgba(0,0,0,.24); cursor: default; }
.gc-post-modern:hover { background: rgba(24,27,37,.92); border-color: var(--gc-border-light); transform: translateY(-1px); }
.gc-post-avatar-col { padding-top: 8px; }
.gc-post-body { min-width: 0; }
.gc-post-header { gap: 5px; }
.gc-post-name { font-size: 15px; letter-spacing: -.01em; }
.gc-post-handle, .gc-post-dot, .gc-post-time { font-size: 13px; color: var(--gc-text-tertiary); }
.gc-post-signal-row { display: flex; align-items: center; gap: 8px; margin-bottom: 5px; flex-wrap: wrap; }
.gc-post-signal { padding: 3px 8px; border-radius: 999px; font-size: 10.5px; line-height: 1.2; font-weight: 900; letter-spacing: .075em; text-transform: uppercase; }
.gc-post-signal-desc { color: var(--gc-text-tertiary); font-size: 12px; }
.gc-post-signal-chapter { color: #ffe0a8; background: rgba(217,164,65,.14); border: 1px solid rgba(217,164,65,.3); }
.gc-post-signal-story { color: #bdd8ff; background: rgba(47,125,209,.14); border: 1px solid rgba(47,125,209,.3); }
.gc-post-signal-visual { color: #ffd1d4; background: rgba(216,74,79,.14); border: 1px solid rgba(216,74,79,.3); }
.gc-post-signal-question { color: #c9f7df; background: rgba(34,197,94,.13); border: 1px solid rgba(34,197,94,.28); }
.gc-post-signal-update, .gc-post-signal-community { color: var(--gc-text-secondary); background: rgba(255,255,255,.06); border: 1px solid var(--gc-border); }
.gc-post-text { margin-top: 8px; font-size: 16px; line-height: 1.66; color: var(--gc-text); }
.gc-post-series { margin-top: 12px; border: 1px solid rgba(47,125,209,.28); background: linear-gradient(135deg, rgba(47,125,209,.16), rgba(216,74,79,.08)); color: #dbeafe; }
.gc-post-image, .gc-post-image-modern { margin-top: 12px; border: 1px solid var(--gc-border-light); border-radius: 14px; overflow: hidden; background: #07080c; }
.gc-post-image img, .gc-post-image-modern img { width: 100%; max-height: 520px; object-fit: cover; }
.gc-post-actions { max-width: none; justify-content: flex-start; gap: 10px; margin-top: 13px; padding-top: 10px; border-top: 1px solid rgba(255,255,255,.06); }
.gc-action { min-width: 38px; min-height: 34px; padding: 6px 9px; background: rgba(255,255,255,.035); border: 1px solid transparent; }
.gc-action:hover { border-color: var(--gc-border-light); transform: translateY(-1px); }
.gc-action-empty { display: none; }
.gc-like-btn.active { color: #ff8c96; background: rgba(216,74,79,.14); }
.gc-repost-btn.active { color: #86efac; background: rgba(34,197,94,.12); }
.gc-bookmark-btn.active { color: #93c5fd; background: rgba(47,125,209,.14); }
.gc-post-more { opacity: .65; }

.gc-tabs { margin-top: 10px; background: rgba(17,19,26,.76); border: 1px solid var(--gc-border); border-radius: 16px; overflow: hidden; }
.gc-tab { min-height: 48px; }
.gc-tab.active::after { width: 44px; height: 3px; background: linear-gradient(90deg, var(--gc-accent), var(--gc-warning)); }

.gc-forge-card, .gc-browse-card { background: rgba(17,19,26,.9); border-color: var(--gc-border-light); box-shadow: var(--gc-shadow-md); }
.gc-forge-card:hover, .gc-browse-card:hover { border-color: rgba(217,164,65,.42); box-shadow: var(--gc-shadow-lg); }
.gc-forge-cover, .gc-browse-cover { filter: saturate(1.08) contrast(1.03); }
.gc-forge-genre-tag, .gc-browse-badge { font-weight: 900; letter-spacing: .05em; }
.gc-trending-item { margin: 4px 8px; border-radius: 12px; }
.gc-forge-studio-card { border-color: rgba(217,164,65,.32); }

@media (max-width: 1200px) {
  .gc-layout { grid-template-columns: 76px minmax(0, 1fr) 310px; max-width: 1180px; }
}
@media (max-width: 1000px) {
  .gc-layout { grid-template-columns: 72px minmax(0, 1fr); }
  .gc-right { display: none; }
}
@media (max-width: 680px) {
  .gc-layout { display: block; padding: 0; }
  .gc-main { padding: 0 10px 76px; }
  .gc-view-header { margin: 0 -10px; border-radius: 0; }
  .gc-community-hero, .gc-discovery-band { grid-template-columns: 1fr; display: grid; margin-top: 10px; padding: 18px; }
  .gc-community-hero h1, .gc-discovery-band h1 { font-size: 25px; }
  .gc-community-hero-actions, .gc-discovery-pills { justify-content: flex-start; }
  .gc-composer { border-radius: 16px; }
  .gc-post-modern { margin: 10px 0; padding: 13px; border-radius: 16px; }
  .gc-post-avatar-col .gc-avatar, .gc-post-avatar-col img.gc-avatar { width: 34px !important; height: 34px !important; }
  .gc-post-text { font-size: 15px; }
  .gc-post-actions { gap: 5px; justify-content: space-between; }
  .gc-action { min-width: 32px; padding: 5px 7px; }
  .gc-post-signal-desc { display: none; }
}
