:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.video-modal{background:#fff;border-radius:8px;max-width:700px;width:90%;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.video-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee}.video-modal-header h2{margin:0;font-size:1.25rem;color:#333}.btn-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:0;line-height:1}.btn-close:hover{color:#333}.video-modal-content{flex:1;overflow-y:auto;padding:20px}.video-upload-section{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #eee}.btn-upload{background:#4caf50;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500}.btn-upload:hover:not(:disabled){background:#45a049}.btn-upload:disabled{background:#ccc;cursor:not-allowed}.upload-progress{display:flex;align-items:center;gap:12px;margin-top:12px}.progress-bar{flex:1;height:8px;background:#eee;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:#4caf50;transition:width .3s ease}.upload-hint{margin:8px 0 0;font-size:.85rem;color:#666}.loading,.no-videos{text-align:center;padding:40px 20px;color:#666}.video-list{display:flex;flex-direction:column;gap:12px}.video-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f8f9fa;border-radius:8px;border:1px solid #eee;transition:box-shadow .2s,opacity .2s}.video-item:hover{box-shadow:0 2px 8px #0000001a}.video-item.dragging{opacity:.5;box-shadow:0 4px 12px #00000026}.video-drag-handle{cursor:grab;color:#999;font-size:1.2rem;padding:4px}.video-drag-handle:active{cursor:grabbing}.video-thumbnail{width:80px;height:60px;border-radius:4px;overflow:hidden;cursor:pointer;flex-shrink:0}.video-thumbnail img{width:100%;height:100%;object-fit:cover}.video-placeholder{width:100%;height:100%;background:#333;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem}.video-info{flex:1;min-width:0}.video-filename{margin:0;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.video-date{margin:4px 0 0;font-size:.85rem;color:#666}.video-actions{display:flex;gap:8px}.btn-preview,.btn-delete-video{width:36px;height:36px;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem}.btn-preview{background:#2196f3;color:#fff}.btn-preview:hover{background:#1976d2}.btn-delete-video{background:#f44336;color:#fff}.btn-delete-video:hover{background:#d32f2f}.video-preview-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1100}.video-preview-container{position:relative;max-width:90%;max-height:90%}.btn-close-preview{position:absolute;top:-40px;right:0;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer}.video-preview-player{max-width:100%;max-height:80vh;border-radius:8px}.video-modal-footer{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-top:1px solid #eee;background:#f8f9fa}.video-count{color:#666;font-size:.9rem}.btn-done{background:#333;color:#fff;border:none;padding:10px 24px;border-radius:6px;cursor:pointer;font-weight:500}.btn-done:hover{background:#222}.fish-manager{padding:20px;max-width:1400px;margin:0 auto}.qr-section{margin-top:20px;padding-top:20px;border-top:1px solid #eee;text-align:center}.qr-container{display:flex;flex-direction:column;align-items:center;gap:10px;background:#f8f9fa;padding:15px;border-radius:8px}.qr-help-text{font-size:.9rem;color:#666;margin:0}.qr-link-text{font-family:monospace;font-size:.8rem;color:#888;margin:0}.fish-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.fish-manager-header h1{margin:0;color:#333}.fish-controls{background:#fff;padding:1.5rem;border-radius:8px;margin-bottom:2rem;box-shadow:0 2px 4px #0000001a}.search-form{display:flex;gap:.5rem;margin-bottom:1rem}.search-input{flex:1;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.filter-section{display:flex;align-items:center;gap:.5rem}.filter-section label{font-weight:500;color:#555}.section-filter{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem}.no-fish{text-align:center;padding:3rem;color:#999;font-size:1.1rem}.fish-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.fish-card{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s}.fish-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026}.fish-image-container{position:relative}.fish-image{width:100%;height:200px;object-fit:cover;background:#f0f0f0}.video-badge{position:absolute;top:10px;right:10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4px 10px;border-radius:12px;font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:4px;box-shadow:0 2px 4px #0003}.video-badge:before{content:"▶";font-size:.7rem}.fish-info{padding:1rem}.fish-info h3{margin:0 0 .5rem;color:#333;font-size:1.1rem}.fish-section{color:#667eea;font-weight:500;font-size:.9rem;margin:0 0 .25rem}.fish-code{color:#999;font-size:.85rem;margin:0 0 .5rem;font-family:monospace}.fish-caption{color:#666;font-size:.9rem;line-height:1.4;margin:0 0 1rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.fish-actions{display:flex;gap:.5rem}.btn-primary,.btn-search,.btn-edit,.btn-delete,.btn-save,.btn-cancel,.btn-clear{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s;font-weight:500}.btn-search{background:#667eea;color:#fff}.btn-search:hover{background:#5568d3}.btn-clear{background:#6c757d;color:#fff}.btn-clear:hover{background:#5a6268}.btn-edit{flex:1;background:#28a745;color:#fff;padding:.5rem 1rem;font-size:.9rem}.btn-edit:hover{background:#218838}.btn-videos{flex:1;background:#17a2b8;color:#fff;padding:.5rem 1rem;font-size:.9rem}.btn-videos:hover{background:#138496}.btn-delete{flex:1;background:#dc3545;color:#fff;padding:.5rem 1rem;font-size:.9rem}.btn-delete:hover{background:#c82333}.modal{background:#fff;border-radius:8px;padding:2rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.form-group input[type=text],.form-group input[type=number],.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit}.form-group input[type=file]{width:100%;padding:.5rem}.form-group textarea{resize:vertical}.current-photo{margin-top:.5rem;text-align:center}.current-photo img{max-width:200px;max-height:200px;border-radius:4px;border:1px solid #ddd}.current-photo p{margin:.5rem 0 0;color:#666;font-size:.9rem}@media(max-width:768px){.fish-grid{grid-template-columns:1fr}.fish-manager-header{flex-direction:column;align-items:flex-start;gap:1rem}.search-form{flex-direction:column}.filter-section{flex-direction:column;align-items:flex-start}.form-row{grid-template-columns:1fr}}.section-manager{padding:2rem;max-width:1200px;margin:0 auto}.section-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-manager-header h1{margin:0;color:#333}.section-description{color:#666;margin-bottom:2rem;font-size:1rem}.loading{text-align:center;padding:3rem;color:#666;font-size:1.1rem}.sections-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.sections-table{width:100%;border-collapse:collapse}.sections-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.sections-table th{text-align:left;padding:1rem;font-weight:600;font-size:.95rem}.sections-table tbody tr{border-bottom:1px solid #e0e0e0;transition:background .2s}.sections-table tbody tr:hover{background:#f8f9fa}.sections-table tbody tr:last-child{border-bottom:none}.sections-table td{padding:1rem;color:#333}.order-cell{font-weight:600;color:#667eea;width:80px}.name-cell{font-size:1.05rem}.count-cell{width:120px}.fish-count-badge{background:#e3f2fd;color:#1976d2;padding:.25rem .75rem;border-radius:12px;font-weight:600;font-size:.9rem}.date-cell{color:#888;font-size:.9rem;width:120px}.actions-cell{width:180px;text-align:right}.btn-edit-small,.btn-delete-small{padding:.5rem 1rem;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .2s;margin-left:.5rem}.btn-edit-small{background:#28a745;color:#fff}.btn-edit-small:hover{background:#218838}.btn-delete-small{background:#dc3545;color:#fff}.btn-delete-small:hover:not(:disabled){background:#c82333}.btn-delete-small:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.no-sections{text-align:center;padding:3rem!important;color:#999;font-size:1.05rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:#fff;border-radius:8px;padding:2rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.modal h2{margin:0 0 1.5rem;color:#333}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#555;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit}.form-group small{display:block;margin-top:.25rem;color:#888;font-size:.85rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.btn-primary,.btn-save,.btn-cancel{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s;font-weight:500}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 8px #667eea66}.btn-cancel{background:#6c757d;color:#fff}.btn-cancel:hover{background:#5a6268}.btn-save{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-save:hover{transform:translateY(-2px);box-shadow:0 4px 8px #667eea66}@media(max-width:768px){.section-manager-header{flex-direction:column;align-items:flex-start;gap:1rem}.sections-table-container{overflow-x:auto}.sections-table{min-width:600px}.actions-cell{white-space:nowrap}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;padding:40px;box-shadow:0 10px 40px #0003;max-width:400px;width:100%}.login-card h1{margin:0 0 10px;color:#333;font-size:28px;text-align:center}.login-subtitle{color:#666;text-align:center;margin-bottom:30px;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#333;font-size:14px}.form-group input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.error-message{background:#fee;border:1px solid #fcc;border-radius:8px;padding:12px;color:#c33;font-size:14px;text-align:center}.login-button{padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:30px;padding-top:20px;border-top:1px solid #e0e0e0;text-align:center}.login-footer p{color:#999;font-size:12px;margin:0}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem 2rem;box-shadow:0 2px 4px #0000001a}.app-header h1{margin:0 0 1rem;font-size:2rem;font-weight:600}.app-nav{display:flex;gap:1rem}.app-nav button{background:#fff3;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;font-size:.95rem;cursor:pointer;transition:background .2s}.app-nav button:hover{background:#ffffff4d;transform:none;box-shadow:none}.app-nav button.active{background:#fff6;font-weight:600}.app-nav button.logout-button{background:#ffffff1a;margin-left:auto;border:1px solid rgba(255,255,255,.3)}.app-nav button.logout-button:hover{background:#fff3}.loading-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;background:#f5f5f5;font-size:1.2rem;color:#666}.app-main{flex:1;padding:2rem;background:#f5f5f5}.dashboard{max-width:1200px;margin:0 auto}.dashboard h2{color:#333;margin-bottom:1.5rem;font-size:1.75rem}.status-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;margin-bottom:1rem}.status-card h3{margin-top:0;color:#555;font-size:1.25rem;margin-bottom:1rem}.status-card p{margin:.5rem 0;color:#666}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-weight:600;font-size:.875rem;margin-left:.5rem}.status-badge.ok{background:#d4edda;color:#155724}.status-badge.error{background:#f8d7da;color:#721c24}.status-badge.unknown{background:#e2e3e5;color:#383d41}button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:transform .2s,box-shadow .2s}button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0003}button:active{transform:translateY(0)}.app-footer{background:#333;color:#fff;padding:1rem 2rem;text-align:center}.app-footer p{margin:0;font-size:.875rem}.quick-links{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;margin-top:1.5rem}.quick-links h3{margin-top:0;color:#555;font-size:1.25rem;margin-bottom:1rem}.link-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:transform .2s,box-shadow .2s;width:100%;text-align:left;font-weight:500;margin-bottom:.75rem}.link-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.link-button:last-child{margin-bottom:0}
