/* KEYGEN AUTOMOTIVE — Forum shared styles */

/* ═══ TOKENS ═══ */
:root{
  --bg:#080808;
  --bg-elev:#0e0e0e;
  --bg-card:#101010;
  --bg-hover:#161616;
  --border:rgba(255,255,255,.07);
  --border-strong:rgba(255,255,255,.14);
  --border-gold:rgba(212,168,80,.28);
  --accent:#d4a850;
  --accent-light:#e2ba62;
  --accent-dark:#b08836;
  --accent-glow:rgba(212,168,80,.16);
  --text-primary:#eeeae5;
  --text-secondary:#cec5b8;
  --text-muted:#aaa097;
  --text-faint:#6e665e;
  --success:#6bbe7f;
  --danger:#c97070;
  --info:#7fa8c7;
}

/* ═══ RESET / BASE ═══ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:'Outfit',system-ui,-apple-system,sans-serif;
  font-size:15px;line-height:1.55;
  background:var(--bg);color:var(--text-primary);
  min-height:100vh;
  max-width:100%;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
/* Long-content safety — wrap unbreakable strings so they don't push
   the viewport sideways on mobile. */
.container,main,article,section{max-width:100%}
pre,code,kbd,samp{overflow-wrap:break-word;word-break:break-word}
table{max-width:100%}

/* ─── Mobile safety baseline (≤640px) ───────────────────────────────────
   Cards/boxes hit the viewport edge with reasonable padding. Flex
   children that hold text are allowed to shrink past their intrinsic
   width (default `min-width:auto` on flex items is the most common
   cause of "text cut at edge" bugs). Long words break rather than
   overflow. Everything stays inside `body { overflow-x:hidden }`. */
@media (max-width: 640px){
  /* Container — tighter side padding so cards have more room */
  .container{padding-left:14px;padding-right:14px}
  /* All card-likes — never wider than viewport, content-box sizing */
  .market-banner,.market-side-card,.buy-card,.prod-desc,.shop-hero,
  .featured-card,.product-card,.review-block,.gallery,.videos,
  .shop-meta,.shop-hero-body,.product-body,.featured-body,
  .mk-card,.mk-section,.delivery-info,.tags-row,.shop-mini,
  .bundle-perks,.preview-banner,.market-toolbar{
    max-width:100%;
    box-sizing:border-box;
  }
  /* Flex children that hold text — allow shrinking past intrinsic width */
  .market-banner .mb-body,.shop-meta,.product-card .product-body,
  .featured-card .featured-body,.shop-mini .body,.delivery-info > div,
  .bundle-perks,.buy-card .price-row > *,.shop-hero-body{
    min-width:0
  }
  /* Long titles wrap at word boundaries */
  h1,h2,h3,h4,.product-title,.featured-title,.market-banner .mb-title,
  .shop-meta h1,.buy-card h1,.prod-desc h1,.prod-desc h2,.prod-desc h3{
    overflow-wrap:break-word;
    word-break:break-word;
    hyphens:auto
  }
  /* Tag chips never push wider than the row */
  .tag,.tags-row .tag,.cat-chip{max-width:100%;white-space:normal}
}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-light)}
img{max-width:100%;display:block}
button{font-family:inherit;font-size:inherit;color:inherit;background:none;border:none;cursor:pointer}

/* ═══ LAYOUT ═══ */
.container{max-width:1180px;margin:0 auto;padding:0 clamp(16px,3vw,32px)}
.page{padding:24px 0 80px}

