* { margin: 0; padding: 0; box-sizing: border-box; } :root { --primary: #059669; --primary-dark: #047857; --primary-light: #10b981; --secondary: #6b7280; --background: #f3f4f6; --surface: #ffffff; --text: #1f2937; --text-light: #6b7280; --border: #e5e7eb; --success: #10b981; --error: #ef4444; --warning: #f59e0b; --radius: 8px; --shadow: 0 1px 3px rgba(0,0,0,0.1), 0 1px 2px rgba(0,0,0,0.06); --shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -2px rgba(0,0,0,0.05); } body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif; background: var(--background); color: var(--text); line-height: 1.6; } /* Navbar */ .navbar { background: var(--surface); border-bottom: 1px solid var(--border); padding: 0 2rem; height: 60px; display: flex; align-items: center; justify-content: space-between; position: sticky; top: 0; z-index: 100; } .nav-brand { font-size: 1.5rem; font-weight: 700; color: var(--primary); display: flex; align-items: center; gap: 0.5rem; } .logo { font-size: 1.75rem; } .nav-links { display: flex; gap: 0.5rem; } .nav-link { padding: 0.5rem 1rem; text-decoration: none; color: var(--text-light); border-radius: var(--radius); transition: all 0.2s; } .nav-link:hover { background: var(--background); color: var(--text); } .nav-link.active { background: var(--primary); color: white; } /* Container */ .container { max-width: 1200px; margin: 0 auto; padding: 2rem; } /* Views */ .view { display: none; } .view.active { display: block; } .view-header { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; } .view-header h1 { flex: 1; } /* Cards */ .card { background: var(--surface); border-radius: var(--radius); border: 1px solid var(--border); padding: 1.5rem; box-shadow: var(--shadow); } .card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1rem; } .grove-card, .tree-card { background: var(--surface); border-radius: var(--radius); border: 1px solid var(--border); padding: 1.25rem; cursor: pointer; transition: all 0.2s; } .grove-card:hover, .tree-card:hover { border-color: var(--primary); box-shadow: var(--shadow-lg); transform: translateY(-2px); } .grove-card h3, .tree-card h3 { color: var(--primary); margin-bottom: 0.5rem; display: flex; align-items: center; gap: 0.5rem; } .grove-card p, .tree-card p { color: var(--text-light); font-size: 0.9rem; } .grove-card .meta, .tree-card .meta { margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--border); font-size: 0.8rem; color: var(--text-light); } .badge { display: inline-block; padding: 0.2rem 0.5rem; border-radius: 4px; font-size: 0.75rem; font-weight: 500; } .badge-public { background: #d1fae5; color: #065f46; } .badge-private { background: #fef3c7; color: #92400e; } /* Sections */ .section { margin-top: 2rem; } .section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; } .section-header h2 { font-size: 1.25rem; } /* Buttons */ .btn { padding: 0.5rem 1rem; border-radius: var(--radius); border: none; font-size: 0.9rem; font-weight: 500; cursor: pointer; transition: all 0.2s; display: inline-flex; align-items: center; gap: 0.5rem; } .btn-primary { background: var(--primary); color: white; } .btn-primary:hover { background: var(--primary-dark); } .btn-secondary { background: var(--background); color: var(--text); border: 1px solid var(--border); } .btn-secondary:hover { background: var(--border); } .btn-lg { padding: 0.75rem 1.5rem; font-size: 1rem; } /* Forms */ .form-group { margin-bottom: 1rem; } .form-group label { display: block; margin-bottom: 0.5rem; font-weight: 500; color: var(--text); } .form-group input[type="text"], .form-group input[type="email"], .form-group textarea, .form-group select { width: 100%; padding: 0.75rem; border: 1px solid var(--border); border-radius: var(--radius); font-size: 1rem; transition: border-color 0.2s; } .form-group input:focus, .form-group textarea:focus, .form-group select:focus { outline: none; border-color: var(--primary); } .form-group textarea { min-height: 100px; resize: vertical; } .form-group.checkbox label { display: flex; align-items: center; gap: 0.5rem; cursor: pointer; } .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; } /* File Drop */ .file-drop { border: 2px dashed var(--border); border-radius: var(--radius); padding: 2rem; text-align: center; cursor: pointer; transition: all 0.2s; position: relative; } .file-drop:hover { border-color: var(--primary); background: #f0fdf4; } .file-drop input[type="file"] { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; cursor: pointer; } .file-drop p { color: var(--text-light); margin-bottom: 0.5rem; } #file-name { color: var(--primary); font-weight: 500; } /* Upload Form */ .upload-form { max-width: 600px; } .upload-form.card { padding: 2rem; } /* Tables */ .table-container { overflow-x: auto; } table { width: 100%; border-collapse: collapse; background: var(--surface); border-radius: var(--radius); overflow: hidden; } th, td { padding: 0.75rem 1rem; text-align: left; border-bottom: 1px solid var(--border); } th { background: var(--background); font-weight: 600; color: var(--text-light); font-size: 0.85rem; text-transform: uppercase; } tr:hover { background: #f9fafb; } .hash { font-family: 'Monaco', 'Menlo', monospace; font-size: 0.85rem; color: var(--text-light); } .hash-short { cursor: pointer; } .hash-short:hover { color: var(--primary); } /* Search */ .search-box { display: flex; gap: 1rem; max-width: 600px; margin-bottom: 2rem; } .search-box input { flex: 1; padding: 0.75rem 1rem; border: 1px solid var(--border); border-radius: var(--radius); font-size: 1rem; } .search-box input:focus { outline: none; border-color: var(--primary); } /* Result Card */ .result-card { background: var(--surface); border-radius: var(--radius); border: 1px solid var(--border); padding: 1.5rem; margin-top: 1.5rem; max-width: 600px; } .result-card.success { border-color: var(--success); background: #f0fdf4; } .result-card.error { border-color: var(--error); background: #fef2f2; } .result-card h3 { margin-bottom: 1rem; } .result-card dl { display: grid; grid-template-columns: 150px 1fr; gap: 0.5rem; } .result-card dt { font-weight: 500; color: var(--text-light); } .result-card dd { word-break: break-all; } .result-card .actions { margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--border); } /* Modal */ .modal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.5); display: flex; align-items: center; justify-content: center; z-index: 1000; } .modal.hidden { display: none; } .modal-content { background: var(--surface); border-radius: var(--radius); width: 100%; max-width: 500px; max-height: 90vh; overflow-y: auto; } .modal-header { padding: 1rem 1.5rem; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; } .modal-header h2 { font-size: 1.25rem; } .modal-close { background: none; border: none; font-size: 1.5rem; cursor: pointer; color: var(--text-light); } .modal-close:hover { color: var(--text); } .modal-content form { padding: 1.5rem; } .modal-actions { display: flex; justify-content: flex-end; gap: 0.5rem; margin-top: 1.5rem; } /* Info boxes */ .grove-info, .tree-info { background: var(--surface); border-radius: var(--radius); border: 1px solid var(--border); padding: 1rem 1.5rem; margin-bottom: 1rem; } .info-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; } .info-item label { display: block; font-size: 0.8rem; color: var(--text-light); margin-bottom: 0.25rem; } .info-item span { font-weight: 500; } /* Toast */ #toast-container { position: fixed; bottom: 2rem; right: 2rem; z-index: 2000; } .toast { background: var(--text); color: white; padding: 1rem 1.5rem; border-radius: var(--radius); margin-top: 0.5rem; box-shadow: var(--shadow-lg); animation: slideIn 0.3s ease; } .toast.success { background: var(--success); } .toast.error { background: var(--error); } @keyframes slideIn { from { transform: translateX(100%); opacity: 0; } to { transform: translateX(0); opacity: 1; } } /* Loading */ .loading { text-align: center; padding: 2rem; color: var(--text-light); } /* Hidden */ .hidden { display: none !important; } /* Empty State */ .empty-state { text-align: center; padding: 3rem; color: var(--text-light); } .empty-state h3 { margin-bottom: 0.5rem; color: var(--text); } /* Responsive */ @media (max-width: 768px) { .navbar { padding: 0 1rem; } .container { padding: 1rem; } .form-row { grid-template-columns: 1fr; } .card-grid { grid-template-columns: 1fr; } }