@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap");:root{--bg-dark-primary:#1e2125;--bg-dark-secondary:#2a2f3b;--bg-dark-tertiary:#343c4a;--text-primary:#e6e9ee;--text-secondary:#a4b0be;--accent-primary:#00d2d3;--accent-green:#2ecc71;--accent-red:#e74c3c;--accent-orange:#f39c12;--border-color:#40485a}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Poppins,sans-serif;background-color:var(--bg-dark-primary);color:var(--text-primary);padding:1rem 2rem}.container{max-width:1600px;margin:auto}h1,h2{margin-bottom:1rem;font-weight:500;color:var(--text-primary)}h1{font-size:1.8rem}h2{font-size:1.5rem;border-bottom:1px solid var(--border-color);padding-bottom:.75rem}.top-bar,h2{margin-bottom:1.5rem}.top-bar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.main-nav button{background-color:var(--bg-dark-secondary);color:var(--text-primary);border:1px solid var(--border-color);padding:.6rem 1.2rem;border-radius:6px;cursor:pointer;font-family:Poppins,sans-serif;font-size:.9rem;font-weight:500;transition:background-color .2s,color .2s}.main-nav button.active,.main-nav button:hover{background-color:var(--accent-primary);color:var(--bg-dark-primary)}.main-nav button.active{box-shadow:0 0 10px rgba(0,210,211,.4)}.status-header{background-color:var(--bg-dark-secondary);border-radius:8px;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.status-header .total-cams{font-size:1.1rem;font-weight:600}.status-header .total-cams span{color:var(--accent-primary);font-size:1.3rem}.status-header .status-indicators{display:flex;gap:1rem}.status-header .indicator{display:flex;align-items:center;gap:.5rem;font-size:1rem;padding:.5rem 1rem;border-radius:6px;cursor:pointer;transition:background-color .2s;border:1px solid transparent}.status-header .indicator:hover{background-color:var(--bg-dark-tertiary);border-color:var(--border-color)}.indicator .dot{width:12px;height:12px;border-radius:50%}.dot.connecting{background-color:var(--accent-orange)}.dot.connected{background-color:var(--accent-green)}.dot.error{background-color:var(--accent-red)}.filter-bar{background-color:var(--bg-dark-secondary);border-radius:8px;padding:1rem 1.5rem;margin-top:1.5rem;display:flex;align-items:flex-end;gap:1.5rem;flex-wrap:wrap}.picker-group{display:flex;flex-direction:column;gap:.5rem}.picker-group label{font-size:.9rem;font-weight:500;color:var(--text-secondary)}.input-group{display:flex;gap:.5rem}.filter-bar input[type=date],.filter-bar input[type=time],.filter-bar select{background-color:var(--bg-dark-tertiary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem;border-radius:6px;font-family:Poppins,sans-serif}.filter-bar button{background-color:var(--accent-primary);color:var(--bg-dark-primary);border:none;padding:.6rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:600;transition:background-color .2s}.filter-bar button.apply-filter{margin-left:auto}.filter-bar button.now-btn{background-color:var(--bg-dark-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.filter-bar button:hover{filter:brightness(1.1)}.page{display:none;margin-top:2rem}.page.active{display:block}.algorithm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1.5rem;gap:1.5rem}.algo-card{background-color:var(--bg-dark-secondary);border-radius:8px;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer;position:relative;border-left:4px solid transparent}.algo-card:hover{transform:translateY(-5px);box-shadow:0 10px 20px rgba(0,0,0,.2);border-left-color:var(--accent-primary)}.algo-card h3{font-size:1.1rem;font-weight:500;margin-bottom:.25rem;color:var(--text-primary)}.algo-card p{font-size:.85rem;color:var(--text-secondary)}.algo-card .warning-icon{position:absolute;top:1rem;right:1rem;background-color:var(--accent-red);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;box-shadow:0 0 10px var(--accent-red)}.report-table-wrapper{background-color:var(--bg-dark-secondary);border-radius:8px;padding:1.5rem;overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.9rem}td,th{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border-color);white-space:nowrap}thead th{color:var(--text-secondary);font-weight:600;font-size:.8rem;text-transform:uppercase}tbody tr:hover{background-color:var(--bg-dark-tertiary)}tbody tr:last-child td{border-bottom:none}td .prop-list{list-style:none;padding:0;margin:0}td .prop-list li{padding:2px 0;font-size:.85rem}td .prop-list .prop-desc{color:var(--text-secondary)}.report-image{width:100px;height:62.5px;object-fit:cover;border-radius:4px;background-color:#1e2125;cursor:pointer;transition:transform .2s}.report-image:hover{transform:scale(2.5);z-index:10;position:relative}.face-image{width:60px;height:60px;object-fit:cover;border-radius:50%;background-color:#1e2125}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.75);display:flex;justify-content:center;align-items:center;z-index:1000;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}.modal-overlay.visible{opacity:1;visibility:visible}.modal-content{background-color:var(--bg-dark-secondary);padding:2rem;border-radius:8px;width:95%;box-shadow:0 10px 30px rgba(0,0,0,.5);transform:scale(.9);transition:transform .3s}.modal-overlay.visible .modal-content{transform:scale(1)}.camera-status-modal .modal-content,.sub-algo-modal .modal-content{max-width:600px}.camera-status-modal .modal-content,.report-detail-modal .modal-content{max-width:95%;width:95%;height:90vh;display:flex;flex-direction:column}.camera-status-modal .modal-body,.report-detail-modal .modal-body{flex-grow:1;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);padding-bottom:1rem;margin-bottom:1rem}.modal-header h3{font-size:1.4rem;color:var(--accent-primary)}.close-button{background:none;border:none;color:var(--text-secondary);font-size:2rem;cursor:pointer;line-height:1}.close-button:hover{color:var(--text-primary)}.modal-body ul{list-style:none}.modal-body ul button{display:block;width:100%;text-align:left;background:none;border:none;color:var(--text-primary);font-family:Poppins,sans-serif;padding:.85rem .5rem;border-bottom:1px solid var(--bg-dark-tertiary);font-size:1rem;cursor:pointer;transition:background-color .2s}.modal-body ul button:hover{background-color:var(--bg-dark-tertiary)}.modal-body ul li:last-child button{border-bottom:none}.line-messenger{background-color:var(--bg-dark-secondary);border-radius:8px;width:100%;max-width:600px;max-height:80vh;overflow-y:auto}.line-header{justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border-color)}.line-header,.line-logo{display:flex;align-items:center}.line-logo{gap:.5rem}.line-icon{font-size:1.5rem}.line-header h3{color:var(--accent-primary);margin:0;font-size:1.2rem}.line-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.alert-info h4,.message-section h4,.recipients-section h4{color:var(--text-primary);margin-bottom:1rem;font-size:1rem;font-weight:600}.alert-details{background-color:var(--bg-dark-tertiary);padding:1rem;border-radius:6px;border-left:4px solid var(--accent-red)}.alert-details p{margin:.5rem 0;font-size:.9rem;color:var(--text-secondary)}.alert-details strong{color:var(--text-primary)}.recipients-list{display:flex;flex-direction:column;gap:.75rem}.recipient-item{display:flex;align-items:center;gap:.75rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .2s}.recipient-item:hover{background-color:var(--bg-dark-tertiary)}.recipient-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent-primary)}.recipient-name{color:var(--text-primary);font-size:.9rem}.message-preview{margin-bottom:1rem}.message-preview h5{color:var(--text-secondary);margin-bottom:.5rem;font-size:.85rem;font-weight:500}.default-message{padding:1rem;border-radius:6px;font-size:.85rem;line-height:1.5;color:var(--text-secondary);white-space:pre-line}.custom-message,.default-message{background-color:var(--bg-dark-tertiary);border:1px solid var(--border-color)}.custom-message{width:100%;color:var(--text-primary);padding:.75rem;border-radius:6px;font-family:Poppins,sans-serif;font-size:.9rem;resize:vertical;min-height:100px}.custom-message:focus{outline:none;border-color:var(--accent-primary)}.line-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--border-color)}.cancel-btn,.send-btn{padding:.75rem 1.5rem;border-radius:6px;font-family:Poppins,sans-serif;font-weight:600;cursor:pointer;transition:all .2s;border:none}.cancel-btn{background-color:var(--bg-dark-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.cancel-btn:hover:not(:disabled){background-color:var(--border-color);color:var(--text-primary)}.send-btn{background-color:var(--accent-primary);color:var(--bg-dark-primary)}.send-btn:hover:not(:disabled){filter:brightness(1.1)}.cancel-btn:disabled,.send-btn:disabled{opacity:.5;cursor:not-allowed}