Spaces:
Sleeping
Sleeping
| /* --------------------------------------------------------------------------- | |
| HRRR Weather Dashboard - Styles | |
| --------------------------------------------------------------------------- */ | |
| :root { | |
| --bg: #f8f9fa; | |
| --sidebar-bg: #ffffff; | |
| --card-bg: #ffffff; | |
| --border: #e0e0e0; | |
| --text: #1a1a2e; | |
| --text-muted: #6c757d; | |
| --primary: #4B9CD3; | |
| --primary-hover: #3a8bc2; | |
| --radius: 8px; | |
| --shadow: 0 1px 3px rgba(0,0,0,0.08); | |
| } | |
| * { box-sizing: border-box; margin: 0; padding: 0; } | |
| body { | |
| font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; | |
| background: var(--bg); | |
| color: var(--text); | |
| display: flex; | |
| min-height: 100vh; | |
| } | |
| /* Sidebar */ | |
| .sidebar { | |
| width: 280px; | |
| min-width: 280px; | |
| background: var(--sidebar-bg); | |
| border-right: 1px solid var(--border); | |
| padding: 24px 20px; | |
| display: flex; | |
| flex-direction: column; | |
| gap: 16px; | |
| overflow-y: auto; | |
| height: 100vh; | |
| position: sticky; | |
| top: 0; | |
| } | |
| .sidebar h2 { | |
| font-size: 1.1rem; | |
| font-weight: 600; | |
| margin-bottom: 8px; | |
| } | |
| .sidebar label { | |
| font-size: 0.8rem; | |
| font-weight: 500; | |
| color: var(--text-muted); | |
| margin-bottom: 4px; | |
| display: block; | |
| } | |
| .sidebar input[type="text"], | |
| .sidebar input[type="date"], | |
| .sidebar select { | |
| width: 100%; | |
| padding: 8px 10px; | |
| border: 1px solid var(--border); | |
| border-radius: var(--radius); | |
| font-size: 0.85rem; | |
| margin-bottom: 12px; | |
| background: #fff; | |
| } | |
| .sidebar input:focus, | |
| .sidebar select:focus { | |
| outline: none; | |
| border-color: var(--primary); | |
| box-shadow: 0 0 0 2px rgba(75,156,211,0.15); | |
| } | |
| .date-row { | |
| display: flex; | |
| gap: 8px; | |
| } | |
| .date-row > div { flex: 1; } | |
| /* Segmented control */ | |
| .segmented-control { | |
| display: flex; | |
| border: 1px solid var(--border); | |
| border-radius: var(--radius); | |
| overflow: hidden; | |
| margin-bottom: 12px; | |
| } | |
| .segmented-control input[type="radio"] { display: none; } | |
| .segmented-control label { | |
| flex: 1; | |
| text-align: center; | |
| padding: 6px 12px; | |
| font-size: 0.8rem; | |
| cursor: pointer; | |
| color: var(--text-muted); | |
| margin: 0; | |
| transition: all 0.15s; | |
| } | |
| .segmented-control input:checked + label { | |
| background: var(--primary); | |
| color: white; | |
| font-weight: 500; | |
| } | |
| /* Toggle */ | |
| .toggle-row { | |
| display: flex; | |
| align-items: center; | |
| justify-content: space-between; | |
| margin-bottom: 12px; | |
| } | |
| .toggle-row label { margin: 0; } | |
| .toggle-row input[type="checkbox"] { | |
| width: 18px; height: 18px; | |
| accent-color: var(--primary); | |
| } | |
| /* Button */ | |
| .btn-primary { | |
| width: 100%; | |
| padding: 10px; | |
| background: var(--primary); | |
| color: white; | |
| border: none; | |
| border-radius: var(--radius); | |
| font-size: 0.9rem; | |
| font-weight: 500; | |
| cursor: pointer; | |
| transition: background 0.15s; | |
| } | |
| .btn-primary:hover { background: var(--primary-hover); } | |
| .btn-secondary { | |
| padding: 6px 12px; | |
| background: transparent; | |
| color: var(--primary); | |
| border: 1px solid var(--primary); | |
| border-radius: var(--radius); | |
| font-size: 0.8rem; | |
| text-decoration: none; | |
| cursor: pointer; | |
| transition: all 0.15s; | |
| } | |
| .btn-secondary:hover { | |
| background: var(--primary); | |
| color: white; | |
| } | |
| .caption { | |
| font-size: 0.75rem; | |
| color: var(--text-muted); | |
| margin-top: auto; | |
| } | |
| /* Main content */ | |
| .content { | |
| flex: 1; | |
| padding: 24px 32px; | |
| overflow-y: auto; | |
| } | |
| .content header { margin-bottom: 20px; } | |
| .content h1 { | |
| font-size: 1.5rem; | |
| font-weight: 700; | |
| } | |
| .subtitle { | |
| font-size: 0.85rem; | |
| color: var(--text-muted); | |
| margin-top: 4px; | |
| } | |
| /* Loading */ | |
| .loading { | |
| display: flex; | |
| align-items: center; | |
| gap: 12px; | |
| padding: 16px; | |
| color: var(--text-muted); | |
| } | |
| .spinner { | |
| width: 20px; height: 20px; | |
| border: 3px solid var(--border); | |
| border-top: 3px solid var(--primary); | |
| border-radius: 50%; | |
| animation: spin 0.8s linear infinite; | |
| } | |
| @keyframes spin { to { transform: rotate(360deg); } } | |
| /* Error */ | |
| .error-msg { | |
| background: #fee2e2; | |
| border: 1px solid #fca5a5; | |
| color: #dc2626; | |
| padding: 12px 16px; | |
| border-radius: var(--radius); | |
| margin-bottom: 16px; | |
| font-size: 0.85rem; | |
| } | |
| /* KPI row */ | |
| .kpi-row { | |
| display: grid; | |
| grid-template-columns: repeat(4, 1fr); | |
| gap: 12px; | |
| margin-bottom: 20px; | |
| } | |
| .kpi-card { | |
| background: var(--card-bg); | |
| border: 1px solid var(--border); | |
| border-radius: var(--radius); | |
| padding: 16px; | |
| box-shadow: var(--shadow); | |
| } | |
| .kpi-label { | |
| font-size: 0.75rem; | |
| color: var(--text-muted); | |
| text-transform: uppercase; | |
| letter-spacing: 0.5px; | |
| margin-bottom: 4px; | |
| } | |
| .kpi-value { | |
| font-size: 1.4rem; | |
| font-weight: 700; | |
| } | |
| /* Cards */ | |
| .card { | |
| background: var(--card-bg); | |
| border: 1px solid var(--border); | |
| border-radius: var(--radius); | |
| padding: 16px; | |
| box-shadow: var(--shadow); | |
| } | |
| .card h3 { | |
| font-size: 0.9rem; | |
| font-weight: 600; | |
| margin-bottom: 12px; | |
| } | |
| /* Charts row */ | |
| .charts-row { | |
| display: grid; | |
| grid-template-columns: 3fr 1fr; | |
| gap: 16px; | |
| margin-bottom: 16px; | |
| } | |
| .chart-main { min-height: 400px; } | |
| .chart-side { min-height: 400px; } | |
| /* Bottom row */ | |
| .bottom-row { | |
| display: grid; | |
| grid-template-columns: 1fr 1fr; | |
| gap: 16px; | |
| } | |
| /* Table */ | |
| .table-header { | |
| display: flex; | |
| justify-content: space-between; | |
| align-items: center; | |
| margin-bottom: 12px; | |
| } | |
| .table-header h3 { margin-bottom: 0; } | |
| .table-wrap { | |
| max-height: 300px; | |
| overflow-y: auto; | |
| border: 1px solid var(--border); | |
| border-radius: var(--radius); | |
| } | |
| #data-table { | |
| width: 100%; | |
| border-collapse: collapse; | |
| font-size: 0.8rem; | |
| } | |
| #data-table th { | |
| background: #f1f3f5; | |
| padding: 8px 10px; | |
| text-align: left; | |
| font-weight: 600; | |
| position: sticky; | |
| top: 0; | |
| border-bottom: 1px solid var(--border); | |
| } | |
| #data-table td { | |
| padding: 6px 10px; | |
| border-bottom: 1px solid #f1f3f5; | |
| } | |
| #data-table tbody tr:hover { background: #f8f9fa; } | |
| /* Utility */ | |
| .hidden { display: none ; } | |
| /* Responsive */ | |
| @media (max-width: 1024px) { | |
| .charts-row { grid-template-columns: 1fr; } | |
| .bottom-row { grid-template-columns: 1fr; } | |
| .kpi-row { grid-template-columns: repeat(2, 1fr); } | |
| } | |
| @media (max-width: 768px) { | |
| body { flex-direction: column; } | |
| .sidebar { | |
| width: 100%; | |
| min-width: unset; | |
| height: auto; | |
| position: static; | |
| border-right: none; | |
| border-bottom: 1px solid var(--border); | |
| } | |
| .kpi-row { grid-template-columns: 1fr 1fr; } | |
| } | |