Spaces:
Sleeping
Sleeping
| /* Global Styles - Mi Pesca RD */ | |
| :root { | |
| --primary-color: #0D47A1; | |
| --secondary-color: #4CAF50; | |
| --warning-color: #FF9800; | |
| --danger-color: #F44336; | |
| --background-color: #ffffff; | |
| --text-color: #000000; | |
| --card-bg: #f8f9fa; | |
| --border-radius: 8px; | |
| --shadow: 0 2px 8px rgba(0, 0, 0, 0.1); | |
| } | |
| * { | |
| box-sizing: border-box; | |
| font-family: 'Inter', system-ui, -apple-system, sans-serif; | |
| } | |
| body { | |
| margin: 0; | |
| padding: 0; | |
| background-color: var(--background-color); | |
| color: var(--text-color); | |
| font-size: 18px; | |
| } | |
| h1, | |
| h2, | |
| h3 { | |
| margin-top: 0; | |
| color: var(--primary-color); | |
| } | |
| html { | |
| scroll-behavior: smooth; | |
| } | |
| /* App Container */ | |
| #app { | |
| max-width: 600px; | |
| margin: 0 auto; | |
| min-height: 100vh; | |
| display: flex; | |
| flex-direction: column; | |
| } | |
| /* Loading State */ | |
| .loading { | |
| display: flex; | |
| flex-direction: column; | |
| align-items: center; | |
| justify-content: center; | |
| min-height: 100vh; | |
| text-align: center; | |
| } | |
| /* Navigation */ | |
| .nav { | |
| background-color: var(--primary-color); | |
| color: white; | |
| padding: 1rem; | |
| display: flex; | |
| align-items: center; | |
| justify-content: space-between; | |
| box-shadow: var(--shadow); | |
| } | |
| .nav h1 { | |
| margin: 0; | |
| font-size: 1.5rem; | |
| color: white; | |
| } | |
| .nav-back { | |
| background: none; | |
| border: none; | |
| color: white; | |
| font-size: 1.5rem; | |
| cursor: pointer; | |
| padding: 0.5rem; | |
| } | |
| /* Main Content */ | |
| .content { | |
| flex: 1; | |
| padding: 1rem; | |
| } | |
| /* Cards */ | |
| .card { | |
| background-color: var(--card-bg); | |
| border-radius: var(--border-radius); | |
| padding: 1.5rem; | |
| margin-bottom: 1rem; | |
| box-shadow: var(--shadow); | |
| } | |
| /* Buttons */ | |
| button { | |
| min-height: 50px; | |
| padding: 0.75rem 1.5rem; | |
| font-size: 1rem; | |
| font-weight: 600; | |
| border: none; | |
| border-radius: var(--border-radius); | |
| cursor: pointer; | |
| touch-action: manipulation; | |
| transition: all 0.2s; | |
| } | |
| .btn-primary { | |
| background-color: var(--primary-color); | |
| color: white; | |
| } | |
| .btn-primary:hover { | |
| background-color: #0a3a7f; | |
| } | |
| .btn-secondary { | |
| background-color: var(--secondary-color); | |
| color: white; | |
| } | |
| .btn-secondary:hover { | |
| background-color: #45a049; | |
| } | |
| .btn-danger { | |
| background-color: var(--danger-color); | |
| color: white; | |
| } | |
| .btn-full { | |
| width: 100%; | |
| margin-bottom: 1rem; | |
| } | |
| /* Forms */ | |
| .form-group { | |
| margin-bottom: 1.5rem; | |
| } | |
| .form-group label { | |
| display: block; | |
| margin-bottom: 0.5rem; | |
| font-weight: 600; | |
| color: var(--primary-color); | |
| } | |
| .form-group input, | |
| .form-group select, | |
| .form-group textarea { | |
| width: 100%; | |
| padding: 0.75rem; | |
| font-size: 1rem; | |
| border: 2px solid #ddd; | |
| border-radius: var(--border-radius); | |
| background-color: white; | |
| } | |
| .form-group input:focus, | |
| .form-group select:focus, | |
| .form-group textarea:focus { | |
| outline: none; | |
| border-color: var(--primary-color); | |
| } | |
| /* Species Grid */ | |
| .species-grid { | |
| margin-bottom: 2rem; | |
| } | |
| .category-header { | |
| grid-column: 1 / -1; | |
| background-color: #f1f3f4; | |
| padding: 0.75rem 1rem; | |
| margin: 1.5rem 0 0.75rem 0; | |
| font-size: 1.1rem; | |
| border-radius: 4px; | |
| border-left: 5px solid var(--primary-color); | |
| color: var(--primary-color); | |
| text-transform: uppercase; | |
| letter-spacing: 0.5px; | |
| } | |
| .species-grid-inner { | |
| display: grid; | |
| grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); | |
| gap: 1rem; | |
| margin-bottom: 1rem; | |
| } | |
| .species-card { | |
| background: white; | |
| border: 3px solid transparent; | |
| border-radius: var(--border-radius); | |
| padding: 1rem; | |
| cursor: pointer; | |
| text-align: center; | |
| transition: all 0.2s; | |
| box-shadow: var(--shadow); | |
| } | |
| .species-card:hover { | |
| transform: translateY(-2px); | |
| box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15); | |
| } | |
| .species-card.selected { | |
| border-color: var(--secondary-color); | |
| background-color: #e8f5e9; | |
| } | |
| .species-card.protected { | |
| border-color: var(--danger-color); | |
| } | |
| .species-card img { | |
| width: 100%; | |
| height: 100px; | |
| object-fit: cover; | |
| border-radius: 4px; | |
| margin-bottom: 0.5rem; | |
| } | |
| .species-card h3 { | |
| font-size: 1rem; | |
| margin: 0.5rem 0 0 0; | |
| color: var(--text-color); | |
| } | |
| .species-card .badge { | |
| display: inline-block; | |
| padding: 0.25rem 0.5rem; | |
| font-size: 0.75rem; | |
| border-radius: 4px; | |
| margin-top: 0.5rem; | |
| } | |
| .badge-protected { | |
| background-color: var(--danger-color); | |
| color: white; | |
| } | |
| .badge-veda { | |
| background-color: var(--warning-color); | |
| color: white; | |
| } | |
| /* History List */ | |
| .history-list { | |
| list-style: none; | |
| padding: 0; | |
| margin: 0; | |
| } | |
| .history-item { | |
| background: white; | |
| border-left: 4px solid var(--primary-color); | |
| padding: 1rem; | |
| margin-bottom: 1rem; | |
| border-radius: var(--border-radius); | |
| box-shadow: var(--shadow); | |
| } | |
| .history-item.synced { | |
| border-left-color: var(--secondary-color); | |
| } | |
| .history-item.unsynced { | |
| border-left-color: var(--warning-color); | |
| } | |
| .history-item h3 { | |
| margin: 0 0 0.5rem 0; | |
| font-size: 1rem; | |
| } | |
| .history-item p { | |
| margin: 0.25rem 0; | |
| font-size: 0.9rem; | |
| color: #666; | |
| } | |
| /* Status Indicators */ | |
| .status-bar { | |
| background-color: var(--card-bg); | |
| padding: 0.5rem 1rem; | |
| text-align: center; | |
| font-size: 0.9rem; | |
| border-bottom: 1px solid #ddd; | |
| } | |
| .status-online { | |
| color: var(--secondary-color); | |
| } | |
| .status-offline { | |
| color: var(--warning-color); | |
| } | |
| /* Confirmation View */ | |
| .confirmation-details { | |
| background: white; | |
| padding: 1rem; | |
| border-radius: var(--border-radius); | |
| margin-bottom: 1rem; | |
| } | |
| .confirmation-details dt { | |
| font-weight: 600; | |
| color: var(--primary-color); | |
| margin-top: 0.5rem; | |
| } | |
| .confirmation-details dd { | |
| margin: 0.25rem 0 0.5rem 0; | |
| } | |
| /* Mobile Responsive */ | |
| @media (max-width: 600px) { | |
| body { | |
| font-size: 16px; | |
| } | |
| .species-grid { | |
| grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); | |
| } | |
| .content { | |
| padding: 0.75rem; | |
| } | |
| } | |
| /* Utility Classes */ | |
| .text-center { | |
| text-align: center; | |
| } | |
| .mt-1 { | |
| margin-top: 1rem; | |
| } | |
| .mb-1 { | |
| margin-bottom: 1rem; | |
| } | |
| .hidden { | |
| display: none; | |
| } | |
| /* GPS Accuracy Visualizer */ | |
| .accuracy-good { | |
| color: #2e7d32; | |
| font-weight: bold; | |
| } | |
| .accuracy-medium { | |
| color: #ef6c00; | |
| font-weight: bold; | |
| } | |
| .accuracy-poor { | |
| color: #c62828; | |
| font-weight: bold; | |
| } |