1274 lines
32 KiB
CSS
1274 lines
32 KiB
CSS
|
|
/* =============================================================
|
|||
|
|
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%; }
|
|||
|
|
}
|