1392 lines
32 KiB
CSS
1392 lines
32 KiB
CSS
/* PIRP - Flat Dark Theme */
|
|
|
|
:root {
|
|
/* Backgrounds */
|
|
--bg-body: #0a0a0a;
|
|
--bg-panel: #141414;
|
|
--bg-inset: #0d0d0d;
|
|
--bg-raised: #1c1c1c;
|
|
--bg-hover: rgba(212,136,42,0.06);
|
|
--bg-highlight: #222222;
|
|
|
|
/* Accent (Orange) */
|
|
--accent: #d4882a;
|
|
--accent-hover: #e8a042;
|
|
--accent-muted: rgba(212,136,42,0.12);
|
|
--accent-dim: rgba(212,136,42,0.45);
|
|
|
|
/* Text */
|
|
--text: #c8c8c8;
|
|
--text-bright: #f0f0f0;
|
|
--text-muted: #6b6b6b;
|
|
--text-dim: #454545;
|
|
|
|
/* Borders */
|
|
--border-dark: #1a1a1a;
|
|
--border-mid: #272727;
|
|
--border-light: #3a3a3a;
|
|
|
|
/* Semantic */
|
|
--success: #22c55e;
|
|
--success-bg: rgba(34,197,94,0.08);
|
|
--success-border: rgba(34,197,94,0.25);
|
|
--warning: #f59e0b;
|
|
--warning-bg: rgba(245,158,11,0.08);
|
|
--warning-border: rgba(245,158,11,0.28);
|
|
--error: #ef4444;
|
|
--error-bg: rgba(239,68,68,0.08);
|
|
--error-border: rgba(239,68,68,0.28);
|
|
--info: #5b8fd6;
|
|
|
|
/* Legacy bevel vars (kept for compatibility, unused) */
|
|
--bevel-light: rgba(255,255,255,0.04);
|
|
--bevel-dark: rgba(0,0,0,0.3);
|
|
|
|
--radius: 2px;
|
|
--radius-sm: 2px;
|
|
--font-size: 14px;
|
|
--font-mono: "Consolas", "Liberation Mono", monospace;
|
|
--main-padding: 20px 36px;
|
|
}
|
|
|
|
* { box-sizing: border-box; margin: 0; padding: 0; }
|
|
|
|
body {
|
|
font-family: "Segoe UI", system-ui, -apple-system, sans-serif;
|
|
font-size: var(--font-size);
|
|
line-height: 1.4;
|
|
color: var(--text);
|
|
background: var(--bg-body);
|
|
min-height: 100vh;
|
|
}
|
|
|
|
a { color: var(--accent); text-decoration: none; }
|
|
a:hover { color: var(--accent-hover); text-decoration: underline; }
|
|
|
|
::selection { background: var(--accent-muted); color: var(--text-bright); }
|
|
|
|
/* ====================== SCROLLBAR ====================== */
|
|
::-webkit-scrollbar { width: 6px; height: 6px; }
|
|
::-webkit-scrollbar-track { background: var(--bg-body); }
|
|
::-webkit-scrollbar-thumb { background: #2a2a2a; }
|
|
::-webkit-scrollbar-thumb:hover { background: var(--border-light); }
|
|
|
|
/* ====================== HEADER / NAV ====================== */
|
|
header {
|
|
background: rgba(10,10,10,0.92);
|
|
backdrop-filter: blur(8px);
|
|
-webkit-backdrop-filter: blur(8px);
|
|
border-bottom: 1px solid var(--border-mid);
|
|
padding: 0;
|
|
display: flex;
|
|
align-items: stretch;
|
|
gap: 0;
|
|
position: sticky;
|
|
top: 0;
|
|
z-index: 100;
|
|
}
|
|
|
|
header h1 {
|
|
font-size: 12px;
|
|
font-weight: 700;
|
|
color: var(--accent);
|
|
padding: 0 20px;
|
|
white-space: nowrap;
|
|
border-right: 1px solid var(--border-mid);
|
|
display: flex;
|
|
align-items: center;
|
|
letter-spacing: 2.5px;
|
|
text-transform: uppercase;
|
|
}
|
|
|
|
header nav {
|
|
display: flex;
|
|
gap: 0;
|
|
align-items: stretch;
|
|
flex: 1;
|
|
overflow-x: auto;
|
|
}
|
|
|
|
header nav a {
|
|
padding: 0 15px;
|
|
height: 40px;
|
|
color: var(--text-muted);
|
|
text-decoration: none;
|
|
font-size: 13px;
|
|
font-weight: 500;
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 6px;
|
|
transition: color 0.12s, background 0.12s;
|
|
white-space: nowrap;
|
|
position: relative;
|
|
}
|
|
|
|
header nav a svg {
|
|
width: 15px;
|
|
height: 15px;
|
|
fill: currentColor;
|
|
opacity: 0.45;
|
|
flex-shrink: 0;
|
|
transition: opacity 0.12s;
|
|
}
|
|
|
|
header nav a:hover svg,
|
|
header nav a.active svg { opacity: 1; }
|
|
|
|
header nav a:hover {
|
|
color: var(--text-bright);
|
|
background: rgba(255,255,255,0.03);
|
|
text-decoration: none;
|
|
}
|
|
|
|
header nav a.active {
|
|
color: var(--accent-hover);
|
|
background: rgba(212,136,42,0.08);
|
|
box-shadow: inset 0 0 0 1px rgba(212,136,42,0.35);
|
|
}
|
|
|
|
/* ====================== MAIN CONTENT ====================== */
|
|
main {
|
|
padding: var(--main-padding);
|
|
width: 100%;
|
|
}
|
|
|
|
main > h2 {
|
|
font-size: 11px;
|
|
font-weight: 600;
|
|
color: var(--text-muted);
|
|
padding: 5px 10px;
|
|
margin: 6px 0;
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.8px;
|
|
background: var(--bg-raised);
|
|
border: 1px solid var(--border-mid);
|
|
}
|
|
|
|
/* ====================== SECTIONS ====================== */
|
|
section {
|
|
margin-bottom: 10px;
|
|
}
|
|
|
|
section h2 {
|
|
font-size: 11px;
|
|
font-weight: 600;
|
|
color: var(--text-muted);
|
|
padding: 6px 12px;
|
|
margin: 0;
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.8px;
|
|
background: var(--bg-raised);
|
|
border: 1px solid var(--border-mid);
|
|
border-bottom: 1px solid var(--border-dark);
|
|
}
|
|
|
|
section > div,
|
|
section > form,
|
|
section > table {
|
|
background: var(--bg-panel);
|
|
border: 1px solid var(--border-mid);
|
|
border-top: none;
|
|
padding: 10px 12px;
|
|
}
|
|
|
|
section > table {
|
|
padding: 0;
|
|
overflow: hidden;
|
|
}
|
|
|
|
/* ====================== BUTTONS ====================== */
|
|
form button,
|
|
button,
|
|
.button {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
gap: 5px;
|
|
padding: 5px 14px;
|
|
font-family: inherit;
|
|
font-size: 13px;
|
|
font-weight: 500;
|
|
color: var(--accent-hover);
|
|
background: var(--accent-muted);
|
|
border: 1px solid var(--accent-dim);
|
|
border-radius: var(--radius);
|
|
cursor: pointer;
|
|
transition: all 0.12s;
|
|
text-decoration: none;
|
|
white-space: nowrap;
|
|
line-height: 1.5;
|
|
}
|
|
|
|
form button:hover,
|
|
button:hover,
|
|
.button:hover {
|
|
background: rgba(212,136,42,0.2);
|
|
border-color: var(--accent);
|
|
color: var(--accent-hover);
|
|
text-decoration: none;
|
|
}
|
|
|
|
form button:active,
|
|
button:active,
|
|
.button:active {
|
|
background: rgba(212,136,42,0.08);
|
|
}
|
|
|
|
button.secondary,
|
|
.button-secondary {
|
|
background: rgba(28,28,28,0.9);
|
|
border: 1px solid var(--border-light);
|
|
color: var(--text-muted);
|
|
}
|
|
|
|
button.secondary:hover,
|
|
.button-secondary:hover {
|
|
background: var(--bg-highlight);
|
|
border-color: #4a4a4a;
|
|
color: var(--text-bright);
|
|
}
|
|
|
|
button.danger {
|
|
background: var(--error-bg);
|
|
border: 1px solid var(--error-border);
|
|
color: #f87171;
|
|
}
|
|
|
|
button.danger:hover {
|
|
background: rgba(239,68,68,0.16);
|
|
border-color: rgba(239,68,68,0.5);
|
|
color: #fca5a5;
|
|
}
|
|
|
|
/* ====================== FORMS ====================== */
|
|
form label {
|
|
display: block;
|
|
margin-bottom: 8px;
|
|
font-size: 13px;
|
|
font-weight: 500;
|
|
color: var(--text);
|
|
}
|
|
|
|
form label input,
|
|
form label select,
|
|
form label textarea {
|
|
display: block;
|
|
width: 100%;
|
|
margin-top: 3px;
|
|
padding: 5px 8px;
|
|
font-family: inherit;
|
|
font-size: 13px;
|
|
color: var(--text-bright);
|
|
background: rgba(13,13,13,0.9);
|
|
border: 1px solid var(--border-light);
|
|
border-radius: var(--radius-sm);
|
|
transition: border-color 0.12s, box-shadow 0.12s;
|
|
line-height: 1.5;
|
|
}
|
|
|
|
form label input:focus,
|
|
form label select:focus,
|
|
form label textarea:focus {
|
|
outline: none;
|
|
border-color: var(--accent-dim);
|
|
box-shadow: 0 0 0 2px var(--accent-muted);
|
|
}
|
|
|
|
form label input[type="checkbox"],
|
|
form label input[type="radio"] {
|
|
display: inline;
|
|
width: auto;
|
|
margin-top: 0;
|
|
margin-right: 4px;
|
|
accent-color: var(--accent);
|
|
}
|
|
|
|
form textarea {
|
|
min-height: 50px;
|
|
resize: vertical;
|
|
}
|
|
|
|
input, select, textarea {
|
|
font-family: inherit;
|
|
font-size: 13px;
|
|
color: var(--text-bright);
|
|
background: rgba(13,13,13,0.9);
|
|
border: 1px solid var(--border-light);
|
|
border-radius: var(--radius-sm);
|
|
padding: 5px 8px;
|
|
line-height: 1.5;
|
|
transition: border-color 0.12s, box-shadow 0.12s;
|
|
}
|
|
|
|
input:focus, select:focus, textarea:focus {
|
|
outline: none;
|
|
border-color: var(--accent-dim);
|
|
box-shadow: 0 0 0 2px var(--accent-muted);
|
|
}
|
|
|
|
input[type="checkbox"], input[type="radio"] {
|
|
accent-color: var(--accent);
|
|
}
|
|
|
|
/* ====================== FLEX ROW ====================== */
|
|
.flex-row {
|
|
display: flex;
|
|
gap: 12px;
|
|
flex-wrap: wrap;
|
|
align-items: flex-end;
|
|
}
|
|
|
|
.flex-row > label {
|
|
flex: 1;
|
|
min-width: 140px;
|
|
}
|
|
|
|
/* ====================== TABLES ====================== */
|
|
table.list {
|
|
width: 100%;
|
|
border-collapse: collapse;
|
|
font-size: 13px;
|
|
}
|
|
|
|
table.list th {
|
|
text-align: left;
|
|
padding: 7px 10px;
|
|
font-size: 11px;
|
|
font-weight: 600;
|
|
color: var(--text-muted);
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.5px;
|
|
background: var(--bg-raised);
|
|
border-bottom: 1px solid var(--border-mid);
|
|
white-space: nowrap;
|
|
}
|
|
|
|
table.list td {
|
|
padding: 7px 10px;
|
|
border-bottom: 1px solid var(--border-dark);
|
|
color: var(--text);
|
|
vertical-align: middle;
|
|
}
|
|
|
|
table.list tbody tr:hover td {
|
|
background: var(--bg-hover);
|
|
}
|
|
|
|
table.list a {
|
|
color: var(--accent);
|
|
text-decoration: none;
|
|
}
|
|
|
|
table.list a:hover {
|
|
color: var(--accent-hover);
|
|
text-decoration: underline;
|
|
}
|
|
|
|
table.list tfoot td {
|
|
font-weight: 600;
|
|
background: var(--bg-raised);
|
|
border-top: 1px solid var(--border-light);
|
|
color: var(--text-bright);
|
|
}
|
|
|
|
/* ====================== MESSAGES ====================== */
|
|
.success, p.success {
|
|
padding: 7px 12px;
|
|
background: var(--success-bg);
|
|
border: 1px solid var(--success-border);
|
|
border-left: 3px solid var(--success);
|
|
border-radius: var(--radius);
|
|
color: var(--success);
|
|
margin-bottom: 8px;
|
|
font-size: 12px;
|
|
}
|
|
|
|
.error, p.error {
|
|
padding: 7px 12px;
|
|
background: var(--error-bg);
|
|
border: 1px solid var(--error-border);
|
|
border-left: 3px solid var(--error);
|
|
border-radius: var(--radius);
|
|
color: #f87171;
|
|
margin-bottom: 8px;
|
|
font-size: 12px;
|
|
}
|
|
|
|
.warning, p.warning {
|
|
padding: 7px 12px;
|
|
background: var(--warning-bg);
|
|
border: 1px solid var(--warning-border);
|
|
border-left: 3px solid var(--warning);
|
|
border-radius: var(--radius);
|
|
color: var(--warning);
|
|
margin-bottom: 8px;
|
|
font-size: 12px;
|
|
}
|
|
|
|
/* ====================== BADGES ====================== */
|
|
.badge,
|
|
.badge-success,
|
|
.badge-warning,
|
|
.badge-danger,
|
|
.badge-info,
|
|
.badge-neutral,
|
|
.badge-error {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
padding: 1px 6px;
|
|
font-size: 10px;
|
|
font-weight: 600;
|
|
border-radius: var(--radius);
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.4px;
|
|
border: 1px solid;
|
|
}
|
|
|
|
.badge-success { background: var(--success-bg); color: var(--success); border-color: var(--success-border); }
|
|
.badge-danger,
|
|
.badge-error { background: var(--error-bg); color: #f87171; border-color: var(--error-border); }
|
|
.badge-warning { background: var(--warning-bg); color: var(--warning); border-color: var(--warning-border); }
|
|
.badge-info { background: rgba(91,143,214,0.1); color: var(--info); border-color: rgba(91,143,214,0.3); }
|
|
.badge-neutral { background: var(--bg-raised); color: var(--text-muted); border-color: var(--border-light); }
|
|
|
|
/* ====================== DASHBOARD ====================== */
|
|
.dashboard-grid {
|
|
display: grid;
|
|
grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
|
|
gap: 8px;
|
|
margin-bottom: 12px;
|
|
}
|
|
|
|
.dashboard-grid .card,
|
|
.card {
|
|
background: var(--bg-panel);
|
|
border: 1px solid var(--border-mid);
|
|
padding: 12px 14px;
|
|
border-radius: var(--radius);
|
|
transition: border-color 0.15s;
|
|
}
|
|
|
|
.card:hover {
|
|
border-color: var(--border-light);
|
|
}
|
|
|
|
.card h3 {
|
|
font-size: 10px;
|
|
font-weight: 600;
|
|
color: var(--text-dim);
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.8px;
|
|
margin-bottom: 4px;
|
|
padding: 0;
|
|
border: none;
|
|
background: none;
|
|
}
|
|
|
|
.card .big {
|
|
font-size: 22px;
|
|
font-weight: 700;
|
|
color: var(--text-bright);
|
|
line-height: 1.3;
|
|
font-variant-numeric: tabular-nums;
|
|
}
|
|
|
|
.card p { margin: 2px 0; font-size: 13px; }
|
|
|
|
.card a {
|
|
color: var(--accent);
|
|
text-decoration: none;
|
|
font-size: 12px;
|
|
}
|
|
|
|
.card a:hover { text-decoration: underline; }
|
|
|
|
.sparkline { display: block; margin-top: 4px; }
|
|
|
|
/* Dashboard two-column layout */
|
|
.dashboard-two-col {
|
|
display: grid;
|
|
grid-template-columns: 1fr 1fr;
|
|
gap: 12px;
|
|
margin-bottom: 12px;
|
|
}
|
|
|
|
/* EÜR page layout */
|
|
.euer-grid {
|
|
display: grid;
|
|
grid-template-columns: 1fr 1fr;
|
|
gap: 20px;
|
|
align-items: start;
|
|
}
|
|
|
|
.euer-section {
|
|
background: var(--bg-panel);
|
|
border: 1px solid var(--border-mid);
|
|
border-radius: var(--radius);
|
|
padding: 16px;
|
|
}
|
|
|
|
.euer-section h3 {
|
|
font-size: 14px;
|
|
font-weight: 600;
|
|
color: var(--accent);
|
|
margin-bottom: 4px;
|
|
}
|
|
|
|
.euer-section h4 {
|
|
font-size: 11px;
|
|
font-weight: 600;
|
|
color: var(--text-muted);
|
|
margin: 12px 0 4px;
|
|
border-bottom: 1px solid var(--border-mid);
|
|
padding-bottom: 4px;
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.5px;
|
|
}
|
|
|
|
.euer-desc {
|
|
font-size: 11px;
|
|
color: var(--text-dim);
|
|
margin-bottom: 12px;
|
|
}
|
|
|
|
.euer-result {
|
|
background: var(--bg-raised);
|
|
}
|
|
|
|
.euer-result.negative {
|
|
color: var(--error);
|
|
}
|
|
|
|
/* ====================== SUB-NAVIGATION ====================== */
|
|
.module-subnav,
|
|
.journal-subnav,
|
|
.settings-tabs {
|
|
display: flex;
|
|
gap: 2px;
|
|
padding: 4px 8px;
|
|
margin-bottom: 10px;
|
|
overflow-x: auto;
|
|
background: var(--bg-panel);
|
|
border: 1px solid var(--border-mid);
|
|
}
|
|
|
|
.module-subnav a,
|
|
.journal-subnav a,
|
|
.settings-tabs a {
|
|
padding: 4px 14px;
|
|
font-size: 12px;
|
|
font-weight: 500;
|
|
color: var(--text-muted);
|
|
text-decoration: none;
|
|
border-radius: var(--radius);
|
|
border: 1px solid transparent;
|
|
transition: all 0.12s;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.module-subnav a:hover,
|
|
.journal-subnav a:hover,
|
|
.settings-tabs a:hover {
|
|
background: var(--bg-raised);
|
|
color: var(--text-bright);
|
|
text-decoration: none;
|
|
border-color: var(--border-light);
|
|
}
|
|
|
|
.module-subnav a.active,
|
|
.journal-subnav a.active,
|
|
.settings-tabs a.active {
|
|
background: var(--accent-muted);
|
|
color: var(--accent);
|
|
border-color: var(--accent-dim);
|
|
}
|
|
|
|
/* Journal Settings Sub-Tabs */
|
|
.journal-settings-subtabs {
|
|
display: flex;
|
|
gap: 2px;
|
|
margin-top: -10px;
|
|
margin-bottom: 16px;
|
|
padding: 3px 8px;
|
|
overflow-x: auto;
|
|
background: var(--bg-inset);
|
|
border: 1px solid var(--border-mid);
|
|
border-top: none;
|
|
}
|
|
|
|
.journal-settings-subtabs a {
|
|
padding: 2px 10px;
|
|
font-size: 11px;
|
|
font-weight: 500;
|
|
color: var(--text-dim);
|
|
text-decoration: none;
|
|
border-radius: var(--radius);
|
|
border: 1px solid transparent;
|
|
transition: all 0.12s;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.journal-settings-subtabs a:hover {
|
|
background: var(--bg-raised);
|
|
color: var(--text);
|
|
text-decoration: none;
|
|
border-color: var(--border-light);
|
|
}
|
|
|
|
.journal-settings-subtabs a.active {
|
|
background: var(--accent-muted);
|
|
color: var(--accent);
|
|
border-color: var(--accent-dim);
|
|
}
|
|
|
|
/* Settings help text */
|
|
.settings-help {
|
|
font-size: 11px;
|
|
color: var(--text-dim);
|
|
margin: -4px 0 12px 0;
|
|
line-height: 1.4;
|
|
}
|
|
|
|
/* ====================== FILTERS ====================== */
|
|
.filters, form.filters {
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
gap: 10px;
|
|
align-items: flex-end;
|
|
padding: 8px 12px;
|
|
background: var(--bg-panel);
|
|
border: 1px solid var(--border-mid);
|
|
margin-bottom: 10px;
|
|
}
|
|
|
|
.filters label {
|
|
margin-bottom: 0;
|
|
min-width: 120px;
|
|
font-size: 10px;
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.5px;
|
|
color: var(--text-muted);
|
|
}
|
|
|
|
.filters label input,
|
|
.filters label select {
|
|
margin-top: 2px;
|
|
padding: 3px 6px;
|
|
font-size: 12px;
|
|
}
|
|
|
|
.filters button {
|
|
padding: 4px 10px;
|
|
}
|
|
|
|
/* ====================== JOURNAL CONTROLS ====================== */
|
|
.journal-controls {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 6px;
|
|
margin-bottom: 4px;
|
|
flex-wrap: wrap;
|
|
}
|
|
|
|
.journal-year-select {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 4px;
|
|
}
|
|
|
|
.journal-month-tabs {
|
|
display: flex;
|
|
gap: 2px;
|
|
padding: 3px 6px;
|
|
background: var(--bg-panel);
|
|
border: 1px solid var(--border-mid);
|
|
flex-wrap: wrap;
|
|
}
|
|
|
|
.journal-month-tabs a {
|
|
padding: 3px 9px;
|
|
font-size: 11px;
|
|
font-weight: 500;
|
|
color: var(--text-muted);
|
|
text-decoration: none;
|
|
border-radius: var(--radius);
|
|
border: 1px solid transparent;
|
|
transition: all 0.1s;
|
|
}
|
|
|
|
.journal-month-tabs a:hover {
|
|
color: var(--text-bright);
|
|
background: var(--bg-raised);
|
|
text-decoration: none;
|
|
border-color: var(--border-light);
|
|
}
|
|
|
|
.journal-month-tabs a.active {
|
|
background: var(--accent-muted);
|
|
color: var(--accent);
|
|
border-color: var(--accent-dim);
|
|
}
|
|
|
|
/* ====================== JOURNAL MONTH SUMMARY ====================== */
|
|
.journal-month-summary {
|
|
display: flex;
|
|
gap: 14px;
|
|
align-items: center;
|
|
padding: 4px 10px;
|
|
background: var(--bg-panel);
|
|
border: 1px solid var(--border-mid);
|
|
margin-bottom: 4px;
|
|
font-size: 11px;
|
|
}
|
|
|
|
.journal-soll { color: var(--info); font-weight: 600; }
|
|
.journal-haben { color: var(--success); font-weight: 600; }
|
|
.journal-diff-warning { color: var(--error); font-weight: 700; font-size: 10px; }
|
|
.journal-sep { border-left: 1px solid var(--border-mid); height: 12px; }
|
|
|
|
.journal-kasse {
|
|
color: var(--accent);
|
|
font-weight: 600;
|
|
background: var(--accent-muted);
|
|
border: 1px solid var(--accent-dim);
|
|
border-radius: var(--radius);
|
|
padding: 1px 7px;
|
|
}
|
|
|
|
.journal-bank {
|
|
color: var(--warning);
|
|
font-weight: 600;
|
|
background: rgba(245,158,11,0.08);
|
|
border: 1px solid rgba(245,158,11,0.25);
|
|
border-radius: var(--radius);
|
|
padding: 1px 7px;
|
|
}
|
|
|
|
/* Prominent diff warning banner above table */
|
|
.journal-diff-banner {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 10px;
|
|
padding: 8px 12px;
|
|
background: var(--error-bg);
|
|
border: 1px solid var(--error-border);
|
|
border-left: 3px solid var(--error);
|
|
color: #f87171;
|
|
font-size: 12px;
|
|
font-weight: 500;
|
|
margin-bottom: 4px;
|
|
}
|
|
|
|
/* ====================== JOURNAL TABLE ====================== */
|
|
.journal-table-wrap {
|
|
overflow: auto;
|
|
max-height: 70vh;
|
|
border: 1px solid var(--border-mid);
|
|
margin-bottom: 4px;
|
|
}
|
|
|
|
.journal-table {
|
|
width: max-content;
|
|
min-width: 100%;
|
|
border-collapse: separate;
|
|
border-spacing: 0;
|
|
font-size: 11px;
|
|
}
|
|
|
|
.journal-table th,
|
|
.journal-table td {
|
|
white-space: nowrap;
|
|
padding: 2px 5px;
|
|
border-right: 1px solid var(--border-dark);
|
|
}
|
|
|
|
.journal-table th {
|
|
text-align: left;
|
|
font-size: 10px;
|
|
font-weight: 600;
|
|
color: var(--text-muted);
|
|
background: var(--bg-raised);
|
|
border-bottom: 1px solid var(--border-mid);
|
|
}
|
|
|
|
.journal-table thead th,
|
|
.journal-table thead td {
|
|
position: sticky;
|
|
z-index: 2;
|
|
}
|
|
|
|
.journal-table td {
|
|
border-bottom: 1px solid var(--border-dark);
|
|
color: var(--text);
|
|
}
|
|
|
|
.journal-table tbody tr:hover td {
|
|
background: var(--bg-hover);
|
|
}
|
|
|
|
/* Group header */
|
|
.journal-table tr.journal-group-header th {
|
|
text-align: center;
|
|
font-size: 8px;
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.5px;
|
|
color: var(--text-dim);
|
|
border-bottom: 1px solid var(--accent-dim);
|
|
padding: 1px 4px;
|
|
background: var(--bg-raised);
|
|
}
|
|
|
|
.journal-table .journal-col-date { min-width: 40px; }
|
|
.journal-table .journal-col-att { min-width: 20px; max-width: 40px; font-size: 10px; color: var(--text-dim); }
|
|
.journal-table .journal-col-text { min-width: 140px; max-width: 250px; overflow: hidden; text-overflow: ellipsis; }
|
|
|
|
/* Source-type badges */
|
|
.source-badge {
|
|
display: inline-block;
|
|
font-size: 8px;
|
|
font-weight: 700;
|
|
padding: 0 3px;
|
|
border-radius: 2px;
|
|
margin-left: 3px;
|
|
text-decoration: none;
|
|
vertical-align: middle;
|
|
}
|
|
.source-invoice { background: rgba(34,197,94,0.12); color: #4ade80; border: 1px solid rgba(34,197,94,0.25); }
|
|
.source-invoice:hover { background: rgba(34,197,94,0.2); }
|
|
.source-expense { background: rgba(239,68,68,0.12); color: #f87171; border: 1px solid rgba(239,68,68,0.25); }
|
|
.source-expense:hover { background: rgba(239,68,68,0.2); }
|
|
|
|
.journal-table .journal-col-betrag {
|
|
text-align: right;
|
|
font-variant-numeric: tabular-nums;
|
|
min-width: 70px;
|
|
font-family: var(--font-mono);
|
|
font-size: 11px;
|
|
font-weight: 600;
|
|
color: var(--text-bright);
|
|
}
|
|
|
|
.journal-table .journal-col-amount {
|
|
text-align: right;
|
|
font-variant-numeric: tabular-nums;
|
|
min-width: 65px;
|
|
font-family: var(--font-mono);
|
|
font-size: 11px;
|
|
}
|
|
|
|
.journal-table .journal-col-amount.journal-soll { color: var(--info); }
|
|
.journal-table .journal-col-amount.journal-haben { color: var(--success); }
|
|
|
|
/* Subtle clickability cue for drilldown links */
|
|
.journal-table .journal-col-amount a {
|
|
color: inherit;
|
|
text-decoration: none;
|
|
border-bottom: 1px dotted transparent;
|
|
transition: border-color 0.1s;
|
|
}
|
|
.journal-table .journal-col-amount a:hover {
|
|
border-bottom-color: currentColor;
|
|
text-decoration: none;
|
|
}
|
|
|
|
/* Action column (B / X / D) */
|
|
.journal-table .journal-col-action {
|
|
min-width: 44px;
|
|
text-align: center;
|
|
}
|
|
|
|
.journal-table .journal-col-action a {
|
|
margin: 0 1px;
|
|
font-size: 10px;
|
|
font-weight: 700;
|
|
color: var(--text-dim);
|
|
padding: 1px 3px;
|
|
border-radius: 1px;
|
|
transition: all 0.1s;
|
|
text-decoration: none;
|
|
}
|
|
|
|
/* B = edit → orange */
|
|
.journal-table .journal-col-action a:nth-child(1):hover { color: var(--accent); background: var(--accent-muted); text-decoration: none; }
|
|
/* X = delete → red */
|
|
.journal-table .journal-col-action a:nth-child(2):hover { color: #f87171; background: var(--error-bg); text-decoration: none; }
|
|
/* D = duplicate → blue */
|
|
.journal-table .journal-col-action a:nth-child(3):hover { color: var(--info); background: rgba(91,143,214,0.1); text-decoration: none; }
|
|
|
|
/* Top sums rows */
|
|
.journal-table .journal-top-sums td {
|
|
background: rgba(13,13,13,0.7);
|
|
border-bottom: 1px solid var(--border-mid);
|
|
font-size: 10px;
|
|
padding: 1px 6px;
|
|
color: var(--text-muted);
|
|
font-family: var(--font-mono);
|
|
position: sticky;
|
|
z-index: 2;
|
|
}
|
|
|
|
.journal-table .journal-top-sums td strong {
|
|
color: var(--text-bright);
|
|
}
|
|
|
|
/* Totals row */
|
|
.journal-table .journal-totals-row td {
|
|
border-top: 1px solid var(--border-light);
|
|
background: var(--bg-raised);
|
|
font-weight: 700;
|
|
position: sticky;
|
|
bottom: 0;
|
|
z-index: 2;
|
|
color: var(--text-bright);
|
|
}
|
|
|
|
/* ====================== JOURNAL INLINE EDITING ====================== */
|
|
.journal-table .journal-inline-row td {
|
|
background: var(--bg-inset);
|
|
border-bottom: 2px solid var(--accent-dim);
|
|
padding: 1px 2px;
|
|
}
|
|
|
|
.journal-table .journal-inline-row input,
|
|
.journal-table .journal-inline-row select {
|
|
padding: 1px 4px;
|
|
font-size: 11px;
|
|
background: var(--bg-body);
|
|
border: 1px solid var(--border-light);
|
|
color: var(--text-bright);
|
|
width: 100%;
|
|
min-width: 0;
|
|
}
|
|
|
|
.journal-table .journal-inline-row input:focus,
|
|
.journal-table .journal-inline-row select:focus {
|
|
border-color: var(--accent-dim);
|
|
box-shadow: 0 0 0 2px var(--accent-muted);
|
|
}
|
|
|
|
.journal-inline-accounts {
|
|
background: var(--bg-inset);
|
|
border: 1px solid var(--border-mid);
|
|
padding: 3px;
|
|
margin: 2px 0;
|
|
}
|
|
|
|
.journal-inline-accounts table {
|
|
width: 100%;
|
|
border-collapse: collapse;
|
|
font-size: 10px;
|
|
}
|
|
|
|
.journal-inline-accounts th {
|
|
padding: 1px 4px;
|
|
text-align: left;
|
|
font-size: 9px;
|
|
color: var(--text-dim);
|
|
font-weight: 600;
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.4px;
|
|
}
|
|
|
|
.journal-inline-accounts td {
|
|
padding: 1px 2px;
|
|
}
|
|
|
|
.journal-inline-accounts input,
|
|
.journal-inline-accounts select {
|
|
padding: 1px 3px;
|
|
font-size: 10px;
|
|
width: 100%;
|
|
}
|
|
|
|
/* ====================== PIRP COMBOBOX ====================== */
|
|
.pirp-combobox {
|
|
position: relative;
|
|
width: 100%;
|
|
}
|
|
|
|
.pirp-combobox input {
|
|
width: 100%;
|
|
}
|
|
|
|
.pirp-combobox-dropdown {
|
|
position: absolute;
|
|
left: 0;
|
|
top: 100%;
|
|
width: 100%;
|
|
max-height: 250px;
|
|
overflow-y: auto;
|
|
background: var(--bg-panel);
|
|
border: 1px solid var(--accent-dim);
|
|
box-shadow: 0 8px 24px rgba(0,0,0,0.6);
|
|
z-index: 200;
|
|
}
|
|
|
|
.pirp-combobox-group {
|
|
padding: 4px 8px 2px;
|
|
font-size: 9px;
|
|
text-transform: uppercase;
|
|
color: var(--text-dim);
|
|
pointer-events: none;
|
|
letter-spacing: 0.5px;
|
|
font-weight: 600;
|
|
border-top: 1px solid var(--border-dark);
|
|
}
|
|
|
|
.pirp-combobox-option {
|
|
padding: 4px 12px;
|
|
font-size: 11px;
|
|
cursor: pointer;
|
|
color: var(--text);
|
|
}
|
|
|
|
.pirp-combobox-option.highlighted {
|
|
background: var(--accent-muted);
|
|
color: var(--text-bright);
|
|
}
|
|
|
|
.journal-inline-accounts .pirp-combobox input {
|
|
font-size: 10px;
|
|
}
|
|
|
|
.journal-inline-accounts .pirp-combobox-dropdown {
|
|
top: auto;
|
|
bottom: 100%;
|
|
}
|
|
|
|
/* ====================== GOBD STATUS ====================== */
|
|
.gobd-warning {
|
|
padding: 8px 12px !important;
|
|
background: var(--warning-bg) !important;
|
|
border: 1px solid var(--warning-border) !important;
|
|
border-left: 3px solid var(--warning) !important;
|
|
border-radius: var(--radius) !important;
|
|
margin: 6px 0 !important;
|
|
font-size: 11px;
|
|
}
|
|
|
|
.gobd-warning h3 {
|
|
color: var(--warning) !important;
|
|
font-size: 11px !important;
|
|
margin-bottom: 4px !important;
|
|
margin-top: 0 !important;
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.5px;
|
|
}
|
|
|
|
.gobd-warning ul {
|
|
list-style: none;
|
|
padding: 0;
|
|
margin: 0 0 4px 0;
|
|
}
|
|
|
|
.gobd-warning li {
|
|
padding: 1px 0;
|
|
color: var(--text);
|
|
font-size: 11px;
|
|
}
|
|
|
|
.gobd-warning li::before { content: none; }
|
|
|
|
.gobd-ok {
|
|
padding: 6px 12px !important;
|
|
background: var(--success-bg) !important;
|
|
border: 1px solid var(--success-border) !important;
|
|
border-left: 3px solid var(--success) !important;
|
|
border-radius: var(--radius) !important;
|
|
color: var(--success) !important;
|
|
margin: 6px 0 !important;
|
|
font-size: 11px;
|
|
}
|
|
|
|
/* ====================== LISTS ====================== */
|
|
ul { list-style: none; padding: 0; margin: 0; }
|
|
|
|
ul li {
|
|
padding: 2px 0;
|
|
border-bottom: 1px solid var(--border-dark);
|
|
font-size: 11px;
|
|
}
|
|
|
|
ul li:last-child { border-bottom: none; }
|
|
|
|
ul li::before {
|
|
content: "\25B8";
|
|
color: var(--text-dim);
|
|
margin-right: 6px;
|
|
font-size: 9px;
|
|
}
|
|
|
|
ul li a { color: var(--text); text-decoration: none; }
|
|
ul li a:hover { color: var(--accent); }
|
|
|
|
/* ====================== CODE ====================== */
|
|
code {
|
|
background: var(--bg-raised);
|
|
padding: 1px 5px;
|
|
border-radius: var(--radius-sm);
|
|
font-family: var(--font-mono);
|
|
font-size: 11px;
|
|
color: var(--accent);
|
|
border: 1px solid var(--border-mid);
|
|
}
|
|
|
|
/* ====================== DETAILS ====================== */
|
|
details { margin-top: 4px; }
|
|
details summary {
|
|
cursor: pointer;
|
|
color: var(--accent);
|
|
font-size: 11px;
|
|
}
|
|
details summary:hover { text-decoration: underline; }
|
|
|
|
/* ====================== UTILITIES ====================== */
|
|
.text-right { text-align: right; }
|
|
.text-center { text-align: center; }
|
|
.text-muted { color: var(--text-muted); }
|
|
.text-success { color: var(--success); }
|
|
.text-warning { color: var(--warning); }
|
|
.text-error { color: var(--error); }
|
|
|
|
.mt-0 { margin-top: 0; }
|
|
.mt-1 { margin-top: 4px; }
|
|
.mt-2 { margin-top: 8px; }
|
|
.mt-3 { margin-top: 12px; }
|
|
.mb-0 { margin-bottom: 0; }
|
|
.mb-1 { margin-bottom: 4px; }
|
|
.mb-2 { margin-bottom: 8px; }
|
|
.mb-3 { margin-bottom: 12px; }
|
|
|
|
.flex { display: flex; }
|
|
.flex-wrap { flex-wrap: wrap; }
|
|
.items-center { align-items: center; }
|
|
.justify-between{ justify-content: space-between; }
|
|
.gap-1 { gap: 4px; }
|
|
.gap-2 { gap: 8px; }
|
|
.hidden { display: none !important; }
|
|
|
|
/* ====================== RESPONSIVE ====================== */
|
|
@media (max-width: 768px) {
|
|
header { flex-wrap: wrap; }
|
|
header h1 { border-right: none; border-bottom: 1px solid var(--border-mid); width: 100%; }
|
|
header nav { overflow-x: auto; }
|
|
main { padding: 8px; }
|
|
.dashboard-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); }
|
|
.flex-row { flex-direction: column; gap: 6px; }
|
|
.journal-month-tabs { flex-wrap: wrap; }
|
|
.dashboard-two-col { grid-template-columns: 1fr; }
|
|
.euer-grid { grid-template-columns: 1fr; }
|
|
}
|
|
|
|
/* ====================== LOGIN PAGE ====================== */
|
|
.login-wrap {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
min-height: 100vh;
|
|
background: var(--bg-body);
|
|
}
|
|
|
|
.login-box {
|
|
background: var(--bg-panel);
|
|
border: 1px solid var(--border-light);
|
|
box-shadow: 0 8px 32px rgba(0,0,0,0.5);
|
|
padding: 28px 32px;
|
|
width: 340px;
|
|
}
|
|
|
|
.login-box h1 {
|
|
font-size: 12px;
|
|
color: var(--accent);
|
|
text-transform: uppercase;
|
|
letter-spacing: 2.5px;
|
|
margin-bottom: 20px;
|
|
text-align: center;
|
|
}
|
|
|
|
/* ====================== COMMAND PALETTE ====================== */
|
|
.cmd-palette-overlay {
|
|
position: fixed;
|
|
inset: 0;
|
|
background: rgba(0,0,0,0.65);
|
|
z-index: 1000;
|
|
display: flex;
|
|
align-items: flex-start;
|
|
justify-content: center;
|
|
padding-top: 15vh;
|
|
}
|
|
|
|
.cmd-palette {
|
|
width: 520px;
|
|
max-width: 92vw;
|
|
background: var(--bg-panel);
|
|
border: 1px solid var(--border-light);
|
|
box-shadow: 0 20px 60px rgba(0,0,0,0.7);
|
|
border-radius: var(--radius);
|
|
}
|
|
|
|
.cmd-palette input {
|
|
width: 100%;
|
|
padding: 12px 16px;
|
|
font-size: 14px;
|
|
color: var(--text-bright);
|
|
background: var(--bg-inset);
|
|
border: none;
|
|
border-bottom: 1px solid var(--border-mid);
|
|
outline: none;
|
|
}
|
|
|
|
.cmd-palette input::placeholder {
|
|
color: var(--text-dim);
|
|
}
|
|
|
|
.cmd-palette-results {
|
|
max-height: 50vh;
|
|
overflow-y: auto;
|
|
padding: 4px 0;
|
|
}
|
|
|
|
.cmd-palette-group {
|
|
padding: 6px 14px 3px;
|
|
font-size: 9px;
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.8px;
|
|
color: var(--text-dim);
|
|
font-weight: 600;
|
|
}
|
|
|
|
.cmd-palette-item {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 8px;
|
|
padding: 7px 14px;
|
|
color: var(--text);
|
|
text-decoration: none;
|
|
cursor: pointer;
|
|
transition: background 0.05s;
|
|
}
|
|
|
|
.cmd-palette-item:hover,
|
|
.cmd-palette-item.active {
|
|
background: var(--accent-muted);
|
|
color: var(--text-bright);
|
|
text-decoration: none;
|
|
}
|
|
|
|
.cmd-palette-icon {
|
|
flex-shrink: 0;
|
|
width: 16px;
|
|
text-align: center;
|
|
font-size: 10px;
|
|
color: var(--text-dim);
|
|
}
|
|
|
|
.cmd-palette-item.active .cmd-palette-icon,
|
|
.cmd-palette-item:hover .cmd-palette-icon {
|
|
color: var(--accent);
|
|
}
|
|
|
|
.cmd-palette-text {
|
|
display: flex;
|
|
flex-direction: column;
|
|
min-width: 0;
|
|
}
|
|
|
|
.cmd-palette-title {
|
|
font-size: 13px;
|
|
font-weight: 500;
|
|
white-space: nowrap;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
}
|
|
|
|
.cmd-palette-subtitle {
|
|
font-size: 11px;
|
|
color: var(--text-dim);
|
|
white-space: nowrap;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
}
|
|
|
|
.cmd-palette-item.active .cmd-palette-subtitle,
|
|
.cmd-palette-item:hover .cmd-palette-subtitle {
|
|
color: var(--text-muted);
|
|
}
|
|
|
|
.cmd-palette-empty {
|
|
padding: 16px 14px;
|
|
color: var(--text-dim);
|
|
font-size: 13px;
|
|
text-align: center;
|
|
}
|
|
|
|
/* Ctrl+K hint */
|
|
.cmd-k-hint {
|
|
margin-left: auto;
|
|
display: flex;
|
|
align-items: center;
|
|
padding: 0 12px;
|
|
cursor: pointer;
|
|
}
|
|
|
|
.cmd-k-hint kbd {
|
|
font-family: inherit;
|
|
font-size: 10px;
|
|
color: var(--text-dim);
|
|
background: var(--bg-raised);
|
|
border: 1px solid var(--border-light);
|
|
border-radius: 2px;
|
|
padding: 1px 5px;
|
|
}
|
|
|
|
.cmd-k-hint:hover kbd {
|
|
color: var(--text-muted);
|
|
border-color: #4a4a4a;
|
|
}
|
|
|
|
/* ====================== PIRP CONFIRM MODAL ====================== */
|
|
.pirp-confirm-overlay {
|
|
position: fixed;
|
|
inset: 0;
|
|
background: rgba(0,0,0,0.65);
|
|
z-index: 2000;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
}
|
|
|
|
.pirp-confirm-box {
|
|
background: var(--bg-panel);
|
|
border: 1px solid var(--border-light);
|
|
padding: 20px 24px;
|
|
min-width: 260px;
|
|
max-width: 360px;
|
|
box-shadow: 0 12px 40px rgba(0,0,0,0.7);
|
|
border-radius: var(--radius);
|
|
}
|
|
|
|
.pirp-confirm-msg {
|
|
color: var(--text-bright);
|
|
font-size: 13px;
|
|
margin-bottom: 16px;
|
|
line-height: 1.5;
|
|
}
|
|
|
|
.pirp-confirm-btns {
|
|
display: flex;
|
|
gap: 8px;
|
|
justify-content: flex-end;
|
|
}
|
|
|
|
/* ====================== PRINT ====================== */
|
|
@media print {
|
|
header { display: none; }
|
|
main { padding: 0; }
|
|
body { background: #fff; color: #000; font-size: 10px; }
|
|
.journal-table th, .journal-table td { border: 1px solid #ccc; }
|
|
.journal-controls, .journal-subnav, .journal-month-summary { display: none; }
|
|
.gobd-warning, .gobd-ok { display: none; }
|
|
a { color: #000; }
|
|
}
|