/* 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; } }