/* ═══ HEADER ═══ */
.kg-header-wrap{position:sticky;top:0;left:0;right:0;width:100%;z-index:100;background:#080808;transition:transform .35s cubic-bezier(.4,0,.2,1)}
.kg-header-wrap.hidden{transform:translateY(-100%)}
.kg-header{width:100%;padding:0 clamp(20px,4vw,60px);height:96px;display:flex;align-items:center;justify-content:space-between;background:rgba(8,8,8,.97);border-bottom:1px solid var(--border)}
.kg-header.scrolled{background:rgba(8,8,8,.99)}
.kg-logo{display:flex;align-items:center;gap:16px;color:var(--text-primary)}
.kg-logo img{height:72px;width:auto;animation:kgLogoGlow 2.6s ease-in-out infinite}
.kg-logo:hover img{animation:kgLogoGlowHover .6s ease forwards}
@keyframes kgLogoGlow{
  0%,100%{filter:drop-shadow(0 0 4px rgba(212,168,80,.45)) drop-shadow(0 0 10px rgba(212,168,80,.18)) drop-shadow(0 0 20px rgba(212,168,80,.08))}
  50%{filter:drop-shadow(0 0 10px rgba(212,168,80,.78)) drop-shadow(0 0 24px rgba(212,168,80,.5)) drop-shadow(0 0 48px rgba(212,168,80,.22))}
}
@keyframes kgLogoGlowHover{to{filter:drop-shadow(0 0 13px rgba(212,168,80,.85)) drop-shadow(0 0 28px rgba(212,168,80,.55)) drop-shadow(0 0 56px rgba(212,168,80,.25))}}
.kg-logo-text{display:flex;flex-direction:column;line-height:1}
.kg-logo-text .brand{font-family:'JetBrains Mono',monospace;font-size:18px;letter-spacing:3px;font-weight:700;color:var(--text-primary)}
.kg-logo-text .sub{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:2.5px;color:var(--accent);margin-top:4px;text-transform:uppercase}
.kg-nav{display:flex;align-items:center;gap:28px}
.kg-nav a{color:var(--text-secondary);font-size:13px;letter-spacing:.5px;font-weight:500;text-transform:uppercase;padding:8px 0;border-bottom:1px solid transparent;transition:all .25s}
.kg-nav a:hover,.kg-nav a.active{color:var(--accent);border-bottom-color:var(--accent)}
.kg-nav-actions{display:flex;align-items:center;gap:12px}
#authSlot{display:flex;align-items:center;gap:10px}
#mobAuthSlot{display:flex;flex-direction:column}
.kg-search{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;color:var(--text-secondary);background:transparent;border:1px solid var(--border);transition:.2s;-webkit-tap-highlight-color:transparent}
.kg-search:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-faint)}
.kg-search.active{color:var(--accent);border-color:var(--accent)}
.kg-search svg{width:16px;height:16px}
.kg-lang{display:flex;align-items:center;gap:2px;padding:5px 8px;border:1px solid var(--border);border-radius:8px;background:transparent}
.kg-lang button{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1px;padding:4px 8px;border-radius:5px;color:var(--text-muted);transition:all .2s;font-weight:600}
.kg-lang button.active{background:var(--accent);color:#080808}
.kg-lang button:hover{color:var(--text-primary)}
.kg-lang button.active:hover{color:#080808}
.kg-btn-dash,.kg-btn-login{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1.5px;padding:9px 18px;border-radius:8px;text-transform:uppercase;font-weight:700;transition:all .25s}
.kg-btn-dash{background:var(--accent);color:#080808}
.kg-btn-dash:hover{background:var(--accent-light);color:#080808}
.kg-btn-login{background:transparent;color:var(--text-primary);border:1px solid var(--border-strong)}
.kg-btn-login:hover{border-color:var(--accent);color:var(--accent)}
.kg-avatar{width:34px;height:34px;border-radius:50%;background:var(--accent);color:#080808;display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;font-weight:700;font-size:12px;letter-spacing:1px;cursor:pointer;border:1px solid var(--border-gold);text-decoration:none;overflow:hidden}
.kg-avatar:hover{background:var(--accent-light)}
.kg-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.kg-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;padding:8px;-webkit-tap-highlight-color:transparent}
.kg-hamburger span{display:block;width:22px;height:1.5px;background:var(--text-primary);transition:all .35s cubic-bezier(.22,1,.36,1);transform-origin:center}
.kg-hamburger.active span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.kg-hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.kg-hamburger.active span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.kg-mobile-menu{display:none;width:100%;background:var(--bg);border-bottom:1px solid var(--border-gold);flex-direction:column}
.kg-mobile-menu.open{display:flex}
.kg-mobile-menu a{padding:18px 24px;color:var(--text-primary);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.kg-mobile-menu a:hover{background:var(--bg-hover);color:var(--accent)}
.kg-mobile-menu .mob-arrow{color:var(--accent);opacity:.6}
.kg-mobile-menu .mob-cta-wrap{padding:24px}
.kg-mobile-menu .mob-cta{display:block;text-align:center;background:var(--accent);color:#080808;padding:14px;border-radius:10px;font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:2px;font-weight:700}

/* ═══ HEROES / WELCOME ═══ */
.welcome{padding:32px 0 28px;border-bottom:1px solid var(--border);margin-bottom:28px}
.welcome h1{font-size:clamp(26px,3.5vw,38px);font-weight:700;margin-bottom:10px;letter-spacing:-.02em}
.welcome h1 .hl{color:var(--accent)}
.welcome p{font-size:15px;color:var(--text-secondary);max-width:640px}
.welcome-actions{margin-top:20px;display:flex;gap:12px;flex-wrap:wrap}

/* ═══ BREADCRUMBS ═══ */
.crumbs{display:flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1px;color:var(--text-muted);text-transform:uppercase;margin-bottom:16px}
.crumbs a{color:var(--text-muted)}
.crumbs a:hover{color:var(--accent)}
.crumbs .sep{color:var(--text-faint)}
.crumbs .cur{color:var(--text-primary)}

/* ═══ SECTION HEADER ═══ */
.section-h{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:18px;gap:16px;flex-wrap:wrap}
.section-h h2{font-size:18px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--text-primary)}
.section-h .section-tools{display:flex;align-items:center;gap:10px}

/* ═══ CATEGORY GRID ═══ */
.cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.cat-card{display:flex;align-items:flex-start;gap:14px;padding:18px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;transition:all .25s;color:inherit;text-decoration:none;cursor:pointer}
.cat-card:hover{border-color:var(--border-gold);background:var(--bg-hover);transform:translateY(-1px)}
.cat-icon{width:42px;height:42px;flex:0 0 42px;border-radius:10px;background:var(--accent-glow);border:1px solid var(--border-gold);display:flex;align-items:center;justify-content:center;color:var(--accent)}
.cat-icon svg{width:22px;height:22px;stroke:currentColor;stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round}
.cat-body{flex:1;min-width:0}
.cat-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:4px;display:flex;align-items:center;gap:8px}
.cat-staff-badge{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:1.5px;padding:2px 6px;background:var(--accent-glow);color:var(--accent);border-radius:4px;border:1px solid var(--border-gold);text-transform:uppercase}
.cat-desc{color:var(--text-muted);font-size:13px;line-height:1.5;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cat-meta{display:flex;gap:16px;font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:1px;color:var(--text-faint);text-transform:uppercase}
.cat-meta b{color:var(--text-secondary);font-weight:600;font-family:'Outfit',sans-serif;letter-spacing:0;font-size:12px;text-transform:none}

/* ═══ TOPIC LIST ═══ */
.topics{display:flex;flex-direction:column;gap:10px}
.topic-row{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;transition:transform .15s ease-out,border-color .15s,background .15s,box-shadow .15s;color:inherit;text-decoration:none}
.topic-row:hover{background:var(--bg-hover);border-color:var(--border-gold);transform:translateY(-1px);box-shadow:0 8px 22px -10px rgba(0,0,0,.55)}
.topic-row.pinned{border-color:var(--border-gold);background:linear-gradient(to right,var(--accent-glow),var(--bg-card) 60%)}
.topic-row.pinned:hover{background:linear-gradient(to right,rgba(212,168,80,.22),var(--bg-hover) 60%)}
.topic-av{width:42px;height:42px;flex:0 0 42px;border-radius:50%;background:var(--accent);color:#080808;display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;font-weight:700;font-size:13px;letter-spacing:1px;border:1px solid var(--border-gold);overflow:hidden}
.topic-av img{width:100%;height:100%;object-fit:cover;display:block}
.topic-main{min-width:0;display:flex;flex-direction:column;gap:6px}
.topic-title{font-size:15.5px;font-weight:600;color:var(--text-primary);line-height:1.35;display:flex;align-items:center;gap:8px;word-break:break-word}
.topic-row:hover .topic-title{color:var(--accent-light)}
.topic-title svg.pin-ico{width:13px;height:13px;flex-shrink:0;color:var(--accent)}
.topic-title svg.lock-ico{width:13px;height:13px;flex-shrink:0;color:var(--text-faint)}
.topic-snippet{font-size:13px;line-height:1.5;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;word-break:break-word}
.topic-row:hover .topic-snippet{color:var(--text-secondary)}
.topic-meta{display:flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.5px;color:var(--text-muted);flex-wrap:wrap}
.topic-meta a{color:var(--text-muted);font-weight:600}
.topic-meta a:hover{color:var(--accent)}
.topic-meta .dot{color:var(--text-faint)}
.topic-cat-tag{padding:2px 8px;background:var(--bg-elev);border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);text-transform:uppercase;font-size:9.5px}
.topic-author-chip{display:inline-flex;align-items:center;gap:6px;padding:2px 8px 2px 3px;background:var(--bg-elev);border:1px solid var(--border);border-radius:999px;font-family:'Outfit',sans-serif;font-size:11.5px;font-weight:500;letter-spacing:0;color:var(--text-secondary);text-transform:none;transition:border-color .15s,color .15s}
.topic-author-chip:hover{border-color:var(--border-gold);color:var(--accent-light)}
.topic-author-chip .av-mini{width:18px;height:18px;border-radius:50%;background:var(--accent);color:#080808;display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;font-weight:700;font-size:9px;letter-spacing:0;overflow:hidden;flex-shrink:0}
.topic-author-chip .av-mini img{width:100%;height:100%;object-fit:cover;display:block}
.topic-author-chip.deleted{color:var(--text-faint);font-style:italic}
.topic-reply-hint{display:inline-flex;align-items:center;gap:3px;color:var(--text-faint);font-family:'Outfit',sans-serif;font-size:11px;font-style:italic;text-transform:none;letter-spacing:0}
.topic-row:hover .topic-reply-hint{color:var(--accent)}
.topic-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;background:var(--bg-elev);border:1px solid var(--border);border-radius:999px;font-family:'JetBrains Mono',monospace;font-size:12.5px;color:var(--text-secondary);letter-spacing:.2px;transition:border-color .15s,color .15s;min-width:62px;justify-content:center}
.topic-pill.is-empty{opacity:.5}
.topic-pill svg{width:14px;height:14px;stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round;color:var(--text-faint);flex-shrink:0}
.topic-pill b{color:var(--text-primary);font-weight:700;font-size:13px}
.topic-pill.is-hot{border-color:var(--border-gold);color:var(--accent-light);background:rgba(212,168,80,.08)}
.topic-pill.is-hot svg{color:var(--accent)}
.topic-pill.is-hot b{color:var(--accent-light)}
.topic-row:hover .topic-pill{border-color:var(--border-strong)}
.topic-row:hover .topic-pill.is-hot{border-color:var(--accent)}
.topic-right{display:flex;flex-direction:column;align-items:flex-end;gap:7px;flex-shrink:0}
.topic-right .topic-pills{display:flex;gap:6px}
.topic-time{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--text-muted);letter-spacing:.5px;white-space:nowrap}
.topic-go{color:var(--text-faint);font-size:18px;line-height:1;transition:color .15s,transform .15s}
.topic-row:hover .topic-go{color:var(--accent);transform:translateX(2px)}

/* ═══ TOPIC PAGE — full body + posts ═══ */
.topic-head{padding:24px 0 22px;border-bottom:1px solid var(--border);margin-bottom:22px}
.topic-head h1{font-size:clamp(22px,2.6vw,30px);font-weight:700;letter-spacing:-.01em;line-height:1.25;margin-bottom:14px;color:var(--text-primary)}
.topic-head .topic-meta{font-size:12px}

/* Post card */
.post{display:grid;grid-template-columns:auto 1fr;gap:20px;padding:22px 0;border-bottom:1px solid var(--border)}
.post-side{display:flex;flex-direction:column;align-items:center;gap:6px;width:78px;flex-shrink:0}
.post-avatar{width:48px;height:48px;border-radius:50%;background:var(--accent);color:#080808;display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;font-weight:700;font-size:14px;letter-spacing:1px;border:1px solid var(--border-gold);text-decoration:none;overflow:hidden}
.post-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.post-author{font-size:12px;color:var(--text-primary);font-weight:600;text-align:center;line-height:1.2;word-break:break-word;text-decoration:none}
.post-rep{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.5px;color:var(--text-muted)}
.post-rep b{color:var(--accent)}
.post-role{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:1.5px;padding:2px 6px;border-radius:3px;text-transform:uppercase;text-align:center}
.post-body{min-width:0}
.post-meta{display:flex;align-items:center;gap:10px;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-muted);margin-bottom:12px}
.post-meta .dot{color:var(--text-faint)}
.post-content{font-size:15px;line-height:1.65;color:var(--text-primary);word-wrap:break-word}
.post-content p{margin-bottom:14px}
.post-content p:last-child{margin-bottom:0}
.post-content h1,.post-content h2,.post-content h3{margin:18px 0 10px;font-weight:700;color:var(--text-primary)}
.post-content h1{font-size:22px}.post-content h2{font-size:19px}.post-content h3{font-size:16px}
.post-content code{background:var(--bg-elev);padding:1px 6px;border-radius:4px;font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--accent-light);border:1px solid var(--border)}
.post-content pre{background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;padding:14px;margin:14px 0;overflow-x:auto}
.post-content pre code{background:none;border:none;padding:0;color:var(--text-secondary)}
.post-content blockquote{border-left:3px solid var(--accent);padding:6px 14px;margin:14px 0;background:var(--bg-elev);color:var(--text-secondary);border-radius:0 6px 6px 0}
.post-content a{color:var(--accent);text-decoration:underline}
.post-content ul,.post-content ol{margin:0 0 14px 22px}
.post-content li{margin-bottom:6px}
.post-content img{margin:14px 0;border-radius:8px;border:1px solid var(--border)}
.post-content hr{border:0;border-top:1px solid var(--border);margin:18px 0}
.post-actions{display:flex;align-items:center;gap:14px;margin-top:14px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.5px}
.post-actions button,.post-actions a{color:var(--text-muted);background:none;border:none;cursor:pointer;padding:6px 0;display:flex;align-items:center;gap:5px;text-transform:uppercase;font-family:inherit;font-size:inherit;letter-spacing:inherit;text-decoration:none;transition:color .2s}
.post-actions button:hover,.post-actions a:hover{color:var(--accent)}
.post-actions button.danger:hover,.post-actions a.danger:hover{color:var(--danger)}

/* ═══ VOTE BUTTON ═══ */
.vote{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid var(--border);border-radius:999px;color:var(--text-muted);transition:all .2s;background:transparent;font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:600;cursor:pointer}
.vote:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
.vote.voted{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
.vote svg{width:14px;height:14px;stroke:currentColor;stroke-width:2.2;fill:none;stroke-linecap:round;stroke-linejoin:round;transition:transform .2s}
.vote.voted svg{transform:translateY(-2px);fill:currentColor}

/* ═══ FORMS ═══ */
.form-group{margin-bottom:16px}
.form-label{display:block;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-secondary);margin-bottom:8px}
.form-label .req{color:var(--accent);margin-left:3px}
.form-control{display:block;width:100%;padding:12px 14px;background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:14px;line-height:1.4;transition:border-color .2s,background .2s}
.form-control:focus{outline:none;border-color:var(--accent);background:var(--bg-card)}
textarea.form-control{min-height:160px;resize:vertical;font-family:inherit;line-height:1.55}
select.form-control{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%23aaa097' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:12px;padding-right:36px}
.form-help{font-size:12px;color:var(--text-muted);margin-top:6px}
.form-error{font-size:12px;color:var(--danger);margin-top:6px}

/* ═══ BUTTONS ═══ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:1.5px;padding:11px 22px;border-radius:8px;font-weight:700;text-transform:uppercase;cursor:pointer;border:1px solid transparent;transition:all .25s;text-decoration:none}
.btn-primary{background:var(--accent);color:#080808}
.btn-primary:hover{background:var(--accent-light);color:#080808}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.btn-outline{background:transparent;color:var(--text-primary);border-color:var(--border-strong)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.btn-ghost{background:transparent;color:var(--text-secondary)}
.btn-ghost:hover{color:var(--accent);background:var(--accent-glow)}
.btn-danger{background:transparent;color:var(--danger);border-color:rgba(201,112,112,.3)}
.btn-danger:hover{background:rgba(201,112,112,.1);border-color:var(--danger)}

/* ═══ EMPTY / LOADING ═══ */
.skel{background:linear-gradient(90deg,var(--bg-elev) 25%,var(--bg-hover) 50%,var(--bg-elev) 75%);background-size:200% 100%;animation:skel 1.5s linear infinite;border-radius:6px;color:transparent}
@keyframes skel{0%{background-position:200% 0}100%{background-position:-200% 0}}
.empty{padding:60px 20px;text-align:center;color:var(--text-muted)}
.empty-icon{width:64px;height:64px;margin:0 auto 16px;color:var(--text-faint);opacity:.4}
.empty h3{color:var(--text-primary);margin-bottom:8px;font-size:18px;font-weight:600}
.empty p{font-size:14px;max-width:360px;margin:0 auto 20px}

/* ═══ TOAST ═══ */
.toast{position:fixed;left:50%;top:24px;transform:translate(-50%,-12px);background:var(--bg-card);border:1px solid var(--border-strong);border-radius:10px;padding:12px 18px;box-shadow:0 12px 28px -8px rgba(0,0,0,.6);font-size:13px;color:var(--text-primary);opacity:0;pointer-events:none;transition:all .3s;z-index:1000;max-width:90vw}
.toast.show{opacity:1;transform:translate(-50%,0)}
.toast.ok{border-color:var(--success);color:var(--success)}
.toast.err{border-color:var(--danger);color:var(--danger)}

/* ═══ CHIP / BADGE ═══ */
.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:1px;text-transform:uppercase;font-weight:600}
.chip-gold{background:var(--accent-glow);color:var(--accent);border:1px solid var(--border-gold)}
.chip-secondary{background:var(--bg-elev);color:var(--text-secondary);border:1px solid var(--border)}
.chip-success{background:rgba(107,190,127,.1);color:var(--success);border:1px solid rgba(107,190,127,.3)}

/* ═══ NOTIFICATIONS (bell + dropdown) ═══ */
.kg-notify-wrap{position:relative;display:inline-flex}
.kg-notify-btn{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;color:var(--text-secondary);background:transparent;border:1px solid var(--border);transition:.2s;cursor:pointer;-webkit-tap-highlight-color:transparent}
.kg-notify-btn:hover,.kg-notify-btn.open{color:var(--accent);border-color:var(--accent)}
.kg-notify-btn svg{width:16px;height:16px;stroke:currentColor;stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round}
.kg-notify-btn .kg-badge{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;border-radius:10px;background:linear-gradient(135deg,#d4a850,#b08836);color:#080808;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 5px;border:1.5px solid #080808;letter-spacing:0}
.kg-notify-pop{position:absolute;top:calc(100% + 10px);right:0;width:380px;max-height:520px;display:none;flex-direction:column;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,.6),0 0 0 1px rgba(212,168,80,.1);overflow:hidden;z-index:120}
.kg-notify-pop.open{display:flex}
.kg-notify-head{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--text-secondary)}
.kg-notify-head .kg-notify-allread{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:1.5px;color:var(--accent);background:transparent;border:1px solid var(--border-gold);padding:5px 10px;border-radius:6px;text-transform:uppercase;cursor:pointer}
.kg-notify-head .kg-notify-allread:hover{background:var(--accent-glow);color:var(--accent-light)}
.kg-notify-list{overflow-y:auto;flex:1;max-height:380px}
.kg-notify-empty{padding:32px 24px;text-align:center;color:var(--text-muted);font-size:13px}
.kg-notify-row{display:flex;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border);text-decoration:none;color:inherit;transition:background .15s;position:relative}
.kg-notify-row:last-child{border-bottom:none}
.kg-notify-row:hover{background:var(--bg-hover)}
.kg-notify-row.is-unread{background:rgba(212,168,80,.05)}
.kg-notify-row.is-unread:hover{background:rgba(212,168,80,.08)}
.kg-notify-av{position:relative;width:38px;height:38px;flex:0 0 38px;border-radius:50%;background:var(--accent);color:#080808;font-family:'JetBrains Mono',monospace;font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid var(--border-gold)}
.kg-notify-av img{width:100%;height:100%;object-fit:cover;display:block}
.kg-notify-typeicon{position:absolute;bottom:-4px;right:-4px;width:18px;height:18px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border-gold);color:var(--accent);display:flex;align-items:center;justify-content:center;overflow:visible}
.kg-notify-typeicon svg{width:10px;height:10px;stroke:currentColor;stroke-width:2.2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.kg-notify-text{flex:1;min-width:0}
.kg-notify-title{font-size:13px;color:var(--text-primary);font-weight:500;line-height:1.35;margin-bottom:2px}
.kg-notify-body{font-size:12px;color:var(--text-muted);line-height:1.4;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}
.kg-notify-time{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-faint);letter-spacing:.5px}
.kg-notify-dot{position:absolute;top:18px;right:14px;width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px rgba(212,168,80,.18)}
.kg-notify-foot{padding:12px 18px;border-top:1px solid var(--border);text-align:center}
.kg-notify-foot a{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1.5px;color:var(--accent);text-transform:uppercase}
.kg-notify-foot a:hover{color:var(--accent-light)}
@media (max-width:560px){
  .kg-notify-pop{position:fixed;top:78px;left:12px;right:12px;width:auto;max-height:calc(100vh - 100px)}
}

/* ═══ Inbox page ═══ */
.inbox-h{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin:8px 0 18px}
.inbox-h h1{font-size:24px;font-weight:700;letter-spacing:-.01em;color:var(--text-primary)}
.inbox-h .inbox-actions{display:flex;gap:10px;align-items:center}
.inbox-filter{display:flex;gap:6px;background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:4px}
.inbox-filter button{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);padding:7px 12px;border-radius:6px;cursor:pointer;background:transparent;border:none}
.inbox-filter button.active{background:var(--accent);color:#080808}
.inbox-filter button:not(.active):hover{color:var(--accent)}
.inbox-list{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;overflow:hidden}
.inbox-empty{padding:60px 24px;text-align:center;color:var(--text-muted)}
.inbox-empty svg{width:54px;height:54px;color:var(--accent);opacity:.45;margin:0 auto 12px;display:block}
.inbox-pager{display:flex;justify-content:center;align-items:center;gap:14px;margin-top:18px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1.5px;color:var(--text-muted);text-transform:uppercase}
.inbox-pager button{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1.5px;color:var(--text-secondary);background:transparent;border:1px solid var(--border-strong);padding:8px 14px;border-radius:8px;text-transform:uppercase;cursor:pointer}
.inbox-pager button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.inbox-pager button:disabled{opacity:.4;cursor:not-allowed}

/* ═══ FOOTER ═══ */
.kg-footer{margin-top:60px;padding:30px 0;border-top:1px solid var(--border);color:var(--text-muted);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1px;text-transform:uppercase}
.kg-footer .container{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.kg-footer a{color:var(--text-muted)}
.kg-footer a:hover{color:var(--accent)}

/* ═══ SCROLL-TOP BUTTON ═══ */
.kg-scroll-top{position:fixed;bottom:24px;right:18px;width:46px;height:46px;border-radius:50%;background:rgba(8,8,8,.86);border:1px solid var(--border-gold);color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transform:translateY(10px) scale(.92);transition:all .3s ease-out;z-index:95;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);-webkit-tap-highlight-color:transparent;box-shadow:0 8px 24px -8px rgba(0,0,0,.5)}
.kg-scroll-top.show{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}
.kg-scroll-top svg{width:18px;height:18px;stroke:currentColor;stroke-width:2.4;fill:none;stroke-linecap:round;stroke-linejoin:round;transition:transform .3s}
.kg-scroll-top:hover{background:var(--accent-glow);border-color:var(--accent);transform:translateY(-2px) scale(1.04)}
.kg-scroll-top:hover svg{transform:translateY(-2px)}

/* ═══ MOBILE ═══ */
@media(max-width:768px){
  .kg-nav,.kg-nav-actions .kg-lang,.kg-nav-actions .kg-btn-login,.kg-nav-actions .kg-search,.kg-nav-actions .kg-btn-dash{display:none}
  .kg-hamburger{display:flex;position:fixed;top:14px;right:12px;z-index:200;background:transparent;border:1px solid transparent;border-radius:12px;padding:11px;transition:background .3s,border-color .3s,box-shadow .3s,top .3s}
  body.header-hidden .kg-hamburger{background:rgba(8,8,8,.88);border-color:var(--border-gold);box-shadow:0 8px 28px -8px rgba(0,0,0,.55);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);top:12px}
  body.header-hidden .kg-hamburger span{background:var(--accent)}
  .kg-hamburger span{transition:all .35s cubic-bezier(.22,1,.36,1),background .3s}
  .kg-header{padding-right:64px;height:80px}
  .kg-logo img{height:56px}
  .kg-logo{gap:10px}
  .kg-logo-text .brand{font-size:15px;letter-spacing:2.5px}
  .kg-logo-text .sub{font-size:10px;letter-spacing:2px}
  .cat-grid{grid-template-columns:1fr;gap:10px}
  .topic-row{grid-template-columns:auto 1fr;gap:10px;padding:12px 14px}
  .topic-av{width:36px;height:36px;flex:0 0 36px;font-size:12px}
  .topic-right{grid-column:1 / -1;flex-direction:row;justify-content:space-between;align-items:center;gap:10px;padding-top:8px;border-top:1px dashed var(--border);margin-top:4px}
  .topic-right .topic-pills{order:1}
  .topic-right .topic-time{order:2}
  .topic-go{display:none}
  .topic-title{font-size:14.5px}
  .topic-snippet{font-size:12.5px;-webkit-line-clamp:2}
  .topic-pill{font-size:11.5px;padding:4px 9px;min-width:54px}
  .topic-pill svg{width:12px;height:12px}
  .topic-pill{font-size:9.5px;padding:2px 7px}
  .post{grid-template-columns:1fr;gap:14px}
  .post-side{flex-direction:row;width:auto;align-items:center;gap:12px}
  .post-author,.post-rep,.post-role{text-align:left}
  .post-content{font-size:14.5px}
  .kg-scroll-top{width:42px;height:42px;bottom:18px;right:14px}
}

/* ═══ QUILL DARK THEME OVERRIDES ═══ */
.kg-editor-wrap{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--bg-elev);position:relative}
.kg-editor-wrap.focused{border-color:var(--accent)}
.kg-editor-wrap .ql-toolbar.ql-snow{
  border:none;border-bottom:1px solid var(--border);
  background:var(--bg-card);padding:8px 10px;
  display:flex;flex-wrap:wrap;gap:4px 8px;
}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-formats{margin-right:8px;display:inline-flex;align-items:center;gap:2px}
.kg-editor-wrap .ql-toolbar.ql-snow button,
.kg-editor-wrap .ql-toolbar.ql-snow .ql-picker-label{
  color:var(--text-secondary);height:28px;width:28px;padding:4px;border-radius:5px;display:inline-flex;align-items:center;justify-content:center;
}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-picker{color:var(--text-secondary)}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-picker-label{width:auto;padding:0 22px 0 8px;border:1px solid transparent;border-radius:5px}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label{border-color:var(--accent)}
.kg-editor-wrap .ql-toolbar.ql-snow button:hover,
.kg-editor-wrap .ql-toolbar.ql-snow .ql-picker-label:hover{color:var(--accent);background:rgba(212,168,80,.08)}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-active,
.kg-editor-wrap .ql-toolbar.ql-snow .ql-selected,
.kg-editor-wrap .ql-toolbar.ql-snow .ql-active .ql-stroke,
.kg-editor-wrap .ql-toolbar.ql-snow .ql-active .ql-fill{color:var(--accent)}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-stroke{stroke:currentColor}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-fill{fill:currentColor}
/* Generic dropdown (header / font / size) — popover styling only when expanded */
.kg-editor-wrap .ql-toolbar.ql-snow .ql-picker-options{
  background:var(--bg-card);border:1px solid var(--border-strong);
  color:var(--text-secondary);padding:6px;border-radius:6px;
  box-shadow:0 8px 24px rgba(0,0,0,.55);
}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-picker-item:hover{color:var(--accent)}

