/* Debug-Dashboard CSS */ /* Reset und Basis-Stile */ * { box-sizing: border-box; margin: 0; padding: 0; } body { font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; line-height: 1.6; color: #333; background-color: #f5f7fa; padding: 0; margin: 0; } h1, h2, h3, h4 { color: #2c3e50; margin-bottom: 15px; } /* Layout */ .page-header { background-color: #2c3e50; color: white; padding: 20px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; } .page-header h1 { color: white; margin: 0; } .last-update { font-size: 0.9em; opacity: 0.8; } .header-actions { display: flex; gap: 10px; } .dashboard-container { display: grid; grid-template-columns: repeat(auto-fit, minmax(450px, 1fr)); gap: 20px; padding: 20px; } .dashboard-section { padding: 20px; } /* Karten */ .card { background-color: white; border-radius: 5px; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); overflow: hidden; margin-bottom: 20px; } .card-header { background-color: #f1f5f9; padding: 15px; font-weight: bold; border-bottom: 1px solid #e2e8f0; display: flex; justify-content: space-between; align-items: center; } .card-body { padding: 20px; } /* Statistik-Karten */ .stats-row { display: flex; justify-content: space-between; margin-bottom: 20px; flex-wrap: wrap; } .stat-card { background-color: #f8fafc; border-radius: 5px; padding: 15px; min-width: 150px; text-align: center; flex: 1; margin: 0 5px; box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); } .stat-label { font-size: 0.9em; color: #64748b; margin-bottom: 5px; } .stat-value { font-size: 1.5em; font-weight: bold; color: #334155; } /* Charts */ .chart-container { position: relative; height: 200px; margin-bottom: 20px; } .chart-container.small { height: 150px; } /* Formularelemente */ .form-group { margin-bottom: 15px; } .form-group label { display: block; margin-bottom: 5px; font-weight: 500; } .form-group input, .form-group select { width: 100%; padding: 8px 12px; border: 1px solid #cbd5e1; border-radius: 4px; font-size: 1em; } .input-group { display: flex; } .input-group input { flex: 1; border-top-right-radius: 0; border-bottom-right-radius: 0; } .input-group-append { display: flex; } .input-group-append .btn { border-top-left-radius: 0; border-bottom-left-radius: 0; } /* Buttons */ .btn { background-color: #3b82f6; color: white; border: none; padding: 8px 15px; border-radius: 4px; cursor: pointer; font-weight: 500; transition: background-color 0.2s; } .btn:hover { background-color: #2563eb; } .btn-sm { padding: 5px 10px; font-size: 0.9em; } .btn-success { background-color: #10b981; } .btn-success:hover { background-color: #059669; } .btn-warning { background-color: #f59e0b; } .btn-warning:hover { background-color: #d97706; } .btn-danger { background-color: #ef4444; } .btn-danger:hover { background-color: #dc2626; } .btn-group { display: flex; gap: 10px; flex-wrap: wrap; } /* Status-Anzeigen */ .status { padding: 10px; border-radius: 4px; margin-bottom: 10px; background-color: #f1f5f9; } .status-good { background-color: #d1fae5; color: #064e3b; } .status-warning { background-color: #fff7ed; color: #7c2d12; } .status-error { background-color: #fee2e2; color: #7f1d1d; } /* Nachrichten */ .message { display: none; padding: 15px; margin: 15px 20px; border-radius: 5px; font-weight: 500; } .message-success { background-color: #d1fae5; color: #064e3b; } .message-error { background-color: #fee2e2; color: #7f1d1d; } /* Systemstatus-Banner */ .system-health-banner { display: none; align-items: center; padding: 10px 20px; color: white; position: relative; } .system-health-banner.checking { background-color: #3b82f6; } .system-health-banner.healthy { background-color: #10b981; } .system-health-banner.warning { background-color: #f59e0b; } .system-health-banner.critical { background-color: #ef4444; } .health-icon { font-size: 1.5em; margin-right: 15px; } .health-status { flex: 1; } .health-status-title { font-weight: bold; margin-bottom: 5px; } .health-details { font-size: 0.9em; display: flex; flex-wrap: wrap; gap: 15px; } .health-good { color: #10b981; } .health-warning { color: #f59e0b; } .health-critical { color: #ef4444; } /* Tabellen */ table { width: 100%; border-collapse: collapse; margin-bottom: 20px; } table th, table td { padding: 12px 15px; text-align: left; border-bottom: 1px solid #e2e8f0; } table th { background-color: #f8fafc; font-weight: 600; } table tbody tr:hover { background-color: #f1f5f9; } /* Tabs */ .tabs { display: flex; border-bottom: 1px solid #e2e8f0; margin-bottom: 20px; } .tab { padding: 10px 20px; cursor: pointer; border-bottom: 2px solid transparent; transition: all 0.2s; } .tab:hover { background-color: #f1f5f9; } .tab.active { border-bottom-color: #3b82f6; color: #3b82f6; font-weight: 500; } .tab-content { display: none; } .tab-content.active { display: block; } /* Docker-Container */ .container-row { transition: background-color 0.2s; } .container-row.running { border-left: 3px solid #10b981; } .container-row.exited { border-left: 3px solid #ef4444; } .container-name { font-weight: bold; } .container-image { font-size: 0.9em; color: #64748b; } .container-running { color: #064e3b; font-weight: 500; } .filter-bar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 15px; } /* Logs und Terminal-Ausgabe */ .logs-container { background-color: #1e293b; color: #e2e8f0; border-radius: 5px; padding: 15px; margin-top: 15px; max-height: 400px; overflow-y: auto; font-family: 'Consolas', 'Monaco', monospace; line-height: 1.5; } .log-placeholder { color: #94a3b8; text-align: center; padding: 20px; } .log-header { display: flex; justify-content: space-between; padding: 10px; background-color: #334155; margin: -15px -15px 10px -15px; border-top-left-radius: 5px; border-top-right-radius: 5px; } .log-line { white-space: pre-wrap; word-break: break-all; margin-bottom: 2px; padding: 2px 0; } .log-error { color: #f87171; } .log-warning { color: #fbbf24; } .log-info { color: #60a5fa; } .log-debug { color: #a3e635; } .log-timestamp { color: #94a3b8; } pre.ping-output, pre.traceroute-output, pre.dns-output { background-color: #1e293b; color: #e2e8f0; padding: 15px; border-radius: 5px; overflow-x: auto; white-space: pre-wrap; font-family: 'Consolas', 'Monaco', monospace; } /* Netzwerkschnittstellen */ .interface-item { background-color: #f8fafc; border-radius: 5px; padding: 15px; margin-bottom: 15px; box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); } .interface-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; padding-bottom: 10px; border-bottom: 1px solid #e2e8f0; } .interface-mac { font-family: monospace; color: #64748b; } .interface-ips h4, .interface-stats h4 { color: #475569; font-size: 1em; margin-top: 15px; margin-bottom: 8px; } .ip-item { padding: 8px; background-color: #f1f5f9; border-radius: 4px; margin-bottom: 8px; } /* Ergebnisse-Container */ .results-container { margin-top: 15px; max-height: 300px; overflow-y: auto; } /* Loading-Anzeige */ .loading { display: flex; align-items: center; justify-content: center; padding: 20px; color: #64748b; } .loading::before { content: ""; width: 20px; height: 20px; margin-right: 10px; border: 2px solid #cbd5e1; border-top-color: #3b82f6; border-radius: 50%; animation: spinner 0.8s linear infinite; } @keyframes spinner { to { transform: rotate(360deg); } } /* Error-Anzeige */ .error { color: #ef4444; padding: 10px; border-radius: 4px; background-color: #fee2e2; } /* Log-Analyse */ .error-list, .warning-list { margin-bottom: 20px; } .error-item, .warning-item { background-color: #fee2e2; border-left: 3px solid #ef4444; padding: 10px; margin-bottom: 10px; border-radius: 4px; } .warning-item { background-color: #fff7ed; border-left-color: #f59e0b; } .error-time, .warning-time { font-size: 0.9em; color: #64748b; margin-bottom: 5px; } /* Responsive Design */ @media (max-width: 768px) { .dashboard-container { grid-template-columns: 1fr; } .page-header { flex-direction: column; align-items: flex-start; gap: 10px; } .header-actions { width: 100%; } .stats-row { flex-direction: column; gap: 10px; } .stat-card { margin: 0 0 10px 0; } .btn-group { flex-direction: column; } .tabs { flex-wrap: wrap; } .tab { flex: 1; text-align: center; padding: 10px; } }