talas-group/talas-wiki/static/style.css

1274 lines
32 KiB
CSS
Raw Normal View History

/* =============================================================
TALAS WIKI Terminal Aesthetic
Palette Nord: derived from one.html
============================================================= */
:root {
--bg: #121212;
--bg-alt: #0e0e0e;
--border: #2e3440;
--text: #a3be8c;
--text-dim: #6b7f5a;
--heading: #eceff4;
--yellow: #ebcb8b;
--cyan: #88c0d0;
--red: #bf616a;
--purple: #b48ead;
--orange: #d08770;
--font: 'JetBrains Mono', 'Consolas', 'Fira Code', monospace;
}
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
::selection { background: rgba(163, 190, 140, 0.25); color: var(--heading); }
html { background: var(--bg); }
body {
font-family: var(--font);
font-size: 14px;
line-height: 1.7;
color: var(--text);
overflow-x: hidden;
}
a {
color: var(--cyan);
text-decoration: none;
border-bottom: 1px dashed rgba(136, 192, 208, 0.3);
transition: all 0.15s;
}
a:hover {
background: var(--text);
color: var(--bg);
border-bottom-color: transparent;
}
/* ═══ LAYOUT ═══ */
.layout {
display: grid;
grid-template-columns: 260px 1fr;
min-height: 100vh;
}
/* ═══ SIDEBAR ═══ */
.sidebar {
background: var(--bg-alt);
border-right: 1px solid var(--border);
padding: 20px 16px;
overflow-y: auto;
position: sticky;
top: 0;
height: 100vh;
}
.sidebar-header {
margin-bottom: 20px;
padding-bottom: 16px;
border-bottom: 1px solid var(--border);
}
.logo {
font-size: 16px;
font-weight: bold;
color: var(--text);
border: none;
}
.logo:hover { background: none; color: var(--heading); }
.logo-dot { color: var(--yellow); }
.sidebar-search {
margin-bottom: 20px;
}
.search-input {
width: 100%;
background: var(--bg);
border: 1px solid var(--border);
color: var(--text);
font-family: var(--font);
font-size: 12px;
padding: 8px 10px;
outline: none;
transition: border-color 0.2s;
}
.search-input:focus {
border-color: var(--cyan);
}
.search-input::placeholder { color: var(--text-dim); }
.sidebar-nav {
display: flex;
flex-direction: column;
gap: 2px;
}
.nav-domain {
display: block;
padding: 6px 10px;
font-size: 12px;
color: var(--yellow);
border: none;
border-radius: 3px;
transition: all 0.15s;
}
.nav-domain:hover {
background: rgba(235, 203, 139, 0.1);
color: var(--yellow);
}
/* ═══ MAIN CONTENT ═══ */
.main {
padding: 32px 48px;
max-width: 960px;
border-left: 2px solid var(--text);
}
/* ═══ BREADCRUMB <20><>══ */
.breadcrumb {
color: var(--text-dim);
font-size: 12px;
margin-bottom: 24px;
}
.breadcrumb::before { content: ">_ "; color: var(--yellow); }
.breadcrumb a { color: var(--cyan); font-size: 12px; border: none; }
.breadcrumb a:hover { background: var(--cyan); color: var(--bg); }
.edit-marker { color: var(--orange); }
/* ═<><E29590><EFBFBD>═ HEADINGS ═<><E29590>═ */
h1, h2, h3, h4, h5, h6 { color: var(--heading); font-weight: 600; }
h1 { font-size: 24px; margin-bottom: 16px; }
h1::before { content: "# "; color: var(--yellow); font-weight: 400; }
h2 { font-size: 20px; margin: 32px 0 12px; }
h2::before { content: "## "; color: var(--yellow); font-weight: 400; }
h3 { font-size: 16px; margin: 24px 0 8px; }
h3::before { content: "### "; color: var(--yellow); font-weight: 400; }
h4 { font-size: 14px; margin: 20px 0 8px; color: var(--text); }
h5, h6 { font-size: 13px; margin: 16px 0 8px; color: var(--text-dim); }
/* ═══ PAGE HEADER ═══ */
.page-header {
display: flex;
align-items: center;
gap: 16px;
margin-bottom: 8px;
}
.page-header h1 { margin-bottom: 0; flex: 1; }
.page-meta {
display: flex;
gap: 16px;
font-size: 11px;
color: var(--text-dim);
margin-bottom: 24px;
padding-bottom: 16px;
border-bottom: 1px solid var(--border);
}
.meta-domain { color: var(--yellow); }
/* ═══ PAGE CONTENT ═══ */
.page-content {
line-height: 1.8;
}
.page-content p { margin-bottom: 12px; }
.page-content ul, .page-content ol {
margin: 8px 0 16px 24px;
}
.page-content li { margin-bottom: 4px; }
.page-content li::marker { color: var(--yellow); }
.page-content blockquote {
border-left: 3px solid var(--yellow);
padding: 8px 16px;
margin: 16px 0;
color: var(--text-dim);
background: rgba(235, 203, 139, 0.03);
}
.page-content pre {
background: var(--bg-alt);
border: 1px solid var(--border);
padding: 16px;
overflow-x: auto;
margin: 16px 0;
font-size: 13px;
line-height: 1.5;
}
.page-content code {
color: var(--cyan);
font-family: var(--font);
font-size: 13px;
}
.page-content pre code { color: var(--text); }
.page-content img {
max-width: 100%;
border: 1px solid var(--border);
margin: 16px 0;
}
.page-content table {
border-collapse: collapse;
width: 100%;
margin: 16px 0;
font-size: 13px;
}
.page-content th {
background: var(--bg-alt);
color: var(--cyan);
text-align: left;
padding: 10px 12px;
border: 1px solid var(--border);
font-weight: 600;
}
.page-content td {
padding: 8px 12px;
border: 1px solid var(--border);
}
.page-content tr:hover td {
background: rgba(163, 190, 140, 0.04);
}
.page-content hr {
border: none;
border-top: 1px solid var(--border);
margin: 24px 0;
}
.page-content input[type="checkbox"] {
accent-color: var(--text);
margin-right: 6px;
}
.page-content strong { color: var(--heading); }
.page-content em { color: var(--purple); font-style: italic; }
/* ═══ WIKILINKS ═══ */
.wikilink {
color: var(--cyan);
border-bottom: 1px solid rgba(136, 192, 208, 0.4);
}
.wikilink:hover {
background: var(--cyan);
color: var(--bg);
}
.wikilink-broken {
color: var(--red);
border-bottom: 1px dashed var(--red);
cursor: help;
}
.asset-link { color: var(--orange); border-bottom-color: rgba(208, 135, 112, 0.4); }
.asset-link:hover { background: var(--orange); }
/* ═══ BACKLINKS ═<><E29590><EFBFBD>═ */
.backlinks {
margin-top: 48px;
padding-top: 24px;
border-top: 1px solid var(--border);
}
.backlinks h3 { font-size: 13px; color: var(--text-dim); margin-bottom: 8px; }
.backlinks h3::before { content: "← "; color: var(--yellow); }
.backlinks ul { list-style: none; margin: 0; padding: 0; }
.backlinks li { margin-bottom: 4px; font-size: 13px; }
.backlink-domain { color: var(--text-dim); font-size: 11px; margin-left: 8px; }
/* ═══ DIRECTORY LISTING ═══ */
.dir-listing {
font-size: 13px;
}
.dir-header {
display: grid;
grid-template-columns: 24px 1fr 130px 80px;
gap: 8px;
padding: 8px 0;
border-bottom: 1px solid var(--border);
color: var(--text-dim);
font-size: 11px;
text-transform: uppercase;
letter-spacing: 0.05em;
}
.dir-entry {
display: grid;
grid-template-columns: 24px 1fr 130px 80px;
gap: 8px;
padding: 6px 0;
border-bottom: 1px solid rgba(46, 52, 64, 0.4);
}
.dir-entry:hover { background: rgba(163, 190, 140, 0.04); }
.dir-type-d { color: var(--yellow); }
.dir-type-f { color: var(--text-dim); }
.dir-type-a { color: var(--orange); }
.dir-folder { color: var(--yellow); border: none; font-weight: 600; }
.dir-folder:hover { background: var(--yellow); color: var(--bg); }
.dir-file { border: none; }
.dir-asset { color: var(--orange); border: none; }
.dir-col-date { color: var(--text-dim); font-size: 12px; }
.dir-col-size { color: var(--text-dim); font-size: 12px; text-align: right; }
.dir-readme {
margin-bottom: 24px;
padding: 16px;
background: rgba(163, 190, 140, 0.03);
border: 1px solid var(--border);
}
.dir-readme h1::before, .dir-readme h2::before, .dir-readme h3::before { content: none; }
.divider {
border: none;
border-top: 1px solid var(--border);
margin: 24px 0;
}
/* ═══ HOME PAGE ═══ */
.ascii-art {
color: var(--red);
white-space: pre;
font-size: 11px;
margin-bottom: 16px;
line-height: 1.3;
}
.subtitle {
color: var(--text-dim);
margin-bottom: 32px;
font-size: 13px;
}
.domain-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
gap: 12px;
}
.domain-card {
display: flex;
flex-direction: column;
padding: 16px;
background: var(--bg-alt);
border: 1px solid var(--border);
color: var(--text);
border-bottom: none;
transition: all 0.15s;
}
.domain-card:hover {
border-color: var(--text);
background: rgba(163, 190, 140, 0.05);
color: var(--text);
}
.domain-num {
font-size: 11px;
color: var(--text-dim);
margin-bottom: 4px;
}
.domain-name {
font-size: 15px;
font-weight: 600;
color: var(--yellow);
margin-bottom: 4px;
}
.domain-count {
font-size: 11px;
color: var(--text-dim);
margin-bottom: 8px;
}
.domain-desc {
font-size: 12px;
color: var(--text-dim);
line-height: 1.5;
}
/* ═══ SEARCH ═══ */
.search-form {
display: flex;
gap: 8px;
margin-bottom: 24px;
}
.search-input-main {
flex: 1;
background: var(--bg-alt);
border: 1px solid var(--border);
color: var(--text);
font-family: var(--font);
font-size: 14px;
padding: 10px 14px;
outline: none;
}
.search-input-main:focus { border-color: var(--cyan); }
.search-input-main::placeholder { color: var(--text-dim); }
.btn-search, .btn-save {
background: var(--text);
color: var(--bg);
border: none;
padding: 10px 20px;
font-family: var(--font);
font-size: 13px;
cursor: pointer;
font-weight: 600;
transition: all 0.15s;
}
.btn-search:hover, .btn-save:hover {
background: var(--heading);
}
.search-count {
color: var(--text-dim);
font-size: 12px;
margin-bottom: 16px;
}
.search-results {
display: flex;
flex-direction: column;
gap: 16px;
}
.search-result {
padding: 16px;
border: 1px solid var(--border);
background: var(--bg-alt);
}
.search-result:hover { border-color: var(--text); }
.result-title {
font-size: 15px;
font-weight: 600;
margin-right: 8px;
}
.result-domain {
font-size: 11px;
color: var(--yellow);
}
.result-score {
font-size: 11px;
color: var(--text-dim);
margin-left: 8px;
}
.result-snippet {
margin-top: 8px;
font-size: 12px;
color: var(--text-dim);
line-height: 1.6;
}
.result-path {
display: block;
margin-top: 4px;
font-size: 11px;
color: var(--text-dim);
}
/* ═══ EDIT ═══ */
.edit-form { margin-top: 16px; }
.edit-textarea {
width: 100%;
min-height: 70vh;
background: var(--bg-alt);
border: 1px solid var(--border);
color: var(--text);
font-family: var(--font);
font-size: 13px;
line-height: 1.7;
padding: 16px;
outline: none;
resize: vertical;
tab-size: 4;
}
.edit-textarea:focus { border-color: var(--cyan); }
.edit-actions {
display: flex;
gap: 12px;
margin-top: 12px;
align-items: center;
}
.btn-edit {
font-size: 12px;
color: var(--text-dim);
border: 1px solid var(--border);
padding: 4px 12px;
border-bottom: 1px solid var(--border);
}
.btn-edit:hover {
background: var(--text);
color: var(--bg);
border-color: var(--text);
}
.btn-cancel {
font-size: 13px;
color: var(--text-dim);
padding: 10px 16px;
}
/* ═══ SIDEBAR TOGGLE (mobile) ═══ */
.sidebar-toggle {
display: none;
position: fixed;
top: 12px;
left: 12px;
z-index: 100;
background: var(--bg-alt);
border: 1px solid var(--border);
padding: 8px;
cursor: pointer;
flex-direction: column;
gap: 4px;
}
.sidebar-toggle span {
display: block;
width: 20px;
height: 2px;
background: var(--text);
}
/* <20><>══ SEARCH SUGGESTIONS ═══ */
.search-wrapper { position: relative; }
.search-suggestions {
display: none;
position: absolute;
top: 100%;
left: 0;
right: 0;
background: var(--bg);
border: 1px solid var(--border);
border-top: none;
z-index: 60;
max-height: 320px;
overflow-y: auto;
}
.suggestion {
display: flex;
flex-direction: column;
padding: 8px 10px;
border: none;
border-bottom: 1px solid rgba(46, 52, 64, 0.4);
font-size: 12px;
}
.suggestion:hover { background: rgba(163, 190, 140, 0.1); }
.sug-title { color: var(--text); }
.sug-domain { color: var(--text-dim); font-size: 10px; }
/* ═══ SIDEBAR NAV EXTRAS ═══ */
.nav-separator { border-top: 1px solid var(--border); margin: 8px 0; }
.nav-link {
display: block;
padding: 4px 10px;
font-size: 11px;
color: var(--text-dim);
border: none;
transition: all 0.15s;
}
.nav-link:hover { color: var(--cyan); background: rgba(136, 192, 208, 0.05); }
.nav-new { color: var(--text); font-weight: 600; }
/* ═══ PAGE ACTIONS ═══ */
.page-actions { display: flex; gap: 8px; }
/* ═══ TOC ═══ */
.page-with-toc { position: relative; }
.toc {
position: sticky;
top: 16px;
float: right;
width: 220px;
margin-left: 24px;
margin-bottom: 16px;
padding: 12px;
background: var(--bg-alt);
border: 1px solid var(--border);
font-size: 11px;
max-height: calc(100vh - 100px);
overflow-y: auto;
}
.toc-title { color: var(--yellow); font-weight: 600; margin-bottom: 8px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em; }
.toc ul { list-style: none; margin: 0; padding: 0; }
.toc li { margin-bottom: 2px; }
.toc a { color: var(--text-dim); border: none; display: block; padding: 2px 0; }
.toc a:hover { color: var(--cyan); background: none; }
.toc-level-2 { padding-left: 8px; }
.toc-level-3 { padding-left: 16px; font-size: 10px; }
.toc-level-4 { padding-left: 24px; font-size: 10px; }
.toc-level-5, .toc-level-6 { display: none; }
/* ═══ TAGS ═══ */
.meta-tag {
background: rgba(180, 142, 173, 0.15);
color: var(--purple);
padding: 1px 6px;
border: none;
font-size: 10px;
}
.meta-tag:hover { background: var(--purple); color: var(--bg); }
.tag-cloud { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 24px; }
.tag {
padding: 4px 12px;
background: var(--bg-alt);
border: 1px solid var(--border);
color: var(--purple);
font-size: 12px;
}
.tag:hover { background: var(--purple); color: var(--bg); border-color: var(--purple); }
.tag-active { background: var(--purple); color: var(--bg); border-color: var(--purple); }
/* ═══ TRANSCLUSION ═══ */
.transclusion {
margin: 16px 0;
padding: 16px;
border-left: 3px solid var(--cyan);
background: rgba(136, 192, 208, 0.03);
}
.transclusion-header {
font-size: 11px;
color: var(--text-dim);
margin-bottom: 8px;
padding-bottom: 8px;
border-bottom: 1px solid var(--border);
}
.transclusion-header::before { content: "↗ "; color: var(--cyan); }
.transclusion-error { color: var(--red); font-size: 12px; padding: 8px; border: 1px dashed var(--red); }
/* ═══ EDITOR TOOLBAR ═══ */
.editor-toolbar {
display: flex;
gap: 8px;
align-items: center;
margin-bottom: 8px;
padding: 8px 0;
border-bottom: 1px solid var(--border);
}
.toolbar-btn, .toolbar-upload {
background: var(--bg-alt);
border: 1px solid var(--border);
color: var(--text-dim);
font-family: var(--font);
font-size: 11px;
padding: 4px 12px;
cursor: pointer;
transition: all 0.15s;
}
.toolbar-btn:hover, .toolbar-upload:hover { color: var(--cyan); border-color: var(--cyan); }
.toolbar-hint { font-size: 10px; color: var(--text-dim); margin-left: auto; }
/* ═══ EDITOR SPLIT ═══ */
.editor-split { display: flex; gap: 0; }
.editor-split .edit-textarea { flex: 1; min-height: 70vh; }
.editor-split.split-active .edit-textarea { width: 50%; min-height: 70vh; border-right: none; }
.preview-pane {
flex: 1;
background: var(--bg);
border: 1px solid var(--border);
padding: 16px;
overflow-y: auto;
max-height: 70vh;
}
/* ═══ FORM ═══ */
.form-group { margin-bottom: 16px; }
.form-label { display: block; font-size: 12px; color: var(--text-dim); margin-bottom: 4px; }
.form-input {
width: 100%;
background: var(--bg-alt);
border: 1px solid var(--border);
color: var(--text);
font-family: var(--font);
font-size: 14px;
padding: 10px 14px;
outline: none;
}
.form-input:focus { border-color: var(--cyan); }
/* ═══ GRAPH ═══ */
.graph-container {
margin-top: 16px;
border: 1px solid var(--border);
background: var(--bg-alt);
}
.graph-controls {
display: flex;
gap: 12px;
align-items: center;
margin-bottom: 12px;
}
.graph-controls select {
background: var(--bg-alt);
border: 1px solid var(--border);
color: var(--text);
font-family: var(--font);
font-size: 12px;
padding: 4px 8px;
outline: none;
}
.graph-controls label { font-size: 12px; color: var(--text-dim); }
/* ═══ DASHBOARD ═══ */
.dash-stats {
display: flex;
gap: 16px;
margin-bottom: 32px;
flex-wrap: wrap;
}
.dash-stat {
background: var(--bg-alt);
border: 1px solid var(--border);
padding: 16px 24px;
display: flex;
flex-direction: column;
align-items: center;
min-width: 100px;
}
.dash-stat-num { font-size: 28px; font-weight: 700; color: var(--heading); }
.dash-stat-label { font-size: 11px; color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.05em; }
.dash-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
gap: 24px;
}
.dash-section {
background: var(--bg-alt);
border: 1px solid var(--border);
padding: 20px;
max-height: 500px;
overflow-y: auto;
}
.dash-section h2 { font-size: 14px; margin-bottom: 12px; }
.dash-section h2::before { content: none; }
.dash-hint { font-size: 11px; color: var(--text-dim); margin-bottom: 8px; }
.dash-list { display: flex; flex-direction: column; }
.dash-item {
display: flex;
justify-content: space-between;
align-items: baseline;
padding: 6px 0;
border-bottom: 1px solid rgba(46, 52, 64, 0.4);
font-size: 12px;
border: none;
gap: 8px;
}
.dash-item:hover { background: rgba(163, 190, 140, 0.04); }
.dash-item-title { color: var(--text); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dash-item-meta { color: var(--text-dim); font-size: 11px; white-space: nowrap; }
.dash-item-meta.broken { color: var(--red); }
.git-msg { color: var(--text-dim); }
/* ═══ HISTORY ═══ */
.history-list { display: flex; flex-direction: column; gap: 4px; }
.history-entry {
display: grid;
grid-template-columns: 80px 1fr auto;
gap: 12px;
padding: 8px 0;
border-bottom: 1px solid rgba(46, 52, 64, 0.4);
font-size: 12px;
align-items: baseline;
}
.history-hash { color: var(--cyan); font-size: 12px; }
.history-msg { color: var(--text); }
.history-meta { color: var(--text-dim); font-size: 11px; }
.diff-view { margin-bottom: 32px; }
.diff-message { color: var(--text-dim); font-size: 12px; margin-bottom: 8px; }
.diff-content {
background: var(--bg-alt);
border: 1px solid var(--border);
padding: 16px;
font-size: 12px;
overflow-x: auto;
white-space: pre;
line-height: 1.5;
}
/* ═══ RESPONSIVE ═══ */
@media (max-width: 768px) {
.layout { grid-template-columns: 1fr; }
.sidebar {
position: fixed;
top: 0;
left: -280px;
width: 280px;
z-index: 50;
transition: left 0.2s;
}
.sidebar.open { left: 0; }
.sidebar-toggle { display: flex; }
.main {
padding: 60px 20px 32px;
border-left: none;
}
.page-header { flex-direction: column; align-items: flex-start; }
.dir-header, .dir-entry {
grid-template-columns: 20px 1fr 80px;
}
.dir-col-size { display: none; }
.domain-grid { grid-template-columns: 1fr; }
.toc { float: none; width: 100%; margin: 0 0 16px 0; position: static; }
.dash-grid { grid-template-columns: 1fr; }
.editor-split.split-active { flex-direction: column; }
.editor-split.split-active .edit-textarea { width: 100%; min-height: 40vh; }
.preview-pane { max-height: 40vh; }
.history-entry { grid-template-columns: 1fr; gap: 2px; }
}
@media (max-width: 480px) {
.main { padding: 60px 12px 24px; }
h1 { font-size: 20px; }
h2 { font-size: 17px; }
.search-form { flex-direction: column; }
}
/* ═══ F13: PAGE TRANSITIONS ═══ */
@keyframes fadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }
.main { animation: fadeIn 0.15s ease-out; }
/* ═══ F14: PRINT STYLESHEET ═══ */
@media print {
.sidebar, .sidebar-toggle, .btn-edit, .btn-cancel, .btn-save, .btn-search,
.editor-toolbar, .edit-actions, .search-form, .page-actions, .toc,
.nav-link, .nav-new, .graph-controls, .backlinks { display: none !important; }
.layout { display: block !important; }
.main { max-width: 100% !important; padding: 0 !important; border: none !important; animation: none !important; }
body { background: white !important; color: #111 !important; font-size: 12px; }
h1, h2, h3, h4, h5, h6 { color: #111 !important; }
h1::before, h2::before, h3::before { content: none !important; }
a { color: #111 !important; border: none !important; }
a[href]::after { content: " (" attr(href) ")"; font-size: 10px; color: #666; }
a.wikilink::after, a.nav-domain::after { content: none; }
pre, code { background: #f5f5f5 !important; color: #111 !important; border: 1px solid #ddd !important; }
table, th, td { border-color: #ccc !important; }
th { background: #eee !important; color: #111 !important; }
h1 { page-break-before: auto; }
.page-content { page-break-inside: auto; }
img { max-width: 100% !important; }
}
/* ═══ F11: COLORED DIFF ═══ */
.diff-line { display: block; padding: 1px 8px; margin: 0 -8px; }
.diff-add { color: var(--text); background: rgba(163, 190, 140, 0.12); }
.diff-del { color: var(--red); background: rgba(191, 97, 106, 0.12); }
.diff-hunk { color: var(--cyan); background: rgba(136, 192, 208, 0.08); font-weight: 600; }
.diff-ctx { color: var(--text-dim); }
/* ═══ F12: DOMAIN ACCENT COLORS ═══ */
.nav-domain { border-left: 3px solid transparent; padding-left: 8px; }
.meta-domain-colored { padding: 1px 6px; font-size: 10px; border: none; }
/* ═══ F2: DRAG & DROP ═══ */
.editor-dragover { border-color: var(--cyan) !important; box-shadow: inset 0 0 20px rgba(136, 192, 208, 0.1); }
/* ═══ F1: WIKILINK AUTOCOMPLETE ═══ */
.wl-autocomplete {
position: absolute;
z-index: 70;
background: var(--bg);
border: 1px solid var(--border);
max-height: 200px;
overflow-y: auto;
min-width: 280px;
display: none;
}
.wl-autocomplete .suggestion { border: none; border-bottom: 1px solid rgba(46, 52, 64, 0.4); }
/* ═══ F3: DRAFT BANNER ═══ */
.draft-banner {
background: rgba(235, 203, 139, 0.1);
border: 1px solid var(--yellow);
padding: 8px 16px;
margin-bottom: 12px;
font-size: 12px;
display: flex;
align-items: center;
gap: 12px;
}
.draft-banner-text { color: var(--yellow); flex: 1; }
.draft-banner-btn {
background: none;
border: 1px solid var(--border);
color: var(--text);
font-family: var(--font);
font-size: 11px;
padding: 3px 10px;
cursor: pointer;
}
.draft-banner-btn:hover { background: var(--text); color: var(--bg); }
/* ═══ F4: EDITOR TOOLBAR BUTTONS ═══ */
.toolbar-buttons { display: flex; gap: 4px; }
.toolbar-buttons button {
background: var(--bg-alt);
border: 1px solid var(--border);
color: var(--text-dim);
font-family: var(--font);
font-size: 11px;
padding: 3px 8px;
cursor: pointer;
min-width: 28px;
}
.toolbar-buttons button:hover { color: var(--cyan); border-color: var(--cyan); }
/* ═══ F17: SHORTCUTS HELP ═══ */
.shortcuts-overlay {
display: none;
position: fixed;
bottom: 16px;
right: 16px;
z-index: 200;
background: var(--bg-alt);
border: 1px solid var(--border);
padding: 16px;
font-size: 11px;
min-width: 220px;
}
.shortcuts-overlay.visible { display: block; }
.shortcuts-overlay h4 { color: var(--heading); margin-bottom: 8px; font-size: 12px; }
.shortcuts-overlay h4::before { content: none; }
.shortcut-row { display: flex; justify-content: space-between; padding: 2px 0; }
.shortcut-key { color: var(--cyan); background: var(--bg); padding: 1px 6px; font-size: 10px; border: 1px solid var(--border); }
/* ═══ F7: HEALTH BARS ═══ */
.health-table { width: 100%; font-size: 12px; border-collapse: collapse; }
.health-table th { text-align: left; color: var(--text-dim); font-weight: 400; padding: 6px 8px; border-bottom: 1px solid var(--border); font-size: 11px; }
.health-table td { padding: 6px 8px; border-bottom: 1px solid rgba(46, 52, 64, 0.4); }
.health-bar { height: 6px; background: var(--border); border-radius: 3px; overflow: hidden; width: 60px; display: inline-block; vertical-align: middle; }
.health-fill { height: 100%; border-radius: 3px; }
.health-good { background: var(--text); }
.health-mid { background: var(--yellow); }
.health-low { background: var(--red); }
/* ═══ F8: READING TIME ═══ */
.meta-reading { color: var(--text-dim); }
/* ═══ F6: BROKEN LINK FIX ═══ */
.fix-btn {
background: none;
border: 1px solid var(--text);
color: var(--text);
font-family: var(--font);
font-size: 10px;
padding: 2px 8px;
cursor: pointer;
margin-left: 8px;
}
.fix-btn:hover { background: var(--text); color: var(--bg); }
/* ═══ F16: LOGIN ═══ */
.login-container {
display: flex;
align-items: center;
justify-content: center;
min-height: 100vh;
background: var(--bg);
}
.login-box {
background: var(--bg-alt);
border: 1px solid var(--border);
padding: 32px;
width: 360px;
max-width: 90vw;
}
.login-box h1 { text-align: center; margin-bottom: 24px; }
.login-error { color: var(--red); font-size: 12px; margin-bottom: 12px; }
.login-box .form-group { margin-bottom: 16px; }
.login-box .btn-save { width: 100%; }
/* ═══ SIMILAR PAGES ═══ */
.similar-pages { margin-top: 32px; padding-top: 16px; border-top: 1px solid var(--border); }
.similar-pages h3 { font-size: 13px; color: var(--text-dim); margin-bottom: 8px; }
.similar-pages h3::before { content: "≈ "; color: var(--purple); }
.similar-list { display: flex; flex-wrap: wrap; gap: 8px; }
.similar-item { font-size: 12px; padding: 4px 10px; background: var(--bg-alt); border: 1px solid var(--border); }
.similar-item:hover { border-color: var(--purple); }
.similar-domain { color: var(--text-dim); font-size: 10px; margin-left: 4px; }
/* ═══ COMMENTS ═══ */
.comments-section { margin-top: 32px; padding-top: 16px; border-top: 1px solid var(--border); }
.comments-section h3 { font-size: 13px; color: var(--text-dim); margin-bottom: 12px; }
.comments-section h3::before { content: "💬 "; }
.comment { padding: 10px; margin-bottom: 8px; background: var(--bg-alt); border: 1px solid var(--border); position: relative; }
.comment-meta { font-size: 10px; color: var(--text-dim); margin-bottom: 4px; }
.comment-content { font-size: 13px; line-height: 1.6; }
.comment-form { margin-top: 12px; }
.comment-input {
width: 100%; background: var(--bg-alt); border: 1px solid var(--border);
color: var(--text); font-family: var(--font); font-size: 12px; padding: 8px; outline: none; resize: vertical;
}
.comment-input:focus { border-color: var(--cyan); }
.comment-del-btn { position: absolute; top: 8px; right: 8px; background: none; border: none; color: var(--text-dim); font-size: 10px; cursor: pointer; font-family: var(--font); }
.comment-del-btn:hover { color: var(--red); }
.comment-delete { display: inline; }
/* ═══ LINK TOOLTIP (hover preview) ═══ */
.link-tooltip {
position: absolute;
z-index: 200;
background: var(--bg-alt);
border: 1px solid var(--border);
padding: 10px 14px;
max-width: 320px;
font-size: 12px;
line-height: 1.5;
pointer-events: none;
box-shadow: 0 4px 12px rgba(0,0,0,0.4);
}
/* ═══ MINIMAP ═══ */
.minimap {
position: fixed;
right: 8px;
top: 100px;
width: 8px;
height: 100px;
background: var(--bg-alt);
border: 1px solid var(--border);
z-index: 30;
}
.minimap-dot {
position: absolute;
left: 1px;
width: 6px;
height: 3px;
background: var(--yellow);
cursor: pointer;
border-radius: 1px;
}
.minimap-dot:hover { background: var(--heading); }
.minimap-viewport {
position: absolute;
left: 0;
width: 100%;
height: 15px;
background: rgba(163, 190, 140, 0.15);
border: 1px solid rgba(163, 190, 140, 0.3);
pointer-events: none;
}
/* ═══ VIEWERS ═══ */
.meta-viewers { color: var(--cyan); }
/* ═══ LINK SUGGESTIONS (dashboard) ═══ */
.suggestion-target { color: var(--cyan); font-size: 11px; }
/* ═══ SCROLL PROGRESS BAR ═══ */
.scroll-progress {
position: fixed;
top: 0;
left: 0;
height: 2px;
width: 0;
background: linear-gradient(to right, var(--text), var(--cyan));
z-index: 300;
transition: width 0.1s;
}
/* ═══ COMMAND PALETTE ═══ */
.cmd-overlay {
position: fixed;
inset: 0;
background: rgba(0,0,0,0.5);
z-index: 400;
}
.cmd-palette {
position: fixed;
top: 20%;
left: 50%;
transform: translateX(-50%);
width: 520px;
max-width: 90vw;
z-index: 401;
background: var(--bg-alt);
border: 1px solid var(--border);
box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}
.cmd-input {
width: 100%;
background: var(--bg);
border: none;
border-bottom: 1px solid var(--border);
color: var(--text);
font-family: var(--font);
font-size: 15px;
padding: 14px 16px;
outline: none;
}
.cmd-input::placeholder { color: var(--text-dim); }
.cmd-results { max-height: 320px; overflow-y: auto; }
.cmd-result {
display: flex;
justify-content: space-between;
align-items: center;
padding: 10px 16px;
border: none;
border-bottom: 1px solid rgba(46, 52, 64, 0.3);
font-size: 13px;
}
.cmd-result:hover, .cmd-result.active { background: rgba(163, 190, 140, 0.08); }
.cmd-result-title { color: var(--text); }
.cmd-result-type { color: var(--text-dim); font-size: 11px; }
.cmd-empty { padding: 16px; color: var(--text-dim); font-size: 13px; text-align: center; }
/* ═══ SEARCH FILTER ═══ */
.search-filter {
background: var(--bg-alt);
border: 1px solid var(--border);
color: var(--text);
font-family: var(--font);
font-size: 13px;
padding: 10px;
outline: none;
min-width: 180px;
}
.search-filter:focus { border-color: var(--cyan); }
/* ═══ CODE COPY BUTTON ═══ */
.code-copy-btn {
position: absolute;
top: 4px;
right: 4px;
background: var(--bg);
border: 1px solid var(--border);
color: var(--text-dim);
font-family: var(--font);
font-size: 10px;
padding: 2px 8px;
cursor: pointer;
opacity: 0;
transition: opacity 0.15s;
}
pre:hover .code-copy-btn { opacity: 1; }
.code-copy-btn:hover { color: var(--cyan); border-color: var(--cyan); }
/* ═══ LIGHTBOX ═══ */
.lightbox-overlay {
position: fixed;
inset: 0;
background: rgba(0,0,0,0.85);
z-index: 500;
display: flex;
align-items: center;
justify-content: center;
cursor: zoom-out;
}
.lightbox-img {
max-width: 90vw;
max-height: 90vh;
border: 1px solid var(--border);
cursor: default;
}
/* ═══ TABLE SORT ═══ */
th.sorted-asc::after { content: " ▲"; color: var(--yellow); font-size: 10px; }
th.sorted-desc::after { content: " ▼"; color: var(--yellow); font-size: 10px; }
/* ═══ TOC ACTIVE ═══ */
.toc a.toc-active { color: var(--cyan); font-weight: 600; }
/* ═══ STALE WARNING ═══ */
.meta-stale {
background: rgba(191, 97, 106, 0.15);
color: var(--red);
padding: 1px 6px;
font-size: 10px;
}
/* ═══ ACTIVITY FEED ═══ */
.activity-feed { display: flex; flex-direction: column; }
.activity-entry {
display: flex;
align-items: flex-start;
gap: 12px;
padding: 10px 0;
border-bottom: 1px solid rgba(46, 52, 64, 0.4);
}
.activity-dot { width: 8px; height: 8px; border-radius: 50%; margin-top: 6px; flex-shrink: 0; }
.activity-content { flex: 1; min-width: 0; }
.activity-title { display: block; font-size: 13px; color: var(--text); }
.activity-meta { font-size: 11px; color: var(--text-dim); }
@media (max-width: 768px) {
.minimap { display: none; }
.link-tooltip { display: none; }
.cmd-palette { width: 95vw; top: 10%; }
}