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