/*
 * Whale Theme - 跳舞的鲸鱼小站
 * 暗色主题样式表
 */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}:root{--bg:#11111b;--bg-card:#181825;--bg-hover:#1e1e30;--text:#e4e4ec;--text-dim:#a0a0b8;--accent:#00d4aa;--accent-glow:rgba(0,212,170,0.2);--purple:#7c5cfc;--border:#282840;--radius:12px;--radius-sm:8px}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}.container{max-width:1100px;margin:0 auto;padding:0 24px}

/* Header */
header{padding:20px 0;border-bottom:1px solid var(--border);margin-bottom:32px}
header .container{display:flex;align-items:center;justify-content:space-between}
.logo{font-size:22px;font-weight:700;color:var(--text);text-decoration:none;letter-spacing:-0.5px}
.logo:hover{color:var(--text)}.logo span{color:var(--accent)}
nav{display:flex;gap:6px;align-items:center}
nav a{color:var(--text-dim);text-decoration:none;padding:8px 16px;border-radius:var(--radius-sm);font-size:14px;transition:all .2s}
nav a:hover,nav a.active{color:var(--text);background:var(--bg-hover)}
nav a.current{color:var(--text);background:var(--bg-hover)}

/* Section */
.section-title{font-size:13px;text-transform:uppercase;letter-spacing:3px;color:var(--text-dim);margin-bottom:24px;font-weight:600}
.section-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.section-header .section-title{margin-bottom:0}
.section-actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.section-actions .add-btn{margin-left:0}
.view-all-btn{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--text-dim);cursor:pointer;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 12px;font-family:inherit;transition:all .2s}
.view-all-btn:hover{color:var(--text);border-color:#3a3a55;background:var(--bg-hover)}
.visitor-stats{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:0 0 18px}
.visitor-stat{display:inline-flex;align-items:center;gap:7px;padding:8px 13px;border:1px solid var(--border);border-radius:999px;background:var(--bg-card);color:var(--text-dim);font-size:12px}
.visitor-stat.online-stat{background:linear-gradient(135deg,rgba(0,212,170,.12),rgba(124,92,252,.08))}
.visitor-stat strong{color:var(--accent);font-size:15px;line-height:1}
.online-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(0,212,170,.12),0 0 16px rgba(0,212,170,.45)}
.home-layout{display:block}
.home-main{min-width:0}
.home-snippet-sidebar{display:none}
@media(min-width:1180px){
  .home-layout{max-width:1360px;display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:24px;align-items:start}
  .home-snippet-sidebar{display:block;position:sticky;top:24px}
  .home-sidebar-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:0 12px 32px rgba(0,0,0,.16)}
  .home-sidebar-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);font-weight:700}
  .home-sidebar-head a{letter-spacing:0;text-transform:none;color:var(--accent);text-decoration:none;font-size:12px;font-weight:500}
  .home-sidebar-list{display:flex;flex-direction:column;gap:8px;max-height:calc(100vh - 150px);overflow:auto;padding-right:2px}
  .home-sidebar-snippet{position:relative;padding:10px 34px 10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);cursor:pointer;transition:all .2s}
  .home-sidebar-snippet:hover{background:var(--bg-hover);border-color:#3a3a55}
  .sidebar-snippet-title{display:flex;align-items:center;gap:6px;min-width:0;padding-right:48px;font-size:13px;font-weight:600;color:var(--text)}
  .sidebar-snippet-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .sidebar-snippet-title .vis-badge{flex:0 0 auto;margin-left:0}
  .sidebar-snippet-content{font-size:11px;color:var(--text-dim);line-height:1.5;margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .home-sidebar-snippet .scopy{font-size:10px;color:var(--accent);margin-top:6px;opacity:0;transition:opacity .2s}
  .home-sidebar-snippet:hover .scopy{opacity:1}
  .sidebar-edit-btn{position:absolute;top:8px;right:8px;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;border:1px solid var(--border);background:var(--bg-hover);color:var(--text-dim);font-size:11px;cursor:pointer;transition:all .2s;font-family:inherit;opacity:0;z-index:2}
  .home-sidebar-snippet .pin-btn{position:absolute;top:8px;right:34px;width:22px;height:22px;font-size:11px;opacity:0}
  .home-sidebar-snippet:hover .sidebar-edit-btn{opacity:1}
  .home-sidebar-snippet:hover .pin-btn{opacity:1}
  .sidebar-edit-btn:hover{color:var(--accent);border-color:var(--accent);background:rgba(0,212,170,.05)}
  .home-sidebar-empty{font-size:12px;color:var(--text-dim);padding:12px}
}

/* Hero */
.hero{text-align:center;padding:60px 0 40px}
.hero h1{font-size:42px;font-weight:800;margin-bottom:12px;background:linear-gradient(135deg,#e4e4ec 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero p{color:var(--text-dim);font-size:17px;max-width:500px;margin:0 auto 32px}
.glow-line{width:60px;height:3px;background:var(--accent);border-radius:3px;margin:0 auto 16px;box-shadow:0 0 20px var(--accent-glow)}

/* Nav Grid */
.nav-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(145px,1fr));gap:16px;margin-bottom:64px}
.nav-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px 20px;text-align:center;cursor:pointer;transition:all .25s;text-decoration:none;display:block;position:relative;overflow:hidden;color:var(--text)}
.nav-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;opacity:0;transition:opacity .25s}
.nav-card:hover::before{opacity:1}
.nav-card:nth-child(1)::before{background:var(--accent)}
.nav-card:nth-child(2)::before{background:var(--purple)}
.nav-card:nth-child(3)::before{background:#f59e0b}
.nav-card:nth-child(4)::before{background:#ef4444}
.nav-card:nth-child(5)::before{background:#ff0000}
.nav-card:nth-child(6)::before{background:#22c55e}
.nav-card:hover{background:var(--bg-hover);transform:translateY(-4px);border-color:#3a3a55;box-shadow:0 12px 40px rgba(0,0,0,.4);color:var(--text)}
.nav-card .icon{font-size:36px;margin-bottom:12px;display:block}
.nav-card h3{font-size:16px;margin-bottom:4px}
.nav-card p{font-size:13px;color:var(--text-dim)}
.nav-card .count{display:inline-block;margin-top:10px;font-size:12px;padding:2px 10px;border-radius:20px;background:rgba(255,255,255,.06);color:var(--text-dim)}

/* Content Grid */
.content-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:64px}
.post-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:all .25s;cursor:pointer}
.post-card{position:relative}
.post-card:hover{background:var(--bg-hover);border-color:#3a3a55;transform:translateY(-2px)}
.post-card .tag{display:inline-block;font-size:11px;padding:2px 8px;border-radius:4px;background:rgba(0,212,170,.12);color:var(--accent);margin-bottom:10px;font-weight:500}
.post-card h4{font-size:16px;margin-bottom:6px;line-height:1.4}
.post-card .excerpt{font-size:13px;color:var(--text-dim);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.post-card .meta{display:flex;gap:16px;margin-top:12px;font-size:12px;color:var(--text-dim)}

/* Article Detail */
.article{max-width:720px;margin:0 auto;padding:24px 0 48px}
.article .back{display:inline-flex;align-items:center;gap:6px;color:var(--text-dim);font-size:13px;text-decoration:none;margin-bottom:24px;cursor:pointer}
.article .back:hover{color:var(--accent)}
.article-labels{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.article .cat{display:inline-block;font-size:12px;padding:3px 10px;border-radius:4px;background:rgba(0,212,170,.12);color:var(--accent);font-weight:500;margin-bottom:12px}
.article-labels .cat{margin-bottom:0}
.article h1{font-size:30px;font-weight:800;line-height:1.3;margin-bottom:12px}
.article .meta{font-size:13px;color:var(--text-dim);display:flex;gap:16px;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.article-edit-link{color:var(--accent);text-decoration:none;border:1px solid rgba(0,212,170,.35);border-radius:var(--radius-sm);padding:2px 10px;font-size:12px}
.article-edit-link:hover{background:rgba(0,212,170,.06);color:var(--accent)}
.article-delete-form{display:inline-flex;margin:0}
.article-delete-link{color:#ef4444;text-decoration:none;border:1px solid rgba(239,68,68,.35);border-radius:var(--radius-sm);padding:2px 10px;font-size:12px;background:transparent;cursor:pointer;font-family:inherit;line-height:inherit}
.article-delete-link:hover{background:rgba(239,68,68,.06);color:#ef4444}
.article .featured-img{width:100%;height:320px;background:var(--bg-hover);border-radius:var(--radius);margin-bottom:32px;display:flex;align-items:center;justify-content:center;font-size:48px;color:var(--text-dim);border:1px solid var(--border);overflow:hidden}
.article .featured-img img{width:100%;height:100%;object-fit:cover}
.article .content{font-size:15px;line-height:1.9;color:var(--text-dim)}
.article .content p{margin-bottom:20px}
.article .content h2{font-size:22px;font-weight:700;color:var(--text);margin:36px 0 16px}
.article .content h3{font-size:18px;font-weight:600;color:var(--text);margin:28px 0 12px}
.article .content ul,.article .content ol{margin:0 0 20px 20px}
.article .content li{margin-bottom:6px}
.article .content code{font-size:13px;padding:2px 6px;border-radius:4px;background:var(--bg-hover);color:var(--accent);font-family:"SF Mono","Cascadia Code","Consolas",monospace}
.article .content pre{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:20px;margin-bottom:24px;overflow-x:auto}
.article .content pre code{background:none;color:var(--text-dim);padding:0;font-size:13px;line-height:1.6}
.article .content blockquote{border-left:3px solid var(--accent);padding:12px 20px;margin-bottom:24px;background:rgba(0,212,170,.04);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-dim)}
.article .content blockquote strong{color:var(--text)}
.article .content table{width:100%;table-layout:fixed;border-collapse:collapse;margin:0 0 24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.article .content th,.article .content td{border:1px solid var(--border);padding:9px 12px;vertical-align:top;min-width:80px}
.article .content th{background:var(--bg-hover);color:var(--text);font-weight:600;text-align:left}
.article .content td{color:var(--text-dim)}
.article .content th p,.article .content td p{margin:0}
.article .content .tableWrapper{overflow-x:auto;margin-bottom:24px}
.article .tag-list{display:flex;gap:6px;flex-wrap:wrap;border-top:1px solid var(--border);padding-top:24px;margin-top:32px}
.article .tag-list span{font-size:12px;padding:4px 10px;border-radius:20px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-dim)}
.article-attachments{margin-top:30px;padding:18px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card)}
.article-attachments h3{font-size:15px;margin-bottom:12px;color:var(--text)}
.article-attachment-list{display:flex;flex-direction:column;gap:8px}
.article-attachment{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);text-decoration:none;transition:all .2s}
.article-attachment:hover{border-color:var(--accent);background:rgba(0,212,170,.05);color:var(--text)}
.article-attachment-icon{font-size:18px}
.article-attachment-main{min-width:0}
.article-attachment-main strong{display:block;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.article-attachment-main em{display:block;font-style:normal;font-size:11px;color:var(--text-dim);margin-top:2px}
.article-nav{display:flex;justify-content:space-between;margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}
.article-nav a{color:var(--text-dim);text-decoration:none;font-size:13px;max-width:45%}
.article-nav a:hover{color:var(--accent)}.article-nav .next{text-align:right}

/* Sites Grid */
.sites-section{margin-bottom:48px}.sites-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:32px}
.site-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;text-decoration:none;color:var(--text);transition:all .2s;display:flex;align-items:center;gap:12px;position:relative}
.site-card:hover{background:var(--bg-hover);border-color:#3a3a55;transform:translateY(-2px);color:var(--text)}
.site-card .favicon{width:28px;height:28px;border-radius:6px;background:var(--bg-hover);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:16px}
.site-card .sinfo{min-width:0;padding-right:50px}
.site-card .sinfo h4{font-size:13px;font-weight:500}
.site-card .sinfo p{font-size:11px;color:var(--text-dim)}
.card-edit-btn{position:absolute;top:8px;right:8px;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;border:1px solid var(--border);background:var(--bg-hover);color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .2s;font-family:inherit;opacity:0;z-index:2}
.pin-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;border:1px solid var(--border);background:var(--bg-hover);color:var(--text-dim);font-size:13px;line-height:1;cursor:pointer;transition:all .2s;font-family:inherit;z-index:2}
.pin-btn:hover,.pin-btn.active{color:#f59e0b;border-color:#f59e0b;background:rgba(245,158,11,.08)}
.site-card .pin-btn{position:absolute;top:8px;right:36px;opacity:0}
.site-card:hover .pin-btn{opacity:1}
.post-card .pin-btn,.post-row .pin-btn{position:absolute;top:12px;right:12px;opacity:0}
.post-card:hover .pin-btn,.post-row:hover .pin-btn{opacity:1}
.article .meta .pin-btn{width:auto;height:24px;padding:2px 10px;border-radius:var(--radius-sm);opacity:1}
.site-card:hover .card-edit-btn{opacity:1}
.card-edit-btn:hover{color:var(--accent);border-color:var(--accent);background:rgba(0,212,170,.05)}

/* Snippets */
.snippets-section{margin-bottom:48px}
.snippets-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.snippets-grid-full{margin-bottom:32px}
.snippet-search,.content-search{display:flex;align-items:center;gap:10px;margin-bottom:20px}
.snippet-search input,.content-search input{flex:1;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}
.snippet-search input:focus,.content-search input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.snippet-search button,.content-search button{padding:12px 22px;background:var(--accent);color:#000;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap}
.snippet-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 18px;cursor:pointer;transition:all .2s;position:relative}
.snippet-card:hover{background:var(--bg-hover);border-color:#3a3a55}
.snippet-card .scontent{font-size:13px;color:var(--text-dim);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-family:"SF Mono","Cascadia Code","Consolas",monospace;padding-right:84px}
.snippet-card .slabel{position:absolute;bottom:14px;right:18px;font-size:10px;color:var(--text-dim);white-space:nowrap;background:linear-gradient(to left,var(--bg-card),transparent 8px);padding-left:10px}
.snippet-card .scopy{font-size:11px;color:var(--text-dim);margin-top:8px;opacity:0;transition:opacity .2s}
.snippet-card:hover .scopy{opacity:1}
.snippet-card-list{min-height:120px}
.snippet-card-list .scontent{-webkit-line-clamp:4;padding-right:34px;padding-bottom:24px}
.snippet-del-btn{position:absolute;top:10px;right:10px;display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;border:1px solid var(--border);background:var(--bg-hover);color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .2s;font-family:inherit;opacity:0;z-index:2}
.snippet-edit-btn{position:absolute;top:10px;right:42px;display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;border:1px solid var(--border);background:var(--bg-hover);color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .2s;font-family:inherit;opacity:0;z-index:2}
.snippet-card .pin-btn{position:absolute;top:10px;right:74px;width:26px;height:26px;opacity:0}
.snippet-card:hover .snippet-del-btn{opacity:1}
.snippet-card:hover .snippet-edit-btn{opacity:1}
.snippet-card:hover .pin-btn{opacity:1}
.snippet-del-btn:hover{color:#ef4444;border-color:#ef4444;background:rgba(239,68,68,.05)}
.snippet-edit-btn:hover{color:var(--accent);border-color:var(--accent);background:rgba(0,212,170,.05)}
.snippet-edit-textarea{width:100%;min-height:160px;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:13px;font-family:inherit;outline:none;resize:vertical;line-height:1.5}
.snippet-edit-textarea:focus{border-color:var(--accent)}

/* Todos */
.todo-page{max-width:860px;margin:0 auto 64px}
.todo-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}
.todo-stats{display:flex;gap:8px;flex-wrap:wrap}
.todo-stats span{display:inline-flex;align-items:center;gap:5px;padding:6px 10px;border:1px solid var(--border);border-radius:999px;background:var(--bg-card);font-size:12px;color:var(--text-dim)}
.todo-stats strong{color:var(--accent)}
.todo-compose{display:grid;grid-template-columns:1fr auto;gap:12px;margin:22px 0 14px;padding:14px;background:linear-gradient(135deg,rgba(0,212,170,.08),rgba(124,92,252,.06));border:1px solid var(--border);border-radius:var(--radius)}
.todo-compose-main{display:flex;flex-direction:column;gap:8px}
.todo-compose input,.todo-compose textarea{width:100%;padding:12px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}
.todo-compose textarea{min-height:72px;resize:vertical;line-height:1.5}
.todo-compose input:focus,.todo-compose textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.todo-compose button{align-self:start;padding:12px 22px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#000;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit}
.todo-compose button:hover{opacity:.86}
.todo-term-select{display:flex;gap:8px;flex-wrap:wrap}
.todo-term-select label{position:relative;cursor:pointer}
.todo-term-select input{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px;padding:0;margin:0}
.todo-term-select span{display:inline-flex;align-items:center;padding:6px 11px;border:1px solid var(--border);border-radius:999px;background:var(--bg);color:var(--text-dim);font-size:12px;transition:all .2s}
.todo-term-select input:checked+span{border-color:var(--accent);background:rgba(0,212,170,.12);color:var(--accent);font-weight:700}
.todo-toolbar{display:flex;align-items:center;gap:8px;margin:0 0 16px;flex-wrap:wrap}
.todo-filter{padding:7px 13px;border:1px solid var(--border);border-radius:999px;background:var(--bg-card);color:var(--text-dim);font-size:13px;cursor:pointer;font-family:inherit;transition:all .2s}
.todo-filter:hover{border-color:#3a3a55;color:var(--text)}
.todo-filter.active{background:var(--accent);border-color:var(--accent);color:#000;font-weight:700}
.todo-sort-hint{margin-left:auto;font-size:12px;color:var(--text-dim)}
.todo-list{display:flex;flex-direction:column;gap:6px}
.todo-item{display:grid;grid-template-columns:22px 22px minmax(0,1fr) auto;gap:8px;align-items:center;padding:7px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);transition:background .2s,border-color .2s,transform .2s,opacity .2s}
.todo-item:hover{background:var(--bg-hover);border-color:#3a3a55}
.todo-item.dragging{opacity:.5;transform:scale(.99)}
.todo-hidden{display:none}
.todo-drag{width:22px;height:24px;border:none;background:transparent;color:var(--text-dim);font-size:14px;line-height:1;cursor:grab;font-family:inherit}
.todo-drag:active{cursor:grabbing}
.todo-check{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);background:transparent;cursor:pointer;transition:all .2s}
.todo-check:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.todo-item.done .todo-check{background:var(--accent);border-color:var(--accent);box-shadow:inset 0 0 0 3px var(--bg-card)}
.todo-body{min-width:0;display:grid;grid-template-columns:minmax(120px,1.25fr) auto minmax(80px,1fr) auto;gap:8px;align-items:center}
.todo-body h3{font-size:13px;line-height:1.3;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.todo-term-badge{display:inline-flex;align-items:center;height:18px;padding:0 7px;border-radius:999px;font-size:10px;font-weight:700;border:1px solid transparent;white-space:nowrap}
.todo-term-badge.short{background:rgba(0,212,170,.12);border-color:rgba(0,212,170,.28);color:var(--accent)}
.todo-term-badge.medium{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.28);color:#f59e0b}
.todo-term-badge.long{background:rgba(124,92,252,.14);border-color:rgba(124,92,252,.32);color:#a996ff}
.todo-body p{font-size:12px;color:var(--text-dim);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}
.todo-meta{font-size:11px;color:#686880;white-space:nowrap;text-align:right}
.todo-item.done .todo-body h3,.todo-item.done .todo-body p{text-decoration:line-through;color:#777790}
.todo-actions{display:flex;gap:6px;opacity:0;transition:opacity .2s}
.todo-item:hover .todo-actions{opacity:1}
.todo-actions button{padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-dim);font-size:11px;cursor:pointer;font-family:inherit;transition:all .2s}
.todo-actions button:hover{color:var(--accent);border-color:var(--accent)}
.todo-actions button.danger:hover{color:#ef4444;border-color:#ef4444;background:rgba(239,68,68,.05)}
.todo-empty{padding:34px 20px;text-align:center;border:1px dashed var(--border);border-radius:var(--radius);color:var(--text-dim);background:rgba(255,255,255,.02)}
.todo-edit-textarea{width:100%;min-height:130px;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:13px;font-family:inherit;outline:none;resize:vertical;line-height:1.5}
.todo-edit-textarea:focus{border-color:var(--accent)}
.company-assets-btn{margin-left:4px}
.company-assets-modal{width:min(1900px,99vw);max-height:96vh;overflow:hidden;display:flex;flex-direction:column;padding:28px 30px 26px}
.company-assets-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}
.company-assets-head .sub{margin-bottom:0}
.company-asset-add{padding:8px 14px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#000;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap}
.company-asset-add:hover{opacity:.86}
.company-assets-table-wrap{overflow:auto;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg)}
.company-assets-table{width:100%;border-collapse:collapse;font-size:12px;min-width:1680px}
.company-assets-table th,.company-assets-table td{padding:9px 10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top;white-space:pre-line}
.company-assets-table th{position:sticky;top:0;background:var(--bg-hover);color:var(--text);z-index:1}
.company-assets-table td{color:var(--text-dim)}
.company-assets-table tr:hover td{background:rgba(255,255,255,.025);color:var(--text)}
.asset-due-soon{color:#f59e0b!important;font-weight:700}
.company-asset-row-actions{display:flex;gap:6px;white-space:nowrap}
.company-asset-edit{padding:5px 9px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-hover);color:var(--text-dim);font-size:12px;cursor:pointer;font-family:inherit;transition:all .2s}
.company-asset-edit:hover{color:var(--accent);border-color:var(--accent);background:rgba(0,212,170,.06)}
.company-asset-delete{padding:5px 9px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-hover);color:var(--text-dim);font-size:12px;cursor:pointer;font-family:inherit;transition:all .2s}
.company-asset-delete:hover{color:#ef4444;border-color:#ef4444;background:rgba(239,68,68,.05)}
.company-asset-edit-modal{width:min(1900px,98vw);max-height:94vh;overflow:auto}
.company-asset-edit-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.company-asset-edit-grid .field{margin-bottom:0}
.company-asset-edit-grid textarea{min-height:44px;resize:vertical;line-height:1.45}
.company-asset-edit-grid .field:first-child,.company-asset-edit-grid .field:nth-child(5),.company-asset-edit-grid .field:nth-child(10){grid-column:span 2}
.company-due-modal{width:min(620px,92vw)}
.company-due-list{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.company-due-row{display:flex;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg)}
.company-due-row strong{display:block;font-size:14px;margin-bottom:3px}
.company-due-row span{display:block;font-size:12px;color:var(--text-dim)}
.company-due-row.overdue{border-color:rgba(239,68,68,.45);background:rgba(239,68,68,.06)}
.company-due-row.soon{border-color:rgba(245,158,11,.4);background:rgba(245,158,11,.06)}
.company-due-date{text-align:right;font-size:13px;color:var(--text);white-space:nowrap}
.company-due-date em{display:block;font-style:normal;color:#f59e0b;font-size:12px;margin-top:3px}
.quick-bar{display:flex;gap:10px;margin-bottom:32px;align-items:center}
.quick-bar input{flex:1;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}
.quick-bar input::placeholder{color:#5a5a70}
.quick-bar input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.quick-bar button{padding:14px 28px;background:var(--accent);color:#000;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:opacity .2s;line-height:1}
.quick-bar button:hover{opacity:.85}
.quick-upload-split{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:0 0 12px;align-items:stretch}
.quick-upload-panel{display:flex;gap:10px;min-width:0}
.quick-upload-panel button{padding:14px 22px;color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:opacity .2s;line-height:1;font-family:inherit}
.quick-upload-panel button:hover{opacity:.85}
.quick-upload-split .file-picker{min-width:0}
.quick-upload-split .image-paste-box{margin:0;min-width:0}

/* Games */
.games-section{margin-bottom:64px}.games-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.game-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .25s;cursor:pointer;color:var(--text);text-decoration:none;display:block}
.game-card:hover{transform:translateY(-4px);border-color:var(--purple);box-shadow:0 12px 40px rgba(124,92,252,.15)}
.game-card .thumb{height:140px;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;font-size:32px;color:var(--text-dim);position:relative}
.game-card .thumb .play-badge{position:absolute;width:40px;height:40px;border-radius:50%;background:rgba(0,0,0,.7);border:2px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:18px;opacity:0;transition:opacity .25s;color:#fff}
.game-card:hover .play-badge{opacity:1}
.game-card .info{padding:14px 16px 16px}
.game-card .info h4{font-size:14px;margin-bottom:2px}
.game-card .info p{font-size:12px;color:var(--text-dim)}
.game-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.game-guest-badge{display:inline-flex;align-items:center;font-size:10px;padding:1px 8px;border-radius:10px;font-weight:500;margin-left:4px;background:rgba(0,212,170,.12);color:var(--accent)}
.game-guest-badge.closed{background:rgba(245,158,11,.12);color:#f59e0b}
.game-guest-btn{display:inline-flex;align-items:center;justify-content:center;height:26px;padding:0 8px;border-radius:999px;border:1px solid var(--border);background:transparent;color:var(--text-dim);font-size:11px;cursor:pointer;transition:all .2s;font-family:inherit;white-space:nowrap;opacity:0}
.game-card:hover .game-guest-btn{opacity:1}
.game-guest-btn:hover,.game-guest-btn.open:hover{color:var(--accent);border-color:var(--accent);background:rgba(0,212,170,.05)}
.game-guest-btn.closed:hover{color:#f59e0b;border-color:#f59e0b;background:rgba(245,158,11,.08)}
.game-del-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;border:1px solid var(--border);background:transparent;color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .2s;font-family:inherit;flex-shrink:0;opacity:0}
.game-card:hover .game-del-btn{opacity:1}
.game-del-btn:hover{color:#ef4444;border-color:#ef4444;background:rgba(239,68,68,.05)}
@media(max-width:768px){.game-del-btn,.game-guest-btn{opacity:1}}

/* Tools */
.tools-section{margin-bottom:64px}
.tool-row{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px 20px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;transition:all .2s;cursor:pointer;color:var(--text);text-decoration:none}
.tool-row:hover{background:var(--bg-hover);border-color:#3a3a55;color:var(--text)}
.tool-row .tl{display:flex;align-items:center;gap:14px}
.tool-row .tl .icon{font-size:22px}
.tool-row .tl .name{font-size:14px;font-weight:500}
.tool-row .tl .desc{font-size:13px;color:var(--text-dim)}
.tool-row .badge{font-size:11px;padding:3px 10px;border-radius:20px;background:rgba(0,212,170,.1);color:var(--accent)}

.tools-dashboard{margin-bottom:28px}
.tool-launcher{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.tool-chip{padding:8px 14px;border:1px solid var(--border);border-radius:999px;background:var(--bg-card);color:var(--text-dim);font-size:13px;cursor:pointer;font-family:inherit;transition:all .2s}
.tool-chip-link{text-decoration:none;display:inline-flex;align-items:center}
.tool-chip:hover{border-color:#3a3a55;color:var(--text)}
.tool-chip.active{background:var(--accent);border-color:var(--accent);color:#000;font-weight:700}
.tool-panel{display:none;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 18px 16px;margin-bottom:12px}
.tool-panel.active{display:block}
.tool-head{margin-bottom:14px}
.tool-head h3{font-size:18px;margin-bottom:4px}
.tool-head p{font-size:13px;color:var(--text-dim)}
.tool-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.tool-field{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}
.tool-field>span{font-size:12px;color:var(--text-dim)}
.tool-field input,.tool-field textarea{width:100%;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}
.tool-field input:focus,.tool-field textarea:focus{border-color:var(--accent)}
.tool-field textarea{line-height:1.6;resize:vertical}
.tool-checks{display:flex;flex-wrap:wrap;gap:10px}
.tool-checks label{font-size:13px;color:var(--text);display:flex;align-items:center;gap:6px}
.tool-checks input{accent-color:var(--accent)}
.tool-actions{display:flex;gap:8px;margin:4px 0 12px}
.secondary-btn{background:var(--bg-hover);color:var(--text-dim);border:1px solid var(--border)}
.secondary-btn:hover{color:var(--text);border-color:#3a3a55}
.tool-result{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px}
.metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.metric{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px}
.metric .k{font-size:12px;color:var(--text-dim);margin-bottom:4px}
.metric .v{font-size:20px;line-height:1.2;font-weight:700;color:var(--text)}
.tool-note{margin-top:10px;font-size:12px;color:var(--text-dim)}
.tool-note.ok{color:var(--accent)}
.tool-table{margin-top:12px;overflow-x:auto}
.tool-table table{width:100%;border-collapse:collapse;font-size:13px}
.tool-table th,.tool-table td{border:1px solid var(--border);padding:8px 10px;text-align:left}
.tool-table th{background:var(--bg-hover);color:var(--text)}
.tool-kv{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);margin-bottom:8px;font-size:13px;color:var(--text-dim)}
.tool-kv strong{color:var(--text);font-size:14px}
.tool-bars{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.tool-bar-row{display:grid;grid-template-columns:120px 1fr 56px;align-items:center;gap:10px}
.tool-bar-row .label{font-size:12px;color:var(--text)}
.tool-bar-row .track{height:10px;background:var(--bg-hover);border:1px solid var(--border);border-radius:999px;overflow:hidden}
.tool-bar-row .fill{height:100%;background:linear-gradient(90deg,var(--accent),#4ade80)}
.tool-bar-row .num{font-size:12px;color:var(--text-dim);text-align:right}

/* Page Header */
.page-header{padding:20px 0 24px}
.page-header h2{font-size:24px;font-weight:700}
.page-header p{color:var(--text-dim);font-size:14px;margin-top:4px}

/* Tags Filter */
.tags-filter{display:flex;gap:6px;margin-bottom:24px;flex-wrap:wrap}
.tag-filter{padding:4px 14px;border-radius:20px;font-size:12px;cursor:pointer;background:var(--bg-card);border:1px solid var(--border);color:var(--text-dim);transition:all .2s}
.tag-filter:hover{border-color:#3a3a55;color:var(--text)}
.tag-filter.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:600}

/* Auth Modal */
.auth-overlay{display:none;position:fixed;inset:0;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);z-index:1000;align-items:center;justify-content:center}
.auth-overlay.active{display:flex}
.auth-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:36px 40px 32px;width:380px;max-width:90vw;position:relative}
.auth-modal .close{position:absolute;top:16px;right:20px;color:var(--text-dim);cursor:pointer;font-size:20px;background:none;border:none;font-family:inherit;padding:4px}
.auth-modal .close:hover{color:var(--text)}
.auth-modal h2{font-size:22px;font-weight:700;margin-bottom:4px}
.auth-modal .sub{font-size:13px;color:var(--text-dim);margin-bottom:24px}
.auth-modal .field{margin-bottom:16px}
.auth-modal .field label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:var(--text-dim)}
.auth-modal .field input,.auth-modal .field select,.auth-modal .field textarea{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}
.auth-modal .field input:focus,.auth-modal .field textarea:focus{border-color:var(--accent)}
.auth-modal .field .hint{font-size:12px;color:var(--text-dim);margin-top:4px}
.auth-modal .btn{width:100%;padding:10px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#000;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .2s;margin-top:4px}
.auth-modal .btn:hover{opacity:.85}
.auth-modal .btn-row{display:flex;gap:8px;margin-top:20px}
.auth-modal .btn-row .btn{margin-top:0}
.auth-modal .btn-row .btn-cancel{flex:1;padding:10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-dim);font-size:14px;cursor:pointer;font-family:inherit;transition:all .2s}
.auth-modal .btn-row .btn-cancel:hover{color:var(--text);background:var(--bg-hover)}
.auth-modal .btn-row .btn-submit{flex:2}
.auth-modal .switch{text-align:center;margin-top:16px;font-size:13px;color:var(--text-dim)}
.auth-modal .switch a{color:var(--accent);cursor:pointer;text-decoration:none}
.auth-modal .switch a:hover{text-decoration:underline}
.auth-modal.company-assets-modal{width:min(1900px,99vw);max-width:99vw;max-height:96vh;overflow:hidden;display:flex;flex-direction:column;padding:28px 30px 26px}
.auth-modal.company-asset-edit-modal{width:min(1900px,98vw);max-width:98vw;max-height:94vh;overflow:auto}

/* User Menu */
#userMenu{position:relative;display:none}
#userMenu.active{display:block}
.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);color:#000;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;cursor:pointer}
.user-dropdown{display:none;position:absolute;top:44px;right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);width:160px;box-shadow:0 8px 32px rgba(0,0,0,0.4);z-index:100}
.user-dropdown.active{display:block}
.user-dropdown a{display:block;padding:10px 16px;font-size:13px;color:var(--text-dim);text-decoration:none;border-bottom:1px solid var(--border);cursor:pointer}
.user-dropdown a:last-child{border-bottom:none}
.user-dropdown a:hover{color:var(--text);background:var(--bg-hover)}

/* Add Button */
.add-btn{display:none;align-items:center;gap:4px;font-size:12px;color:var(--accent);cursor:pointer;background:none;border:1px dashed var(--accent);border-radius:var(--radius-sm);padding:4px 12px;font-family:inherit;transition:all .2s;margin-left:auto;opacity:.6}
.add-btn:hover{opacity:1;background:rgba(0,212,170,.05)}
.logged-in .add-btn{display:inline-flex}

/* Visibility */
.vis-badge{font-size:10px;padding:1px 8px;border-radius:10px;font-weight:500;margin-left:6px}
.vis-badge.public{background:rgba(0,212,170,.12);color:var(--accent)}
.vis-badge.private{background:rgba(255,159,67,.12);color:#f59e0b}
.pin-badge{font-size:10px;padding:1px 8px;border-radius:10px;font-weight:600;background:rgba(245,158,11,.12);color:#f59e0b;border:1px solid rgba(245,158,11,.18)}
.vis-selector{display:flex;gap:8px}
.vis-selector label{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;font-size:13px;color:var(--text-dim);transition:all .2s}
.vis-selector label:hover{border-color:#3a3a55}
.vis-selector label.active{border-color:var(--accent);background:rgba(0,212,170,.05)}

/* Editor */
.editor-page{max-width:720px;margin:0 auto;padding:24px 0 48px}
.editor-page .back{display:inline-flex;align-items:center;gap:6px;color:var(--text-dim);font-size:13px;cursor:pointer;margin-bottom:24px}
.editor-page .back:hover{color:var(--accent)}
.editor-page .field{margin-bottom:20px}
.editor-page .field label{display:block;font-size:13px;font-weight:500;color:var(--text-dim);margin-bottom:6px}
.editor-page .field input,.editor-page .field select,.editor-page .field textarea{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}
.editor-page .field input:focus,.editor-page .field textarea:focus{border-color:var(--accent)}
.editor-page .field textarea{min-height:200px;resize:vertical;line-height:1.6}
.editor-page .row{display:flex;gap:16px}
.editor-page .row .field{flex:1}
.editor-page .btn-bar{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}
.editor-page .btn{padding:10px 24px;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit}
.editor-page .btn.primary{background:var(--accent);color:#000}
.editor-page .btn.primary:hover{opacity:.85}
.editor-page .btn.secondary{background:var(--bg-card);color:var(--text-dim);border:1px solid var(--border)}
.editor-page .btn.secondary:hover{color:var(--text)}

/* Footer */
footer{border-top:1px solid var(--border);padding:32px 0;margin-top:48px;text-align:center;font-size:13px;color:var(--text-dim)}
footer a{color:var(--text-dim);text-decoration:none}
footer a:hover{color:var(--accent)}
footer .icp{margin-top:4px;font-size:12px}

/* Responsive */
@media(max-width:768px){
  .quick-bar{flex-direction:row}
  .quick-bar button{width:auto;padding:10px 16px}
  .quick-upload-split{grid-template-columns:1fr}
  .quick-upload-panel button{padding:10px 16px}
  .todo-compose{grid-template-columns:1fr}
  .todo-compose button{width:100%}
  .todo-sort-hint{width:100%;margin-left:0}
  .todo-item{grid-template-columns:22px 22px minmax(0,1fr);gap:8px}
  .todo-body{grid-template-columns:minmax(0,1fr) auto;gap:6px}
  .todo-body p{grid-column:1/-1}
  .todo-meta{display:none}
  .todo-actions{grid-column:3;opacity:1;flex-wrap:wrap}
  .company-assets-modal{width:98vw;padding:22px 16px}
  .auth-modal.company-assets-modal{width:98vw;max-width:98vw;padding:22px 16px}
  .auth-modal.company-asset-edit-modal{width:98vw;max-width:98vw}
  .company-assets-head{flex-direction:column;align-items:stretch}
  .company-asset-edit-grid{grid-template-columns:1fr}
  .company-asset-edit-grid .field:first-child,.company-asset-edit-grid .field:nth-child(5),.company-asset-edit-grid .field:nth-child(10){grid-column:auto}
  .snippet-search,.content-search{flex-wrap:wrap}
  .snippet-search input,.content-search input{flex-basis:100%}
  .snippet-del-btn,.snippet-edit-btn,.card-edit-btn,.pin-btn{opacity:1}
  .nav-grid{grid-template-columns:repeat(3,1fr);gap:6px}
  .nav-card{padding:14px 4px}
  .nav-card .icon{font-size:22px;margin-bottom:4px}
  .nav-card h3{font-size:12px}
  .nav-card p{display:none}
  .nav-card .count{font-size:9px;margin-top:4px;padding:1px 6px}
  .content-grid{grid-template-columns:1fr}
  .games-grid{grid-template-columns:1fr}
  .sites-grid{grid-template-columns:repeat(2,1fr)}
  .snippets-grid{grid-template-columns:1fr}
  .post-row{flex-direction:column;align-items:flex-start;gap:8px;padding:14px 18px}
  .post-row-meta{flex-direction:row;gap:12px}
  header .container{flex-direction:column;gap:12px}
  nav{flex-wrap:wrap;justify-content:center}
  .tool-grid{grid-template-columns:1fr}
  .metric-grid{grid-template-columns:1fr}
  .tool-actions{flex-wrap:wrap}
  .tool-actions .write-btn{flex:1}
  .tool-bar-row{grid-template-columns:1fr}
  .tool-bar-row .num{text-align:left}
}

/* Article List */
.article-cat-tabs{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:-4px 0 22px}
.article-cat-tabs a{display:inline-flex;align-items:center;height:30px;padding:0 13px;border-radius:999px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-dim);font-size:12px;text-decoration:none;transition:all .2s}
.article-cat-tabs a:hover{color:var(--text);border-color:#3a3a55;background:var(--bg-hover)}
.article-cat-tabs a.active{color:#001512;background:var(--accent);border-color:var(--accent);font-weight:700}
.post-list{display:flex;flex-direction:column;gap:8px;margin-bottom:40px}
.post-row{display:flex;justify-content:space-between;align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:18px 24px;text-decoration:none;color:var(--text);transition:all .2s;gap:20px}
.post-row{position:relative;padding-right:58px}
.post-row:hover{background:var(--bg-hover);border-color:#3a3a55;color:var(--text);transform:translateY(-1px)}
.post-row-main{flex:1;min-width:0}
.post-row-labels{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:6px}
.post-row-labels .vis-badge{margin-left:0}
.post-row-cat{display:inline-block;font-size:11px;padding:2px 8px;border-radius:4px;background:rgba(0,212,170,.12);color:var(--accent);margin-bottom:6px;font-weight:500}
.post-row-labels .post-row-cat{margin-bottom:0}
.post-row h3{font-size:16px;margin-bottom:4px;line-height:1.4}
.post-row-excerpt{font-size:13px;color:var(--text-dim);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.post-row-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;font-size:12px;color:var(--text-dim);white-space:nowrap;flex-shrink:0}
.pagination{display:flex;justify-content:center;gap:8px;margin-bottom:48px}
.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 12px;border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border);color:var(--text-dim);font-size:13px;text-decoration:none;transition:all .2s}
.pagination a:hover{background:var(--bg-hover);color:var(--text);border-color:#3a3a55}
.pagination span.current{background:var(--accent);color:#000;border-color:var(--accent);font-weight:600}

/* Write Editor */
.write-page{max-width:960px;margin:0 auto;padding:20px 0 48px}
.write-back{display:inline-flex;align-items:center;gap:6px;color:var(--text-dim);font-size:13px;text-decoration:none;margin-bottom:16px;cursor:pointer}
.write-back:hover{color:var(--accent)}
.write-title{font-size:22px;font-weight:700;margin-bottom:24px}
.write-field{margin-bottom:16px}
.write-input-title{width:100%;padding:16px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:22px;font-weight:700;font-family:inherit;outline:none;transition:border-color .2s}
.write-input-title::placeholder{color:#5a5a70}
.write-input-title:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.write-attachments{margin:0 0 16px;padding:14px;border:1px dashed var(--border);border-radius:var(--radius-sm);background:var(--bg-card);transition:all .2s}
.write-attachments.drag-over{border-color:var(--accent);background:rgba(0,212,170,.06)}
.write-attachments-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.write-attachments-head strong{display:block;font-size:14px;color:var(--text)}
.write-attachments-head span{display:block;font-size:12px;color:var(--text-dim);margin-top:2px}
.write-attachments-head button{padding:8px 13px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-hover);color:var(--text);font-size:13px;cursor:pointer;font-family:inherit;transition:all .2s}
.write-attachments-head button:hover{color:var(--accent);border-color:var(--accent)}
.write-attachment-list{display:flex;flex-direction:column;gap:6px;margin-top:12px}
.write-attachment-empty{font-size:12px;color:var(--text-dim);padding:6px 0}
.write-attachment-item{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:10px;align-items:center;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg)}
.write-attachment-item a{font-size:13px;color:var(--text);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.write-attachment-item a:hover{color:var(--accent)}
.write-attachment-item span{font-size:11px;color:var(--text-dim);white-space:nowrap}
.write-attachment-item button{padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-dim);font-size:11px;cursor:pointer;font-family:inherit}
.write-attachment-item button:hover{color:#ef4444;border-color:#ef4444;background:rgba(239,68,68,.05)}
.write-editor-wrap{margin-bottom:16px;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-card)}

/* ProseMirror WYSIWYG 样式 */
.ProseMirror{min-height:600px;padding:20px;outline:none;font-size:15px;line-height:1.8;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",sans-serif}
.ProseMirror p{margin-bottom:12px}
.ProseMirror h2{font-size:22px;font-weight:700;margin:28px 0 12px;color:var(--text)}
.ProseMirror h3{font-size:18px;font-weight:600;margin:24px 0 10px;color:var(--text)}
.ProseMirror h4{font-size:16px;font-weight:600;margin:20px 0 8px;color:var(--text)}
.ProseMirror ul,.ProseMirror ol{padding-left:20px;margin-bottom:16px}
.ProseMirror li{margin-bottom:4px}
.ProseMirror code{font-size:13px;padding:2px 6px;border-radius:4px;background:var(--bg-hover);color:var(--accent);font-family:"SF Mono","Cascadia Code","Consolas",monospace}
.ProseMirror pre{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;margin:0 0 16px;overflow-x:auto}
.ProseMirror pre code{background:none;color:var(--text-dim);padding:0;font-size:13px}
.ProseMirror blockquote{border-left:3px solid var(--accent);padding:4px 16px;margin:0 0 16px;color:var(--text-dim)}
.ProseMirror img{max-width:100%;border-radius:8px;margin:8px 0}
.ProseMirror hr{border:none;border-top:2px dashed var(--border);margin:24px 0}
.ProseMirror a{color:var(--accent);text-decoration:underline;cursor:pointer}
.ProseMirror a:hover{color:#00e8c0}
.ProseMirror s{text-decoration:line-through}
.ProseMirror u{text-decoration:underline}
.ProseMirror p.is-editor-empty:first-child::before{content:attr(data-placeholder);float:left;color:#5a5a70;pointer-events:none;height:0}
/* 表格 */
.ProseMirror table{width:100%;table-layout:fixed;border-collapse:collapse;margin-bottom:16px;overflow:hidden}
.ProseMirror td,.ProseMirror th{position:relative;border:2px solid var(--border);padding:8px 12px;vertical-align:top;min-width:80px}
.ProseMirror th{background:var(--bg-hover);font-weight:600;text-align:left}
.ProseMirror td p,.ProseMirror th p{margin:0}
.ProseMirror .tableWrapper{overflow-x:auto;margin-bottom:16px}
.ProseMirror .resize-cursor{cursor:ew-resize;cursor:col-resize}
.ProseMirror .column-resize-handle{position:absolute;right:-3px;top:0;bottom:-2px;width:6px;background:var(--accent);opacity:.85;pointer-events:none;z-index:5}
.ProseMirror .selectedCell::after{content:"";position:absolute;inset:0;background:rgba(0,212,170,.10);pointer-events:none;z-index:1}
/* 待办列表 */
.ProseMirror ul[data-type="taskList"]{list-style:none;padding:0}
.ProseMirror ul[data-type="taskList"] li{display:flex;align-items:flex-start;gap:8px;margin-bottom:4px}
.ProseMirror ul[data-type="taskList"] li>label{flex-shrink:0;margin-top:3px}
.ProseMirror ul[data-type="taskList"] li>label input[type="checkbox"]{accent-color:var(--accent);cursor:pointer;width:16px;height:16px}
.ProseMirror ul[data-type="taskList"] li[data-checked="true"]>div{text-decoration:line-through;color:var(--text-dim)}
.ProseMirror ul[data-type="taskList"] li>div{flex:1}

/* 封面图 */
.write-featured{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm)}
.featured-preview{position:relative;display:inline-flex;border-radius:8px;overflow:hidden;max-height:120px}
.featured-preview img{max-height:120px;border-radius:8px}
.featured-remove{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;border:none;background:rgba(0,0,0,0.6);color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}
.featured-preview:hover .featured-remove{opacity:1}
.featured-btn{padding:8px 18px;background:var(--bg-hover);color:var(--text-dim);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;cursor:pointer;font-family:inherit;transition:all .2s}
.featured-btn:hover{color:var(--text);border-color:var(--accent)}

/* 字数/导航栏 */
.write-meta-bar{display:flex;align-items:center;gap:16px;padding:6px 12px;font-size:12px;color:var(--text-dim);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);margin-bottom:16px;background:var(--bg-card)}
.draft-status{flex:1;text-align:right}

/* 标题导航 */
.heading-nav{margin-bottom:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;max-height:200px;overflow-y:auto}
.heading-nav-title{font-size:13px;font-weight:600;margin-bottom:8px;color:var(--text-dim)}
.heading-nav-list{display:flex;flex-direction:column;gap:2px}
.hn-item{padding:4px 8px;font-size:13px;cursor:pointer;border-radius:4px;color:var(--text-dim);transition:all .15s;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hn-item:hover{background:var(--bg-hover);color:var(--accent)}
.hn-l2{padding-left:8px;font-weight:600;color:var(--text)}
.hn-l3{padding-left:20px;font-size:12px}
.hn-l4{padding-left:32px;font-size:12px}
.hn-empty{font-size:12px;color:var(--text-dim);padding:4px 0}

.write-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.write-bar-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.write-bar-right{display:flex;gap:8px}
.write-select{padding:8px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:13px;font-family:inherit;outline:none;cursor:pointer}
.write-select:focus{border-color:var(--accent)}
.write-btn{padding:10px 24px;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .2s}
.write-btn:hover{opacity:.85}
.write-btn-save{background:var(--accent);color:#000}

/* 工具栏 */
.write-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:2px;padding:6px 10px;background:var(--bg-card);border:1px solid var(--border);border-bottom:none;border-radius:var(--radius-sm) var(--radius-sm) 0 0;margin-bottom:0}
.tb-btn{padding:5px 10px;background:transparent;color:var(--text-dim);border:none;border-radius:4px;font-size:13px;cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap;line-height:1.4}
.tb-btn:hover{background:var(--bg-hover);color:var(--text)}
.tb-table-btn{font-size:12px;padding:5px 7px;border:1px solid transparent}
.tb-table-btn:hover{border-color:var(--border)}
.tb-table-btn.danger:hover{color:#ef4444;border-color:rgba(239,68,68,.45);background:rgba(239,68,68,.06)}
.tb-btn b{font-weight:700}
.tb-btn i{font-style:italic}
.tb-btn s{text-decoration:line-through}
.tb-sep{width:1px;height:20px;background:var(--border);margin:0 3px;flex-shrink:0}
.tb-group{position:relative;display:inline-flex}
.tb-dropdown{display:none;position:absolute;top:100%;left:0;z-index:100;min-width:120px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 4px 20px rgba(0,0,0,0.3);padding:4px;margin-top:4px}
.tb-dropdown.active{display:block}
.tb-dropdown div{padding:7px 12px;cursor:pointer;border-radius:4px;font-size:13px;color:var(--text)}
.tb-dropdown div:hover{background:var(--bg-hover);color:var(--accent)}
.tb-drop-divider{height:1px;background:var(--border);margin:4px 8px;padding:0!important}

/* 斜杠菜单 */
.slash-menu{display:none;position:fixed;z-index:1000;min-width:200px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 6px 24px rgba(0,0,0,0.35);padding:6px}
.slash-menu.visible{display:block}
.slash-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;border-radius:4px;font-size:13px;color:var(--text);transition:background .1s}
.slash-item:hover,.slash-item.active{background:var(--bg-hover);color:var(--accent)}
.slash-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:var(--bg-hover);font-size:13px;flex-shrink:0}
.slash-label{font-size:13px}
.write-img-status{font-size:12px;color:var(--text-dim);margin-left:8px}

@media(max-width:768px){
  .write-page{max-width:100%;padding:12px 0 32px}
  .write-input-title{font-size:18px;padding:12px 16px}
  .ProseMirror{min-height:400px;padding:14px;font-size:14px}
  .write-bar{flex-direction:column;align-items:stretch}
  .write-bar-left,.write-bar-right{justify-content:stretch}
  .write-btn{flex:1;text-align:center}
  .write-toolbar{padding:4px 6px;gap:1px}
  .tb-btn{padding:4px 7px;font-size:12px}
  .write-meta-bar{flex-wrap:wrap;gap:8px;font-size:11px}
  .heading-nav{max-height:150px}
  .write-featured{flex-wrap:wrap}
}

/* About Page */
.about-page{max-width:680px;margin:0 auto;padding:20px 0 48px}
.about-header{text-align:center;padding:40px 0}
.about-avatar{font-size:64px;margin-bottom:16px}
.about-header h1{font-size:32px;font-weight:800;margin-bottom:8px}
.about-subtitle{font-size:15px;color:var(--text-dim)}
.about-actions{display:flex;justify-content:center;margin-top:18px}
.about-link-btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--accent);font-size:13px;text-decoration:none;transition:all .2s}
.about-link-btn:hover{border-color:var(--accent);background:rgba(0,212,170,.05);color:var(--accent)}
.about-body{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:36px}
.about-section{margin-bottom:32px}
.about-section:last-child{margin-bottom:0}
.about-section h2{font-size:20px;font-weight:700;margin-bottom:12px}
.about-section p{font-size:14px;color:var(--text-dim);line-height:1.8}
.about-section ul{list-style:none;padding:0;margin-top:8px}
.about-section ul li{font-size:14px;color:var(--text-dim);padding:4px 0}
.about-section ul li a{color:var(--accent);text-decoration:none}
.about-section ul li a:hover{text-decoration:underline}
.skill-list{display:flex;flex-wrap:wrap;gap:8px}
.skill-tag{padding:6px 16px;border-radius:20px;font-size:13px;background:rgba(0,212,170,.1);color:var(--accent);border:1px solid rgba(0,212,170,.2);font-weight:500}
.personality-list{display:flex;flex-wrap:wrap;gap:10px}
.personality-tag{padding:7px 18px;border-radius:20px;font-size:13px;font-weight:600;letter-spacing:.5px;transition:transform .2s,box-shadow .2s;cursor:default}
.personality-tag:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.3)}
.tag-skeptic{background:linear-gradient(135deg,rgba(120,80,220,.2),rgba(80,40,180,.1));color:#b794f4;border:1px solid rgba(120,80,220,.3)}
.tag-thinker{background:linear-gradient(135deg,rgba(60,140,255,.2),rgba(40,80,200,.1));color:#7eb8ff;border:1px solid rgba(60,140,255,.3)}
.tag-fearless{background:linear-gradient(135deg,rgba(255,100,80,.2),rgba(200,50,30,.1));color:#ff8a7a;border:1px solid rgba(255,100,80,.3)}
.tag-lonewolf{background:linear-gradient(135deg,rgba(0,200,160,.2),rgba(0,150,120,.1));color:#64d8c0;border:1px solid rgba(0,200,160,.3)}
/* Utilities */
.page-section{display:block}
.page-enter{animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* Announcement */
.announce{background:linear-gradient(135deg,rgba(124,92,252,.1) 0%,rgba(0,212,170,.1) 100%);border:1px solid rgba(124,92,252,.2);border-radius:var(--radius-sm);padding:16px 20px;text-align:center;font-size:14px;margin-bottom:40px}
.announce a{color:var(--accent);text-decoration:none}
.announce a:hover{text-decoration:underline}

/* Favicon preview */
.favicon-preview{width:28px;height:28px;border-radius:6px;display:none;background:var(--bg-hover);flex-shrink:0}

/* File list */
.file-picker{flex:1;padding:12px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-dim);font-size:14px;cursor:pointer;transition:border-color .2s;display:flex;align-items:center}
.file-picker:hover{border-color:var(--accent)}
.file-picker.drag-over{border-color:var(--accent);background:rgba(0,212,170,.06);box-shadow:0 0 0 2px rgba(0,212,170,.14)}
.file-picker span{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.image-paste-box{display:flex;align-items:center;gap:12px;margin:-18px 0 18px;padding:14px 16px;border:1px dashed var(--border);border-radius:var(--radius-sm);background:rgba(255,255,255,.02);color:var(--text-dim);cursor:text;outline:none;transition:all .2s}
.image-paste-box:hover,.image-paste-box:focus{border-color:var(--accent);background:rgba(0,212,170,.05);box-shadow:0 0 0 2px rgba(0,212,170,.10)}
.image-paste-box.pasting{border-color:var(--accent);color:var(--accent)}
.image-paste-icon{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-sm);background:var(--bg-hover);color:var(--accent);font-size:18px;font-weight:700;flex-shrink:0}
.image-paste-title{font-size:14px;color:var(--text);font-weight:600;line-height:1.3}
.image-paste-hint{font-size:12px;color:var(--text-dim);line-height:1.4}
.file-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:-4px 0 16px}
.file-tab{display:inline-flex;align-items:center;justify-content:center;padding:6px 14px;border-radius:999px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-dim);font-size:13px;text-decoration:none;transition:all .2s}
.file-tab:hover{border-color:#3a3a55;color:var(--text);background:var(--bg-hover)}
.file-tab.active{border-color:var(--accent);background:rgba(0,212,170,.1);color:var(--accent);font-weight:600}

/* Drag/drop helpers */
.write-featured.drag-over{border-color:var(--accent);background:rgba(0,212,170,.06);box-shadow:0 0 0 2px rgba(0,212,170,.10)}
.ProseMirror.drag-over{box-shadow:inset 0 0 0 2px rgba(0,212,170,.18);background:rgba(0,212,170,.02)}
#gameCoverArea.drag-over .featured-btn{border-color:var(--accent);background:rgba(0,212,170,.06);color:var(--text)}
.featured-btn.drag-over{border-color:var(--accent);background:rgba(0,212,170,.06);color:var(--text)}
.files-grid{display:flex;flex-direction:column;gap:8px;margin-bottom:48px}
.file-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 18px;display:flex;align-items:center;gap:14px;transition:all .2s}
.file-card:hover{background:var(--bg-hover);border-color:#3a3a55}
.file-card-viewable{cursor:pointer}
.file-card-viewable:hover{border-color:var(--accent)}
.file-icon{font-size:28px;flex-shrink:0;width:40px;text-align:center}
.file-info{flex:1;min-width:0}
.file-name{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.file-meta{display:flex;gap:10px;align-items:center;margin-top:4px;font-size:12px;color:var(--text-dim)}
.file-type-badge{display:inline-block;font-size:10px;padding:1px 6px;border-radius:4px;background:rgba(0,212,170,.12);color:var(--accent);font-weight:600}
.file-actions{display:flex;gap:6px;flex-shrink:0}
.btn-download{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);background:var(--bg-hover);border:1px solid var(--border);color:var(--text-dim);text-decoration:none;font-size:14px;cursor:pointer;transition:all .2s}
.btn-download:hover{color:var(--accent);border-color:var(--accent);background:rgba(0,212,170,.05)}
.btn-view{color:var(--accent);border-color:rgba(0,212,170,.35);background:rgba(0,212,170,.05)}
.btn-delete{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);background:var(--bg-hover);border:1px solid var(--border);color:var(--text-dim);font-size:14px;cursor:pointer;transition:all .2s;font-family:inherit}
.btn-delete:hover{color:#ef4444;border-color:#ef4444;background:rgba(239,68,68,.05)}
.image-preview-overlay{display:none;position:fixed;inset:0;z-index:1100;background:rgba(0,0,0,.72);backdrop-filter:blur(4px);align-items:center;justify-content:center;padding:24px}
.image-preview-overlay.active{display:flex}
.image-preview-box{position:relative;max-width:min(92vw,1100px);max-height:88vh;display:flex;flex-direction:column;gap:10px}
.image-preview-title{max-width:calc(92vw - 48px);color:var(--text);font-size:13px;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.image-preview-box img{max-width:100%;max-height:82vh;object-fit:contain;border-radius:var(--radius-sm);background:var(--bg-card);box-shadow:0 18px 60px rgba(0,0,0,.45)}
.image-preview-close{position:absolute;top:-12px;right:-12px;width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;font-family:inherit;font-size:14px;box-shadow:0 8px 24px rgba(0,0,0,.35)}
.image-preview-close:hover{color:#ef4444;border-color:#ef4444}

/* Changelog */
.changelog-list{display:flex;flex-direction:column;gap:10px;margin-bottom:48px}
.changelog-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px 18px}
.changelog-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:12px;color:var(--text-dim);margin-bottom:8px}
.changelog-meta strong{color:var(--accent);font-size:12px}
.changelog-content{font-size:14px;color:var(--text);line-height:1.7}
