mirror of
https://github.com/tdurieux/anonymous_github.git
synced 2026-05-15 14:38:03 +02:00
5122 lines
120 KiB
CSS
5122 lines
120 KiB
CSS
/* ===== Paper design tokens =====
|
||
Editorial minimal — warm neutrals, single indigo accent.
|
||
Serif display (Instrument Serif), Inter body, JetBrains Mono. */
|
||
|
||
.dark-mode {
|
||
/* Warm charcoal — softened from pure black */
|
||
--canvas-bg-color: #1f1f1f;
|
||
--sidebar-bg-color: #1A1918;
|
||
--main-bg-color: #1f1f1f;
|
||
--header-bg-color: #1A1918;
|
||
|
||
--hover-bg-color: rgba(255, 255, 255, 0.05);
|
||
--header-color: #FAF9F6;
|
||
--color: #D6D1C5;
|
||
--link-color: #A7B2FF;
|
||
--link-hover-color: #C8CEFF;
|
||
--border-color: #33302B;
|
||
--border-soft: #2A2825;
|
||
|
||
--btn-color: #FAF9F6;
|
||
|
||
--input-color: #E6E1D8;
|
||
--input-bg: #25231F;
|
||
|
||
--primary-bg: #FAF9F6;
|
||
--primary-hover-bg: #FFFFFF;
|
||
--primary-color: #1A1815;
|
||
--primary-active-color: #1A1815;
|
||
|
||
--accent: #A7B2FF;
|
||
--accent-soft: rgba(167, 178, 255, 0.12);
|
||
--ink-muted: #8A857C;
|
||
--ink-soft: #B5AFA2;
|
||
|
||
--admin-nav-bg: #1A1918;
|
||
--admin-nav-active: rgba(167, 178, 255, 0.12);
|
||
--admin-stat-bg: #25231F;
|
||
|
||
--paper-card: #25231F;
|
||
--paper-bg-alt: #201E1B;
|
||
--highlight: #3A341E;
|
||
|
||
background-color: var(--canvas-bg-color);
|
||
color: var(--color);
|
||
}
|
||
|
||
body {
|
||
/* Paper palette */
|
||
--canvas-bg-color: #FAF9F6;
|
||
--sidebar-bg-color: #FFFFFF;
|
||
--header-bg-color: #FAF9F6;
|
||
--header-color: #1A1815;
|
||
--main-bg-color: #FAF9F6;
|
||
--hover-bg-color: rgba(26, 24, 21, 0.05);
|
||
--input-color: #1A1815;
|
||
--color: #1A1815;
|
||
--link-color: #3B4AD6;
|
||
--link-hover-color: #2E3BB8;
|
||
--border-color: #E6E1D8;
|
||
--border-soft: #EDE9E1;
|
||
|
||
--btn-color: #1A1815;
|
||
|
||
--input-bg: #FFFFFF;
|
||
|
||
--primary-bg: #1A1815;
|
||
--primary-hover-bg: #000000;
|
||
--primary-color: #FAF9F6;
|
||
--primary-active-color: #FAF9F6;
|
||
|
||
--accent: #3B4AD6;
|
||
--accent-soft: #EEF0FF;
|
||
--ink-muted: #8A857C;
|
||
--ink-soft: #4A4641;
|
||
--paper-bg-alt: #F3F1EC;
|
||
--paper-card: #FFFFFF;
|
||
--highlight: #FFF3C4;
|
||
|
||
--font-serif: 'Instrument Serif', 'Iowan Old Style', Georgia, serif;
|
||
--font-sans: 'Inter', ui-sans-serif, system-ui, -apple-system, sans-serif;
|
||
--font-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
|
||
|
||
background-color: var(--canvas-bg-color);
|
||
color: var(--color);
|
||
font-family: var(--font-sans);
|
||
font-size: 14px;
|
||
letter-spacing: -0.005em;
|
||
line-height: 1.5;
|
||
}
|
||
|
||
.fadeIn {
|
||
opacity: 1;
|
||
animation-name: fadeInOpacity;
|
||
animation-iteration-count: 1;
|
||
animation-timing-function: ease-in;
|
||
animation-duration: 0.6s;
|
||
}
|
||
|
||
@keyframes fadeInOpacity {
|
||
0% {
|
||
opacity: 0;
|
||
}
|
||
|
||
100% {
|
||
opacity: 1;
|
||
}
|
||
}
|
||
|
||
.btn:focus,
|
||
.btn:active {
|
||
outline: none !important;
|
||
box-shadow: none;
|
||
}
|
||
|
||
textarea,
|
||
select,
|
||
input,
|
||
button {
|
||
outline: none;
|
||
}
|
||
|
||
input:hover,
|
||
input:active {
|
||
box-shadow: none !important;
|
||
}
|
||
|
||
input:-webkit-autofill,
|
||
input:-webkit-autofill:hover,
|
||
input:-webkit-autofill:focus,
|
||
textarea:-webkit-autofill,
|
||
textarea:-webkit-autofill:hover,
|
||
textarea:-webkit-autofill:focus,
|
||
select:-webkit-autofill,
|
||
select:-webkit-autofill:hover,
|
||
select:-webkit-autofill:focus {
|
||
border-color: var(--border-color);
|
||
-webkit-text-fill-color: var(--color);
|
||
-webkit-box-shadow: none;
|
||
transition: background-color 1000s ease-in-out 0s;
|
||
}
|
||
|
||
input:-internal-autofill-selected,
|
||
.form-control,
|
||
.custom-select {
|
||
color: var(--input-color);
|
||
background-color: var(--input-bg) !important;
|
||
border-color: var(--border-color);
|
||
}
|
||
|
||
.form-control:focus {
|
||
border-color: var(--border-color);
|
||
}
|
||
|
||
html,
|
||
body {
|
||
position: relative;
|
||
height: 100%;
|
||
overflow-x: hidden;
|
||
}
|
||
|
||
/* Prevent ng-view from scrolling horizontally */
|
||
[ng-view] {
|
||
overflow-x: hidden !important;
|
||
overflow-y: auto !important;
|
||
max-width: 100%;
|
||
}
|
||
|
||
.markdown-body a,
|
||
a {
|
||
color: var(--link-color);
|
||
}
|
||
|
||
.markdown-body a:hover,
|
||
a:hover {
|
||
text-decoration: none;
|
||
color: var(--link-hover-color);
|
||
}
|
||
|
||
.dropdown-menu a.dropdown-item {
|
||
color: var(--color);
|
||
}
|
||
.dropdown-menu a.dropdown-item:hover {
|
||
color: var(--color);
|
||
text-decoration: none;
|
||
}
|
||
|
||
.markdown-body .emoji {
|
||
height: 1.3em;
|
||
margin: 0;
|
||
vertical-align: -0.1em;
|
||
}
|
||
|
||
.navbar.navbar-expand-lg {
|
||
background: var(--header-bg-color) !important;
|
||
border-bottom: 1px solid var(--border-color);
|
||
transition: background-color 0.5s ease;
|
||
padding: 10px max(20px, calc((100vw - 1200px) / 2));
|
||
font-family: var(--font-sans);
|
||
}
|
||
|
||
.navbar-toggler {
|
||
border: 1px solid var(--border-color) !important;
|
||
color: var(--color) !important;
|
||
}
|
||
.navbar-toggler .navbar-toggler-icon {
|
||
background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30'%3E%3Cpath stroke='%231A1815' stroke-width='2' stroke-linecap='round' d='M4 8h22M4 15h22M4 22h22'/%3E%3C/svg%3E") !important;
|
||
}
|
||
|
||
.navbar .navbar-nav {
|
||
align-items: center;
|
||
}
|
||
|
||
.navbar .nav-link {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
font-size: 13px;
|
||
color: var(--ink-muted) !important;
|
||
padding: 6px 0 !important;
|
||
margin: 0 12px;
|
||
border-bottom: 1px solid transparent;
|
||
letter-spacing: -0.005em;
|
||
line-height: 1;
|
||
}
|
||
|
||
.navbar .nav-link:hover {
|
||
color: var(--color) !important;
|
||
}
|
||
|
||
.navbar .nav-link.active {
|
||
color: var(--color) !important;
|
||
border-bottom-color: var(--color);
|
||
}
|
||
|
||
.navbar .nav-link.nav-icon {
|
||
padding: 0 !important;
|
||
margin: 0 8px;
|
||
display: inline-flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
width: 28px;
|
||
height: 28px;
|
||
}
|
||
|
||
.navbar .nav-link .fa,
|
||
.navbar .nav-link .fab {
|
||
font-size: 15px;
|
||
line-height: 1;
|
||
}
|
||
|
||
.navbar #navbarSupportedContent {
|
||
align-items: center;
|
||
}
|
||
|
||
.navbar-brand {
|
||
font-family: var(--font-serif) !important;
|
||
font-size: 20px !important;
|
||
letter-spacing: -0.01em;
|
||
color: var(--color) !important;
|
||
padding-right: 18px;
|
||
margin-right: 12px;
|
||
border-right: 1px solid var(--border-color);
|
||
}
|
||
|
||
.navbar-brand em,
|
||
.navbar-brand i {
|
||
font-style: italic;
|
||
font-weight: 400;
|
||
}
|
||
|
||
.navbar-dark .navbar-toggler {
|
||
border-color: var(--border-color);
|
||
color: var(--color);
|
||
}
|
||
|
||
.navbar-dark .navbar-toggler-icon {
|
||
background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30'%3E%3Cpath stroke='%231A1815' stroke-width='2' stroke-linecap='round' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
|
||
}
|
||
|
||
.navbar .btn-signin {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
height: 32px;
|
||
padding: 0 14px !important;
|
||
margin-left: 6px;
|
||
border: 1px solid var(--color);
|
||
background: var(--color);
|
||
color: var(--canvas-bg-color) !important;
|
||
border-radius: 6px;
|
||
font-size: 13px;
|
||
font-weight: 500;
|
||
line-height: 1;
|
||
}
|
||
|
||
.navbar .btn-signin:hover {
|
||
background: var(--primary-hover-bg);
|
||
color: var(--canvas-bg-color) !important;
|
||
}
|
||
|
||
.navbar .user-chip {
|
||
display: inline-flex !important;
|
||
align-items: center;
|
||
gap: 8px;
|
||
padding: 4px 12px 4px 6px !important;
|
||
margin-left: 6px;
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 999px;
|
||
background: var(--sidebar-bg-color);
|
||
font-size: 12.5px;
|
||
color: var(--color) !important;
|
||
}
|
||
|
||
.navbar .user-chip:hover {
|
||
background: var(--hover-bg-color);
|
||
}
|
||
|
||
.navbar .user-chip img {
|
||
width: 22px;
|
||
height: 22px;
|
||
}
|
||
|
||
.navbar .user-chip .user-chip-name {
|
||
color: var(--color);
|
||
font-weight: 500;
|
||
}
|
||
|
||
.navbar .user-chip::after {
|
||
color: var(--ink-muted);
|
||
}
|
||
|
||
#navbarSupportedContent {
|
||
padding-right: 0;
|
||
}
|
||
|
||
.generalMessage {
|
||
display: block;
|
||
text-align: center;
|
||
color: var(--header-color);
|
||
}
|
||
|
||
.rgba-gradient {
|
||
background: var(--canvas-bg-color);
|
||
color: var(--color);
|
||
}
|
||
|
||
/* ===== Paper landing — editorial hero ===== */
|
||
|
||
.paper-hero {
|
||
max-width: 1100px;
|
||
margin: 0 auto;
|
||
padding: 72px 32px 40px;
|
||
}
|
||
|
||
.paper-eyebrow {
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
letter-spacing: 0.14em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
font-weight: 500;
|
||
}
|
||
|
||
.paper-hero h1.hero-title {
|
||
font-family: var(--font-serif);
|
||
font-weight: 400;
|
||
font-size: clamp(2.4rem, 6vw, 4.9rem);
|
||
line-height: 1.02;
|
||
letter-spacing: -0.025em;
|
||
margin: 18px 0 0;
|
||
color: var(--color);
|
||
text-wrap: balance;
|
||
}
|
||
|
||
.paper-hero h1 .accent {
|
||
color: var(--accent);
|
||
font-style: italic;
|
||
}
|
||
|
||
.hero-subtitle {
|
||
margin-top: 20px;
|
||
font-size: 17px;
|
||
line-height: 1.55;
|
||
color: var(--ink-soft);
|
||
max-width: 580px;
|
||
text-wrap: pretty;
|
||
opacity: 1;
|
||
}
|
||
|
||
.paper-cta-row {
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
gap: 10px;
|
||
align-items: center;
|
||
margin-top: 32px;
|
||
}
|
||
|
||
.paper-cta-row .meta {
|
||
margin-left: 6px;
|
||
font-size: 12.5px;
|
||
color: var(--ink-muted);
|
||
}
|
||
|
||
.btn-hero {
|
||
font-family: var(--font-sans);
|
||
border: 1px solid var(--color);
|
||
background: var(--color);
|
||
color: var(--canvas-bg-color);
|
||
padding: 12px 20px;
|
||
font-size: 14px;
|
||
font-weight: 500;
|
||
border-radius: 6px;
|
||
letter-spacing: -0.005em;
|
||
transition: background 0.15s, border-color 0.15s, transform 0.1s;
|
||
}
|
||
|
||
.btn-hero:hover {
|
||
background: var(--primary-hover-bg);
|
||
border-color: var(--primary-hover-bg);
|
||
color: var(--canvas-bg-color);
|
||
}
|
||
|
||
.btn-hero-ghost {
|
||
background: transparent;
|
||
border: 1px solid var(--border-color);
|
||
color: var(--color);
|
||
padding: 12px 20px;
|
||
font-size: 14px;
|
||
font-weight: 500;
|
||
border-radius: 6px;
|
||
}
|
||
|
||
.btn-hero-ghost:hover {
|
||
background: var(--hover-bg-color);
|
||
border-color: var(--color);
|
||
color: var(--color);
|
||
}
|
||
|
||
/* Before/after preview card */
|
||
.paper-preview {
|
||
margin-top: 48px;
|
||
display: grid;
|
||
grid-template-columns: 1fr 1fr;
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 10px;
|
||
overflow: hidden;
|
||
background: var(--paper-card, #fff);
|
||
}
|
||
|
||
.paper-preview .pane {
|
||
padding: 0;
|
||
}
|
||
|
||
.paper-preview .pane + .pane {
|
||
border-left: 1px solid var(--border-color);
|
||
}
|
||
|
||
.paper-preview .pane-header {
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: space-between;
|
||
gap: 12px;
|
||
padding: 12px 18px;
|
||
border-bottom: 1px solid var(--border-color);
|
||
}
|
||
|
||
.paper-preview .pane-label {
|
||
font-family: var(--font-mono);
|
||
font-size: 10.5px;
|
||
letter-spacing: 0.12em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
}
|
||
|
||
.paper-preview .pane-url {
|
||
font-family: var(--font-mono);
|
||
font-size: 11.5px;
|
||
color: var(--ink-soft);
|
||
overflow: hidden;
|
||
text-overflow: ellipsis;
|
||
white-space: nowrap;
|
||
}
|
||
|
||
.paper-preview .pane-body {
|
||
padding: 22px;
|
||
font-family: var(--font-mono);
|
||
font-size: 13.5px;
|
||
line-height: 1.85;
|
||
color: var(--color);
|
||
}
|
||
|
||
.paper-preview .tok {
|
||
color: var(--ink-muted);
|
||
}
|
||
|
||
.paper-preview .redact {
|
||
background: var(--highlight, #FFF3C4);
|
||
padding: 0 4px;
|
||
border-radius: 3px;
|
||
color: var(--color);
|
||
position: relative;
|
||
}
|
||
|
||
.paper-preview .redact::after {
|
||
content: '';
|
||
position: absolute;
|
||
left: 4px;
|
||
right: 4px;
|
||
top: 50%;
|
||
border-top: 1.5px solid var(--color);
|
||
opacity: 0.55;
|
||
}
|
||
|
||
.dark-mode .paper-preview .redact {
|
||
background: rgba(255, 243, 196, 0.15);
|
||
}
|
||
|
||
@media (max-width: 767px) {
|
||
.paper-preview {
|
||
grid-template-columns: 1fr;
|
||
}
|
||
.paper-preview .pane + .pane {
|
||
border-left: none;
|
||
border-top: 1px solid var(--border-color);
|
||
}
|
||
}
|
||
|
||
/* Stats strip */
|
||
.paper-stats {
|
||
border-top: 1px solid var(--border-color);
|
||
border-bottom: 1px solid var(--border-color);
|
||
background: var(--paper-bg-alt, #F3F1EC);
|
||
}
|
||
|
||
.dark-mode .paper-stats {
|
||
background: #181715;
|
||
}
|
||
|
||
.paper-stats-inner {
|
||
max-width: 1100px;
|
||
margin: 0 auto;
|
||
padding: 28px 32px 32px;
|
||
}
|
||
|
||
.paper-stats-meta {
|
||
display: flex;
|
||
justify-content: space-between;
|
||
align-items: center;
|
||
font-family: var(--font-mono, ui-monospace, SFMono-Regular, Menlo, monospace);
|
||
font-size: 11px;
|
||
letter-spacing: 0.08em;
|
||
color: var(--ink-muted);
|
||
margin-bottom: 20px;
|
||
}
|
||
|
||
.paper-stats-meta-left {
|
||
text-transform: uppercase;
|
||
}
|
||
|
||
.paper-stats-meta-right {
|
||
text-transform: lowercase;
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 6px;
|
||
}
|
||
|
||
.paper-stats-dot {
|
||
display: inline-block;
|
||
width: 8px;
|
||
height: 8px;
|
||
border-radius: 50%;
|
||
background: #1f9d55;
|
||
box-shadow: 0 0 0 3px rgba(31, 157, 85, 0.18);
|
||
}
|
||
|
||
.paper-stats-grid {
|
||
display: grid;
|
||
grid-template-columns: repeat(4, 1fr);
|
||
gap: 32px;
|
||
}
|
||
|
||
@media (max-width: 900px) {
|
||
.paper-stats-grid { grid-template-columns: repeat(2, 1fr); gap: 28px; }
|
||
}
|
||
|
||
.paper-stat-card {
|
||
display: flex;
|
||
flex-direction: column;
|
||
}
|
||
|
||
.paper-stat-value {
|
||
font-family: var(--font-serif);
|
||
font-size: 56px;
|
||
line-height: 1;
|
||
color: var(--color);
|
||
letter-spacing: -0.02em;
|
||
}
|
||
|
||
.paper-stat-label {
|
||
margin-top: 10px;
|
||
font-size: 13px;
|
||
color: var(--ink-muted);
|
||
}
|
||
|
||
.paper-stat-bars {
|
||
display: block;
|
||
width: 100%;
|
||
height: 36px;
|
||
margin-top: 16px;
|
||
overflow: visible;
|
||
}
|
||
|
||
.paper-stat-bars rect {
|
||
fill: var(--ink-muted);
|
||
opacity: 0.35;
|
||
}
|
||
|
||
.paper-stat-bars rect.is-latest {
|
||
fill: #2937e3;
|
||
opacity: 1;
|
||
}
|
||
|
||
.dark-mode .paper-stat-bars rect.is-latest {
|
||
fill: #6c7bff;
|
||
}
|
||
|
||
.paper-stat-delta {
|
||
margin-top: 12px;
|
||
font-family: var(--font-mono, ui-monospace, SFMono-Regular, Menlo, monospace);
|
||
font-size: 12px;
|
||
color: var(--ink-muted);
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 8px;
|
||
}
|
||
|
||
.paper-stat-sep {
|
||
opacity: 0.5;
|
||
}
|
||
|
||
.paper-stat-pct.is-up {
|
||
color: #1f9d55;
|
||
}
|
||
|
||
.paper-stat-pct.is-down {
|
||
color: #b54137;
|
||
}
|
||
|
||
.paper-stat-arrow {
|
||
font-size: 10px;
|
||
margin-right: 2px;
|
||
}
|
||
|
||
/* How it works — editorial numbered steps */
|
||
.paper-how {
|
||
max-width: 1100px;
|
||
margin: 0 auto;
|
||
padding: 64px 32px;
|
||
display: grid;
|
||
grid-template-columns: 260px 1fr;
|
||
gap: 56px;
|
||
}
|
||
|
||
.paper-how-heading {
|
||
font-family: var(--font-serif);
|
||
font-weight: 400;
|
||
font-size: 32px;
|
||
line-height: 1.1;
|
||
margin-top: 12px;
|
||
letter-spacing: -0.02em;
|
||
}
|
||
|
||
.paper-step {
|
||
display: grid;
|
||
grid-template-columns: 64px 1fr;
|
||
gap: 20px;
|
||
padding: 22px 0;
|
||
border-bottom: 1px solid var(--border-color);
|
||
}
|
||
|
||
.paper-step:first-child {
|
||
border-top: 1px solid var(--border-color);
|
||
}
|
||
|
||
.paper-step .step-num {
|
||
font-family: var(--font-mono);
|
||
font-size: 12px;
|
||
color: var(--ink-muted);
|
||
padding-top: 6px;
|
||
}
|
||
|
||
.paper-step .step-title {
|
||
font-family: var(--font-serif);
|
||
font-size: 22px;
|
||
letter-spacing: -0.01em;
|
||
line-height: 1.2;
|
||
}
|
||
|
||
.paper-step .step-desc {
|
||
margin-top: 6px;
|
||
color: var(--ink-soft);
|
||
max-width: 560px;
|
||
text-wrap: pretty;
|
||
}
|
||
|
||
.paper-step .step-desc a {
|
||
color: var(--accent);
|
||
}
|
||
|
||
@media (max-width: 767px) {
|
||
.paper-how {
|
||
grid-template-columns: 1fr;
|
||
gap: 24px;
|
||
padding: 40px 20px;
|
||
}
|
||
}
|
||
|
||
/* Trust row — conferences */
|
||
.paper-trust {
|
||
max-width: 1100px;
|
||
margin: 0 auto 80px;
|
||
padding: 0 32px;
|
||
}
|
||
|
||
.paper-trust-inner {
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 10px;
|
||
padding: 24px 28px;
|
||
display: grid;
|
||
grid-template-columns: 1.3fr 1fr 1fr 1fr;
|
||
gap: 28px;
|
||
background: var(--paper-card, #fff);
|
||
}
|
||
|
||
.dark-mode .paper-trust-inner {
|
||
background: var(--admin-stat-bg);
|
||
}
|
||
|
||
.paper-trust-lede {
|
||
font-family: var(--font-serif);
|
||
font-size: 22px;
|
||
line-height: 1.25;
|
||
margin-top: 10px;
|
||
text-wrap: balance;
|
||
}
|
||
|
||
.paper-trust-item {
|
||
border-left: 1px solid var(--border-color);
|
||
padding-left: 20px;
|
||
}
|
||
|
||
.paper-trust-item .short {
|
||
font-family: var(--font-serif);
|
||
font-size: 26px;
|
||
letter-spacing: -0.01em;
|
||
}
|
||
|
||
.paper-trust-item .long {
|
||
font-size: 11.5px;
|
||
color: var(--ink-muted);
|
||
margin-top: 4px;
|
||
line-height: 1.4;
|
||
text-wrap: pretty;
|
||
}
|
||
|
||
@media (max-width: 767px) {
|
||
.paper-trust-inner {
|
||
grid-template-columns: 1fr;
|
||
gap: 16px;
|
||
padding: 20px;
|
||
}
|
||
.paper-trust-item {
|
||
border-left: none;
|
||
border-top: 1px solid var(--border-color);
|
||
padding-left: 0;
|
||
padding-top: 16px;
|
||
}
|
||
}
|
||
|
||
/* Legacy featurette / home-content left in place but restyled */
|
||
.home-content {
|
||
max-width: 900px;
|
||
}
|
||
|
||
.usage-steps {
|
||
font-size: 1.05rem;
|
||
line-height: 1.8;
|
||
padding-left: 1.2em;
|
||
}
|
||
|
||
.usage-example {
|
||
font-size: 0.9rem;
|
||
color: var(--ink-muted);
|
||
margin-top: 8px;
|
||
}
|
||
|
||
.featurette-lead {
|
||
font-size: 1.05rem;
|
||
line-height: 1.7;
|
||
color: var(--ink-soft);
|
||
}
|
||
|
||
/* Metrics grid */
|
||
.metrics-grid {
|
||
display: grid;
|
||
grid-template-columns: repeat(3, 1fr);
|
||
gap: 16px;
|
||
margin-bottom: 48px;
|
||
}
|
||
|
||
.metric-card {
|
||
text-align: center;
|
||
padding: 24px 16px;
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 8px;
|
||
background: var(--admin-stat-bg);
|
||
}
|
||
|
||
.metric-value {
|
||
font-family: var(--font-serif);
|
||
font-size: 2.4rem;
|
||
font-weight: 400;
|
||
line-height: 1.1;
|
||
letter-spacing: -0.02em;
|
||
}
|
||
|
||
.metric-label {
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
text-transform: uppercase;
|
||
letter-spacing: 0.12em;
|
||
color: var(--ink-muted);
|
||
margin-top: 6px;
|
||
}
|
||
|
||
.dropdown-menu {
|
||
background-color: var(--paper-card, var(--main-bg-color)) !important;
|
||
color: var(--color) !important;
|
||
border: 1px solid var(--border-color) !important;
|
||
border-radius: 8px !important;
|
||
box-shadow: 0 12px 28px rgba(26, 24, 21, 0.08), 0 2px 6px rgba(26, 24, 21, 0.05) !important;
|
||
padding: 6px !important;
|
||
font-family: var(--font-sans);
|
||
font-size: 13px;
|
||
min-width: 11rem;
|
||
}
|
||
|
||
.dropdown-menu .dropdown-item {
|
||
color: var(--color) !important;
|
||
padding: 7px 10px !important;
|
||
border-radius: 5px;
|
||
font-size: 13px;
|
||
}
|
||
|
||
.dropdown-menu .dropdown-item:hover,
|
||
.dropdown-menu .dropdown-item:focus {
|
||
background: var(--hover-bg-color) !important;
|
||
color: var(--color) !important;
|
||
}
|
||
|
||
.dropdown-menu .dropdown-divider {
|
||
border-top-color: var(--border-color) !important;
|
||
margin: 4px 2px;
|
||
}
|
||
|
||
.dropdown-menu .dropdown-header {
|
||
color: var(--ink-muted);
|
||
font-family: var(--font-mono);
|
||
font-size: 10.5px;
|
||
letter-spacing: 0.08em;
|
||
text-transform: uppercase;
|
||
}
|
||
|
||
.body,
|
||
.file-content,
|
||
.markdown-body {
|
||
background-color: var(--main-bg-color) !important;
|
||
color: var(--color) !important;
|
||
}
|
||
|
||
.markdown-body table tr {
|
||
background-color: var(--main-bg-color);
|
||
border-top: 1px solid var(--border-color);
|
||
}
|
||
|
||
.markdown-body table tr:nth-child(2n) {
|
||
background-color: var(--paper-bg-alt);
|
||
}
|
||
|
||
.markdown-body table td,
|
||
.markdown-body table th {
|
||
border: 1px solid var(--border-color);
|
||
}
|
||
|
||
.file-content {
|
||
padding: 4px 7px;
|
||
text-align: left;
|
||
min-height: 100%;
|
||
}
|
||
|
||
.badge {
|
||
font-size: 75%;
|
||
font-weight: 500;
|
||
padding: 3px 8px;
|
||
border-radius: 10px;
|
||
vertical-align: middle;
|
||
}
|
||
|
||
.warning-feedback {
|
||
width: 100%;
|
||
margin-top: 0.25rem;
|
||
font-size: 80%;
|
||
color: #dc8e35;
|
||
}
|
||
|
||
.dropdown-item:focus,
|
||
.dropdown-item:hover {
|
||
background-color: var(--hover-bg-color);
|
||
}
|
||
|
||
.card-header .btn,
|
||
.card-header .btn:hover,
|
||
.card-header .btn:focus {
|
||
border: none !important;
|
||
background: transparent !important;
|
||
}
|
||
|
||
.btn {
|
||
color: var(--btn-color);
|
||
border: 1px solid var(--border-color);
|
||
background: transparent;
|
||
border-radius: 4px;
|
||
white-space: nowrap;
|
||
}
|
||
|
||
.btn:hover,
|
||
.btn:active {
|
||
color: var(--btn-color);
|
||
border: 1px solid var(--border-color);
|
||
background-color: var(--hover-bg-color);
|
||
box-shadow: none !important;
|
||
}
|
||
|
||
.btn.btn-primary {
|
||
color: var(--primary-color);
|
||
background-color: var(--primary-bg);
|
||
}
|
||
|
||
.btn.btn-primary:active,
|
||
.btn.btn-primary:hover {
|
||
color: var(--primary-active-color);
|
||
background-color: var(--primary-hover-bg) !important;
|
||
}
|
||
|
||
.btn::placeholder {
|
||
/* Chrome, Firefox, Opera, Safari 10.1+ */
|
||
color: var(--color);
|
||
opacity: 1;
|
||
/* Firefox */
|
||
}
|
||
|
||
.white_border {
|
||
border: 1px solid white;
|
||
color: white;
|
||
}
|
||
|
||
.leftCol {
|
||
display: flex;
|
||
position: relative;
|
||
flex: 0 0 auto;
|
||
width: 100%;
|
||
z-index: 9;
|
||
flex-direction: column;
|
||
}
|
||
|
||
.leftCol,
|
||
.sidePanel,
|
||
.card {
|
||
background-color: var(--sidebar-bg-color);
|
||
border: 1px solid var(--border-color);
|
||
}
|
||
|
||
@media (min-width: 768px) {
|
||
.leftCol {
|
||
flex: 0 0 310px;
|
||
width: 310px;
|
||
height: 100%;
|
||
}
|
||
}
|
||
|
||
.files {
|
||
position: relative;
|
||
display: block;
|
||
overflow: auto;
|
||
height: 100%;
|
||
padding: 8px 6px;
|
||
}
|
||
|
||
.files ul {
|
||
list-style: none;
|
||
margin: 0;
|
||
padding: 0;
|
||
}
|
||
|
||
.files li ul {
|
||
padding-left: 14px;
|
||
margin-left: 6px;
|
||
border-left: 1px dashed var(--border-color);
|
||
}
|
||
|
||
.files .folder > ul { display: none; }
|
||
.files .folder.open > ul { display: block; }
|
||
|
||
.files .file,
|
||
.files .folder {
|
||
position: relative;
|
||
color: var(--ink-soft);
|
||
cursor: pointer;
|
||
word-break: break-all;
|
||
}
|
||
|
||
.files a {
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 6px;
|
||
padding: 3px 8px 3px 26px;
|
||
font-family: var(--font-mono);
|
||
font-size: 12.5px;
|
||
color: var(--ink-soft);
|
||
border-radius: 4px;
|
||
text-decoration: none;
|
||
line-height: 1.55;
|
||
position: relative;
|
||
}
|
||
|
||
.files a:hover {
|
||
background: var(--hover-bg-color);
|
||
color: var(--color);
|
||
text-decoration: none;
|
||
}
|
||
|
||
.files .file.active > a {
|
||
background: var(--color);
|
||
color: var(--paper-card);
|
||
}
|
||
.files .file.active > a::before { color: var(--paper-card) !important; opacity: 0.85; }
|
||
|
||
.files .file::before,
|
||
.files .folder::before {
|
||
font-family: 'Font Awesome 5 Free';
|
||
font-weight: 400;
|
||
position: absolute;
|
||
left: 8px;
|
||
top: 4px;
|
||
width: 14px;
|
||
font-size: 12px;
|
||
color: var(--ink-muted);
|
||
text-align: center;
|
||
pointer-events: none;
|
||
z-index: 1;
|
||
}
|
||
|
||
.files .file::before {
|
||
content: "\f15b";
|
||
font-weight: 400;
|
||
}
|
||
|
||
.files .folder::before {
|
||
content: "\f07b";
|
||
font-weight: 900;
|
||
color: var(--color);
|
||
opacity: 0.7;
|
||
}
|
||
|
||
.files .folder.open::before {
|
||
content: "\f07c";
|
||
opacity: 1;
|
||
}
|
||
|
||
.files .folder > a {
|
||
color: var(--color);
|
||
font-weight: 500;
|
||
}
|
||
|
||
.files .folder > a::after {
|
||
content: "\f105";
|
||
font-family: 'Font Awesome 5 Free';
|
||
font-weight: 900;
|
||
font-size: 10px;
|
||
color: var(--ink-muted);
|
||
position: absolute;
|
||
left: -2px;
|
||
top: 6px;
|
||
transition: transform 0.12s ease;
|
||
}
|
||
|
||
.files .folder.open > a::after {
|
||
transform: rotate(90deg);
|
||
}
|
||
|
||
/* ===== Explorer IDE chrome ===== */
|
||
.leftCol {
|
||
background: var(--paper-bg-alt, #F3F1EC);
|
||
border-right: 1px solid var(--border-color);
|
||
}
|
||
.dark-mode .leftCol { background: var(--sidebar-bg-color); }
|
||
|
||
.status-bar {
|
||
background: var(--canvas-bg-color);
|
||
border-bottom: 1px solid var(--border-color);
|
||
padding: 10px 14px;
|
||
}
|
||
|
||
.paths .breadcrumb-item,
|
||
.paths .breadcrumb-item a {
|
||
font-family: var(--font-mono);
|
||
font-size: 12px;
|
||
color: var(--ink-muted);
|
||
letter-spacing: 0.02em;
|
||
}
|
||
.paths .breadcrumb-item.active,
|
||
.paths .breadcrumb-item:last-child {
|
||
color: var(--color);
|
||
}
|
||
.paths .breadcrumb-item + .breadcrumb-item::before {
|
||
content: '/';
|
||
color: var(--ink-muted);
|
||
}
|
||
|
||
.last-update {
|
||
font-family: var(--font-mono);
|
||
font-size: 10.5px;
|
||
color: var(--ink-muted);
|
||
padding: 8px 10px;
|
||
border-top: 1px solid var(--border-color);
|
||
letter-spacing: 0.02em;
|
||
}
|
||
|
||
.ace_editor {
|
||
height: 100%;
|
||
}
|
||
|
||
.ace_scroller {
|
||
cursor: default;
|
||
}
|
||
|
||
.status-bar {
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 12px;
|
||
background-color: var(--canvas-bg-color);
|
||
padding: 10px 14px;
|
||
margin: 0;
|
||
border-bottom: 1px solid var(--border-color);
|
||
border-radius: 0;
|
||
flex-shrink: 0;
|
||
}
|
||
.status-bar-actions {
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 6px;
|
||
flex-shrink: 0;
|
||
}
|
||
.status-bar-actions .btn {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 6px;
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
color: var(--color);
|
||
border-radius: 6px;
|
||
padding: 4px 10px;
|
||
font-size: 12.5px;
|
||
min-height: 30px;
|
||
}
|
||
.status-bar-actions .btn:hover {
|
||
background: var(--hover-bg-color);
|
||
color: var(--color);
|
||
}
|
||
|
||
.paths {
|
||
flex: 1 1 auto;
|
||
min-width: 0;
|
||
padding: 0;
|
||
margin: 0;
|
||
background-color: initial;
|
||
border: none;
|
||
border-radius: 0;
|
||
align-items: center;
|
||
overflow-x: auto;
|
||
white-space: nowrap;
|
||
flex-wrap: nowrap;
|
||
}
|
||
.paths::-webkit-scrollbar { display: none; }
|
||
|
||
.paths a {
|
||
color: var(--color);
|
||
}
|
||
|
||
.paths .breadcrumb-item {
|
||
padding-left: 3px;
|
||
}
|
||
|
||
.paths .breadcrumb-item::before {
|
||
padding-right: 3px;
|
||
}
|
||
|
||
.content {
|
||
height: 100%;
|
||
overflow: scroll;
|
||
padding-top: 42px;
|
||
background-color: var(--main-bg-color);
|
||
text-align: center;
|
||
}
|
||
|
||
.image-content {
|
||
max-width: 100%;
|
||
max-height: 100%;
|
||
text-align: center;
|
||
padding: 4px;
|
||
}
|
||
|
||
.file-error {
|
||
font-weight: bold;
|
||
font-size: 50px;
|
||
text-align: center;
|
||
}
|
||
|
||
pdfviewer {
|
||
display: block;
|
||
padding: 15px;
|
||
}
|
||
|
||
pdfpageviewer {
|
||
display: block;
|
||
width: 100%;
|
||
margin-bottom: 10px;
|
||
}
|
||
|
||
notebook {
|
||
display: block;
|
||
text-align: left;
|
||
padding: 15px;
|
||
}
|
||
|
||
@media (min-width: 768px) {
|
||
notebook {
|
||
padding-left: 100px;
|
||
}
|
||
}
|
||
|
||
.nb-output th,
|
||
.nb-output td {
|
||
border: 1px solid var(--border-color) !important;
|
||
}
|
||
|
||
.floatingchat-container-wrap {
|
||
left: auto !important;
|
||
top: auto !important;
|
||
bottom: 3px !important;
|
||
height: 47px !important;
|
||
right: 3px !important;
|
||
}
|
||
|
||
.floating-chat-kofi-popup-iframe {
|
||
left: auto !important;
|
||
top: auto !important;
|
||
bottom: 55px !important;
|
||
right: 10px !important;
|
||
}
|
||
|
||
/* ===== Paper FAQ (two-col editorial) ===== */
|
||
.paper-faq {
|
||
max-width: 1180px;
|
||
margin: 0 auto;
|
||
padding: 48px 32px 80px;
|
||
font-family: var(--font-sans);
|
||
}
|
||
.paper-faq-hero {
|
||
padding-bottom: 40px;
|
||
border-bottom: 1px solid var(--border-color);
|
||
margin-bottom: 36px;
|
||
}
|
||
.paper-faq-eyebrow {
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
color: var(--ink-muted);
|
||
letter-spacing: 0.14em;
|
||
text-transform: uppercase;
|
||
margin-bottom: 32px;
|
||
}
|
||
.paper-faq-title {
|
||
font-family: var(--font-serif);
|
||
font-weight: 400;
|
||
font-size: clamp(2.6rem, 5.5vw, 4.6rem);
|
||
line-height: 1.03;
|
||
letter-spacing: -0.02em;
|
||
color: var(--color);
|
||
margin: 0 0 22px;
|
||
max-width: 14em;
|
||
}
|
||
.paper-faq-title em { font-style: italic; color: var(--color); }
|
||
.paper-faq-lede {
|
||
color: var(--ink-soft);
|
||
font-size: 17px;
|
||
line-height: 1.55;
|
||
max-width: 38em;
|
||
margin: 0;
|
||
}
|
||
.paper-faq-lede a { color: var(--color); border-bottom: 1px solid var(--color); }
|
||
.paper-faq-lede a:hover { color: var(--accent); border-bottom-color: var(--accent); }
|
||
|
||
.paper-faq-body {
|
||
display: grid;
|
||
grid-template-columns: 220px 1fr;
|
||
gap: 60px;
|
||
align-items: start;
|
||
}
|
||
.paper-faq-toc {
|
||
position: sticky;
|
||
top: 32px;
|
||
font-size: 13.5px;
|
||
}
|
||
.paper-faq-toc-head {
|
||
font-family: var(--font-mono);
|
||
font-size: 10.5px;
|
||
color: var(--ink-muted);
|
||
letter-spacing: 0.14em;
|
||
text-transform: uppercase;
|
||
padding-bottom: 10px;
|
||
margin-bottom: 6px;
|
||
border-bottom: 1px solid var(--border-color);
|
||
}
|
||
.paper-faq-toc nav {
|
||
display: flex;
|
||
flex-direction: column;
|
||
}
|
||
.paper-faq-toc nav a {
|
||
color: var(--ink-soft);
|
||
padding: 8px 0 8px 14px;
|
||
border-left: 2px solid transparent;
|
||
text-decoration: none;
|
||
margin-left: -2px;
|
||
}
|
||
.paper-faq-toc nav a:hover,
|
||
.paper-faq-toc nav a.active {
|
||
color: var(--color);
|
||
border-left-color: var(--color);
|
||
}
|
||
|
||
.faq-section {
|
||
min-width: 0;
|
||
}
|
||
.faq-section > div {
|
||
width: 100%;
|
||
}
|
||
.faq-section h4.faq-cat {
|
||
font-family: var(--font-serif);
|
||
font-weight: 400;
|
||
font-size: clamp(1.7rem, 2.6vw, 2.2rem);
|
||
letter-spacing: -0.015em;
|
||
color: var(--color);
|
||
margin: 0 0 6px;
|
||
padding-bottom: 14px;
|
||
border-bottom: 1px solid var(--border-color);
|
||
}
|
||
.faq-section h4.faq-cat i { display: none; }
|
||
.faq-section .panel-group { margin-bottom: 56px; }
|
||
|
||
.faq-section .panel-default .panel-title a {
|
||
display: block;
|
||
position: relative;
|
||
padding: 22px 0 22px 42px;
|
||
font-family: var(--font-serif);
|
||
font-weight: 400;
|
||
font-size: 20px;
|
||
line-height: 1.35;
|
||
letter-spacing: -0.005em;
|
||
color: var(--color);
|
||
text-decoration: none;
|
||
cursor: pointer;
|
||
}
|
||
.faq-section .panel-default .panel-title a:hover {
|
||
color: var(--accent);
|
||
}
|
||
|
||
.faq-section .panel-heading {
|
||
background: transparent;
|
||
padding: 0 !important;
|
||
border: none;
|
||
}
|
||
|
||
.faq-section .panel-default {
|
||
background: transparent;
|
||
border: none;
|
||
border-bottom: 1px solid var(--border-soft);
|
||
border-radius: 0;
|
||
margin-bottom: 0 !important;
|
||
box-shadow: none;
|
||
}
|
||
|
||
.faq-section .panel-default .panel-title {
|
||
margin-bottom: 0;
|
||
}
|
||
|
||
.faq-section .panel-default .panel-title a:after {
|
||
content: "−";
|
||
position: absolute;
|
||
left: 0;
|
||
right: auto;
|
||
top: 22px;
|
||
transform: none;
|
||
font-family: var(--font-mono);
|
||
font-size: 18px;
|
||
line-height: 1.35;
|
||
color: var(--ink-muted);
|
||
float: none;
|
||
margin: 0;
|
||
font-weight: 400;
|
||
}
|
||
|
||
.faq-section .panel-default .panel-title a.collapsed:after {
|
||
content: "+";
|
||
}
|
||
|
||
.faq-section .panel-default .panel-body {
|
||
padding: 0 0 22px 42px !important;
|
||
color: var(--ink-soft);
|
||
font-size: 15px;
|
||
line-height: 1.65;
|
||
border-top: none;
|
||
max-width: 42em;
|
||
}
|
||
|
||
.table {
|
||
color: var(--color);
|
||
}
|
||
|
||
.table td,
|
||
.table th,
|
||
hr,
|
||
.dropdown-divider {
|
||
border-color: var(--border-color);
|
||
}
|
||
|
||
.table.repositories td {
|
||
word-break: break-word;
|
||
}
|
||
|
||
loc {
|
||
display: block;
|
||
position: relative;
|
||
width: 100%;
|
||
height: 5px;
|
||
}
|
||
|
||
loc .lang {
|
||
float: left;
|
||
height: 100%;
|
||
}
|
||
|
||
.rounded-circle.fa {
|
||
display: inline-block;
|
||
font-size: 75px;
|
||
height: 140px;
|
||
width: 140px;
|
||
border: 4px solid;
|
||
line-height: 140px;
|
||
text-align: center;
|
||
}
|
||
|
||
.featurette-divider {
|
||
margin: 4.5rem 0;
|
||
border-color: var(--border-color);
|
||
}
|
||
|
||
/* Featurette headings */
|
||
.featurette-heading {
|
||
font-family: var(--font-serif);
|
||
font-weight: 400;
|
||
font-size: 2rem;
|
||
line-height: 1.15;
|
||
letter-spacing: -0.02em;
|
||
margin-bottom: 14px;
|
||
color: var(--color);
|
||
}
|
||
|
||
.dark-mode .shadow {
|
||
box-shadow: none;
|
||
}
|
||
|
||
.dark-mode .overflow-auto::-webkit-scrollbar {
|
||
width: 10px;
|
||
}
|
||
|
||
.dark-mode .overflow-auto::-webkit-scrollbar-track {
|
||
-webkit-box-shadow: none;
|
||
background: inherit;
|
||
border-radius: 0;
|
||
}
|
||
|
||
.dark-mode .overflow-auto::-webkit-scrollbar-thumb {
|
||
border-radius: 10px;
|
||
border: 1px solid var(--border-color);
|
||
background-color: var(--hover-bg-color);
|
||
}
|
||
|
||
.dark-mode .rgba-gradient {
|
||
background: linear-gradient(135deg, #2a2d4a, #151728);
|
||
}
|
||
|
||
|
||
.section-number {
|
||
padding-right: 10px;
|
||
font-weight: bold;
|
||
font-style: italic;
|
||
}
|
||
|
||
.org-subscript-child {
|
||
font-size: 85%;
|
||
}
|
||
|
||
.highlighted-line {
|
||
position: absolute;
|
||
background: rgba(100, 200, 100, 0.5);
|
||
z-index: 20
|
||
}
|
||
|
||
pre,
|
||
code {
|
||
font-family: "Fira Code", "Courier New", Courier, monospace;
|
||
line-height: 1.1;
|
||
color: var(--color)
|
||
}
|
||
|
||
.diff-lines,
|
||
.diff-file,
|
||
.diff-index {
|
||
background: rgba(172, 172, 172, 0.5);
|
||
}
|
||
|
||
.diff-add {
|
||
background: rgba(100, 200, 100, 0.5);
|
||
}
|
||
|
||
.diff-remove {
|
||
background: rgba(200, 100, 100, 0.5);
|
||
}
|
||
|
||
/* ===== Dashboard & List Styles ===== */
|
||
|
||
.dashboard-title {
|
||
font-size: 1.4rem;
|
||
font-weight: 600;
|
||
letter-spacing: -0.01em;
|
||
}
|
||
|
||
/* Quota bars */
|
||
.quota-row {
|
||
display: flex;
|
||
gap: 16px;
|
||
margin-bottom: 16px;
|
||
padding: 0;
|
||
}
|
||
|
||
.quota-item {
|
||
flex: 1;
|
||
min-width: 0;
|
||
}
|
||
|
||
.quota-header {
|
||
display: flex;
|
||
justify-content: space-between;
|
||
align-items: baseline;
|
||
margin-bottom: 4px;
|
||
}
|
||
|
||
.quota-label {
|
||
font-size: 0.75rem;
|
||
font-weight: 600;
|
||
text-transform: uppercase;
|
||
letter-spacing: 0.3px;
|
||
opacity: 0.7;
|
||
}
|
||
|
||
.quota-value {
|
||
font-size: 0.8rem;
|
||
font-weight: 500;
|
||
font-variant-numeric: tabular-nums;
|
||
}
|
||
|
||
.quota-progress {
|
||
height: 6px;
|
||
border-radius: 3px;
|
||
background: var(--hover-bg-color);
|
||
}
|
||
|
||
.quota-progress .progress-bar {
|
||
border-radius: 3px;
|
||
}
|
||
|
||
/* Filter chips */
|
||
.filter-chip {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 4px;
|
||
padding: 3px 10px;
|
||
font-size: 0.8rem;
|
||
font-weight: 500;
|
||
background: var(--primary-bg);
|
||
color: var(--primary-color);
|
||
border-radius: 12px;
|
||
line-height: 1.4;
|
||
}
|
||
|
||
.filter-chip-close {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
background: none;
|
||
border: none;
|
||
color: inherit;
|
||
opacity: 0.7;
|
||
cursor: pointer;
|
||
padding: 0;
|
||
margin-left: 2px;
|
||
font-size: 1rem;
|
||
line-height: 1;
|
||
}
|
||
|
||
.filter-chip-close:hover {
|
||
opacity: 1;
|
||
}
|
||
|
||
/* Repository/PR list */
|
||
.repo-list {
|
||
list-style: none;
|
||
padding: 0;
|
||
margin: 0;
|
||
}
|
||
|
||
.repo-list-item {
|
||
display: flex;
|
||
align-items: flex-start;
|
||
justify-content: space-between;
|
||
padding: 16px 0;
|
||
border-bottom: 1px solid var(--border-color);
|
||
gap: 12px;
|
||
}
|
||
|
||
.repo-list-item:first-child {
|
||
border-top: 1px solid var(--border-color);
|
||
}
|
||
|
||
.repo-list-item.repo-inactive {
|
||
opacity: 0.6;
|
||
}
|
||
|
||
.repo-list-item-content {
|
||
flex: 1;
|
||
min-width: 0;
|
||
}
|
||
|
||
.repo-list-item-header {
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 8px;
|
||
flex-wrap: wrap;
|
||
margin-bottom: 4px;
|
||
}
|
||
|
||
.repo-name {
|
||
font-family: var(--font-mono);
|
||
font-size: 14px;
|
||
font-weight: 500;
|
||
color: var(--color);
|
||
word-break: break-word;
|
||
}
|
||
|
||
.repo-name:hover {
|
||
color: var(--accent);
|
||
}
|
||
|
||
.repo-source {
|
||
font-size: 0.85rem;
|
||
opacity: 0.8;
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
align-items: center;
|
||
gap: 6px;
|
||
}
|
||
|
||
.repo-date {
|
||
opacity: 0.7;
|
||
}
|
||
|
||
.repo-meta {
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
gap: 12px;
|
||
margin-top: 8px;
|
||
font-size: 0.8rem;
|
||
opacity: 0.7;
|
||
}
|
||
|
||
.repo-meta span {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 4px;
|
||
white-space: nowrap;
|
||
}
|
||
|
||
.repo-list-item-actions {
|
||
flex-shrink: 0;
|
||
padding-top: 2px;
|
||
margin-left: 14px;
|
||
}
|
||
|
||
.repo-list-empty {
|
||
display: flex;
|
||
flex-direction: column;
|
||
align-items: center;
|
||
gap: 8px;
|
||
padding: 48px 20px;
|
||
opacity: 0.5;
|
||
font-size: 0.95rem;
|
||
list-style: none;
|
||
border-bottom: 1px solid var(--border-color);
|
||
border-top: 1px solid var(--border-color);
|
||
}
|
||
|
||
.repo-list-empty i {
|
||
font-size: 1.8rem;
|
||
}
|
||
|
||
/* Type badges (Repo / PR) */
|
||
.type-badge {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 3px;
|
||
font-size: 0.7rem;
|
||
font-weight: 600;
|
||
text-transform: uppercase;
|
||
letter-spacing: 0.3px;
|
||
padding: 2px 8px;
|
||
border-radius: 4px;
|
||
white-space: nowrap;
|
||
}
|
||
|
||
.type-badge {
|
||
font-family: var(--font-mono);
|
||
letter-spacing: 0.06em;
|
||
padding: 2px 7px;
|
||
border-radius: 3px;
|
||
border: 1px solid var(--border-color);
|
||
background: var(--paper-bg-alt, transparent);
|
||
}
|
||
.type-badge.type-repo,
|
||
.type-badge.type-pr {
|
||
background: var(--paper-bg-alt);
|
||
color: var(--ink-muted);
|
||
border-color: var(--border-color);
|
||
}
|
||
|
||
.dark-mode .type-badge.type-repo,
|
||
.dark-mode .type-badge.type-pr {
|
||
background: rgba(255, 255, 255, 0.06);
|
||
color: var(--ink-muted);
|
||
border-color: var(--border-color);
|
||
}
|
||
|
||
.type-badge.type-coauthor {
|
||
background: rgba(99, 102, 241, 0.12);
|
||
color: #4f46e5;
|
||
border-color: rgba(99, 102, 241, 0.35);
|
||
margin-left: 6px;
|
||
}
|
||
.dark-mode .type-badge.type-coauthor {
|
||
background: rgba(129, 140, 248, 0.18);
|
||
color: #a5b4fc;
|
||
border-color: rgba(165, 180, 252, 0.45);
|
||
}
|
||
|
||
/* Type filter button group */
|
||
.btn-group .btn:not(.btn-primary) {
|
||
background: var(--hover-bg-color);
|
||
}
|
||
|
||
/* ===== Anonymize Page Layout ===== */
|
||
|
||
/* Landing state: centered URL input */
|
||
.anonymize-landing {
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
height: 100%;
|
||
padding: 20px;
|
||
}
|
||
|
||
.anonymize-landing-inner {
|
||
width: 100%;
|
||
max-width: 600px;
|
||
}
|
||
|
||
.anonymize-landing-inner h2 {
|
||
font-weight: 700;
|
||
}
|
||
|
||
/* Anonymize workspace: topbar + split */
|
||
.anonymize-workspace {
|
||
display: flex;
|
||
flex-direction: column;
|
||
height: 100%;
|
||
background: var(--canvas-bg-color);
|
||
}
|
||
.anonymize-topbar {
|
||
background: var(--paper-card);
|
||
border-bottom: 1px solid var(--border-color);
|
||
padding: 18px 28px;
|
||
flex: 0 0 auto;
|
||
}
|
||
.anonymize-topbar-inner { max-width: 1400px; margin: 0 auto; }
|
||
.anonymize-topbar-head {
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 14px;
|
||
flex-wrap: wrap;
|
||
}
|
||
.anonymize-topbar-title {
|
||
margin: 4px 0 0;
|
||
font-size: clamp(1.8rem, 3vw, 2.4rem);
|
||
}
|
||
.anonymize-split {
|
||
flex: 1 1 auto;
|
||
display: flex;
|
||
min-height: 0;
|
||
}
|
||
|
||
/* Form column (left) */
|
||
.anonymize-form-col {
|
||
flex: 0 0 auto;
|
||
width: 100%;
|
||
min-width: 0;
|
||
background: var(--canvas-bg-color);
|
||
border-right: 1px solid var(--border-color);
|
||
overflow-y: auto;
|
||
}
|
||
.anonymize-form-col .paper-settings-main {
|
||
max-width: 720px;
|
||
padding: 28px 32px 40px;
|
||
margin: 0;
|
||
}
|
||
.anonymize-form-col .paper-settings-section:first-child { padding-top: 0; }
|
||
.anonymize-form-col .anonymize-submit-bar {
|
||
position: sticky;
|
||
bottom: 0;
|
||
background: var(--canvas-bg-color);
|
||
padding: 14px 0 0;
|
||
border-top: 1px solid var(--border-color);
|
||
margin-top: 20px;
|
||
}
|
||
.anonymize-form-col .anonymize-submit-bar .btn { width: 100%; padding: 12px 16px; font-size: 15px; }
|
||
|
||
/* Preview column */
|
||
.anonymize-preview-col {
|
||
flex: 1 1 auto;
|
||
min-width: 0;
|
||
overflow: auto;
|
||
background: var(--paper-bg-alt);
|
||
padding: 28px 32px;
|
||
}
|
||
.anonymize-preview-head {
|
||
display: flex;
|
||
align-items: baseline;
|
||
gap: 12px;
|
||
padding-bottom: 12px;
|
||
border-bottom: 1px solid var(--border-color);
|
||
margin-bottom: 20px;
|
||
}
|
||
.anonymize-preview-head .paper-eyebrow {
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
letter-spacing: 0.14em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
}
|
||
.anonymize-preview-sub { color: var(--ink-soft); font-size: 13px; }
|
||
.anonymize-preview-body {
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 10px;
|
||
padding: 28px 32px;
|
||
}
|
||
|
||
/* Form grids for paired fields */
|
||
.form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
|
||
.form-grid-3 { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 16px; }
|
||
@media (max-width: 700px) {
|
||
.form-grid-2, .form-grid-3 { grid-template-columns: 1fr; }
|
||
}
|
||
|
||
.paper-optional {
|
||
font-family: var(--font-sans);
|
||
font-weight: 400;
|
||
color: var(--ink-muted);
|
||
text-transform: none;
|
||
letter-spacing: 0;
|
||
font-size: 11px;
|
||
margin-left: 6px;
|
||
}
|
||
|
||
/* Plan cards */
|
||
.paper-plan-grid {
|
||
display: grid;
|
||
grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
|
||
gap: 14px;
|
||
}
|
||
.paper-plan-card {
|
||
position: relative;
|
||
display: block;
|
||
padding: 18px 20px;
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 10px;
|
||
cursor: pointer;
|
||
transition: border-color 0.15s ease, box-shadow 0.15s ease;
|
||
margin: 0;
|
||
}
|
||
.paper-plan-card input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; }
|
||
.paper-plan-card.selected {
|
||
border-color: var(--color);
|
||
box-shadow: 0 0 0 2px var(--color) inset;
|
||
}
|
||
.paper-plan-head {
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
letter-spacing: 0.14em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
}
|
||
.paper-plan-price {
|
||
font-family: var(--font-serif);
|
||
font-size: 2rem;
|
||
color: var(--color);
|
||
margin: 6px 0 4px;
|
||
}
|
||
.paper-plan-price .paper-plan-per { font-family: var(--font-sans); font-size: 12px; color: var(--ink-soft); }
|
||
.paper-plan-desc { font-size: 13px; color: var(--ink-soft); }
|
||
.paper-plan-desc ul { padding-left: 18px; margin: 0; }
|
||
|
||
.paper-settings-copy { color: var(--ink-soft); font-size: 13px; margin: 0 0 14px; }
|
||
|
||
.anonymize-section-title {
|
||
font-size: 0.85rem;
|
||
font-weight: 600;
|
||
text-transform: uppercase;
|
||
letter-spacing: 0.3px;
|
||
margin: 18px 0 8px 0;
|
||
padding-bottom: 6px;
|
||
border-bottom: 1px solid var(--border-color);
|
||
opacity: 0.7;
|
||
}
|
||
|
||
.anonymize-section-title i {
|
||
margin-right: 4px;
|
||
}
|
||
|
||
.anonymize-submit-bar {
|
||
padding: 12px 0 4px 0;
|
||
}
|
||
|
||
.anonymize-submit-bar .btn {
|
||
font-size: 1rem;
|
||
padding: 10px 20px;
|
||
font-weight: 600;
|
||
}
|
||
|
||
.anonymize-page .form-check {
|
||
padding-top: 4px;
|
||
padding-bottom: 4px;
|
||
}
|
||
|
||
.anonymize-page .form-check-label {
|
||
font-weight: 500;
|
||
}
|
||
|
||
/* Preview column on desktop */
|
||
.anonymize-preview-col {
|
||
min-height: 0;
|
||
min-width: 0;
|
||
}
|
||
|
||
/* PR diff overflow */
|
||
.pr-diff pre {
|
||
overflow-x: auto;
|
||
max-width: 100%;
|
||
}
|
||
|
||
@media (min-width: 768px) {
|
||
.anonymize-form-col {
|
||
height: 100%;
|
||
width: 520px;
|
||
flex: 0 0 520px;
|
||
}
|
||
|
||
.anonymize-preview-col {
|
||
height: 100%;
|
||
flex: 1;
|
||
}
|
||
}
|
||
|
||
/* Mobile: stack form above preview, tighten paddings */
|
||
@media (max-width: 767px) {
|
||
.anonymize-workspace { height: auto; min-height: 100%; }
|
||
.anonymize-topbar { padding: 14px 16px; }
|
||
.anonymize-topbar-title { font-size: 1.6rem; margin-top: 2px; }
|
||
.anonymize-split {
|
||
display: flex;
|
||
flex-direction: column;
|
||
flex: 1 1 auto;
|
||
min-height: 0;
|
||
}
|
||
.anonymize-form-col {
|
||
width: 100% !important;
|
||
flex: 0 0 auto !important;
|
||
height: auto !important;
|
||
border-right: none;
|
||
border-bottom: 1px solid var(--border-color);
|
||
overflow: visible;
|
||
}
|
||
.anonymize-form-col .paper-settings-main {
|
||
padding: 18px 16px 24px;
|
||
max-width: none;
|
||
}
|
||
.anonymize-form-col .anonymize-submit-bar {
|
||
position: sticky;
|
||
bottom: 0;
|
||
margin: 20px -16px 0;
|
||
padding: 12px 16px;
|
||
background: var(--canvas-bg-color);
|
||
border-top: 1px solid var(--border-color);
|
||
z-index: 10;
|
||
}
|
||
.anonymize-form-col .anonymize-submit-bar .btn {
|
||
width: 100%;
|
||
padding: 12px 16px;
|
||
font-size: 15px;
|
||
}
|
||
.anonymize-preview-col {
|
||
width: 100%;
|
||
flex: 0 0 auto;
|
||
height: auto !important;
|
||
max-height: none;
|
||
padding: 18px 16px 24px;
|
||
overflow: visible;
|
||
}
|
||
.anonymize-preview-body {
|
||
padding: 16px;
|
||
border-radius: 8px;
|
||
}
|
||
.anonymize-preview-body pre,
|
||
.anonymize-preview-body .pr-diff pre {
|
||
overflow-x: auto;
|
||
max-width: 100%;
|
||
}
|
||
.anonymize-landing-inner { padding: 16px; }
|
||
}
|
||
|
||
@media (min-width: 1280px) {
|
||
.anonymize-form-col {
|
||
width: 620px;
|
||
flex: 0 0 620px;
|
||
}
|
||
}
|
||
|
||
/* ===== Mobile Responsive Improvements ===== */
|
||
|
||
/* Mobile-friendly touch targets */
|
||
@media (max-width: 767px) {
|
||
.btn {
|
||
min-height: 38px;
|
||
padding: 6px 14px;
|
||
font-size: 14px;
|
||
}
|
||
|
||
.btn-sm {
|
||
min-height: 34px;
|
||
padding: 5px 10px;
|
||
}
|
||
|
||
.navbar .nav-link {
|
||
padding: 8px 12px;
|
||
}
|
||
|
||
.navbar .nav-link .fa,
|
||
.navbar .nav-link .fab {
|
||
font-size: 24px;
|
||
line-height: 32px;
|
||
}
|
||
|
||
.container.page {
|
||
padding-left: 15px;
|
||
padding-right: 15px;
|
||
max-width: 100%;
|
||
}
|
||
|
||
h1 { font-size: 1.6rem; }
|
||
h2 { font-size: 1.35rem; }
|
||
h3 { font-size: 1.15rem; }
|
||
|
||
/* Dashboard list items */
|
||
.repo-list-item {
|
||
flex-direction: column;
|
||
}
|
||
|
||
.repo-list-item-actions {
|
||
align-self: flex-start;
|
||
}
|
||
|
||
/* Quota row stacks on mobile */
|
||
.quota-row {
|
||
flex-direction: column;
|
||
gap: 10px;
|
||
padding: 10px 12px;
|
||
}
|
||
|
||
/* Dropdown menus right-aligned on mobile */
|
||
.dropdown-menu {
|
||
position: absolute;
|
||
right: 0;
|
||
left: auto;
|
||
}
|
||
|
||
/* Form controls spacing */
|
||
.form-group {
|
||
margin-bottom: 12px;
|
||
}
|
||
|
||
.form-control {
|
||
font-size: 16px; /* Prevents iOS zoom */
|
||
}
|
||
|
||
/* Status bar wrapping */
|
||
.status-bar {
|
||
gap: 6px;
|
||
padding: 8px 10px;
|
||
}
|
||
.status-bar .btn {
|
||
font-size: 12px;
|
||
padding: 4px 10px;
|
||
min-height: 32px;
|
||
}
|
||
.status-bar .paths {
|
||
font-size: 11.5px;
|
||
overflow-x: auto;
|
||
flex-wrap: nowrap;
|
||
white-space: nowrap;
|
||
-webkit-overflow-scrolling: touch;
|
||
}
|
||
.status-bar .paths::-webkit-scrollbar { display: none; }
|
||
.status-bar-actions {
|
||
flex-shrink: 0;
|
||
gap: 4px;
|
||
}
|
||
|
||
/* Home hero section */
|
||
#home .display-4 {
|
||
font-size: 1.8rem;
|
||
}
|
||
|
||
#home h4.subtext-header {
|
||
font-size: 1rem;
|
||
}
|
||
|
||
/* Progress bars on dashboard */
|
||
.progress:not(.quota-progress) {
|
||
min-width: 120px !important;
|
||
}
|
||
|
||
/* Badge readability */
|
||
.badge {
|
||
font-size: 70%;
|
||
}
|
||
|
||
/* Search & filter toolbar */
|
||
.col-2.input-group {
|
||
width: 100% !important;
|
||
max-width: 100%;
|
||
flex: 0 0 100%;
|
||
}
|
||
|
||
/* Metadata spans wrapping */
|
||
.color-text-secondary span {
|
||
display: inline-block;
|
||
margin-bottom: 2px;
|
||
}
|
||
|
||
/* Ko-fi widget hidden on mobile */
|
||
.floatingchat-container-wrap {
|
||
display: none !important;
|
||
}
|
||
|
||
/* Metrics cards on mobile */
|
||
.metrics-grid {
|
||
grid-template-columns: 1fr;
|
||
gap: 10px;
|
||
}
|
||
|
||
.metric-value {
|
||
font-size: 1.5rem;
|
||
}
|
||
|
||
.hero-title {
|
||
font-size: 1.8rem;
|
||
}
|
||
|
||
.hero-subtitle {
|
||
font-size: 0.95rem;
|
||
}
|
||
|
||
/* ---- Anonymize page mobile ---- */
|
||
|
||
.anonymize-landing {
|
||
align-items: flex-start;
|
||
padding-top: 60px;
|
||
}
|
||
|
||
.anonymize-page .container-fluid > .row {
|
||
height: auto !important;
|
||
min-height: 100%;
|
||
}
|
||
|
||
.anonymize-form-col {
|
||
width: 100% !important;
|
||
flex: 0 0 100% !important;
|
||
border-right: none;
|
||
border-top: 1px solid var(--border-color);
|
||
}
|
||
|
||
.anonymize-preview-col {
|
||
height: auto !important;
|
||
max-height: none;
|
||
}
|
||
|
||
.anonymize-section-title {
|
||
font-size: 0.8rem;
|
||
margin: 12px 0 8px 0;
|
||
}
|
||
|
||
.anonymize-submit-bar {
|
||
position: sticky;
|
||
bottom: 0;
|
||
background: var(--sidebar-bg-color);
|
||
padding: 10px 0;
|
||
margin: 0 -12px;
|
||
padding-left: 12px;
|
||
padding-right: 12px;
|
||
border-top: 1px solid var(--border-color);
|
||
z-index: 10;
|
||
}
|
||
|
||
.anonymize-submit-bar .btn {
|
||
font-size: 1rem;
|
||
padding: 12px 20px;
|
||
}
|
||
|
||
/* Compact checkboxes on mobile */
|
||
.anonymize-page .form-check {
|
||
padding-top: 6px;
|
||
padding-bottom: 6px;
|
||
min-height: 36px;
|
||
}
|
||
|
||
.anonymize-page .form-check-label {
|
||
font-size: 0.95rem;
|
||
}
|
||
|
||
.anonymize-page .card-body {
|
||
padding: 12px;
|
||
}
|
||
|
||
/* PR preview on mobile */
|
||
.pr-title {
|
||
font-size: 1.15rem;
|
||
}
|
||
|
||
.pr-diff pre {
|
||
font-size: 0.75rem;
|
||
}
|
||
|
||
.pr-comment .mb-1 h5 {
|
||
font-size: 1rem;
|
||
}
|
||
|
||
.nav-tabs .nav-link {
|
||
padding: 8px 12px;
|
||
font-size: 0.9rem;
|
||
}
|
||
}
|
||
|
||
/* Tablet tweaks */
|
||
@media (min-width: 768px) and (max-width: 991px) {
|
||
.container.page {
|
||
max-width: 100%;
|
||
padding-left: 15px;
|
||
padding-right: 15px;
|
||
}
|
||
|
||
.leftCol {
|
||
flex: 0 0 250px;
|
||
width: 250px;
|
||
}
|
||
}
|
||
|
||
/* ===== Explorer page (paper) ===== */
|
||
.explorer-page {
|
||
display: flex;
|
||
height: 100%;
|
||
width: 100%;
|
||
background: var(--canvas-bg-color);
|
||
position: relative;
|
||
}
|
||
.explorer-main {
|
||
flex: 1 1 auto;
|
||
min-width: 0;
|
||
display: flex;
|
||
flex-direction: column;
|
||
overflow: hidden;
|
||
background: var(--canvas-bg-color);
|
||
}
|
||
.explorer-content {
|
||
flex: 1 1 auto;
|
||
min-height: 0;
|
||
width: 100%;
|
||
overflow: auto;
|
||
}
|
||
|
||
.leftCol-head,
|
||
.leftCol-close {
|
||
display: none;
|
||
}
|
||
.leftCol-body {
|
||
flex: 1 1 auto;
|
||
min-height: 0;
|
||
overflow: auto;
|
||
}
|
||
.leftCol-foot {
|
||
padding: 8px 12px;
|
||
border-top: 1px solid var(--border-color);
|
||
background: var(--paper-bg-alt);
|
||
}
|
||
.leftCol-foot .last-update {
|
||
border-top: none;
|
||
padding: 0;
|
||
}
|
||
.leftCol-backdrop { display: none; }
|
||
|
||
.paper-inline-warning {
|
||
display: flex;
|
||
align-items: flex-start;
|
||
gap: 8px;
|
||
margin: 8px;
|
||
padding: 10px 12px;
|
||
background: rgba(138, 107, 30, 0.08);
|
||
border: 1px solid rgba(138, 107, 30, 0.35);
|
||
border-radius: 8px;
|
||
color: var(--color);
|
||
font-size: 12.5px;
|
||
line-height: 1.4;
|
||
}
|
||
.paper-inline-warning i { color: #8A6B1E; margin-top: 2px; flex-shrink: 0; }
|
||
.dark-mode .paper-inline-warning i { color: #FFD37A; }
|
||
|
||
@media (min-width: 768px) {
|
||
.leftCol-body { padding: 8px 4px; }
|
||
}
|
||
|
||
/* Mobile / tablet toggle */
|
||
.sidebar-toggle {
|
||
display: none;
|
||
align-items: center;
|
||
gap: 8px;
|
||
position: fixed;
|
||
bottom: 18px;
|
||
right: 18px;
|
||
z-index: 1100;
|
||
padding: 10px 14px;
|
||
background: var(--color);
|
||
color: var(--canvas-bg-color);
|
||
border: 1px solid var(--color);
|
||
border-radius: 999px;
|
||
font-family: var(--font-sans);
|
||
font-size: 13px;
|
||
font-weight: 500;
|
||
box-shadow: 0 6px 20px rgba(0,0,0,0.15);
|
||
cursor: pointer;
|
||
outline: none;
|
||
}
|
||
.sidebar-toggle:hover { background: var(--primary-hover-bg); }
|
||
.sidebar-toggle:focus,
|
||
.sidebar-toggle:focus-visible { outline: none; box-shadow: 0 6px 20px rgba(0,0,0,0.15); }
|
||
|
||
@media (max-width: 991px) {
|
||
.sidebar-toggle { display: inline-flex; }
|
||
|
||
/* Move Ko-fi widget to the left to avoid clashing with the Files button */
|
||
.floatingchat-container-wrap {
|
||
left: 3px !important;
|
||
right: auto !important;
|
||
}
|
||
.floating-chat-kofi-popup-iframe {
|
||
left: 10px !important;
|
||
right: auto !important;
|
||
}
|
||
|
||
/* Sidebar becomes a slide-in drawer */
|
||
.leftCol {
|
||
position: fixed;
|
||
top: 0;
|
||
left: 0;
|
||
bottom: 0;
|
||
width: min(86vw, 340px);
|
||
max-width: 340px;
|
||
z-index: 1200;
|
||
border: none;
|
||
border-right: 1px solid var(--border-color);
|
||
transform: translateX(0);
|
||
transition: transform 0.22s ease;
|
||
box-shadow: 4px 0 24px rgba(0,0,0,0.18);
|
||
background: var(--sidebar-bg-color);
|
||
}
|
||
.leftCol.collapsed {
|
||
transform: translateX(-105%);
|
||
box-shadow: none;
|
||
pointer-events: none;
|
||
}
|
||
.leftCol-head {
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: space-between;
|
||
padding: 12px 14px;
|
||
border-bottom: 1px solid var(--border-color);
|
||
background: var(--paper-bg-alt);
|
||
}
|
||
.leftCol-eyebrow {
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
letter-spacing: 0.14em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
}
|
||
.leftCol-close {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
width: 32px;
|
||
height: 32px;
|
||
padding: 0;
|
||
background: transparent;
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 8px;
|
||
color: var(--ink-muted);
|
||
cursor: pointer;
|
||
}
|
||
.leftCol-close:hover { color: var(--color); border-color: var(--color); }
|
||
.leftCol-foot { display: block; }
|
||
.leftCol-body { padding: 4px 0; }
|
||
|
||
.leftCol-backdrop {
|
||
display: block;
|
||
position: fixed;
|
||
inset: 0;
|
||
background: rgba(0,0,0,0.32);
|
||
z-index: 1150;
|
||
backdrop-filter: blur(2px);
|
||
}
|
||
.dark-mode .leftCol-backdrop { background: rgba(0,0,0,0.5); }
|
||
}
|
||
|
||
/* ===== Admin Interface (Paper style) ===== */
|
||
|
||
.admin-nav {
|
||
display: flex;
|
||
gap: 4px;
|
||
padding: 4px;
|
||
margin: 8px 0 20px;
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 10px;
|
||
flex-wrap: wrap;
|
||
}
|
||
|
||
.admin-nav a {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 8px;
|
||
padding: 8px 14px;
|
||
border-radius: 7px;
|
||
color: var(--ink-muted);
|
||
text-decoration: none;
|
||
font-family: var(--font-mono);
|
||
font-size: 11.5px;
|
||
font-weight: 500;
|
||
letter-spacing: 0.06em;
|
||
text-transform: uppercase;
|
||
transition: background-color 0.15s, color 0.15s;
|
||
white-space: nowrap;
|
||
}
|
||
|
||
.admin-nav a:hover {
|
||
background: var(--paper-bg-alt);
|
||
color: var(--color);
|
||
}
|
||
|
||
.admin-nav a.active {
|
||
background: var(--color);
|
||
color: var(--paper-card);
|
||
}
|
||
|
||
.admin-nav a i {
|
||
font-size: 12px;
|
||
width: 14px;
|
||
text-align: center;
|
||
}
|
||
|
||
@media (max-width: 767px) {
|
||
.admin-nav {
|
||
flex-direction: column;
|
||
}
|
||
.admin-nav a {
|
||
justify-content: flex-start;
|
||
}
|
||
}
|
||
|
||
/* Admin stat cards — compact, denser packing for many KPIs */
|
||
.admin-stats {
|
||
display: grid;
|
||
grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
|
||
gap: 8px;
|
||
margin-bottom: 16px;
|
||
}
|
||
|
||
.admin-stat-card {
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 8px;
|
||
padding: 10px 12px;
|
||
}
|
||
|
||
.admin-stat-card .stat-value {
|
||
font-family: var(--font-serif);
|
||
font-size: 1.4rem;
|
||
font-weight: 400;
|
||
line-height: 1.1;
|
||
color: var(--color);
|
||
}
|
||
|
||
.admin-stat-card .stat-label {
|
||
font-family: var(--font-mono);
|
||
font-size: 9.5px;
|
||
color: var(--ink-muted);
|
||
text-transform: uppercase;
|
||
letter-spacing: 0.08em;
|
||
margin-top: 4px;
|
||
}
|
||
|
||
/* Admin toolbar — kept as alias to dashboard filter row */
|
||
.admin-toolbar {
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
gap: 10px;
|
||
align-items: center;
|
||
margin: 16px 0 12px;
|
||
}
|
||
|
||
.admin-toolbar .form-control {
|
||
max-width: 320px;
|
||
}
|
||
|
||
@media (max-width: 767px) {
|
||
.admin-toolbar .form-control {
|
||
max-width: 100%;
|
||
width: 100%;
|
||
}
|
||
}
|
||
|
||
.pagination-compact {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 6px;
|
||
flex-wrap: nowrap;
|
||
font-family: var(--font-mono);
|
||
font-size: 12px;
|
||
color: var(--ink-muted);
|
||
}
|
||
|
||
.pagination-compact input {
|
||
width: 60px;
|
||
text-align: center;
|
||
flex-shrink: 0;
|
||
}
|
||
|
||
.pagination-compact .btn {
|
||
padding: 4px 10px;
|
||
min-height: 34px;
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
color: var(--color);
|
||
flex-shrink: 0;
|
||
}
|
||
|
||
.pagination-compact > span {
|
||
white-space: nowrap;
|
||
}
|
||
|
||
/* Admin list items */
|
||
.admin-list-item {
|
||
display: flex;
|
||
align-items: flex-start;
|
||
gap: 12px;
|
||
padding: 12px 0;
|
||
border-bottom: 1px solid var(--border-color);
|
||
}
|
||
|
||
.admin-list-item:last-child {
|
||
border-bottom: none;
|
||
}
|
||
|
||
.admin-list-item .item-main {
|
||
flex: 1;
|
||
min-width: 0;
|
||
}
|
||
|
||
.admin-list-item .item-title {
|
||
font-size: 1rem;
|
||
font-weight: 600;
|
||
margin-bottom: 4px;
|
||
word-break: break-word;
|
||
}
|
||
|
||
.admin-list-item .item-meta {
|
||
font-size: 0.85rem;
|
||
opacity: 0.8;
|
||
}
|
||
|
||
.admin-list-item .item-meta span {
|
||
margin-right: 12px;
|
||
display: inline-block;
|
||
margin-bottom: 2px;
|
||
}
|
||
|
||
.admin-list-item .item-actions {
|
||
flex-shrink: 0;
|
||
}
|
||
|
||
@media (max-width: 767px) {
|
||
.admin-list-item {
|
||
flex-direction: column;
|
||
gap: 8px;
|
||
}
|
||
.admin-list-item .item-actions {
|
||
align-self: flex-start;
|
||
}
|
||
}
|
||
|
||
/* Status badge improvements */
|
||
.status-badge {
|
||
display: inline-block;
|
||
font-size: 11px;
|
||
font-weight: 600;
|
||
padding: 2px 8px;
|
||
border-radius: 10px;
|
||
text-transform: uppercase;
|
||
letter-spacing: 0.3px;
|
||
vertical-align: middle;
|
||
}
|
||
|
||
.status-badge {
|
||
font-family: var(--font-sans);
|
||
font-weight: 500;
|
||
letter-spacing: 0.02em;
|
||
border: 1px solid transparent;
|
||
text-transform: none;
|
||
font-size: 11.5px;
|
||
padding: 1px 9px 2px;
|
||
border-radius: 999px;
|
||
}
|
||
.status-badge.status-ready {
|
||
background: #E8F3EC;
|
||
color: #2F7A44;
|
||
border-color: #CFE6D6;
|
||
}
|
||
|
||
.status-badge.status-error {
|
||
background: #FBE7E7;
|
||
color: #B42318;
|
||
border-color: #F3C7C7;
|
||
}
|
||
|
||
.status-badge.status-preparing,
|
||
.status-badge.status-download {
|
||
background: #EEF0FF;
|
||
color: #3B4AD6;
|
||
border-color: #D4D8FA;
|
||
}
|
||
|
||
.status-badge.status-expired,
|
||
.status-badge.status-removed,
|
||
.status-badge.status-removing,
|
||
.status-badge.status-expiring {
|
||
background: var(--paper-bg-alt);
|
||
color: var(--ink-muted);
|
||
border-color: var(--border-color);
|
||
}
|
||
|
||
.status-badge.status-active {
|
||
background: #E8F3EC;
|
||
color: #2F7A44;
|
||
border-color: #CFE6D6;
|
||
}
|
||
|
||
/* Admin queue job cards */
|
||
.queue-job-card {
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 10px;
|
||
padding: 16px 18px;
|
||
margin-bottom: 10px;
|
||
}
|
||
|
||
.queue-job-card .job-header {
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: space-between;
|
||
margin-bottom: 8px;
|
||
flex-wrap: wrap;
|
||
gap: 8px;
|
||
}
|
||
|
||
.queue-job-card .job-id {
|
||
font-family: var(--font-mono);
|
||
font-size: 0.95rem;
|
||
color: var(--color);
|
||
word-break: break-all;
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 10px;
|
||
}
|
||
|
||
.queue-job-card .job-timestamps {
|
||
font-family: var(--font-mono);
|
||
font-size: 11.5px;
|
||
color: var(--ink-muted);
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
gap: 14px;
|
||
}
|
||
|
||
.queue-job-card .job-actions {
|
||
display: flex;
|
||
gap: 8px;
|
||
margin-top: 10px;
|
||
}
|
||
|
||
.queue-job-card .job-actions .btn {
|
||
font-size: 12px;
|
||
padding: 4px 12px;
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
color: var(--color);
|
||
}
|
||
|
||
/* Admin section headers */
|
||
.admin-section-header {
|
||
display: flex;
|
||
align-items: center;
|
||
flex-wrap: wrap;
|
||
gap: 8px;
|
||
margin: 24px 0 12px;
|
||
padding-bottom: 8px;
|
||
border-bottom: 1px solid var(--border-color);
|
||
}
|
||
|
||
.admin-section-header h2 {
|
||
margin: 0;
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
font-weight: 500;
|
||
color: var(--ink-muted);
|
||
text-transform: uppercase;
|
||
letter-spacing: 0.08em;
|
||
}
|
||
|
||
.admin-section-header h2 i {
|
||
margin-right: 6px;
|
||
color: var(--ink-muted);
|
||
}
|
||
|
||
.admin-section-header .section-count {
|
||
background: var(--paper-bg-alt);
|
||
color: var(--ink-muted);
|
||
border: 1px solid var(--border-color);
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
padding: 1px 10px;
|
||
border-radius: 999px;
|
||
}
|
||
|
||
/* User detail card */
|
||
.user-detail-card {
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 10px;
|
||
padding: 22px;
|
||
margin-bottom: 24px;
|
||
}
|
||
|
||
.user-detail-card .user-header {
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 16px;
|
||
margin-bottom: 18px;
|
||
padding-bottom: 16px;
|
||
border-bottom: 1px solid var(--border-color);
|
||
flex-wrap: wrap;
|
||
}
|
||
|
||
.user-detail-card .user-header img {
|
||
border-radius: 50%;
|
||
}
|
||
|
||
.user-detail-card .user-header h1 {
|
||
margin: 0;
|
||
font-family: var(--font-serif);
|
||
font-weight: 400;
|
||
font-size: 1.6rem;
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 10px;
|
||
flex-wrap: wrap;
|
||
}
|
||
|
||
.user-detail-grid {
|
||
display: grid;
|
||
grid-template-columns: 160px 1fr;
|
||
gap: 10px 20px;
|
||
font-size: 0.92rem;
|
||
}
|
||
|
||
.user-detail-grid .detail-label {
|
||
font-family: var(--font-mono);
|
||
font-size: 10.5px;
|
||
text-transform: uppercase;
|
||
letter-spacing: 0.08em;
|
||
color: var(--ink-muted);
|
||
white-space: nowrap;
|
||
padding-top: 2px;
|
||
}
|
||
|
||
.user-detail-grid .detail-value {
|
||
word-break: break-all;
|
||
color: var(--color);
|
||
}
|
||
|
||
@media (max-width: 767px) {
|
||
.user-detail-grid {
|
||
grid-template-columns: 1fr;
|
||
}
|
||
.user-detail-grid .detail-label {
|
||
margin-top: 8px;
|
||
border-top: 1px solid var(--border-color);
|
||
padding-top: 8px;
|
||
}
|
||
.user-detail-grid .detail-label:first-child {
|
||
border-top: none;
|
||
margin-top: 0;
|
||
padding-top: 0;
|
||
}
|
||
}
|
||
|
||
/* ===== Paper empty/error states ===== */
|
||
.paper-empty {
|
||
min-height: calc(100vh - 60px);
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
padding: 40px 24px;
|
||
}
|
||
.paper-empty-inner {
|
||
max-width: 560px;
|
||
text-align: left;
|
||
}
|
||
.paper-empty-title {
|
||
font-family: var(--font-serif);
|
||
font-weight: 400;
|
||
font-size: clamp(2.4rem, 6vw, 4.4rem);
|
||
line-height: 1.02;
|
||
letter-spacing: -0.025em;
|
||
margin: 18px 0 20px;
|
||
color: var(--color);
|
||
}
|
||
.paper-empty-title em {
|
||
color: var(--accent);
|
||
font-style: italic;
|
||
}
|
||
.paper-empty-lede {
|
||
font-size: 17px;
|
||
line-height: 1.55;
|
||
color: var(--ink-soft);
|
||
text-wrap: pretty;
|
||
}
|
||
.paper-empty-cta {
|
||
display: flex;
|
||
gap: 10px;
|
||
margin-top: 28px;
|
||
flex-wrap: wrap;
|
||
}
|
||
|
||
/* ===== Paper page chrome ===== */
|
||
.paper-page {
|
||
max-width: 1100px;
|
||
margin: 0 auto;
|
||
padding: 32px 32px 80px;
|
||
}
|
||
@media (max-width: 991px) {
|
||
.paper-page,
|
||
.paper-page.container,
|
||
.paper-page.container-fluid { padding: 20px 18px 60px !important; }
|
||
.paper-page .row { margin-left: 0; margin-right: 0; }
|
||
.paper-page .row > [class*='col'],
|
||
.paper-page .row > .w-100 { padding-left: 0; padding-right: 0; }
|
||
|
||
/* Navbar drawer (mobile + tablet — navbar-expand-lg collapses <992px) */
|
||
.navbar.navbar-expand-lg {
|
||
padding: 10px 18px !important;
|
||
}
|
||
.navbar .navbar-collapse {
|
||
margin: 10px -18px 0;
|
||
padding: 12px 18px 16px;
|
||
border-top: 1px solid var(--border-color);
|
||
background: var(--header-bg-color);
|
||
}
|
||
.navbar .navbar-nav {
|
||
align-items: stretch !important;
|
||
gap: 2px;
|
||
}
|
||
.navbar .navbar-nav .nav-item,
|
||
.navbar .navbar-nav .nav-link {
|
||
width: 100%;
|
||
}
|
||
.navbar .nav-link {
|
||
display: flex !important;
|
||
align-items: center;
|
||
justify-content: flex-start;
|
||
margin: 0 !important;
|
||
padding: 12px 4px !important;
|
||
border-bottom: 1px solid var(--border-color) !important;
|
||
border-radius: 0;
|
||
font-size: 14px;
|
||
line-height: 1.2;
|
||
gap: 0;
|
||
min-height: 44px;
|
||
box-sizing: border-box;
|
||
}
|
||
.navbar .nav-link:not(.btn-signin):not(.user-chip) {
|
||
color: var(--color) !important;
|
||
}
|
||
.navbar .nav-link .fas,
|
||
.navbar .nav-link .fab,
|
||
.navbar .nav-link .fa,
|
||
.navbar .nav-link i {
|
||
display: inline-flex !important;
|
||
align-items: center;
|
||
justify-content: center;
|
||
width: 28px;
|
||
flex-shrink: 0;
|
||
font-size: 16px;
|
||
line-height: 1;
|
||
margin: 0 10px 0 0 !important;
|
||
}
|
||
.navbar .navbar-nav .nav-item:last-child .nav-link,
|
||
.navbar .navbar-nav > .nav-link:last-child { border-bottom-color: transparent !important; }
|
||
.navbar .nav-link.active {
|
||
color: var(--color) !important;
|
||
border-bottom-color: var(--border-color) !important;
|
||
}
|
||
/* Items without leading icon: reserve the same 28px icon column so text aligns */
|
||
.navbar .nav-item > .nav-link:not(.btn-signin):not(.user-chip)::before {
|
||
content: '';
|
||
display: inline-block;
|
||
width: 28px;
|
||
margin-right: 10px;
|
||
flex-shrink: 0;
|
||
}
|
||
.navbar .nav-link:has(> i)::before,
|
||
.navbar .nav-link.nav-icon::before { display: none !important; }
|
||
.navbar .nav-link.nav-icon {
|
||
width: 100% !important;
|
||
height: auto !important;
|
||
justify-content: flex-start !important;
|
||
padding: 12px 4px !important;
|
||
}
|
||
.navbar .nav-link.nav-icon::after {
|
||
content: attr(title);
|
||
font-family: var(--font-sans);
|
||
font-size: 14px;
|
||
color: var(--color);
|
||
}
|
||
.navbar .btn-signin {
|
||
display: inline-flex !important;
|
||
width: auto !important;
|
||
align-self: flex-start;
|
||
justify-content: center;
|
||
height: 40px;
|
||
padding: 0 18px !important;
|
||
margin: 14px 0 0 !important;
|
||
border-radius: 8px;
|
||
border-bottom: none !important;
|
||
}
|
||
.navbar .btn-signin i { margin: 0 8px 0 0 !important; width: auto !important; }
|
||
|
||
/* User chip — integrate into drawer as a normal row */
|
||
.navbar .user-chip-wrap { width: 100%; }
|
||
.navbar .user-chip {
|
||
display: flex !important;
|
||
width: 100%;
|
||
margin: 0 !important;
|
||
padding: 10px 4px !important;
|
||
background: transparent !important;
|
||
border: none !important;
|
||
border-bottom: 1px solid var(--border-color) !important;
|
||
border-radius: 0 !important;
|
||
justify-content: flex-start;
|
||
gap: 0;
|
||
min-height: 44px;
|
||
}
|
||
.navbar .user-chip::before { display: none !important; }
|
||
.navbar .user-chip img {
|
||
width: 28px !important;
|
||
height: 28px !important;
|
||
margin-right: 10px !important;
|
||
flex-shrink: 0;
|
||
}
|
||
.navbar .user-chip .user-chip-name {
|
||
font-size: 14px;
|
||
font-weight: 500;
|
||
color: var(--color) !important;
|
||
}
|
||
.navbar .user-chip.dropdown-toggle::after {
|
||
margin-left: auto;
|
||
color: var(--ink-muted);
|
||
}
|
||
/* Dropdown menu items render inline, not floating */
|
||
.navbar .user-chip-wrap .dropdown-menu {
|
||
position: static !important;
|
||
float: none;
|
||
width: 100%;
|
||
margin: 0 !important;
|
||
padding: 0 !important;
|
||
background: transparent !important;
|
||
border: none !important;
|
||
box-shadow: none !important;
|
||
transform: none !important;
|
||
}
|
||
.navbar .user-chip-wrap .dropdown-menu .dropdown-item {
|
||
padding: 10px 4px 10px 42px !important;
|
||
font-size: 13.5px;
|
||
color: var(--ink-muted) !important;
|
||
background: transparent !important;
|
||
border-bottom: 1px solid var(--border-color);
|
||
text-align: left !important;
|
||
}
|
||
.navbar .user-chip-wrap .dropdown-menu .dropdown-item:last-child { border-bottom: none; }
|
||
.navbar .user-chip-wrap .dropdown-divider { display: none; }
|
||
.navbar-brand { border-right: none !important; padding-right: 0 !important; margin-right: 0 !important; }
|
||
|
||
.dark-mode .navbar .navbar-collapse { background: var(--header-bg-color); border-top-color: var(--border-color); }
|
||
.dark-mode .navbar .nav-link { border-bottom-color: var(--border-color) !important; }
|
||
.dark-mode .navbar-toggler .navbar-toggler-icon {
|
||
background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30'%3E%3Cpath stroke='%23f5f5f5' stroke-width='2' stroke-linecap='round' d='M4 8h22M4 15h22M4 22h22'/%3E%3C/svg%3E") !important;
|
||
}
|
||
}
|
||
/* Status pill — page header indicator */
|
||
.status-pill {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 8px;
|
||
padding: 6px 12px;
|
||
border-radius: 999px;
|
||
background: var(--paper-bg-alt);
|
||
border: 1px solid var(--border-color);
|
||
color: var(--ink-soft);
|
||
font-family: var(--font-mono);
|
||
font-size: 11.5px;
|
||
letter-spacing: 0.08em;
|
||
text-transform: uppercase;
|
||
}
|
||
|
||
/* Paper progress bar */
|
||
.paper-progress {
|
||
position: relative;
|
||
height: 8px;
|
||
background: var(--paper-bg-alt);
|
||
border-radius: 999px;
|
||
overflow: visible;
|
||
margin: 18px 0 8px;
|
||
}
|
||
.paper-progress .paper-progress-bar {
|
||
height: 100%;
|
||
background: var(--color);
|
||
border-radius: 999px;
|
||
transition: width 0.4s ease;
|
||
min-width: 4px;
|
||
}
|
||
.paper-progress .paper-progress-label {
|
||
display: flex;
|
||
justify-content: space-between;
|
||
align-items: center;
|
||
margin-top: 10px;
|
||
font-family: var(--font-mono);
|
||
font-size: 11.5px;
|
||
letter-spacing: 0.06em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
}
|
||
.paper-progress .paper-progress-pct { color: var(--color); }
|
||
.paper-progress.paper-progress-ready .paper-progress-bar { background: var(--color); }
|
||
|
||
/* Status error card */
|
||
.paper-error-card {
|
||
margin-top: 18px;
|
||
padding: 20px 22px;
|
||
background: var(--paper-bg-alt);
|
||
border: 1px solid var(--border-color);
|
||
border-left: 3px solid #C53030;
|
||
border-radius: 10px;
|
||
color: var(--color);
|
||
}
|
||
.dark-mode .paper-error-card { border-left-color: #FF8B7B; }
|
||
.paper-error-head {
|
||
display: flex;
|
||
align-items: flex-start;
|
||
gap: 14px;
|
||
}
|
||
.paper-error-head > i {
|
||
font-size: 18px;
|
||
color: #C53030;
|
||
margin-top: 4px;
|
||
flex-shrink: 0;
|
||
}
|
||
.dark-mode .paper-error-head > i { color: #FF8B7B; }
|
||
.paper-error-eyebrow {
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
letter-spacing: 0.14em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
}
|
||
.paper-error-title {
|
||
font-family: var(--font-serif);
|
||
font-size: 1.4rem;
|
||
line-height: 1.2;
|
||
margin-top: 2px;
|
||
color: var(--color);
|
||
}
|
||
.paper-error-msg {
|
||
margin: 12px 0 0;
|
||
font-size: 14px;
|
||
line-height: 1.55;
|
||
color: var(--ink-soft);
|
||
font-family: var(--font-mono);
|
||
word-break: break-word;
|
||
white-space: pre-wrap;
|
||
}
|
||
.paper-error-hints {
|
||
margin: 14px 0 0;
|
||
padding-left: 18px;
|
||
color: var(--ink-soft);
|
||
font-size: 13.5px;
|
||
line-height: 1.6;
|
||
}
|
||
.paper-error-actions {
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
gap: 8px;
|
||
margin-top: 18px;
|
||
}
|
||
|
||
/* Detail grid (status page, generic) */
|
||
.paper-detail-grid {
|
||
display: grid;
|
||
grid-template-columns: 160px 1fr;
|
||
gap: 10px 20px;
|
||
margin-top: 18px;
|
||
font-size: 0.92rem;
|
||
}
|
||
.paper-detail-grid .detail-label {
|
||
font-family: var(--font-mono);
|
||
font-size: 10.5px;
|
||
text-transform: uppercase;
|
||
letter-spacing: 0.08em;
|
||
color: var(--ink-muted);
|
||
white-space: nowrap;
|
||
padding-top: 2px;
|
||
}
|
||
.paper-detail-grid .detail-value { word-break: break-all; color: var(--color); }
|
||
.paper-detail-grid .detail-value a { color: var(--color); border-bottom: 1px solid var(--border-color); }
|
||
.paper-detail-grid .detail-value a:hover { border-bottom-color: var(--color); }
|
||
|
||
@media (max-width: 700px) {
|
||
.paper-detail-grid { grid-template-columns: 1fr; gap: 4px 0; }
|
||
.paper-detail-grid .detail-label { padding-top: 8px; }
|
||
}
|
||
|
||
/* Support cards (Contribute / Feedback / Sponsor) */
|
||
.paper-support-grid {
|
||
display: grid;
|
||
grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
|
||
gap: 14px;
|
||
margin: 18px 0 28px;
|
||
}
|
||
.paper-support-card {
|
||
display: flex;
|
||
flex-direction: column;
|
||
gap: 10px;
|
||
padding: 20px;
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 10px;
|
||
color: var(--color);
|
||
text-decoration: none;
|
||
transition: border-color 0.15s ease, transform 0.15s ease;
|
||
}
|
||
.paper-support-card:hover {
|
||
border-color: var(--color);
|
||
text-decoration: none;
|
||
color: var(--color);
|
||
}
|
||
.paper-support-card .paper-support-eyebrow {
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
letter-spacing: 0.14em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 8px;
|
||
}
|
||
.paper-support-card p {
|
||
margin: 0;
|
||
font-size: 14px;
|
||
line-height: 1.55;
|
||
color: var(--ink-soft);
|
||
}
|
||
.paper-support-card .paper-support-cta {
|
||
margin-top: auto;
|
||
font-size: 13px;
|
||
font-weight: 500;
|
||
color: var(--color);
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 6px;
|
||
}
|
||
.paper-support-card:hover .paper-support-cta i { transform: translateX(2px); }
|
||
.paper-support-card .paper-support-cta i { transition: transform 0.15s ease; }
|
||
|
||
/* Ko-fi embed wrapper */
|
||
.paper-kofi-wrap {
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 10px;
|
||
overflow: hidden;
|
||
background: var(--paper-card);
|
||
}
|
||
.paper-kofi-wrap iframe {
|
||
border: 0;
|
||
width: 100%;
|
||
height: 650px;
|
||
display: block;
|
||
}
|
||
@media (max-width: 700px) {
|
||
.paper-kofi-wrap iframe { height: 720px; }
|
||
}
|
||
|
||
/* ===== Pull request page (paper) ===== */
|
||
.pr-page {
|
||
min-height: 100%;
|
||
background: var(--canvas-bg-color);
|
||
}
|
||
.pr-page-inner { padding-top: 24px; padding-bottom: 60px; }
|
||
|
||
.pr-header {
|
||
margin: 6px 0 18px;
|
||
}
|
||
.pr-title {
|
||
margin: 4px 0 10px;
|
||
font-size: clamp(1.6rem, 3vw, 2.4rem);
|
||
line-height: 1.15;
|
||
word-break: break-word;
|
||
}
|
||
.pr-header-meta {
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
align-items: center;
|
||
gap: 8px 14px;
|
||
font-family: var(--font-mono);
|
||
font-size: 12px;
|
||
color: var(--ink-muted);
|
||
}
|
||
.pr-header-meta .pr-meta-item {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 6px;
|
||
}
|
||
.pr-header-meta .pr-meta-item i { color: var(--ink-muted); }
|
||
|
||
.pr-body-card {
|
||
margin: 18px 0 24px;
|
||
padding: 20px 22px;
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 10px;
|
||
}
|
||
.pr-body-card .paper-section-eyebrow { margin-bottom: 12px; }
|
||
|
||
/* Paper-style tabs */
|
||
.paper-tabs {
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
gap: 0;
|
||
border-bottom: 1px solid var(--border-color);
|
||
margin: 18px 0 0;
|
||
}
|
||
.paper-tabs .paper-tab {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 8px;
|
||
padding: 10px 16px;
|
||
background: transparent;
|
||
border: 0;
|
||
border-bottom: 2px solid transparent;
|
||
font-family: var(--font-sans);
|
||
font-size: 13.5px;
|
||
font-weight: 500;
|
||
color: var(--ink-muted);
|
||
cursor: pointer;
|
||
transition: color 0.15s ease, border-color 0.15s ease;
|
||
margin-bottom: -1px;
|
||
}
|
||
.paper-tabs .paper-tab:hover { color: var(--color); }
|
||
.paper-tabs .paper-tab.active {
|
||
color: var(--color);
|
||
border-bottom-color: var(--color);
|
||
}
|
||
.paper-tabs .paper-tab i { color: inherit; opacity: 0.85; }
|
||
.paper-tabs .paper-tab:focus,
|
||
.paper-tabs .paper-tab:focus-visible,
|
||
.paper-tabs .paper-tab:active {
|
||
outline: none;
|
||
box-shadow: none;
|
||
}
|
||
.paper-tabs .paper-tab:focus-visible {
|
||
color: var(--color);
|
||
background: var(--hover-bg-color);
|
||
border-radius: 6px 6px 0 0;
|
||
}
|
||
|
||
/* ===== Diff (file-grouped, gutter line numbers) ===== */
|
||
.pr-diff {
|
||
margin: 16px 0 28px;
|
||
display: flex;
|
||
flex-direction: column;
|
||
gap: 16px;
|
||
}
|
||
.diff-file-block {
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 10px;
|
||
overflow: hidden;
|
||
}
|
||
.diff-file-header {
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 10px;
|
||
padding: 10px 14px;
|
||
background: var(--paper-bg-alt);
|
||
border-bottom: 1px solid var(--border-color);
|
||
font-family: var(--font-mono);
|
||
font-size: 12.5px;
|
||
color: var(--color);
|
||
}
|
||
.diff-file-icon { color: var(--ink-muted); flex-shrink: 0; }
|
||
.diff-file-name {
|
||
flex: 1 1 auto;
|
||
min-width: 0;
|
||
overflow: hidden;
|
||
text-overflow: ellipsis;
|
||
white-space: nowrap;
|
||
word-break: break-all;
|
||
}
|
||
.diff-file-status {
|
||
flex-shrink: 0;
|
||
padding: 2px 8px;
|
||
border-radius: 999px;
|
||
font-size: 10px;
|
||
letter-spacing: 0.12em;
|
||
text-transform: uppercase;
|
||
border: 1px solid var(--border-color);
|
||
color: var(--ink-muted);
|
||
background: var(--paper-card);
|
||
}
|
||
.diff-file-status-added { color: #2F6B3E; border-color: rgba(47,107,62,0.35); background: rgba(47,107,62,0.08); }
|
||
.diff-file-status-deleted { color: #A13A2E; border-color: rgba(161,58,46,0.35); background: rgba(161,58,46,0.08); }
|
||
.diff-file-status-renamed { color: #8A6B1E; border-color: rgba(138,107,30,0.35); background: rgba(138,107,30,0.08); }
|
||
.dark-mode .diff-file-status-added { color: #A7E2A7; border-color: rgba(167,226,167,0.35); background: rgba(167,226,167,0.08); }
|
||
.dark-mode .diff-file-status-deleted { color: #FF8B7B; border-color: rgba(255,139,123,0.35); background: rgba(255,139,123,0.08); }
|
||
.dark-mode .diff-file-status-renamed { color: #FFD37A; border-color: rgba(255,211,122,0.35); background: rgba(255,211,122,0.08); }
|
||
|
||
.diff-file-table {
|
||
width: 100%;
|
||
border-collapse: collapse;
|
||
font-family: var(--font-mono);
|
||
font-size: 12.5px;
|
||
line-height: 1.55;
|
||
table-layout: fixed;
|
||
}
|
||
.diff-file-table tr.diff-row { vertical-align: top; }
|
||
.diff-file-table .diff-gutter {
|
||
width: 48px;
|
||
padding: 0 10px;
|
||
text-align: right;
|
||
color: var(--ink-muted);
|
||
background: var(--paper-bg-alt);
|
||
border-right: 1px solid var(--border-color);
|
||
user-select: none;
|
||
font-variant-numeric: tabular-nums;
|
||
vertical-align: top;
|
||
white-space: nowrap;
|
||
}
|
||
.diff-file-table .diff-gutter-new { border-right: 1px solid var(--border-color); }
|
||
.diff-file-table .diff-sign {
|
||
width: 18px;
|
||
padding: 0 6px;
|
||
text-align: center;
|
||
color: var(--ink-muted);
|
||
background: var(--paper-bg-alt);
|
||
user-select: none;
|
||
vertical-align: top;
|
||
}
|
||
.diff-file-table .diff-code {
|
||
padding: 1px 12px;
|
||
white-space: pre-wrap;
|
||
word-break: break-word;
|
||
color: var(--color);
|
||
}
|
||
|
||
/* Hunk header row */
|
||
.diff-row-hunk td {
|
||
background: var(--paper-bg-alt) !important;
|
||
color: var(--ink-muted);
|
||
border-top: 1px solid var(--border-color);
|
||
border-bottom: 1px solid var(--border-color);
|
||
font-size: 12px;
|
||
letter-spacing: 0.02em;
|
||
padding-top: 6px;
|
||
padding-bottom: 6px;
|
||
}
|
||
.diff-row-hunk .diff-code { color: var(--ink-muted); }
|
||
|
||
/* Add / remove rows */
|
||
.diff-row-add .diff-code {
|
||
background: rgba(47,107,62,0.10);
|
||
color: #1F4A2A;
|
||
}
|
||
.diff-row-add .diff-sign,
|
||
.diff-row-add .diff-gutter {
|
||
background: rgba(47,107,62,0.06);
|
||
color: #2F6B3E;
|
||
}
|
||
.diff-row-remove .diff-code {
|
||
background: rgba(161,58,46,0.10);
|
||
color: #6E1F1A;
|
||
}
|
||
.diff-row-remove .diff-sign,
|
||
.diff-row-remove .diff-gutter {
|
||
background: rgba(161,58,46,0.06);
|
||
color: #A13A2E;
|
||
}
|
||
|
||
.dark-mode .diff-row-add .diff-code { background: rgba(167,226,167,0.10); color: #C9F0C9; }
|
||
.dark-mode .diff-row-add .diff-sign,
|
||
.dark-mode .diff-row-add .diff-gutter { background: rgba(167,226,167,0.06); color: #A7E2A7; }
|
||
.dark-mode .diff-row-remove .diff-code { background: rgba(255,139,123,0.10); color: #FFC9C0; }
|
||
.dark-mode .diff-row-remove .diff-sign,
|
||
.dark-mode .diff-row-remove .diff-gutter { background: rgba(255,139,123,0.06); color: #FF8B7B; }
|
||
|
||
@media (max-width: 700px) {
|
||
.diff-file-table { font-size: 11.5px; }
|
||
.diff-file-table .diff-gutter { width: 36px; padding: 0 6px; }
|
||
.diff-file-table .diff-sign { width: 14px; padding: 0 4px; }
|
||
.diff-file-table .diff-code { padding: 1px 8px; }
|
||
}
|
||
|
||
/* Comments */
|
||
.pr-comments {
|
||
list-style: none;
|
||
margin: 16px 0 28px;
|
||
padding: 0;
|
||
display: flex;
|
||
flex-direction: column;
|
||
gap: 12px;
|
||
}
|
||
.pr-comment {
|
||
padding: 16px 18px;
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 10px;
|
||
}
|
||
.pr-comment-head {
|
||
display: flex;
|
||
justify-content: space-between;
|
||
align-items: baseline;
|
||
gap: 12px;
|
||
flex-wrap: wrap;
|
||
padding-bottom: 8px;
|
||
margin-bottom: 8px;
|
||
border-bottom: 1px solid var(--border-color);
|
||
}
|
||
.pr-comment-author {
|
||
font-weight: 600;
|
||
color: var(--color);
|
||
font-size: 14px;
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 6px;
|
||
}
|
||
.pr-comment-author i { color: var(--ink-muted); font-size: 12px; }
|
||
.pr-comment-date {
|
||
font-family: var(--font-mono);
|
||
font-size: 11.5px;
|
||
color: var(--ink-muted);
|
||
letter-spacing: 0.02em;
|
||
}
|
||
.pr-comment-body { color: var(--color); font-size: 14px; line-height: 1.6; }
|
||
.pr-comment-body :last-child { margin-bottom: 0; }
|
||
|
||
@media (max-width: 700px) {
|
||
.pr-page-inner { padding-top: 14px; padding-bottom: 40px; }
|
||
.pr-body-card { padding: 14px 14px; border-radius: 8px; }
|
||
.pr-comment { padding: 12px 14px; }
|
||
.paper-tabs .paper-tab { padding: 10px 12px; font-size: 13px; }
|
||
.pr-diff pre { font-size: 11.5px; padding: 12px; }
|
||
}
|
||
|
||
/* Toasts — paper style, dark-mode aware */
|
||
.toast {
|
||
background-color: var(--paper-card) !important;
|
||
color: var(--color) !important;
|
||
border: 1px solid var(--border-color) !important;
|
||
border-radius: 10px !important;
|
||
box-shadow: 0 8px 24px rgba(0,0,0,0.08);
|
||
backdrop-filter: none;
|
||
min-width: 280px;
|
||
max-width: calc(100vw - 24px);
|
||
}
|
||
.toast .toast-header {
|
||
background: transparent !important;
|
||
color: var(--color) !important;
|
||
border-bottom: 1px solid var(--border-color) !important;
|
||
font-family: var(--font-sans);
|
||
padding: 10px 12px;
|
||
}
|
||
.toast .toast-header strong {
|
||
font-weight: 600;
|
||
color: var(--color);
|
||
letter-spacing: 0.01em;
|
||
}
|
||
.toast .toast-header .close {
|
||
color: var(--ink-muted) !important;
|
||
text-shadow: none;
|
||
opacity: 0.9;
|
||
font-size: 1.2rem;
|
||
}
|
||
.toast .toast-header .close:hover { color: var(--color) !important; opacity: 1; }
|
||
.toast .toast-body {
|
||
color: var(--color) !important;
|
||
padding: 12px;
|
||
font-size: 14px;
|
||
line-height: 1.45;
|
||
}
|
||
.dark-mode .toast { box-shadow: 0 8px 24px rgba(0,0,0,0.5); }
|
||
|
||
.paper-crumbs {
|
||
font-family: var(--font-mono);
|
||
font-size: 11.5px;
|
||
color: var(--ink-muted);
|
||
letter-spacing: 0.02em;
|
||
}
|
||
.paper-crumbs a, .paper-crumbs .here {
|
||
color: var(--color);
|
||
text-decoration: none;
|
||
}
|
||
.paper-page-title {
|
||
font-family: var(--font-serif);
|
||
font-weight: 400;
|
||
font-size: clamp(2rem, 4.5vw, 3.2rem);
|
||
line-height: 1.05;
|
||
letter-spacing: -0.02em;
|
||
margin: 10px 0 6px;
|
||
color: var(--color);
|
||
}
|
||
.paper-page-title em { color: var(--accent); font-style: italic; }
|
||
.paper-page-lede {
|
||
color: var(--ink-soft);
|
||
font-size: 16px;
|
||
max-width: 640px;
|
||
line-height: 1.55;
|
||
}
|
||
.paper-meta-rule {
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
gap: 16px 24px;
|
||
align-items: center;
|
||
margin: 22px 0 18px;
|
||
padding: 12px 0;
|
||
border-top: 1px solid var(--border-color);
|
||
border-bottom: 1px solid var(--border-color);
|
||
font-family: var(--font-mono);
|
||
font-size: 11.5px;
|
||
color: var(--ink-muted);
|
||
letter-spacing: 0.02em;
|
||
}
|
||
.paper-meta-rule b { color: var(--color); font-weight: 500; }
|
||
|
||
.paper-card {
|
||
background: var(--paper-card, #fff);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 10px;
|
||
padding: 20px 22px;
|
||
}
|
||
.dark-mode .paper-card { background: var(--admin-stat-bg); }
|
||
|
||
.paper-section-eyebrow {
|
||
font-family: var(--font-mono);
|
||
font-size: 10.5px;
|
||
letter-spacing: 0.14em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
font-weight: 500;
|
||
margin-bottom: 10px;
|
||
display: block;
|
||
}
|
||
|
||
.paper-section-title {
|
||
font-family: var(--font-serif);
|
||
font-weight: 400;
|
||
font-size: 22px;
|
||
letter-spacing: -0.01em;
|
||
margin: 0 0 8px;
|
||
}
|
||
|
||
.paper-kbd {
|
||
display: inline-block;
|
||
font-family: var(--font-mono);
|
||
font-size: 10.5px;
|
||
padding: 1px 6px;
|
||
border: 1px solid var(--border-color);
|
||
border-bottom-width: 2px;
|
||
border-radius: 3px;
|
||
background: var(--paper-card, #fff);
|
||
color: var(--color);
|
||
}
|
||
|
||
/* Pill for status / meta */
|
||
.paper-pill {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 6px;
|
||
font-family: var(--font-mono);
|
||
font-size: 10.5px;
|
||
padding: 2px 8px;
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 999px;
|
||
color: var(--ink-soft);
|
||
background: var(--paper-card, #fff);
|
||
letter-spacing: 0.04em;
|
||
}
|
||
.paper-pill.accent { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
|
||
.paper-pill.good { border-color: #2F6B3E; color: #2F6B3E; }
|
||
.paper-pill.warn { border-color: #8A6B1E; color: #8A6B1E; }
|
||
.paper-pill.bad { border-color: #A13A2E; color: #A13A2E; }
|
||
|
||
/* Editorial list row */
|
||
.paper-row {
|
||
display: grid;
|
||
grid-template-columns: 1fr auto;
|
||
gap: 16px;
|
||
align-items: start;
|
||
padding: 18px 0;
|
||
border-bottom: 1px solid var(--border-color);
|
||
}
|
||
.paper-row:first-child { border-top: 1px solid var(--border-color); }
|
||
.paper-row .row-title {
|
||
font-family: var(--font-serif);
|
||
font-size: 20px;
|
||
letter-spacing: -0.01em;
|
||
line-height: 1.2;
|
||
}
|
||
.paper-row .row-title a { color: var(--color); }
|
||
.paper-row .row-meta {
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
color: var(--ink-muted);
|
||
letter-spacing: 0.03em;
|
||
margin-top: 6px;
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
gap: 14px;
|
||
}
|
||
.paper-row .row-actions { display: flex; gap: 6px; flex-shrink: 0; }
|
||
|
||
/* Paper form building blocks */
|
||
.paper-form-step {
|
||
display: grid;
|
||
grid-template-columns: 48px 1fr;
|
||
gap: 20px;
|
||
padding: 22px 0;
|
||
border-bottom: 1px solid var(--border-color);
|
||
}
|
||
.paper-form-step:first-child { border-top: 1px solid var(--border-color); }
|
||
.paper-form-step .step-num {
|
||
font-family: var(--font-mono);
|
||
font-size: 11.5px;
|
||
color: var(--ink-muted);
|
||
padding-top: 4px;
|
||
letter-spacing: 0.02em;
|
||
}
|
||
.paper-form-step .step-title {
|
||
font-family: var(--font-serif);
|
||
font-size: 22px;
|
||
letter-spacing: -0.01em;
|
||
line-height: 1.2;
|
||
margin-bottom: 4px;
|
||
}
|
||
.paper-form-step .step-sub {
|
||
color: var(--ink-soft);
|
||
font-size: 13.5px;
|
||
margin-bottom: 14px;
|
||
text-wrap: pretty;
|
||
}
|
||
|
||
.paper-field-label {
|
||
display: block;
|
||
font-family: var(--font-mono);
|
||
font-size: 10.5px;
|
||
letter-spacing: 0.12em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
font-weight: 500;
|
||
margin-bottom: 6px;
|
||
}
|
||
|
||
.paper-switch-row {
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: space-between;
|
||
padding: 10px 0;
|
||
gap: 16px;
|
||
}
|
||
.paper-switch-row + .paper-switch-row {
|
||
border-top: 1px dashed var(--border-soft);
|
||
}
|
||
.paper-switch-row .sw-label { font-weight: 500; }
|
||
.paper-switch-row .sw-sub {
|
||
display: block;
|
||
font-size: 12.5px;
|
||
color: var(--ink-muted);
|
||
margin-top: 2px;
|
||
}
|
||
|
||
/* Paper-style form controls reuse Bootstrap classes */
|
||
.paper-page .form-control,
|
||
.paper-page .custom-select {
|
||
border-radius: 6px;
|
||
border-color: var(--border-color);
|
||
font-size: 14px;
|
||
padding: 8px 12px;
|
||
height: auto;
|
||
background: var(--input-bg);
|
||
color: var(--input-color);
|
||
}
|
||
.paper-page .form-control:focus,
|
||
.paper-page .custom-select:focus {
|
||
color: var(--input-color);
|
||
background: var(--input-bg);
|
||
border-color: var(--accent);
|
||
box-shadow: 0 0 0 2px var(--accent-soft);
|
||
}
|
||
.form-control:focus,
|
||
.custom-select:focus,
|
||
input:focus,
|
||
textarea:focus,
|
||
select:focus {
|
||
color: var(--input-color) !important;
|
||
background-color: var(--input-bg) !important;
|
||
}
|
||
.form-control::selection,
|
||
input::selection,
|
||
textarea::selection {
|
||
background: var(--accent-soft);
|
||
color: var(--input-color);
|
||
}
|
||
.dark-mode .form-control::selection,
|
||
.dark-mode input::selection,
|
||
.dark-mode textarea::selection {
|
||
background: rgba(167, 178, 255, 0.30);
|
||
color: var(--input-color);
|
||
}
|
||
|
||
/* Primary/accent button variants */
|
||
.btn.btn-ink {
|
||
background: var(--color);
|
||
color: var(--canvas-bg-color);
|
||
border: 1px solid var(--color);
|
||
font-weight: 500;
|
||
border-radius: 6px;
|
||
padding: 8px 14px;
|
||
}
|
||
.btn.btn-ink:hover {
|
||
background: var(--primary-hover-bg);
|
||
color: var(--canvas-bg-color);
|
||
border-color: var(--primary-hover-bg);
|
||
}
|
||
.btn.btn-accent {
|
||
background: var(--accent);
|
||
color: #fff;
|
||
border: 1px solid var(--accent);
|
||
font-weight: 500;
|
||
border-radius: 6px;
|
||
}
|
||
.btn.btn-accent:hover { background: #2E3BB8; border-color: #2E3BB8; color: #fff; }
|
||
|
||
/* Paper-style filter row buttons (Sort / Status / type filter) */
|
||
.paper-page .dashboard-filter-row {
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 10px;
|
||
padding: 14px 0;
|
||
border-top: 1px solid var(--border-color);
|
||
border-bottom: 1px solid var(--border-color);
|
||
margin: 18px 0 0;
|
||
flex-wrap: wrap;
|
||
}
|
||
.paper-page .dashboard-filter-row .form-control {
|
||
height: 38px;
|
||
background: var(--paper-card);
|
||
}
|
||
.paper-page .dashboard-filter-row .dropdown-toggle,
|
||
.paper-page .dashboard-filter-row .btn-group .btn {
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
color: var(--color);
|
||
height: 38px;
|
||
padding: 0 14px;
|
||
font-size: 14px;
|
||
font-weight: 500;
|
||
border-radius: 6px;
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 6px;
|
||
line-height: 1;
|
||
}
|
||
.paper-page .dashboard-filter-row .dropdown-toggle:hover,
|
||
.paper-page .dashboard-filter-row .btn-group .btn:hover {
|
||
background: var(--hover-bg-color);
|
||
border-color: var(--border-color);
|
||
color: var(--color);
|
||
}
|
||
.paper-page .dashboard-filter-row .btn-group {
|
||
gap: 0;
|
||
}
|
||
.paper-page .dashboard-filter-row .btn-group .btn {
|
||
border-radius: 0;
|
||
border-right-width: 0;
|
||
}
|
||
.paper-page .dashboard-filter-row .btn-group .btn:first-child { border-top-left-radius: 6px; border-bottom-left-radius: 6px; }
|
||
.paper-page .dashboard-filter-row .btn-group .btn:last-child { border-top-right-radius: 6px; border-bottom-right-radius: 6px; border-right-width: 1px; }
|
||
.paper-page .dashboard-filter-row .btn-group .btn.btn-primary {
|
||
background: var(--color);
|
||
color: var(--canvas-bg-color);
|
||
border-color: var(--color);
|
||
}
|
||
.paper-page .dashboard-filter-row .search-wrap {
|
||
flex: 1 1 280px;
|
||
min-width: 220px;
|
||
}
|
||
|
||
/* Quota row refinements */
|
||
.paper-page .quota-row {
|
||
display: grid;
|
||
grid-template-columns: repeat(3, 1fr);
|
||
gap: 40px;
|
||
margin: 24px 0 0;
|
||
padding: 0;
|
||
background: transparent;
|
||
border: none;
|
||
border-radius: 0;
|
||
}
|
||
.paper-page .quota-label {
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
letter-spacing: 0.14em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
opacity: 1;
|
||
}
|
||
.paper-page .quota-value {
|
||
font-family: var(--font-mono);
|
||
font-size: 12px;
|
||
color: var(--ink-soft);
|
||
}
|
||
.paper-page .quota-progress {
|
||
height: 6px;
|
||
background: var(--paper-bg-alt);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 999px;
|
||
margin-bottom: 0;
|
||
width: 100%;
|
||
min-width: 0;
|
||
}
|
||
.paper-page .quota-progress .progress-bar {
|
||
background: var(--color);
|
||
}
|
||
|
||
/* Dashboard repo/PR list refinements */
|
||
.paper-page .repo-list { margin-top: 8px; }
|
||
.paper-page .repo-list-item {
|
||
padding: 20px 0;
|
||
gap: 16px;
|
||
border-bottom: 1px solid var(--border-soft, var(--border-color));
|
||
}
|
||
.paper-page .repo-list-item:first-child { border-top: none; }
|
||
.paper-page .repo-list-item-header { gap: 10px; margin-bottom: 6px; }
|
||
.paper-page .repo-name {
|
||
font-family: var(--font-mono);
|
||
font-size: 15px;
|
||
color: var(--color);
|
||
}
|
||
.paper-page .repo-source {
|
||
font-size: 13px;
|
||
color: var(--ink-soft);
|
||
opacity: 1;
|
||
gap: 10px;
|
||
}
|
||
.paper-page .repo-source a { color: var(--ink-soft); border-bottom: 1px dotted var(--border-color); }
|
||
.paper-page .repo-source a:hover { color: var(--color); }
|
||
.paper-page .repo-meta {
|
||
font-family: var(--font-mono);
|
||
font-size: 12px;
|
||
color: var(--ink-muted);
|
||
opacity: 1;
|
||
gap: 16px;
|
||
margin-top: 10px;
|
||
}
|
||
.paper-page .type-badge {
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
padding: 3px 8px;
|
||
letter-spacing: 0.1em;
|
||
}
|
||
.paper-page .repo-list-item-actions .dropdown-toggle {
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
color: var(--color);
|
||
border-radius: 6px;
|
||
font-size: 13px;
|
||
padding: 6px 12px;
|
||
height: auto;
|
||
}
|
||
|
||
/* Paper settings (editorial 2-col) */
|
||
.paper-settings { max-width: 1180px; margin: 0 auto; padding: 48px 32px 80px; }
|
||
.paper-settings .paper-page-title { max-width: 14em; }
|
||
.paper-settings-body {
|
||
display: grid;
|
||
grid-template-columns: 220px 1fr;
|
||
gap: 60px;
|
||
margin-top: 32px;
|
||
border-top: 1px solid var(--border-color);
|
||
padding-top: 28px;
|
||
}
|
||
.paper-settings-toc { position: sticky; top: 32px; align-self: start; }
|
||
.paper-settings-toc-head {
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
letter-spacing: 0.14em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
margin-bottom: 12px;
|
||
}
|
||
.paper-settings-toc nav { display: flex; flex-direction: column; gap: 2px; }
|
||
.paper-settings-toc nav a {
|
||
padding: 8px 0 8px 14px;
|
||
border-left: 2px solid transparent;
|
||
color: var(--ink-soft);
|
||
font-size: 14px;
|
||
text-decoration: none;
|
||
}
|
||
.paper-settings-toc nav a:hover,
|
||
.paper-settings-toc nav a.active {
|
||
color: var(--color);
|
||
border-left-color: var(--color);
|
||
}
|
||
.paper-settings-main { min-width: 0; max-width: 720px; }
|
||
.paper-settings-section { padding: 28px 0; border-bottom: 1px solid var(--border-soft, var(--border-color)); }
|
||
.paper-settings-section:first-child { padding-top: 0; }
|
||
.paper-settings-section:last-of-type { border-bottom: none; }
|
||
.paper-settings-section .form-group { margin-bottom: 18px; }
|
||
.paper-settings-section .form-check { padding: 10px 0 10px 28px; border-bottom: 1px solid var(--border-soft, var(--border-color)); }
|
||
.paper-settings-section .form-check:last-child { border-bottom: none; }
|
||
.paper-settings-section .form-check-label { font-family: var(--font-serif); font-size: 16px; color: var(--color); }
|
||
.paper-settings-section .form-text { color: var(--ink-soft); font-size: 13px; margin-top: 4px; max-width: 48em; }
|
||
.paper-settings-footer { padding-top: 24px; display: flex; flex-direction: column; gap: 14px; }
|
||
.paper-settings-footer .btn-ink { align-self: flex-start; }
|
||
.paper-field-label {
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
letter-spacing: 0.14em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
margin-bottom: 6px;
|
||
display: block;
|
||
}
|
||
|
||
@media (max-width: 900px) {
|
||
.paper-settings-body { grid-template-columns: 1fr; gap: 24px; }
|
||
.paper-settings-toc { position: static; }
|
||
.paper-settings-toc nav { flex-direction: row; flex-wrap: wrap; gap: 8px; }
|
||
.paper-settings-toc nav a { border-left: none; border-bottom: 2px solid transparent; padding: 4px 0; }
|
||
.paper-settings-toc nav a.active, .paper-settings-toc nav a:hover { border-bottom-color: var(--color); border-left: none; }
|
||
}
|
||
|
||
/* Paper table (reference grid) */
|
||
.paper-table {
|
||
display: block;
|
||
margin-top: 20px;
|
||
background: transparent;
|
||
border: none;
|
||
border-top: 1px solid var(--border-color);
|
||
border-radius: 0;
|
||
overflow: visible;
|
||
}
|
||
.paper-table .paper-table-head,
|
||
.paper-table .paper-table-row {
|
||
display: grid;
|
||
grid-template-columns: minmax(280px, 2.4fr) minmax(140px, 1fr) 140px 90px 140px 52px;
|
||
align-items: center;
|
||
gap: 18px;
|
||
padding: 12px 4px;
|
||
}
|
||
.paper-table.paper-table-conferences .paper-table-head,
|
||
.paper-table.paper-table-conferences .paper-table-row {
|
||
grid-template-columns: minmax(280px, 2.4fr) 140px 90px 220px 52px;
|
||
}
|
||
.paper-table.paper-table-repos .paper-table-head,
|
||
.paper-table.paper-table-repos .paper-table-row {
|
||
grid-template-columns: minmax(280px, 2.4fr) minmax(140px, 1fr) 90px 140px 52px;
|
||
}
|
||
.paper-table.paper-table-repos.has-bulk .paper-table-head,
|
||
.paper-table.paper-table-repos.has-bulk .paper-table-row {
|
||
grid-template-columns: 28px minmax(280px, 2.4fr) minmax(140px, 1fr) 90px 140px 52px;
|
||
gap: 12px;
|
||
}
|
||
.paper-table .admin-users-row {
|
||
grid-template-columns: 28px minmax(280px, 2.4fr) 90px 120px 100px 52px !important;
|
||
gap: 12px !important;
|
||
}
|
||
.paper-table .paper-table-head {
|
||
background: transparent;
|
||
border-bottom: 1px solid var(--border-color);
|
||
font-family: var(--font-mono);
|
||
font-size: 10.5px;
|
||
letter-spacing: 0.14em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
padding-top: 8px;
|
||
padding-bottom: 8px;
|
||
}
|
||
.paper-table .paper-table-head .sortable {
|
||
cursor: pointer;
|
||
user-select: none;
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 4px;
|
||
}
|
||
.paper-table .paper-table-head .sortable:hover { color: var(--color); }
|
||
.paper-table .paper-table-head .sortable.active { color: var(--color); }
|
||
.paper-table .paper-table-head .sortable i { font-size: 10px; }
|
||
.paper-table .paper-table-head .num,
|
||
.paper-table .paper-table-row .num { text-align: left; }
|
||
.paper-table .paper-table-row {
|
||
border-top: 1px solid var(--border-soft, var(--border-color));
|
||
font-size: 14px;
|
||
transition: background-color 0.12s ease;
|
||
}
|
||
.paper-table .paper-table-row:hover {
|
||
background: var(--hover-bg-color);
|
||
}
|
||
.paper-table .paper-table-row.repo-inactive { opacity: 0.55; }
|
||
.paper-table .paper-table-row.repo-error {
|
||
background: rgba(180, 35, 24, 0.04);
|
||
border-left: 2px solid #B42318;
|
||
padding-left: 6px;
|
||
}
|
||
.paper-table .paper-table-row.repo-error:hover { background: rgba(180, 35, 24, 0.08); }
|
||
.dark-mode .paper-table .paper-table-row.repo-error { background: rgba(240, 138, 130, 0.05); border-left-color: #F08A82; }
|
||
.dark-mode .paper-table .paper-table-row.repo-error:hover { background: rgba(240, 138, 130, 0.1); }
|
||
.paper-table .cell-status .status-sub-error,
|
||
.cell-status .status-sub.status-sub-error {
|
||
color: #B42318;
|
||
font-family: var(--font-mono);
|
||
}
|
||
.dark-mode .paper-table .cell-status .status-sub-error,
|
||
.dark-mode .cell-status .status-sub.status-sub-error { color: #F08A82; }
|
||
.paper-table .cell-anon {
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 12px;
|
||
min-width: 0;
|
||
}
|
||
.paper-table .cell-anon .type-badge {
|
||
flex-shrink: 0;
|
||
min-width: 52px;
|
||
justify-content: center;
|
||
}
|
||
.paper-table .cell-anon .anon-text { min-width: 0; display: flex; flex-direction: column; gap: 2px; }
|
||
.paper-table .cell-anon .repo-name {
|
||
font-family: var(--font-mono);
|
||
font-size: 14px;
|
||
color: var(--color);
|
||
font-weight: 500;
|
||
overflow: hidden;
|
||
text-overflow: ellipsis;
|
||
white-space: nowrap;
|
||
display: block;
|
||
max-width: 100%;
|
||
}
|
||
.paper-table .cell-anon .anon-sub {
|
||
font-size: 12px;
|
||
color: var(--ink-muted);
|
||
overflow: hidden;
|
||
text-overflow: ellipsis;
|
||
white-space: nowrap;
|
||
}
|
||
.paper-table .cell-anon .anon-sub a { color: var(--ink-muted); border-bottom: 1px dotted var(--border-color); }
|
||
.paper-table .cell-anon .anon-sub a:hover { color: var(--color); }
|
||
.paper-table .cell-conf { font-family: var(--font-mono); font-size: 13px; color: var(--color); }
|
||
.paper-table .cell-status { display: flex; flex-wrap: wrap; align-items: center; gap: 2px 8px; font-size: 14px; color: var(--color); }
|
||
.paper-table .cell-status .status-line { display: inline-flex; align-items: center; gap: 8px; }
|
||
.paper-table .cell-status .status-sub { flex-basis: 100%; font-size: 11px; line-height: 1.2; color: var(--ink-muted); }
|
||
.paper-table .cell-views { font-family: var(--font-mono); font-variant-numeric: tabular-nums; color: var(--color); }
|
||
.paper-table .cell-expires { font-size: 13px; color: var(--ink-soft); }
|
||
.paper-table .empty-dash { color: var(--ink-muted); opacity: 0.5; }
|
||
.paper-table .cell-actions { display: flex; justify-content: flex-end; }
|
||
|
||
.status-dot {
|
||
width: 8px;
|
||
height: 8px;
|
||
border-radius: 999px;
|
||
display: inline-block;
|
||
background: var(--ink-muted);
|
||
}
|
||
.status-dot.status-ready { background: #2F7A44; }
|
||
.status-dot.status-error { background: #B42318; }
|
||
.status-dot.status-preparing { background: #C48A2E; }
|
||
.status-dot.status-removed { background: #9A8F7B; }
|
||
|
||
.bulk-bar {
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 8px;
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 8px;
|
||
padding: 8px 12px;
|
||
margin: 8px 0;
|
||
}
|
||
|
||
/* Tighter admin page header — admin is power-user UI, no need for huge title + lede */
|
||
.paper-page.admin-page .paper-page-title { font-size: 1.6rem; margin: 4px 0; }
|
||
.paper-page.admin-page .paper-page-lede { display: none; }
|
||
.paper-page.admin-page .paper-crumbs { margin-bottom: 4px; }
|
||
.paper-page.admin-page .admin-nav { margin: 6px 0 12px; }
|
||
|
||
/* Admin filter toolbar — single compact line, inline labels (no boxed groups) */
|
||
.admin-filter-toolbar {
|
||
display: flex;
|
||
flex-direction: column;
|
||
gap: 6px;
|
||
margin: 8px 0 12px;
|
||
position: sticky;
|
||
top: 0;
|
||
z-index: 4;
|
||
background: var(--canvas-bg-color);
|
||
padding: 6px 0;
|
||
border-bottom: 1px solid var(--border-soft, var(--border-color));
|
||
box-shadow: 0 1px 0 var(--canvas-bg-color);
|
||
}
|
||
@media (max-width: 900px) {
|
||
.admin-filter-toolbar { position: static; box-shadow: none; }
|
||
}
|
||
.admin-filter-row {
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
gap: 6px;
|
||
align-items: center;
|
||
}
|
||
.admin-filter-row .search-wrap { flex: 1; min-width: 220px; }
|
||
.admin-filter-row .search-wrap .form-control { height: 34px; }
|
||
|
||
.admin-filter-inline {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 4px;
|
||
font-size: 12px;
|
||
color: var(--ink-muted);
|
||
}
|
||
.admin-filter-inline > label {
|
||
font-family: var(--font-mono);
|
||
font-size: 10px;
|
||
text-transform: uppercase;
|
||
letter-spacing: 0.06em;
|
||
color: var(--ink-muted);
|
||
margin: 0;
|
||
white-space: nowrap;
|
||
}
|
||
.admin-filter-inline .form-control-sm {
|
||
height: 28px;
|
||
padding: 2px 8px;
|
||
font-size: 12px;
|
||
}
|
||
.admin-filter-inline input[type="text"].form-control-sm,
|
||
.admin-filter-inline input[type="search"].form-control-sm { width: 130px; }
|
||
.admin-filter-inline input[type="date"].form-control-sm { width: 130px; }
|
||
.admin-filter-inline select.form-control-sm { width: auto; min-width: 88px; }
|
||
.admin-filter-inline .arrow { color: var(--ink-muted); font-size: 11px; }
|
||
|
||
.admin-filter-spacer { flex: 1; }
|
||
|
||
/* Active-filter chips — visually surface what's currently constraining the view */
|
||
.admin-active-chips {
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
gap: 6px;
|
||
align-items: center;
|
||
font-size: 12px;
|
||
color: var(--ink-muted);
|
||
}
|
||
.admin-active-chip {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 4px;
|
||
padding: 2px 4px 2px 10px;
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 999px;
|
||
background: var(--hover-bg-color);
|
||
font-size: 12px;
|
||
color: var(--color);
|
||
}
|
||
.admin-active-chip .key { color: var(--ink-muted); font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.06em; }
|
||
.admin-active-chip button {
|
||
background: none;
|
||
border: none;
|
||
cursor: pointer;
|
||
padding: 0 4px;
|
||
color: var(--ink-muted);
|
||
font-size: 12px;
|
||
border-radius: 50%;
|
||
}
|
||
.admin-active-chip button:hover { color: #B42318; }
|
||
|
||
.admin-search-hint {
|
||
position: absolute;
|
||
right: 10px;
|
||
top: 50%;
|
||
transform: translateY(-50%);
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
color: var(--ink-muted);
|
||
pointer-events: none;
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 4px;
|
||
padding: 1px 5px;
|
||
background: var(--paper-card);
|
||
}
|
||
.admin-filter-row .search-wrap { position: relative; }
|
||
.admin-filter-row .search-wrap .form-control { padding-right: 40px; }
|
||
.paper-table-row.row-selected {
|
||
background: rgba(47, 122, 68, 0.06);
|
||
}
|
||
|
||
.queue-state-pills { display: inline-flex; gap: 6px; margin-left: 8px; flex-wrap: wrap; }
|
||
.queue-state-pills .pill {
|
||
font-size: 11px;
|
||
padding: 2px 8px;
|
||
border-radius: 999px;
|
||
border: 1px solid var(--border-color);
|
||
background: var(--paper-card);
|
||
color: var(--ink-muted);
|
||
}
|
||
.queue-state-pills .pill-active { color: #C48A2E; border-color: rgba(196,138,46,0.4); }
|
||
.queue-state-pills .pill-failed { color: #B42318; border-color: rgba(180,35,24,0.4); }
|
||
.queue-state-pills .pill-completed { color: #2F7A44; border-color: rgba(47,122,68,0.3); }
|
||
.queue-state-pills .pill-waiting { color: var(--ink-soft); }
|
||
.queue-state-pills .pill-delayed { color: var(--ink-muted); }
|
||
|
||
/* Compact summary bar — replaces stat cards. Each pill is also a filter shortcut. */
|
||
.admin-summary {
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
align-items: center;
|
||
gap: 6px;
|
||
margin: 8px 0 12px;
|
||
font-size: 13px;
|
||
}
|
||
.admin-summary .summary-total {
|
||
font-family: var(--font-serif);
|
||
font-size: 1.05rem;
|
||
color: var(--color);
|
||
margin-right: 8px;
|
||
}
|
||
.admin-summary .summary-meta {
|
||
color: var(--ink-muted);
|
||
font-size: 12px;
|
||
margin-right: 8px;
|
||
}
|
||
.admin-summary .summary-pill {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 6px;
|
||
padding: 3px 10px;
|
||
border-radius: 999px;
|
||
border: 1px solid var(--border-color);
|
||
background: var(--paper-card);
|
||
color: var(--ink-muted);
|
||
cursor: pointer;
|
||
font-size: 12px;
|
||
user-select: none;
|
||
transition: background-color 0.1s, border-color 0.1s;
|
||
}
|
||
.admin-summary .summary-pill:hover { background: var(--hover-bg-color); }
|
||
.admin-summary .summary-pill .count {
|
||
font-family: var(--font-mono);
|
||
font-variant-numeric: tabular-nums;
|
||
color: var(--color);
|
||
}
|
||
.admin-summary .summary-pill.active {
|
||
background: var(--primary-bg);
|
||
color: var(--primary-color);
|
||
border-color: var(--primary-bg);
|
||
}
|
||
.admin-summary .summary-pill.active .count { color: inherit; }
|
||
.admin-summary .summary-pill.error .count { color: #B42318; }
|
||
.admin-summary .summary-pill.warn .count { color: #C48A2E; }
|
||
.admin-summary .summary-pill.ok .count { color: #2F7A44; }
|
||
.dark-mode .admin-summary .summary-pill.error .count { color: #F08A82; }
|
||
.dark-mode .admin-summary .summary-pill.warn .count { color: #E8B970; }
|
||
.dark-mode .admin-summary .summary-pill.ok .count { color: #7DC894; }
|
||
.dark-mode .queue-state-pills .pill-active { color: #E8B970; border-color: rgba(232,185,112,0.4); }
|
||
.dark-mode .queue-state-pills .pill-failed { color: #F08A82; border-color: rgba(240,138,130,0.4); }
|
||
.dark-mode .queue-state-pills .pill-completed { color: #7DC894; border-color: rgba(125,200,148,0.3); }
|
||
|
||
.job-progress {
|
||
flex: 1;
|
||
height: 6px;
|
||
background: var(--border-soft, var(--border-color));
|
||
border-radius: 999px;
|
||
overflow: hidden;
|
||
margin-left: 12px;
|
||
max-width: 200px;
|
||
}
|
||
.job-progress-bar { height: 100%; background: #2F7A44; transition: width 0.3s; }
|
||
|
||
.paper-table-empty {
|
||
padding: 48px 4px;
|
||
text-align: center;
|
||
color: var(--ink-muted);
|
||
display: flex;
|
||
flex-direction: column;
|
||
align-items: center;
|
||
gap: 8px;
|
||
border-top: 1px solid var(--border-soft, var(--border-color));
|
||
}
|
||
.paper-table-empty i { font-size: 1.6rem; }
|
||
|
||
@media (max-width: 900px) {
|
||
.paper-table .paper-table-head { display: none; }
|
||
.paper-table .paper-table-row,
|
||
.paper-table.paper-table-conferences .paper-table-row,
|
||
.paper-table.paper-table-repos .paper-table-row,
|
||
.paper-table .admin-users-row {
|
||
display: flex !important;
|
||
flex-wrap: wrap;
|
||
align-items: center;
|
||
gap: 6px 12px;
|
||
padding: 14px 0;
|
||
grid-template-columns: none !important;
|
||
}
|
||
.paper-table .cell-anon {
|
||
flex: 1 1 calc(100% - 52px);
|
||
min-width: 0;
|
||
order: 1;
|
||
}
|
||
.paper-table .cell-actions {
|
||
flex: 0 0 auto;
|
||
order: 2;
|
||
align-self: center;
|
||
}
|
||
.paper-table .cell-status,
|
||
.paper-table .cell-views,
|
||
.paper-table .cell-conf,
|
||
.paper-table .cell-expires {
|
||
order: 3;
|
||
font-size: 12px;
|
||
color: var(--ink-muted);
|
||
display: inline-flex;
|
||
align-items: center;
|
||
gap: 6px;
|
||
text-align: left;
|
||
}
|
||
.paper-table .cell-views.num { text-align: left; }
|
||
.paper-table .cell-views::before {
|
||
content: '\f06e';
|
||
font-family: 'Font Awesome 5 Free';
|
||
font-weight: 900;
|
||
font-size: 10px;
|
||
color: var(--ink-muted);
|
||
}
|
||
.paper-table .cell-expires::before {
|
||
content: '\f017';
|
||
font-family: 'Font Awesome 5 Free';
|
||
font-weight: 400;
|
||
font-size: 10px;
|
||
color: var(--ink-muted);
|
||
}
|
||
.paper-table .cell-conf::before {
|
||
content: '\f51c';
|
||
font-family: 'Font Awesome 5 Free';
|
||
font-weight: 900;
|
||
font-size: 10px;
|
||
color: var(--ink-muted);
|
||
}
|
||
.paper-table .cell-conf:has(.empty-dash),
|
||
.paper-table .cell-expires:has(.empty-dash) { display: none; }
|
||
}
|
||
|
||
/* Paper-themed dropdown menus (Sort / Status / Actions) */
|
||
.paper-page .dropdown-menu {
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 8px;
|
||
box-shadow: 0 12px 28px rgba(26, 24, 21, 0.08);
|
||
padding: 6px;
|
||
min-width: 220px;
|
||
font-family: var(--font-sans);
|
||
font-size: 14px;
|
||
color: var(--color);
|
||
margin-top: 6px;
|
||
}
|
||
.paper-page .dropdown-menu .dropdown-header {
|
||
font-family: var(--font-mono);
|
||
font-size: 10px;
|
||
letter-spacing: 0.14em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
padding: 8px 10px 6px;
|
||
font-weight: 500;
|
||
}
|
||
.paper-page .dropdown-menu .dropdown-item {
|
||
border-radius: 6px;
|
||
padding: 8px 10px;
|
||
color: var(--color);
|
||
font-size: 14px;
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 8px;
|
||
}
|
||
.paper-page .dropdown-menu .dropdown-item:hover,
|
||
.paper-page .dropdown-menu .dropdown-item:focus {
|
||
background: var(--hover-bg-color);
|
||
color: var(--color);
|
||
}
|
||
.paper-page .dropdown-menu .dropdown-item i {
|
||
width: 16px;
|
||
font-size: 13px;
|
||
color: var(--ink-muted);
|
||
}
|
||
.paper-page .dropdown-menu .form-check.dropdown-item {
|
||
padding: 8px 10px 8px 36px !important;
|
||
position: relative;
|
||
}
|
||
.paper-page .dropdown-menu .form-check.dropdown-item .form-check-input {
|
||
position: absolute;
|
||
left: 12px;
|
||
top: 50%;
|
||
transform: translateY(-50%);
|
||
margin: 0;
|
||
width: 16px;
|
||
height: 16px;
|
||
accent-color: var(--color);
|
||
cursor: pointer;
|
||
}
|
||
.paper-page .dropdown-menu .form-check.dropdown-item .form-check-label {
|
||
font-family: var(--font-sans);
|
||
font-size: 14px;
|
||
color: var(--color);
|
||
font-weight: 400;
|
||
margin: 0;
|
||
cursor: pointer;
|
||
}
|
||
|
||
/* Three-dots icon action button */
|
||
.btn.btn-icon-dots {
|
||
width: 32px;
|
||
height: 32px;
|
||
padding: 0;
|
||
border: 1px solid transparent;
|
||
background: transparent;
|
||
color: var(--ink-muted);
|
||
border-radius: 6px;
|
||
display: inline-flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
line-height: 1;
|
||
}
|
||
.btn.btn-icon-dots:hover,
|
||
.btn.btn-icon-dots:focus,
|
||
.btn.btn-icon-dots[aria-expanded="true"] {
|
||
background: var(--hover-bg-color);
|
||
border-color: var(--border-color);
|
||
color: var(--color);
|
||
}
|
||
.btn.btn-icon-dots::after { display: none; }
|
||
.btn.btn-icon-dots i { font-size: 15px; }
|
||
.paper-page .repo-list-empty {
|
||
border-top: none;
|
||
padding: 56px 20px;
|
||
color: var(--ink-muted);
|
||
}
|
||
|
||
/* Filter chips */
|
||
.paper-page .filter-chip {
|
||
background: var(--paper-bg-alt);
|
||
color: var(--color);
|
||
border: 1px solid var(--border-color);
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
letter-spacing: 0.08em;
|
||
text-transform: uppercase;
|
||
padding: 4px 10px;
|
||
border-radius: 999px;
|
||
}
|
||
|
||
@media (max-width: 768px) {
|
||
.paper-page .paper-page-title { font-size: clamp(1.4rem, 6vw, 1.9rem); margin: 4px 0 2px; }
|
||
.paper-page .paper-page-lede { font-size: 13px; line-height: 1.4; margin-bottom: 0; }
|
||
.paper-page .btn-ink { padding: 6px 12px; font-size: 13px; }
|
||
|
||
.paper-page .quota-row {
|
||
grid-template-columns: repeat(3, 1fr);
|
||
gap: 10px 12px;
|
||
padding: 0;
|
||
margin: 12px 0 0;
|
||
}
|
||
.paper-page .dashboard-filter-row {
|
||
padding: 8px 0;
|
||
margin-top: 10px;
|
||
}
|
||
.paper-page .quota-header {
|
||
flex-direction: column;
|
||
align-items: flex-start;
|
||
gap: 2px;
|
||
}
|
||
.paper-page .quota-label { font-size: 10px; letter-spacing: 0.1em; }
|
||
.paper-page .quota-value { font-size: 11px; }
|
||
|
||
.paper-page .dashboard-filter-row { gap: 8px; }
|
||
}
|
||
|
||
@media (max-width: 480px) {
|
||
.paper-page .paper-page-lede {
|
||
display: -webkit-box;
|
||
-webkit-line-clamp: 2;
|
||
-webkit-box-orient: vertical;
|
||
overflow: hidden;
|
||
}
|
||
.paper-page .quota-row { gap: 8px; }
|
||
.paper-page .quota-label { font-size: 9px; letter-spacing: 0.06em; }
|
||
.paper-page .quota-value { font-size: 10px; white-space: nowrap; }
|
||
}
|
||
|
||
/* Empty state */
|
||
.empty-state {
|
||
text-align: center;
|
||
padding: 40px 20px;
|
||
opacity: 0.6;
|
||
}
|
||
|
||
.empty-state i {
|
||
font-size: 2rem;
|
||
margin-bottom: 10px;
|
||
display: block;
|
||
}
|
||
|
||
/* ===== Paper profile / settings ===== */
|
||
.paper-page .progress {
|
||
height: 10px;
|
||
background: var(--paper-bg-alt);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 999px;
|
||
overflow: hidden;
|
||
margin-bottom: 20px;
|
||
}
|
||
.paper-page .progress .progress-bar {
|
||
background: var(--color);
|
||
color: var(--canvas-bg-color);
|
||
font-family: var(--font-mono);
|
||
font-size: 10px;
|
||
line-height: 10px;
|
||
}
|
||
.paper-page .progress .progress-bar.bg-success { background: #2F7A44; }
|
||
.paper-page .progress .progress-bar.bg-warning { background: #C48A2E; color: #fff; }
|
||
.paper-page .progress .progress-bar.bg-danger { background: #B42318; }
|
||
.paper-page .progress .progress-bar.bg-dark { background: var(--ink-muted); }
|
||
|
||
.paper-page > h5,
|
||
.paper-page form > h5,
|
||
.paper-page .form > h5 {
|
||
font-family: var(--font-mono);
|
||
font-size: 11px;
|
||
font-weight: 500;
|
||
letter-spacing: 0.1em;
|
||
text-transform: uppercase;
|
||
color: var(--ink-muted);
|
||
margin: 24px 0 8px;
|
||
}
|
||
|
||
.paper-page .accordion .card {
|
||
background: var(--paper-card, var(--sidebar-bg-color));
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 8px !important;
|
||
margin-bottom: 8px;
|
||
overflow: hidden;
|
||
}
|
||
.paper-page .accordion .card + .card { border-top: 1px solid var(--border-color); }
|
||
.paper-page .accordion .card-header {
|
||
background: transparent;
|
||
border: none;
|
||
padding: 0;
|
||
}
|
||
.paper-page .accordion .card-header .btn {
|
||
color: var(--color) !important;
|
||
font-family: var(--font-sans);
|
||
font-weight: 500;
|
||
font-size: 14px;
|
||
padding: 14px 18px !important;
|
||
background: transparent !important;
|
||
border: none !important;
|
||
position: relative;
|
||
}
|
||
.paper-page .accordion .card-header .btn::after {
|
||
content: "+";
|
||
position: absolute;
|
||
right: 18px;
|
||
font-family: var(--font-serif);
|
||
font-size: 20px;
|
||
color: var(--ink-muted);
|
||
}
|
||
.paper-page .accordion .card-header .btn:not(.collapsed)::after { content: "–"; }
|
||
.paper-page .accordion .card-body {
|
||
padding: 6px 18px 18px !important;
|
||
border-top: 1px solid var(--border-soft);
|
||
}
|
||
.paper-page .accordion .form-check-label {
|
||
color: var(--color);
|
||
font-weight: 500;
|
||
font-size: 13.5px;
|
||
}
|
||
.paper-page .accordion .form-text {
|
||
color: var(--ink-muted);
|
||
font-size: 12px;
|
||
margin-top: 2px;
|
||
}
|
||
|
||
.faq-section .panel-body code {
|
||
font-family: var(--font-mono);
|
||
font-size: 13px;
|
||
padding: 1px 6px;
|
||
background: var(--paper-bg-alt);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 3px;
|
||
color: var(--color);
|
||
}
|
||
.faq-section .panel-body a {
|
||
color: var(--accent);
|
||
}
|
||
|
||
@media (max-width: 820px) {
|
||
.paper-faq-body {
|
||
grid-template-columns: 1fr;
|
||
gap: 24px;
|
||
}
|
||
.paper-faq-toc {
|
||
position: static;
|
||
}
|
||
}
|
||
|
||
/* ===== Paper footer ===== */
|
||
.paper-footer {
|
||
margin-top: 80px;
|
||
padding: 56px max(20px, calc((100vw - 1200px) / 2)) 28px;
|
||
border-top: 1px solid var(--border-color);
|
||
background: var(--canvas-bg-color);
|
||
font-family: var(--font-sans);
|
||
}
|
||
.paper-footer-inner {
|
||
display: grid;
|
||
grid-template-columns: 1.6fr 1fr 1fr 1fr;
|
||
gap: 40px;
|
||
}
|
||
.paper-footer-brand .paper-footer-mark {
|
||
font-family: var(--font-serif);
|
||
font-size: 22px;
|
||
letter-spacing: -0.01em;
|
||
color: var(--color);
|
||
}
|
||
.paper-footer-brand .paper-footer-mark em {
|
||
font-style: italic;
|
||
font-weight: 400;
|
||
}
|
||
.paper-footer-tag {
|
||
margin-top: 10px;
|
||
color: var(--ink-soft);
|
||
font-size: 13.5px;
|
||
line-height: 1.55;
|
||
max-width: 340px;
|
||
}
|
||
.paper-footer-head {
|
||
font-family: var(--font-mono);
|
||
font-size: 10.5px;
|
||
color: var(--ink-muted);
|
||
letter-spacing: 0.1em;
|
||
text-transform: uppercase;
|
||
margin-bottom: 14px;
|
||
}
|
||
.paper-footer-col a {
|
||
display: block;
|
||
color: var(--color);
|
||
font-size: 13.5px;
|
||
padding: 4px 0;
|
||
text-decoration: none;
|
||
}
|
||
.paper-footer-col a:hover {
|
||
color: var(--accent);
|
||
}
|
||
.paper-footer-rule {
|
||
height: 1px;
|
||
background: var(--border-color);
|
||
margin: 40px 0 16px;
|
||
}
|
||
.paper-footer-foot {
|
||
display: flex;
|
||
justify-content: space-between;
|
||
flex-wrap: wrap;
|
||
gap: 12px;
|
||
font-size: 12px;
|
||
color: var(--ink-muted);
|
||
font-family: var(--font-mono);
|
||
letter-spacing: 0.02em;
|
||
}
|
||
.paper-footer-foot .paper-footer-meta {
|
||
font-family: var(--font-serif);
|
||
font-style: italic;
|
||
font-size: 13.5px;
|
||
letter-spacing: 0;
|
||
color: var(--ink-soft);
|
||
}
|
||
@media (max-width: 768px) {
|
||
.paper-footer-inner {
|
||
grid-template-columns: 1fr 1fr;
|
||
}
|
||
}
|
||
.file.folder.truncated > .truncated-warning {
|
||
color: #d39e00;
|
||
margin-left: 6px;
|
||
font-size: 0.85em;
|
||
}
|
||
.file.folder.truncated > a {
|
||
color: #d39e00;
|
||
}
|
||
|
||
/* ===== Errors admin page =====
|
||
Uses the existing design tokens (--paper-card, --border-color, --ink-muted,
|
||
--primary-bg, etc.) so light + dark themes are picked up automatically.
|
||
Bucket colors are exposed as their own tokens with light/dark overrides
|
||
below so status pills stay legible against the dark canvas. */
|
||
body {
|
||
--bucket-error-bg: #FCEDED;
|
||
--bucket-error-fg: #8A1F1F;
|
||
--bucket-error-bd: #F0C4C4;
|
||
--bucket-error-dot: #B53737;
|
||
--bucket-warn-bg: #FFF3DF;
|
||
--bucket-warn-fg: #7A4D00;
|
||
--bucket-warn-bd: #F0D8A0;
|
||
--bucket-warn-dot: #B07A2F;
|
||
--bucket-info-bg: #EAF2EC;
|
||
--bucket-info-fg: #2C5D3A;
|
||
--bucket-info-bd: #C5DCCD;
|
||
--bucket-info-dot: #5B8D6B;
|
||
/* Subtle elevation tokens — gives cards weight without losing the paper
|
||
palette. Single soft shadow + a 1px hairline to keep the editorial feel. */
|
||
--card-shadow: 0 1px 2px rgba(26, 24, 21, 0.04), 0 4px 14px rgba(26, 24, 21, 0.05);
|
||
--card-shadow-hover: 0 1px 2px rgba(26, 24, 21, 0.06), 0 8px 24px rgba(26, 24, 21, 0.08);
|
||
}
|
||
.dark-mode {
|
||
--bucket-error-bg: rgba(255, 139, 123, 0.10);
|
||
--bucket-error-fg: #FF8B7B;
|
||
--bucket-error-bd: rgba(255, 139, 123, 0.28);
|
||
--bucket-error-dot: #FF8B7B;
|
||
--bucket-warn-bg: rgba(255, 211, 122, 0.10);
|
||
--bucket-warn-fg: #FFD37A;
|
||
--bucket-warn-bd: rgba(255, 211, 122, 0.28);
|
||
--bucket-warn-dot: #FFD37A;
|
||
--bucket-info-bg: rgba(152, 200, 168, 0.10);
|
||
--bucket-info-fg: #98C8A8;
|
||
--bucket-info-bd: rgba(152, 200, 168, 0.28);
|
||
--bucket-info-dot: #98C8A8;
|
||
--card-shadow: 0 1px 2px rgba(0, 0, 0, 0.35), 0 6px 18px rgba(0, 0, 0, 0.30);
|
||
--card-shadow-hover: 0 2px 4px rgba(0, 0, 0, 0.45), 0 12px 28px rgba(0, 0, 0, 0.40);
|
||
}
|
||
|
||
.errors-page .errors-header { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin: 4px 0 8px; }
|
||
.errors-page .errors-actions { display: flex; gap: 6px; }
|
||
|
||
.errors-page .kpi-grid {
|
||
display: grid;
|
||
grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
|
||
gap: 16px;
|
||
margin: 14px 0 18px;
|
||
}
|
||
.errors-page .kpi-card {
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 12px;
|
||
padding: 18px 20px;
|
||
display: flex;
|
||
flex-direction: column;
|
||
gap: 4px;
|
||
box-shadow: var(--card-shadow);
|
||
transition: box-shadow 160ms ease, transform 160ms ease;
|
||
}
|
||
.errors-page .kpi-card:hover { box-shadow: var(--card-shadow-hover); }
|
||
.errors-page .kpi-label {
|
||
font-family: var(--font-mono);
|
||
font-size: 0.7rem;
|
||
text-transform: uppercase;
|
||
letter-spacing: 0.08em;
|
||
color: var(--ink-muted);
|
||
}
|
||
.errors-page .kpi-value {
|
||
font-family: var(--font-serif);
|
||
font-size: 2.6rem;
|
||
font-weight: 400;
|
||
line-height: 1;
|
||
margin-top: 2px;
|
||
color: var(--color);
|
||
}
|
||
.errors-page .kpi-card.kpi-error .kpi-value { color: var(--bucket-error-fg); }
|
||
.errors-page .kpi-card.kpi-warn .kpi-value { color: var(--bucket-warn-fg); }
|
||
.errors-page .kpi-card.kpi-info .kpi-value { color: var(--bucket-info-fg); }
|
||
.errors-page .kpi-sub { font-size: 0.78rem; color: var(--ink-muted); font-style: italic; }
|
||
.errors-page .kpi-sub.up { color: var(--bucket-error-fg); font-style: normal; }
|
||
.errors-page .kpi-sub.down { color: var(--bucket-info-fg); font-style: normal; }
|
||
.errors-page .dropped-warn { color: var(--bucket-error-fg); font-weight: 600; font-style: normal; }
|
||
|
||
.errors-page .volume-chart {
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 12px;
|
||
padding: 18px 22px;
|
||
margin-bottom: 18px;
|
||
box-shadow: var(--card-shadow);
|
||
}
|
||
.errors-page .volume-head {
|
||
display: flex; justify-content: space-between; align-items: center;
|
||
font-family: var(--font-mono);
|
||
font-size: 0.7rem; color: var(--ink-muted);
|
||
text-transform: uppercase; letter-spacing: 0.08em;
|
||
margin-bottom: 10px;
|
||
}
|
||
.errors-page .volume-legend { display: flex; gap: 14px; align-items: center; text-transform: none; letter-spacing: 0; font-family: var(--font-sans); }
|
||
.errors-page .volume-legend .dot { display: inline-block; width: 8px; height: 8px; border-radius: 2px; margin-right: 5px; vertical-align: middle; }
|
||
.errors-page .dot.dot-error { background: var(--bucket-error-dot); }
|
||
.errors-page .dot.dot-warn { background: var(--bucket-warn-dot); }
|
||
.errors-page .dot.dot-info { background: var(--bucket-info-dot); }
|
||
.errors-page .volume-bars { display: flex; align-items: flex-end; gap: 4px; height: 80px; }
|
||
.errors-page .volume-bar { display: flex; flex-direction: column-reverse; flex: 1 1 0; min-width: 6px; height: 100%; }
|
||
.errors-page .volume-bar .seg { display: block; width: 100%; }
|
||
.errors-page .seg.seg-error { background: var(--bucket-error-dot); }
|
||
.errors-page .seg.seg-warn { background: var(--bucket-warn-dot); }
|
||
.errors-page .seg.seg-info { background: var(--bucket-info-dot); opacity: 0.7; }
|
||
|
||
.errors-page .errors-toolbar { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-bottom: 12px; }
|
||
.errors-page .seg-tabs {
|
||
display: inline-flex;
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 8px;
|
||
overflow: hidden;
|
||
background: var(--paper-card);
|
||
}
|
||
.errors-page .seg-tabs button {
|
||
background: transparent; border: none;
|
||
padding: 6px 14px; font-size: 0.85rem; cursor: pointer;
|
||
color: var(--color); font-family: var(--font-sans);
|
||
}
|
||
.errors-page .seg-tabs button + button { border-left: 1px solid var(--border-color); }
|
||
.errors-page .seg-tabs button.active { background: var(--primary-bg); color: var(--primary-color); }
|
||
.errors-page .errors-toolbar .search-wrap { position: relative; flex: 1 1 320px; min-width: 220px; }
|
||
.errors-page .errors-toolbar .search-wrap input {
|
||
width: 100%;
|
||
padding: 6px 10px 6px 32px;
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 8px;
|
||
font-family: var(--font-mono); font-size: 0.82rem;
|
||
background: var(--input-bg);
|
||
color: var(--input-color);
|
||
}
|
||
.errors-page .errors-toolbar .search-icon { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--ink-muted); font-size: 0.85rem; }
|
||
.errors-page .errors-toolbar .filter-count { position: absolute; right: 10px; top: 50%; transform: translateY(-50%); font-size: 0.72rem; color: var(--ink-muted); }
|
||
.errors-page .errors-toolbar .select-wrap { display: inline-flex; align-items: center; gap: 6px; }
|
||
.errors-page .errors-toolbar .select-wrap label {
|
||
font-family: var(--font-mono);
|
||
font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.08em;
|
||
color: var(--ink-muted); margin: 0;
|
||
}
|
||
.errors-page .errors-toolbar .select-wrap select {
|
||
background: var(--input-bg); color: var(--input-color);
|
||
border: 1px solid var(--border-color); border-radius: 8px;
|
||
}
|
||
.errors-page .errors-toolbar .autoref { display: inline-flex; gap: 6px; align-items: center; font-size: 0.82rem; color: var(--color); cursor: pointer; margin: 0; }
|
||
.errors-page .btn-icon { width: 32px; padding: 4px 0; }
|
||
|
||
.errors-page .errors-list {
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 12px;
|
||
overflow: hidden;
|
||
box-shadow: var(--card-shadow);
|
||
}
|
||
.errors-page .errors-list-head,
|
||
.errors-page .errors-row-main {
|
||
display: grid;
|
||
grid-template-columns: 110px 100px 100px 1fr 60px 70px;
|
||
gap: 16px;
|
||
padding: 18px 20px;
|
||
align-items: start;
|
||
}
|
||
.errors-page .errors-list-head { padding: 12px 20px; align-items: center; }
|
||
.errors-page .errors-list-head {
|
||
font-family: var(--font-mono);
|
||
font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.08em;
|
||
color: var(--ink-muted);
|
||
border-bottom: 1px solid var(--border-color);
|
||
background: var(--paper-bg-alt);
|
||
}
|
||
.errors-page .errors-row { border-bottom: 1px solid var(--border-soft); }
|
||
.errors-page .errors-row:last-child { border-bottom: none; }
|
||
.errors-page .errors-row.open { background: var(--paper-bg-alt); }
|
||
.errors-page .errors-row-main { cursor: pointer; }
|
||
.errors-page .errors-row-main:hover { background: var(--hover-bg-color); }
|
||
.errors-page .col-when .when-rel { font-size: 0.95rem; color: var(--color); font-variant-numeric: tabular-nums; }
|
||
.errors-page .col-when .when-abs { font-family: var(--font-mono); font-size: 0.78rem; color: var(--ink-muted); font-variant-numeric: tabular-nums; margin-top: 2px; }
|
||
.errors-page .col-sev { display: flex; align-items: center; gap: 8px; }
|
||
.errors-page .sev-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
|
||
.errors-page .sev-dot.sev-error { background: var(--bucket-error-dot); }
|
||
.errors-page .sev-dot.sev-warn { background: var(--bucket-warn-dot); }
|
||
.errors-page .sev-dot.sev-info { background: var(--bucket-info-dot); }
|
||
.errors-page .sev-label { font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.08em; color: var(--color); }
|
||
|
||
.errors-page .pill-module {
|
||
display: inline-block;
|
||
font-family: var(--font-mono); font-size: 0.78rem;
|
||
background: var(--paper-bg-alt); color: var(--ink-soft);
|
||
border: 1px solid var(--border-color);
|
||
padding: 3px 10px; border-radius: 6px;
|
||
}
|
||
.errors-page .col-msg .msg-code {
|
||
font-family: var(--font-mono);
|
||
font-size: 1rem;
|
||
color: var(--color);
|
||
font-weight: 600;
|
||
}
|
||
.errors-page .col-msg .msg-context { color: var(--ink-muted); font-style: italic; font-size: 0.88rem; margin-left: 10px; }
|
||
.errors-page .col-msg .msg-detail {
|
||
color: var(--ink-soft);
|
||
font-family: var(--font-mono);
|
||
font-size: 0.82rem;
|
||
margin-left: 10px;
|
||
}
|
||
.errors-page .col-msg .msg-url {
|
||
color: var(--ink-muted);
|
||
font-family: var(--font-mono);
|
||
font-size: 0.8rem;
|
||
margin-top: 6px;
|
||
word-break: break-all;
|
||
}
|
||
|
||
.errors-page .count-pill {
|
||
display: inline-block;
|
||
padding: 2px 8px; border-radius: 4px;
|
||
background: var(--primary-bg); color: var(--primary-color);
|
||
font-family: var(--font-mono); font-size: 0.78rem; font-variant-numeric: tabular-nums;
|
||
}
|
||
.errors-page .count-pill.count-pill-muted {
|
||
background: transparent; color: var(--ink-muted);
|
||
border: 1px solid var(--border-color);
|
||
}
|
||
.errors-page .status-pill {
|
||
display: inline-block;
|
||
padding: 2px 10px; border-radius: 4px;
|
||
font-family: var(--font-mono); font-size: 0.8rem; font-variant-numeric: tabular-nums;
|
||
border: 1px solid transparent;
|
||
}
|
||
.errors-page .status-pill.status-error { background: var(--bucket-error-bg); color: var(--bucket-error-fg); border-color: var(--bucket-error-bd); }
|
||
.errors-page .status-pill.status-warn { background: var(--bucket-warn-bg); color: var(--bucket-warn-fg); border-color: var(--bucket-warn-bd); }
|
||
.errors-page .status-pill.status-info { background: var(--bucket-info-bg); color: var(--bucket-info-fg); border-color: var(--bucket-info-bd); }
|
||
|
||
.errors-page .errors-row-detail { padding: 0 16px 16px; }
|
||
.errors-page .detail-tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--border-color); margin-bottom: 12px; }
|
||
.errors-page .detail-tabs button {
|
||
background: transparent; border: 0;
|
||
border-bottom: 2px solid transparent;
|
||
padding: 8px 12px; font-size: 0.85rem; cursor: pointer;
|
||
color: var(--ink-muted); font-family: var(--font-sans);
|
||
}
|
||
.errors-page .detail-tabs button.active { color: var(--color); border-bottom-color: var(--color); }
|
||
.errors-page .detail-body { display: grid; grid-template-columns: 1fr 260px; gap: 20px; }
|
||
.errors-page .detail-main pre {
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 12px;
|
||
padding: 18px 22px;
|
||
font-family: var(--font-mono);
|
||
font-size: 0.85rem;
|
||
line-height: 1.7;
|
||
color: var(--color);
|
||
max-height: 26em;
|
||
overflow: auto;
|
||
/* pre-wrap honors leading-space indentation (so aligned columns survive)
|
||
while still wrapping long string values; overflow-wrap forces the break
|
||
mid-word for unbroken URLs / encoded JSON detail strings. */
|
||
white-space: pre-wrap;
|
||
overflow-wrap: anywhere;
|
||
margin: 0;
|
||
box-shadow: var(--card-shadow);
|
||
}
|
||
.errors-page .related-list {
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 12px;
|
||
max-height: 22em; overflow: auto;
|
||
box-shadow: var(--card-shadow);
|
||
}
|
||
.errors-page .stack-pre {
|
||
/* Stack frames look better with a tighter line-height than the curated
|
||
JSON view, since each frame is a single readable line. */
|
||
line-height: 1.45;
|
||
white-space: pre;
|
||
overflow-x: auto;
|
||
}
|
||
.errors-page .related-row {
|
||
display: flex; gap: 10px; padding: 6px 12px; align-items: center;
|
||
border-bottom: 1px solid var(--border-soft);
|
||
font-size: 0.8rem;
|
||
}
|
||
.errors-page .related-row:last-child { border-bottom: none; }
|
||
.errors-page .detail-actions { display: flex; gap: 6px; align-items: center; margin-top: 10px; }
|
||
.errors-page .copy-hint { font-size: 0.78rem; color: var(--bucket-info-fg); }
|
||
|
||
.errors-page .detail-aside {
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 12px;
|
||
padding: 18px;
|
||
box-shadow: var(--card-shadow);
|
||
}
|
||
.errors-page .aside-block + .aside-block { margin-top: 16px; }
|
||
.errors-page .aside-label {
|
||
font-family: var(--font-mono);
|
||
font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.08em;
|
||
color: var(--ink-muted); margin-bottom: 4px;
|
||
}
|
||
.errors-page .aside-value {
|
||
font-family: var(--font-serif);
|
||
font-size: 1.05rem;
|
||
color: var(--color);
|
||
word-break: break-word;
|
||
line-height: 1.3;
|
||
}
|
||
.errors-page .aside-value.mono { font-family: var(--font-mono); font-size: 0.82rem; }
|
||
.errors-page .aside-sub { color: var(--ink-muted); font-style: italic; font-size: 0.8rem; font-family: var(--font-sans); }
|
||
|
||
.errors-page .errors-pager { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; color: var(--ink-muted); font-size: 0.85rem; }
|
||
|
||
@media (max-width: 720px) {
|
||
.errors-page .errors-list-head,
|
||
.errors-page .errors-row-main { grid-template-columns: 80px 80px 1fr 60px; }
|
||
.errors-page .errors-list-head .col-mod,
|
||
.errors-page .errors-row-main .col-mod,
|
||
.errors-page .errors-list-head .col-sev,
|
||
.errors-page .errors-row-main .col-sev { display: none; }
|
||
.errors-page .detail-body { grid-template-columns: 1fr; }
|
||
}
|
||
|