Files
anonymous_github/public/css/style.css
T
2026-04-24 15:25:23 +02:00

3723 lines
78 KiB
CSS
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
/* ===== 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: 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;
}
}
/* 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 */
}
/* 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: 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;
}
}
/* 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 {
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;
}
}