| :root { |
| --primary: #2563eb; |
| --surface: #ffffff; |
| --background: #f8fafc; |
| --text: #1e293b; |
| --text-secondary: #64748b; |
| --border: #e2e8f0; |
| --radius: 16px; |
| --shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1); |
| } |
|
|
| @media (prefers-color-scheme: dark) { |
| :root { |
| --primary: #3b82f6; |
| --surface: #1e293b; |
| --background: #0f172a; |
| --text: #f8fafc; |
| --text-secondary: #94a3b8; |
| --border: #334155; |
| } |
| } |
|
|
| * { |
| box-sizing: border-box; |
| margin: 0; |
| padding: 0; |
| } |
|
|
| body { |
| background: var(--background); |
| color: var(--text); |
| font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; |
| line-height: 1.5; |
| padding: 1rem; |
| transition: background-color 0.3s ease; |
| } |
|
|
| .container { |
| max-width: 1200px; |
| margin: 0 auto; |
| padding: 2rem; |
| } |
|
|
| .header { |
| text-align: center; |
| margin-bottom: 2rem; |
| } |
|
|
| .title { |
| font-size: 2rem; |
| font-weight: 700; |
| margin-bottom: 0.5rem; |
| background: linear-gradient(45deg, var(--primary), #6366f1); |
| -webkit-background-clip: text; |
| -webkit-text-fill-color: transparent; |
| } |
|
|
| .description { |
| color: var(--text-secondary); |
| max-width: 600px; |
| margin: 0 auto; |
| } |
|
|
| .grid { |
| display: grid; |
| grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); |
| gap: 1.5rem; |
| margin-bottom: 2rem; |
| } |
|
|
| .card { |
| background: var(--surface); |
| border-radius: var(--radius); |
| padding: 1.5rem; |
| box-shadow: var(--shadow); |
| border: 1px solid var(--border); |
| transition: transform 0.2s ease, box-shadow 0.2s ease; |
| } |
|
|
| .card:hover { |
| transform: translateY(-2px); |
| box-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1); |
| } |
|
|
| .card-title { |
| font-size: 1.25rem; |
| font-weight: 600; |
| margin-bottom: 1rem; |
| display: flex; |
| align-items: center; |
| gap: 0.5rem; |
| } |
|
|
| .input-group { |
| margin-bottom: 1rem; |
| } |
|
|
| .input-group label { |
| display: block; |
| margin-bottom: 0.5rem; |
| font-weight: 500; |
| } |
|
|
| input, select, textarea { |
| width: 100%; |
| padding: 0.75rem; |
| border: 1px solid var(--border); |
| border-radius: calc(var(--radius) / 2); |
| background: var(--background); |
| color: var(--text); |
| font-size: 0.95rem; |
| transition: border-color 0.2s ease, box-shadow 0.2s ease; |
| } |
|
|
| input:focus, select:focus, textarea:focus { |
| outline: none; |
| border-color: var(--primary); |
| box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1); |
| } |
|
|
| .button { |
| display: inline-flex; |
| align-items: center; |
| gap: 0.5rem; |
| padding: 0.75rem 1.5rem; |
| background: var(--primary); |
| color: white; |
| border: none; |
| border-radius: calc(var(--radius) / 2); |
| font-weight: 500; |
| cursor: pointer; |
| transition: background-color 0.2s ease, transform 0.2s ease; |
| } |
|
|
| .button:hover { |
| background: #1d4ed8; |
| transform: translateY(-1px); |
| } |
|
|
| .button:active { |
| transform: translateY(0); |
| } |
|
|
| .button:disabled { |
| opacity: 0.7; |
| cursor: not-allowed; |
| } |
|
|
| .progress-container { |
| position: relative; |
| height: 200px; |
| border-radius: var(--radius); |
| overflow: hidden; |
| background: var(--background); |
| border: 1px solid var(--border); |
| } |
|
|
| .progress-bar { |
| height: 6px; |
| background: var(--background); |
| border-radius: 3px; |
| overflow: hidden; |
| margin: 1rem 0; |
| } |
|
|
| .progress-value { |
| height: 100%; |
| background: var(--primary); |
| border-radius: 3px; |
| transition: width 0.3s ease; |
| } |
|
|
| .stats { |
| display: grid; |
| grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); |
| gap: 1rem; |
| margin-top: 1rem; |
| } |
|
|
| .stat { |
| text-align: center; |
| padding: 1rem; |
| background: var(--background); |
| border-radius: calc(var(--radius) / 2); |
| border: 1px solid var(--border); |
| } |
|
|
| .stat-value { |
| font-size: 1.5rem; |
| font-weight: 600; |
| margin-bottom: 0.25rem; |
| } |
|
|
| .stat-label { |
| color: var(--text-secondary); |
| font-size: 0.875rem; |
| } |
|
|
| @keyframes fadeIn { |
| from { |
| opacity: 0; |
| transform: translateY(10px); |
| } |
| to { |
| opacity: 1; |
| transform: translateY(0); |
| } |
| } |
|
|
| .animate-in { |
| animation: fadeIn 0.3s ease forwards; |
| } |
|
|
| @media (max-width: 768px) { |
| .container { |
| padding: 1rem; |
| } |
| |
| .grid { |
| grid-template-columns: 1fr; |
| } |
| |
| .card { |
| padding: 1rem; |
| } |
| } |