Files
PackControl/pirp/public/assets/style.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; }
}