*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#1a1a1a;color:#e0e0e0}html,body,#app{height:100%;width:100%}.app-container{display:flex;flex-direction:column;min-height:100vh;background-color:#1a1a1a;color:#e0e0e0}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;box-shadow:0 2px 8px #0000004d}.header-content{display:flex;justify-content:space-between;align-items:center}.app-header h1{font-size:1.8rem;margin:0}.header-user{display:flex;align-items:center;gap:1rem}.user-info{font-size:.95rem;opacity:.9}.btn-logout{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:600;transition:all .3s}.btn-logout:hover{background:#ffffff4d}.app-main{flex:1;padding:1rem;max-width:100%;overflow-y:auto}.loading{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000c;color:#fff;padding:2rem;border-radius:12px;z-index:1000}.error-message{position:fixed;bottom:1rem;right:1rem;background:#f44;color:#fff;padding:1rem;border-radius:8px;display:flex;align-items:center;gap:1rem;z-index:1001;max-width:90%}.btn-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:inherit}@media(max-width:600px){.app-header{padding:1rem}.header-content{flex-direction:column;gap:1rem}.app-header h1{font-size:1.5rem}.header-user{width:100%;justify-content:space-between}.app-main{padding:.75rem}.error-message{bottom:auto;top:1rem;right:.5rem;left:.5rem;max-width:none}}.list-container[data-v-a36da8e2]{display:flex;flex-direction:column;gap:1.5rem}.add-button-section[data-v-a36da8e2]{display:flex;justify-content:center;padding:1rem 0}.btn-large[data-v-a36da8e2]{padding:1rem 2rem;font-size:1.1rem;width:100%;max-width:300px}.list-section[data-v-a36da8e2]{margin-bottom:2rem}.empty-state[data-v-a36da8e2]{text-align:center;padding:2rem;color:#888}.traffic-lights-list[data-v-a36da8e2]{display:flex;flex-direction:column;gap:1rem}.traffic-light-card[data-v-a36da8e2]{background:#2d2d2d;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000004d;transition:all .3s;border:1px solid #444;text-decoration:none;color:inherit;display:block;cursor:pointer}.traffic-light-card[data-v-a36da8e2]:hover{box-shadow:0 4px 12px #0006;transform:translateY(-2px)}.card-header[data-v-a36da8e2]{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#1f1f1f;border-bottom:1px solid #444}.header-actions[data-v-a36da8e2]{display:flex;gap:.5rem}.card-content[data-v-a36da8e2]{padding:1rem}.card-content h3[data-v-a36da8e2]{margin-bottom:1rem;font-size:1.1rem;color:#e0e0e0}.card-details[data-v-a36da8e2]{margin-bottom:1rem;font-size:.9rem;color:#b0b0b0}.card-details p[data-v-a36da8e2]{margin-bottom:.5rem}.location-coords[data-v-a36da8e2]{font-family:monospace}.notes[data-v-a36da8e2]{font-style:italic}.timestamp[data-v-a36da8e2]{font-size:.8rem;color:#666}.card-edit[data-v-a36da8e2]{padding:1rem;background:#1f1f1f;border-top:1px solid #444;display:flex;flex-direction:column;gap:1rem}.edit-actions[data-v-a36da8e2]{display:flex;gap:.5rem}.edit-actions .btn[data-v-a36da8e2]{flex:1}.btn[data-v-a36da8e2]{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;text-decoration:none;display:inline-block;text-align:center}.btn-primary[data-v-a36da8e2]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary[data-v-a36da8e2]:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary[data-v-a36da8e2]{background:#3a3a3a;color:#e0e0e0;border:1px solid #555}.btn-secondary[data-v-a36da8e2]:hover{background:#4a4a4a}@media(max-width:600px){.add-button-section[data-v-a36da8e2]{padding:.5rem 0}.btn-large[data-v-a36da8e2]{padding:.75rem 1.5rem;font-size:1rem}.filter-buttons[data-v-a36da8e2]{gap:.5rem}.filter-btn[data-v-a36da8e2]{padding:.5rem 1rem;font-size:.9rem}.card-header[data-v-a36da8e2],.card-content[data-v-a36da8e2]{padding:.75rem}}.add-container[data-v-40490285]{display:flex;justify-content:center;align-items:flex-start;padding:1rem 0;min-height:100%}.add-form-card[data-v-40490285]{background:#2d2d2d;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000004d;border:1px solid #444;width:100%;max-width:500px}.add-form-card h2[data-v-40490285]{font-size:1.5rem;margin-bottom:1.5rem;color:#e0e0e0;text-align:center}.add-form[data-v-40490285]{display:flex;flex-direction:column;gap:1rem}.form-group[data-v-40490285]{display:flex;flex-direction:column;gap:.5rem}.form-row[data-v-40490285]{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group label[data-v-40490285]{font-weight:600;color:#e0e0e0;font-size:.9rem}.form-group input[data-v-40490285],.form-group select[data-v-40490285],.form-group textarea[data-v-40490285]{padding:.75rem;border:2px solid #444;border-radius:8px;font-size:1rem;font-family:inherit;transition:border-color .3s;background-color:#3a3a3a;color:#e0e0e0}.form-group input[data-v-40490285]:focus,.form-group select[data-v-40490285]:focus,.form-group textarea[data-v-40490285]:focus{outline:none;border-color:#667eea}.form-actions[data-v-40490285]{display:flex;gap:.75rem;margin-top:1rem}.btn[data-v-40490285]{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;text-decoration:none;display:inline-block;text-align:center;flex:1}.btn-primary[data-v-40490285]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary[data-v-40490285]:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary[data-v-40490285]{background:#3a3a3a;color:#e0e0e0;border:1px solid #555}.btn-secondary[data-v-40490285]:hover{background:#4a4a4a}@media(max-width:600px){.add-container[data-v-40490285]{padding:.5rem 0}.add-form-card[data-v-40490285]{padding:1.5rem;margin:0 .5rem}.add-form-card h2[data-v-40490285]{font-size:1.2rem;margin-bottom:1rem}.form-row[data-v-40490285]{grid-template-columns:1fr}.form-actions[data-v-40490285]{flex-direction:column}}.detail-container[data-v-a1249d9d]{display:flex;justify-content:center;align-items:flex-start;padding:1rem 0;min-height:100%}.detail-card[data-v-a1249d9d]{background:#2d2d2d;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000004d;border:1px solid #444;width:100%;max-width:600px}.card-header[data-v-a1249d9d]{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#1f1f1f;border-bottom:1px solid #444}.btn-back[data-v-a1249d9d]{background:#3a3a3a;color:#e0e0e0;border:1px solid #555;padding:.5rem 1rem;border-radius:6px;text-decoration:none;font-weight:600;cursor:pointer;transition:all .3s}.btn-back[data-v-a1249d9d]:hover{background:#4a4a4a}.btn-delete-icon[data-v-a1249d9d]{background:none;border:none;font-size:1.3rem;cursor:pointer;opacity:.6;transition:opacity .3s;padding:.5rem}.btn-delete-icon[data-v-a1249d9d]:hover{opacity:1}.card-content[data-v-a1249d9d]{padding:2rem}.card-content h2[data-v-a1249d9d]{font-size:1.8rem;margin-bottom:2rem;color:#e0e0e0}.pattern-section[data-v-a1249d9d]{margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid #444}.pattern-section h3[data-v-a1249d9d]{font-size:1.2rem;margin-bottom:1rem;color:#e0e0e0}.pattern-info[data-v-a1249d9d]{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.pattern-item[data-v-a1249d9d]{background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem;border-radius:8px;text-align:center}.pattern-item label[data-v-a1249d9d]{display:block;font-weight:600;color:#fffc;font-size:.85rem;margin-bottom:.5rem}.pattern-item .value[data-v-a1249d9d]{color:#fff;margin:0;font-size:1.2rem;font-weight:700}.empty-pattern[data-v-a1249d9d]{background:#3a3a3a;padding:1.5rem;border-radius:8px;text-align:center;color:#888}.timeline-section[data-v-a1249d9d]{margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid #444}.timeline-section h3[data-v-a1249d9d]{font-size:1.2rem;margin-bottom:1rem;color:#e0e0e0}.timeline-info[data-v-a1249d9d]{margin-bottom:1rem}.validation-info[data-v-a1249d9d]{font-size:.9rem;color:#888;text-align:center}.timeline-container[data-v-a1249d9d]{background:#1f1f1f;border-radius:8px;padding:1rem;overflow-x:auto}.timeline-hours[data-v-a1249d9d]{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.75rem;color:#888}.hour-marker[data-v-a1249d9d]{flex:1;text-align:center;min-width:40px}.timeline-bar[data-v-a1249d9d]{position:relative;height:40px;background:linear-gradient(to right,#ef44444d 0% 100%);border-radius:6px;overflow:visible}.timeline-entry[data-v-a1249d9d]{position:absolute;top:0;height:100%;transition:all .3s;border-radius:4px;cursor:pointer}.timeline-entry.state-green[data-v-a1249d9d]{background:#22c55ecc;border:1px solid #22c55e}.timeline-entry.state-red[data-v-a1249d9d]{background:#ef444466;border:1px solid rgba(239,68,68,.6)}.timeline-entry[data-v-a1249d9d]:hover{transform:scaleY(1.1);z-index:10}.timeline-current-time[data-v-a1249d9d]{position:absolute;top:-5px;bottom:-5px;width:2px;background:#fbbf24;box-shadow:0 0 10px #fbbf24cc;z-index:20;pointer-events:none}.timeline-current-time[data-v-a1249d9d]:before{content:"";position:absolute;top:-5px;left:-4px;width:10px;height:10px;background:#fbbf24;border-radius:50%;box-shadow:0 0 8px #fbbf24cc}.prediction-section[data-v-a1249d9d]{margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid #444}.prediction-section h3[data-v-a1249d9d]{font-size:1.2rem;margin-bottom:1.5rem;color:#e0e0e0}.prediction-display[data-v-a1249d9d]{display:flex;justify-content:center}.countdown-box[data-v-a1249d9d]{padding:2rem 3rem;border-radius:12px;text-align:center;min-width:280px;transition:all .3s ease;border:3px solid}.countdown-box.state-green[data-v-a1249d9d]{background:#22c55e33;border-color:#22c55e}.countdown-box.state-red[data-v-a1249d9d]{background:#ef444433;border-color:#ef4444}.countdown-box.state-unknown[data-v-a1249d9d]{background:#6b728033;border-color:#6b7280}.countdown-label[data-v-a1249d9d]{font-size:.95rem;font-weight:600;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:1px}.countdown-box.state-green .countdown-label[data-v-a1249d9d]{color:#22c55e}.countdown-box.state-red .countdown-label[data-v-a1249d9d]{color:#ef4444}.countdown-box.state-unknown .countdown-label[data-v-a1249d9d]{color:#6b7280}.countdown-time[data-v-a1249d9d]{font-size:3rem;font-weight:700;font-family:Monaco,Courier New,monospace;letter-spacing:2px}.countdown-box.state-green .countdown-time[data-v-a1249d9d]{color:#22c55e}.countdown-box.state-red .countdown-time[data-v-a1249d9d]{color:#ef4444}.countdown-box.state-unknown .countdown-time[data-v-a1249d9d]{color:#6b7280}.prediction-content[data-v-a1249d9d]{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.prediction-item[data-v-a1249d9d]{background:#2d5a2d;padding:1rem;border-radius:8px;border-left:4px solid #22c55e}.prediction-item label[data-v-a1249d9d]{display:block;font-weight:600;color:#22c55e;font-size:.85rem;margin-bottom:.5rem}.prediction-item .value[data-v-a1249d9d]{color:#e0e0e0;margin:0;font-size:.95rem;font-weight:500}.metadata-section[data-v-a1249d9d]{margin-bottom:2rem}.metadata-section h3[data-v-a1249d9d]{font-size:1.2rem;margin-bottom:1rem;color:#e0e0e0;border-bottom:2px solid #444;padding-bottom:.5rem}.metadata-item[data-v-a1249d9d]{margin-bottom:1rem;padding:.75rem;background:#3a3a3a;border-radius:8px}.metadata-item label[data-v-a1249d9d]{display:block;font-weight:600;color:#667eea;font-size:.85rem;margin-bottom:.25rem}.metadata-item p[data-v-a1249d9d]{color:#e0e0e0;margin:0;word-break:break-all}.monospace[data-v-a1249d9d]{font-family:Courier New,monospace;font-size:.9rem}.actions-section[data-v-a1249d9d]{display:flex;flex-direction:column;gap:.75rem}.btn[data-v-a1249d9d]{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;text-decoration:none;display:inline-block;text-align:center}.btn-primary[data-v-a1249d9d]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary[data-v-a1249d9d]:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary[data-v-a1249d9d]{background:#3a3a3a;color:#e0e0e0;border:1px solid #555}.btn-secondary[data-v-a1249d9d]:hover{background:#4a4a4a}.loading-or-error[data-v-a1249d9d]{text-align:center;padding:2rem;color:#888}@media(max-width:600px){.detail-container[data-v-a1249d9d]{padding:.5rem 0}.detail-card[data-v-a1249d9d]{margin:0 .5rem;border-radius:0}.card-content[data-v-a1249d9d]{padding:1.5rem}.card-content h2[data-v-a1249d9d]{font-size:1.5rem;margin-bottom:1.5rem}.card-header[data-v-a1249d9d]{padding:.75rem}.btn-back[data-v-a1249d9d]{padding:.5rem .75rem;font-size:.9rem}}.schedules-container[data-v-d809d482]{display:flex;flex-direction:column;gap:1.5rem}.schedules-header[data-v-d809d482]{display:flex;align-items:center;gap:1rem}.btn-back[data-v-d809d482]{background:#3a3a3a;color:#e0e0e0;border:1px solid #555;padding:.5rem 1rem;border-radius:6px;text-decoration:none;font-weight:600;cursor:pointer;transition:all .3s}.btn-back[data-v-d809d482]:hover{background:#4a4a4a}.schedules-header h2[data-v-d809d482]{flex:1;font-size:1.3rem;color:#e0e0e0;margin:0}.add-button-section[data-v-d809d482]{display:flex;justify-content:center;padding:1rem 0}.btn-large[data-v-d809d482]{padding:1rem 2rem;font-size:1.1rem;width:100%;max-width:300px}.list-section[data-v-d809d482]{margin-bottom:2rem}.empty-state[data-v-d809d482]{text-align:center;padding:2rem;color:#888}.schedules-list[data-v-d809d482]{display:flex;flex-direction:column;gap:1rem}.schedule-card[data-v-d809d482]{background:#2d2d2d;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000004d;border:1px solid #444}.schedule-header[data-v-d809d482]{display:flex;justify-content:flex-end;padding:.75rem;background:#1f1f1f;border-bottom:1px solid #444}.btn-delete-icon[data-v-d809d482]{background:none;border:none;font-size:1.2rem;cursor:pointer;opacity:.6;transition:opacity .3s;padding:.5rem}.btn-delete-icon[data-v-d809d482]:hover{opacity:1}.schedule-content[data-v-d809d482]{padding:1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem}.schedule-item[data-v-d809d482]{display:flex;flex-direction:column;gap:.5rem}.schedule-item label[data-v-d809d482]{font-weight:600;color:#667eea;font-size:.85rem}.schedule-item p[data-v-d809d482]{color:#e0e0e0;margin:0;padding:.5rem;background:#3a3a3a;border-radius:6px}.timestamp[data-v-d809d482]{font-size:.85rem;font-family:Courier New,monospace}.duration[data-v-d809d482]{font-weight:700;font-size:1.1rem;color:#667eea}.schedule-item.highlight[data-v-d809d482]{grid-column:1 / -1}.btn[data-v-d809d482]{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;text-decoration:none;display:inline-block;text-align:center}.btn-primary[data-v-d809d482]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary[data-v-d809d482]:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}@media(max-width:600px){.schedules-header[data-v-d809d482]{flex-direction:column;align-items:flex-start}.schedules-header h2[data-v-d809d482]{width:100%}.schedule-content[data-v-d809d482]{grid-template-columns:1fr}.schedule-item.highlight[data-v-d809d482]{grid-column:1}.btn-large[data-v-d809d482]{padding:.75rem 1.5rem;font-size:1rem}}.capture-container[data-v-423ade39]{display:flex;justify-content:center;align-items:flex-start;padding:1rem 0;min-height:100%}.capture-card[data-v-423ade39]{background:#2d2d2d;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000004d;border:1px solid #444;width:100%;max-width:500px}.card-header[data-v-423ade39]{display:flex;align-items:center;gap:1rem;padding:1rem;background:#1f1f1f;border-bottom:1px solid #444}.btn-back[data-v-423ade39]{background:#3a3a3a;color:#e0e0e0;border:1px solid #555;padding:.5rem 1rem;border-radius:6px;text-decoration:none;font-weight:600;cursor:pointer;transition:all .3s}.btn-back[data-v-423ade39]:hover{background:#4a4a4a}.card-header h2[data-v-423ade39]{flex:1;font-size:1.2rem;color:#e0e0e0;margin:0}.card-content[data-v-423ade39]{padding:2rem}.instruction[data-v-423ade39]{text-align:center;margin-bottom:2rem;color:#b0b0b0}.instruction p[data-v-423ade39]{margin:.5rem 0;font-size:.95rem}.timer-display[data-v-423ade39]{text-align:center;margin-bottom:2rem;padding:2rem;background:#3a3a3a;border-radius:12px;border:2px solid #444;min-height:100px;display:flex;align-items:center;justify-content:center}.status-idle[data-v-423ade39]{font-size:1.5rem;color:#888;font-weight:600}.status-running[data-v-423ade39]{font-size:2.5rem;color:#667eea;font-weight:700;font-family:Courier New,monospace}.status-complete[data-v-423ade39]{font-size:1.8rem;color:#4c4;font-weight:700}.action-buttons[data-v-423ade39]{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.btn[data-v-423ade39]{padding:1rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;text-decoration:none;text-align:center}.btn-large[data-v-423ade39]{font-size:1.1rem;padding:1.2rem}.btn-primary[data-v-423ade39]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary[data-v-423ade39]:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-danger[data-v-423ade39]{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff}.btn-danger[data-v-423ade39]:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ff6b6b66}.btn-success[data-v-423ade39]{background:linear-gradient(135deg,#51cf66,#40c057);color:#fff}.btn-success[data-v-423ade39]:hover{transform:translateY(-2px);box-shadow:0 4px 12px #51cf6666}.btn-secondary[data-v-423ade39]{background:#3a3a3a;color:#e0e0e0;border:1px solid #555;flex:none}.btn-secondary[data-v-423ade39]:hover{background:#4a4a4a}.error-message[data-v-423ade39]{background:#f44;color:#fff;padding:1rem;border-radius:8px;text-align:center;margin-top:1rem}.loading[data-v-423ade39]{text-align:center;color:#667eea;font-weight:600;margin-top:1rem}@media(max-width:600px){.capture-container[data-v-423ade39]{padding:.5rem 0}.capture-card[data-v-423ade39]{margin:0 .5rem;border-radius:0}.card-header[data-v-423ade39]{flex-direction:column;align-items:flex-start}.card-header h2[data-v-423ade39]{width:100%}.card-content[data-v-423ade39]{padding:1.5rem}.timer-display[data-v-423ade39]{min-height:80px;padding:1.5rem}.status-running[data-v-423ade39]{font-size:2rem}}
