mirror of
https://github.com/tdurieux/anonymous_github.git
synced 2026-05-15 14:38:03 +02:00
3519 lines
72 KiB
CSS
3519 lines
72 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: #3B4AD6;
|
||
--primary-hover-bg: #2E3BB8;
|
||
--primary-color: #FFFFFF;
|
||
--primary-active-color: #E9EBFF;
|
||
|
||
--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;
|
||
|
||
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: 36px 32px;
|
||
display: grid;
|
||
grid-template-columns: repeat(3, 1fr);
|
||
gap: 24px;
|
||
}
|
||
|
||
.paper-stat-value {
|
||
font-family: var(--font-serif);
|
||
font-size: 42px;
|
||
line-height: 1;
|
||
color: var(--color);
|
||
letter-spacing: -0.02em;
|
||
}
|
||
|
||
.paper-stat-label {
|
||
margin-top: 8px;
|
||
font-size: 12.5px;
|
||
color: var(--ink-muted);
|
||
}
|
||
|
||
/* 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;
|
||
}
|
||
|
||
.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 {
|
||
background-color: var(--main-bg-color);
|
||
padding: 8px 6px;
|
||
margin: 0;
|
||
border-bottom: 1px solid var(--border-color);
|
||
border-radius: 0;
|
||
}
|
||
|
||
.paths {
|
||
padding: 0;
|
||
margin: 0;
|
||
background-color: initial;
|
||
border: none;
|
||
border-radius: 0;
|
||
align-items: center;
|
||
}
|
||
|
||
.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 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;
|
||
}
|
||
}
|
||
|
||
@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 */
|
||
}
|
||
|
||
/* File explorer mobile layout */
|
||
.leftCol {
|
||
max-height: 40vh;
|
||
border-bottom: 2px solid var(--border-color);
|
||
}
|
||
|
||
/* Status bar wrapping */
|
||
.status-bar {
|
||
flex-wrap: wrap;
|
||
gap: 4px;
|
||
}
|
||
|
||
.status-bar .btn {
|
||
font-size: 12px;
|
||
padding: 3px 8px;
|
||
min-height: 28px;
|
||
}
|
||
|
||
/* Home hero section */
|
||
#home .display-4 {
|
||
font-size: 1.8rem;
|
||
}
|
||
|
||
#home h4.subtext-header {
|
||
font-size: 1rem;
|
||
}
|
||
|
||
/* Progress bars on dashboard */
|
||
.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;
|
||
}
|
||
}
|
||
|
||
/* Mobile toggle for file explorer sidebar */
|
||
.sidebar-toggle {
|
||
display: none;
|
||
width: 100%;
|
||
padding: 8px;
|
||
text-align: center;
|
||
background: var(--sidebar-bg-color);
|
||
border: 1px solid var(--border-color);
|
||
color: var(--color);
|
||
cursor: pointer;
|
||
font-size: 14px;
|
||
}
|
||
|
||
@media (max-width: 767px) {
|
||
.sidebar-toggle {
|
||
display: block;
|
||
}
|
||
|
||
.leftCol.collapsed {
|
||
display: none !important;
|
||
}
|
||
}
|
||
|
||
/* ===== 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 */
|
||
.admin-stats {
|
||
display: grid;
|
||
grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
|
||
gap: 12px;
|
||
margin-bottom: 20px;
|
||
}
|
||
|
||
.admin-stat-card {
|
||
background: var(--paper-card);
|
||
border: 1px solid var(--border-color);
|
||
border-radius: 10px;
|
||
padding: 16px 18px;
|
||
}
|
||
|
||
.admin-stat-card .stat-value {
|
||
font-family: var(--font-serif);
|
||
font-size: 1.9rem;
|
||
font-weight: 400;
|
||
line-height: 1.1;
|
||
color: var(--color);
|
||
}
|
||
|
||
.admin-stat-card .stat-label {
|
||
font-family: var(--font-mono);
|
||
font-size: 10.5px;
|
||
color: var(--ink-muted);
|
||
text-transform: uppercase;
|
||
letter-spacing: 0.08em;
|
||
margin-top: 6px;
|
||
}
|
||
|
||
/* 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: baseline;
|
||
justify-content: space-between;
|
||
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: 767px) {
|
||
.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 mobile drawer */
|
||
.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(--paper-card, var(--canvas-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 {
|
||
justify-content: flex-start;
|
||
margin: 0 !important;
|
||
padding: 10px 6px !important;
|
||
border-bottom: 1px solid var(--border-soft, transparent) !important;
|
||
border-radius: 0;
|
||
font-size: 14px;
|
||
gap: 10px;
|
||
}
|
||
.navbar .nav-link.active {
|
||
color: var(--color) !important;
|
||
border-bottom-color: var(--border-color) !important;
|
||
}
|
||
.navbar .nav-link.nav-icon {
|
||
width: 100% !important;
|
||
height: auto !important;
|
||
justify-content: flex-start;
|
||
}
|
||
.navbar .nav-link.nav-icon::after {
|
||
content: attr(aria-label);
|
||
font-family: var(--font-sans);
|
||
font-size: 14px;
|
||
color: var(--ink-muted);
|
||
margin-left: 2px;
|
||
}
|
||
.navbar-brand { border-right: none !important; padding-right: 0 !important; margin-right: 0 !important; }
|
||
}
|
||
.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 {
|
||
border-color: var(--accent);
|
||
box-shadow: 0 0 0 2px var(--accent-soft);
|
||
}
|
||
|
||
/* 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;
|
||
}
|
||
.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) 140px 90px 140px 52px;
|
||
}
|
||
.paper-table .admin-users-row {
|
||
grid-template-columns: minmax(280px, 2.4fr) 140px 140px 52px !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 .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 .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; align-items: center; gap: 8px; font-size: 14px; color: var(--color); }
|
||
.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; }
|
||
|
||
.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 .quota-row { grid-template-columns: 1fr; gap: 14px; padding: 16px; }
|
||
.paper-page .dashboard-filter-row { gap: 8px; }
|
||
}
|
||
|
||
/* 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;
|
||
}
|
||
} |