/* ── Color & background pickers ──────────────────────────────────────── */
/* IMPORTANT: hide popover by default; only show + grid-layout when expanded.
   Without the .ql-expanded gate the palette is permanently visible. */
.kg-editor-wrap .ql-toolbar.ql-snow .ql-color-picker .ql-picker-options,
.kg-editor-wrap .ql-toolbar.ql-snow .ql-background .ql-picker-options{
  display:none;
}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-color-picker.ql-expanded .ql-picker-options,
.kg-editor-wrap .ql-toolbar.ql-snow .ql-background.ql-expanded .ql-picker-options{
  display:grid;grid-template-columns:repeat(7,20px);gap:5px;
  background:#1a1611;padding:8px;width:auto;min-width:0;
  border:1px solid var(--border-gold);border-radius:6px;
  box-shadow:0 8px 24px rgba(0,0,0,.6);
  position:absolute;z-index:50;margin-top:4px;
  top:100%;left:auto;right:auto;
}
/* Fullscreen mode: wrap has overflow:hidden which clips the dropdown.
   Override to overflow:visible — wrap is full-viewport so there's nothing to clip,
   and z-index inside is contained. The palette popup then renders normally below the toolbar. */
.kg-editor-wrap.is-fullscreen{overflow:visible}
.kg-editor-wrap.is-fullscreen .ql-toolbar{position:relative;z-index:1}
.kg-editor-wrap.is-fullscreen .ql-toolbar.ql-snow .ql-color-picker.ql-expanded .ql-picker-options,
.kg-editor-wrap.is-fullscreen .ql-toolbar.ql-snow .ql-background.ql-expanded .ql-picker-options{
  z-index:10001;
}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-color-picker .ql-picker-item,
.kg-editor-wrap .ql-toolbar.ql-snow .ql-background .ql-picker-item{
  width:20px;height:20px;margin:0;padding:0;float:none;display:block;
  border:1px solid rgba(255,255,255,.35);border-radius:3px;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.25);
  cursor:pointer;transition:transform .12s,outline-color .12s;
}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover,
.kg-editor-wrap .ql-toolbar.ql-snow .ql-background .ql-picker-item:hover{
  outline:2px solid var(--accent);outline-offset:1px;transform:scale(1.12);
}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,
.kg-editor-wrap .ql-toolbar.ql-snow .ql-background .ql-picker-item.ql-selected{
  outline:2px solid var(--accent);outline-offset:1px;
}
/* "No color" / transparent swatch — gold diagonal so it's distinguishable */
.kg-editor-wrap .ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:not([data-value]),
.kg-editor-wrap .ql-toolbar.ql-snow .ql-background .ql-picker-item:not([data-value]){
  background:linear-gradient(45deg,transparent 47%,#d4a850 47%,#d4a850 53%,transparent 53%),#fff !important;
}

/* Toolbar trigger labels for color/background — make the "A" / fill swatch readable */
.kg-editor-wrap .ql-toolbar.ql-snow .ql-color .ql-picker-label,
.kg-editor-wrap .ql-toolbar.ql-snow .ql-background .ql-picker-label{
  width:34px;padding:2px 14px 2px 4px;color:var(--text-primary);
  border:1px solid var(--border-strong);background:rgba(0,0,0,.25);
  position:relative;
}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-color .ql-picker-label::before{
  content:'A';font-family:'JetBrains Mono',monospace;font-weight:700;font-size:13px;
  display:inline-block;line-height:1;
}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-background .ql-picker-label::before{
  content:'BG';font-family:'JetBrains Mono',monospace;font-weight:700;font-size:10px;
  letter-spacing:.3px;display:inline-block;line-height:1;
}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-color .ql-picker-label svg,
.kg-editor-wrap .ql-toolbar.ql-snow .ql-background .ql-picker-label svg{display:none}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-color .ql-picker-label::after,
.kg-editor-wrap .ql-toolbar.ql-snow .ql-background .ql-picker-label::after{
  content:'';position:absolute;left:4px;right:14px;bottom:2px;height:3px;
  background:var(--accent);border-radius:1px;
}
.kg-editor-wrap .ql-toolbar.ql-snow .ql-color .ql-picker-label:hover,
.kg-editor-wrap .ql-toolbar.ql-snow .ql-background .ql-picker-label:hover{
  border-color:var(--accent);background:rgba(212,168,80,.1);
}
.kg-editor-wrap .ql-container.ql-snow{border:none;font-family:'Outfit',sans-serif;font-size:15px;color:var(--text-primary);min-height:200px}
.kg-editor-wrap .ql-editor{padding:18px 20px;min-height:200px;color:var(--text-primary)}
.kg-editor-wrap .ql-editor.ql-blank::before{color:var(--text-faint);font-style:normal;left:20px;right:20px}
.kg-editor-wrap .ql-editor h1,.kg-editor-wrap .ql-editor h2,.kg-editor-wrap .ql-editor h3{color:var(--text-primary);font-weight:700;line-height:1.25;margin:14px 0 8px}
.kg-editor-wrap .ql-editor h1{font-size:24px}
.kg-editor-wrap .ql-editor h2{font-size:20px}
.kg-editor-wrap .ql-editor h3{font-size:17px}
.kg-editor-wrap .ql-editor blockquote{border-left:3px solid var(--accent);padding:6px 14px;color:var(--text-secondary);background:rgba(212,168,80,.04);margin:10px 0}
.kg-editor-wrap .ql-editor pre.ql-syntax,.kg-editor-wrap .ql-editor pre{background:#000;color:#cec5b8;border:1px solid var(--border);border-radius:8px;padding:14px 16px;font-family:'JetBrains Mono',monospace;font-size:13px;line-height:1.5;overflow-x:auto;white-space:pre-wrap;word-break:break-word}
.kg-editor-wrap .ql-editor code{background:rgba(212,168,80,.08);color:var(--accent-light);padding:1px 6px;border-radius:4px;font-family:'JetBrains Mono',monospace;font-size:.92em}
.kg-editor-wrap .ql-editor a{color:var(--accent);text-decoration:underline;text-decoration-color:var(--accent-dark)}
.kg-editor-wrap .ql-editor a:hover{color:var(--accent-light)}
.kg-editor-wrap .ql-editor ul,.kg-editor-wrap .ql-editor ol{padding-left:1.4em;margin:8px 0}
.kg-editor-wrap .ql-editor img{border-radius:6px;margin:8px 0;max-width:100%;max-height:320px;height:auto;object-fit:contain;cursor:pointer;transition:outline-color .12s}
.kg-editor-wrap .ql-editor img:hover{outline:2px solid var(--accent);outline-offset:2px}
.kg-editor-wrap .ql-editor video{display:block;max-width:100%;max-height:340px;border-radius:6px;margin:8px 0}
.kg-editor-wrap .ql-editor kbd,.post-content kbd{font-family:'JetBrains Mono',monospace;font-size:.88em;background:linear-gradient(180deg,#222,#111);color:var(--accent-light);border:1px solid var(--border-strong);border-bottom-width:2px;border-radius:4px;padding:1px 6px;box-shadow:inset 0 -1px 0 rgba(0,0,0,.4);white-space:nowrap}
.kg-editor-wrap .ql-tooltip{background:var(--bg-card);border:1px solid var(--border-strong);color:var(--text-primary);box-shadow:0 8px 24px rgba(0,0,0,.5)}
.kg-editor-wrap .ql-tooltip input[type=text]{background:var(--bg);border:1px solid var(--border);color:var(--text-primary);padding:6px 10px;border-radius:5px}
.kg-editor-wrap .ql-tooltip a.ql-action,.kg-editor-wrap .ql-tooltip a.ql-remove{color:var(--accent)}
.kg-editor-wrap .ql-snow .ql-tooltip[data-mode=link]::before{color:var(--text-muted);content:"Enter link URL:"}
.kg-editor-wrap .ql-snow .ql-tooltip[data-mode=video]::before{color:var(--text-muted);content:"Enter YouTube/Vimeo URL:"}
.kg-editor-wrap .ql-snow .ql-tooltip[data-mode=formula]::before{color:var(--text-muted);content:"Enter formula:"}
.kg-editor-wrap .ql-snow.ql-toolbar button.ql-image,
.kg-editor-wrap .ql-snow.ql-toolbar button.ql-video{color:var(--text-secondary)}
/* code-block syntax tweak */
.kg-editor-wrap .ql-editor .ql-code-block-container{background:#000;border:1px solid var(--border);border-radius:8px;padding:0;overflow:hidden}
.kg-editor-wrap .ql-editor .ql-code-block{font-family:'JetBrains Mono',monospace;font-size:13px;color:#cec5b8;padding:6px 16px;line-height:1.5}

/* Fullscreen mode */
.kg-editor-wrap.is-fullscreen{position:fixed;inset:0;width:100vw;height:100vh;height:100dvh;z-index:9999;border:none;border-radius:0;background:var(--bg);display:flex;flex-direction:column}
.kg-editor-wrap.is-fullscreen .ql-toolbar{flex:0 0 auto;width:100%}
.kg-editor-wrap.is-fullscreen .ql-container.ql-snow{flex:1 1 0;min-height:0;overflow-y:auto;background:var(--bg);width:100%;max-width:980px;margin:0 auto;border:none}
.kg-editor-wrap.is-fullscreen .ql-editor{padding:32px 40px;text-align:left;min-height:100%;width:auto}
.kg-editor-wrap.is-fullscreen .ql-editor.ql-blank::before{top:32px;left:40px;right:40px;font-size:15px}
.kg-editor-wrap.is-fullscreen .ql-editor img{max-height:540px}
.kg-editor-wrap.is-fullscreen .ql-editor video{max-height:560px}
body.kg-editor-fs-on{overflow:hidden}
@media (max-width:640px){.kg-editor-wrap.is-fullscreen .ql-editor{padding:18px 14px}}

/* Drop overlay */
.kg-drop-overlay{position:absolute;inset:0;display:none;align-items:center;justify-content:center;flex-direction:column;gap:12px;background:rgba(8,8,8,.92);border:2px dashed var(--accent);border-radius:10px;color:var(--accent);font-size:18px;font-weight:600;letter-spacing:.5px;z-index:50;pointer-events:none;text-align:center;padding:20px}
.kg-editor-wrap.is-dragover .kg-drop-overlay{display:flex}
.kg-drop-overlay svg{width:46px;height:46px;opacity:.85}
.kg-drop-overlay .kg-drop-hint{font-size:13px;font-weight:400;color:var(--text-secondary);letter-spacing:0}

/* Image: alignment, selection, uploading state */
.kg-editor-wrap .ql-editor img.kg-img-left,.post-content img.kg-img-left{float:left;margin:8px 16px 8px 0;max-width:60%}
.kg-editor-wrap .ql-editor img.kg-img-center,.post-content img.kg-img-center{display:block;float:none;margin:12px auto}
.kg-editor-wrap .ql-editor img.kg-img-right,.post-content img.kg-img-right{float:right;margin:8px 0 8px 16px;max-width:60%}
.kg-editor-wrap .ql-editor img.kg-img-selected{outline:3px solid var(--accent);outline-offset:2px}
.kg-editor-wrap .ql-editor img[data-uploading]{opacity:.55;animation:kg-img-pulse 1.4s ease-in-out infinite;pointer-events:none}
@keyframes kg-img-pulse{0%,100%{opacity:.55}50%{opacity:.85}}
/* Float clearing in editor and rendered posts */
.kg-editor-wrap .ql-editor p,.kg-editor-wrap .ql-editor blockquote,.post-content p,.post-content blockquote,.post-content ul,.post-content ol{overflow:auto}

/* Image floating toolbar (over selected img) */
.kg-img-toolbar{position:fixed;display:flex;align-items:center;gap:2px;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:8px;padding:4px;box-shadow:0 8px 24px rgba(0,0,0,.55);z-index:10000;font-family:'Outfit',sans-serif}
.kg-img-toolbar button{background:transparent;border:none;color:var(--text-secondary);width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:5px;cursor:pointer;padding:0;transition:background .12s,color .12s}
.kg-img-toolbar button:hover{background:rgba(212,168,80,.15);color:var(--accent)}
.kg-img-toolbar button[data-act="delete"]:hover{background:rgba(220,80,60,.18);color:#e57b6e}
.kg-img-toolbar svg{width:18px;height:18px}
.kg-img-tb-sep{display:inline-block;width:1px;height:22px;background:var(--border);margin:0 4px}

/* Resize overlay + corner handles */
.kg-img-resizer{position:fixed;pointer-events:none;z-index:9999;outline:2px dashed var(--accent);outline-offset:0}
.kg-img-handle{position:absolute;width:14px;height:14px;background:var(--accent);border:2px solid #000;border-radius:3px;pointer-events:auto;box-shadow:0 0 0 1px rgba(212,168,80,.5)}
.kg-img-handle-nw{top:-7px;left:-7px;cursor:nwse-resize}
.kg-img-handle-ne{top:-7px;right:-7px;cursor:nesw-resize}
.kg-img-handle-sw{bottom:-7px;left:-7px;cursor:nesw-resize}
.kg-img-handle-se{bottom:-7px;right:-7px;cursor:nwse-resize}

/* Mobile: hide resize handles, normalise alignment to full-width */
@media (max-width:640px){
  .kg-img-resizer{display:none}
  .kg-editor-wrap .ql-editor img.kg-img-left,.kg-editor-wrap .ql-editor img.kg-img-right,.kg-editor-wrap .ql-editor img.kg-img-center,
  .post-content img.kg-img-left,.post-content img.kg-img-right,.post-content img.kg-img-center{float:none;display:block;margin:8px auto;max-width:100%}
}

/* ═══ RENDERED POST CONTENT (re-use editor styles) ═══ */
.post-content{color:var(--text-primary);line-height:1.65}
.post-content h1,.post-content h2,.post-content h3{color:var(--text-primary);margin:16px 0 8px;font-weight:700;line-height:1.2}
.post-content h1{font-size:24px}.post-content h2{font-size:20px}.post-content h3{font-size:17px}
.post-content p{margin:8px 0}
.post-content ul,.post-content ol{padding-left:1.4em;margin:8px 0}
.post-content blockquote{border-left:3px solid var(--accent);padding:6px 14px;color:var(--text-secondary);background:rgba(212,168,80,.04);margin:10px 0;border-radius:0 6px 6px 0}
.post-content pre,.post-content .ql-syntax,.post-content .ql-code-block-container{background:#000;color:#cec5b8;border:1px solid var(--border);border-radius:8px;padding:14px 16px;font-family:'JetBrains Mono',monospace;font-size:13px;line-height:1.55;overflow-x:auto;white-space:pre-wrap;word-break:break-word;margin:10px 0}
.post-content code{background:rgba(212,168,80,.08);color:var(--accent-light);padding:1px 6px;border-radius:4px;font-family:'JetBrains Mono',monospace;font-size:.92em}
.post-content pre code{background:none;color:inherit;padding:0;font-size:inherit}
.post-content a{color:var(--accent);text-decoration:underline;text-decoration-color:var(--accent-dark)}
.post-content a:hover{color:var(--accent-light)}
.post-content img{border-radius:6px;margin:8px 0;max-width:100%;height:auto;display:block}
.post-content iframe{max-width:100%;border-radius:8px;border:1px solid var(--border);margin:10px 0}
.post-content video{max-width:100%;border-radius:8px;margin:10px 0}
.post-content table{border-collapse:collapse;margin:10px 0;width:auto}
.post-content th,.post-content td{border:1px solid var(--border-strong);padding:6px 12px}
.post-content th{background:var(--bg-card);color:var(--accent);font-weight:600}

/* ═══ Custom scrollbars (dark + gold accent) ═══════════════════════════ */
/* Firefox */
html{scrollbar-width:thin;scrollbar-color:rgba(212,168,80,.32) rgba(255,255,255,.025)}
*{scrollbar-width:thin;scrollbar-color:rgba(212,168,80,.32) rgba(255,255,255,.025)}
/* Webkit (Chrome / Edge / Safari) */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:rgba(255,255,255,.025);border-radius:6px}
::-webkit-scrollbar-thumb{background:rgba(212,168,80,.32);border-radius:6px;border:2px solid transparent;background-clip:content-box;transition:background .15s}
::-webkit-scrollbar-thumb:hover{background:rgba(212,168,80,.6);background-clip:content-box}
::-webkit-scrollbar-thumb:active{background:var(--accent);background-clip:content-box}
::-webkit-scrollbar-corner{background:transparent}
/* Compact variant for tight surfaces (modal bodies, editor, dropdowns) */
.modal-body::-webkit-scrollbar,.ql-container::-webkit-scrollbar,.kg-notify-dropdown::-webkit-scrollbar,textarea::-webkit-scrollbar,select::-webkit-scrollbar,.kg-section-tabs::-webkit-scrollbar,.subtabs::-webkit-scrollbar{width:8px;height:8px}
.modal-body,.ql-container,.kg-notify-dropdown,textarea,select{scrollbar-width:thin}
