*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fa}#root{width:100vw;height:100vh;overflow:hidden;border-radius:0}#root.panel-mode{width:100vw;height:100vh;background:#333;border-radius:0}.panel-with-map{display:flex;width:100%;height:100vh}.panel-container{width:240px;min-width:240px;height:100%;display:flex;flex-direction:column;overflow:hidden;background:#333}.panel-map-container{flex:1;height:100%;position:relative}.app-container{display:flex;width:100%;height:100%}.sidebar{width:400px;height:100%;background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:24px;border-bottom:1px solid #e0e0e0}.sidebar-header h1{font-size:20px;font-weight:600;color:#1a1a1a;margin-bottom:8px}.sidebar-header p{font-size:14px;color:#666;line-height:1.5}.sidebar-content{flex:1;overflow-y:auto;padding:20px}.map-container{flex:1;position:relative}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:500;color:#333;margin-bottom:8px}.form-group input,.form-group select{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:0;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#4285f4}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.upload-area{border:2px dashed #ddd;border-radius:0;padding:32px;text-align:center;cursor:pointer;transition:all .2s;background:#fafafa}.upload-area:hover{border-color:#4285f4;background:#f0f7ff}.upload-area.drag-over{border-color:#4285f4;background:#e3f2fd}.upload-icon{font-size:48px;margin-bottom:12px}.upload-text{font-size:14px;color:#666;margin-bottom:8px}.upload-hint{font-size:12px;color:#999}.btn{padding:10px 20px;border:none;border-radius:0;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:#4285f4;color:#fff}.btn-primary:hover{background:#3367d6}.btn-primary:disabled{background:#ccc;cursor:not-allowed}.btn-secondary{background:#fff;color:#4285f4;border:1px solid #4285f4}.btn-secondary:hover{background:#f0f7ff}.camera-list{margin-top:20px}.camera-list h3{font-size:16px;font-weight:600;color:#333;margin-bottom:12px}.camera-item{padding:12px;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:0;margin-bottom:8px;cursor:pointer;transition:all .2s}.camera-item:hover,.camera-item.selected{background:#e3f2fd;border-color:#4285f4}.camera-name{font-size:14px;font-weight:500;color:#333;margin-bottom:4px}.camera-coords{font-size:12px;color:#666}.section{margin-bottom:24px}.section-title{font-size:14px;font-weight:600;color:#333;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.alert{padding:12px 16px;border-radius:0;margin-bottom:16px;font-size:14px}.alert-success{background:#e8f5e9;color:#2e7d32;border:1px solid #81c784}.alert-error{background:#ffebee;color:#c62828;border:1px solid #e57373}.alert-info{background:#e3f2fd;color:#1565c0;border:1px solid #64b5f6}.loading{text-align:center;padding:20px;color:#666}.empty-state{text-align:center;padding:40px 20px;color:#999}.empty-state-icon{font-size:48px;margin-bottom:12px;opacity:.5}.empty-state-text{font-size:14px}input[type=file]{display:none}.project-selector{margin-bottom:20px}.coordinates-input{display:grid;grid-template-columns:1fr 1fr;gap:12px}.divider{height:1px;background:#e0e0e0;margin:24px 0}.panel-container{width:240px;height:100vh;background:#333;color:#dadada;font-size:12px;overflow-x:hidden;overflow-y:hidden;border-radius:0;display:flex;flex-direction:column}.panel-message{padding:8px;font-size:11px;text-align:center;border-bottom:1px solid #444}.panel-message-success{background:#2d4a2d;color:#64c864}.panel-message-error{background:#4a2d2d;color:#c86464}.panel-section{padding:4px 12px}.panel-section-header{display:flex;justify-content:space-between;align-items:center;font-size:10px;font-weight:600;margin-bottom:8px;color:#dadada;text-transform:uppercase;letter-spacing:.5px}.panel-select{width:100%;padding:6px 8px;background:#2a2a2a;border:1px solid #555;color:#dadada;font-size:11px;border-radius:0;cursor:pointer}.panel-select:hover{background:#353535}.panel-select option{background:#2a2a2a;color:#dadada}.panel-input{width:100%;padding:6px 8px;background:#2a2a2a;border:1px solid #555;color:#dadada;font-size:11px;border-radius:0}.panel-input:focus{outline:none;border-color:#666;background:#353535}.panel-input::-moz-placeholder{color:#777}.panel-input::placeholder{color:#777}.pac-container{background-color:#2a2a2a;border:1px solid #555;font-size:11px;z-index:10000}.pac-item{border-top:1px solid #444;color:#dadada;padding:4px 8px;cursor:pointer}.pac-item:hover{background-color:#3a3a3a}.pac-item-query{color:#fff}.pac-matched{color:#4285f4}.pac-icon{display:none}.panel-btn-small{width:20px;height:20px;padding:0;background:transparent;border:1px solid #555;color:#dadada;font-size:14px;border-radius:0;cursor:pointer;display:flex;align-items:center;justify-content:center}.panel-btn-small:hover{background:transparent;border-color:#666}.panel-btn-small.active{background:#4285f4;border-color:#4285f4;color:#fff}.panel-btn-upload{width:100%;height:18px;padding:0 8px;background:transparent;border:none;color:#dadada;font-size:11px;border-radius:0;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.panel-btn-upload:hover:not(:disabled){background:transparent}.panel-btn-upload:disabled{opacity:.5;cursor:not-allowed}.panel-divider{height:1px;background:#444}.panel-separator{height:1px;background:#444;margin:8px 0}.panel-loading,.panel-empty{padding:16px 8px;text-align:center;font-size:11px;color:#999}.panel-section-shots{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.panel-shot-list{flex:1;overflow-y:auto;min-height:0}.panel-shot-item{padding:8px;background:#2a2a2a;border:1px solid #444;border-radius:0;margin-bottom:6px;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;gap:4px;position:relative}.panel-shot-delete{position:absolute;top:2px;right:2px;width:14px;height:14px;background:none;border:none;color:#666;font-size:12px;line-height:1;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center}.panel-shot-delete:hover{color:#f44}.panel-shot-info{height:18px;display:flex;align-items:center}.panel-shot-details{display:flex;gap:2px}.panel-shot-col{flex:1;min-width:0;height:18px;background:#222;border-radius:1px;display:flex;align-items:center;justify-content:center}.panel-shot-col-placeholder{font-size:9px;color:#e8a317;-webkit-user-select:none;-moz-user-select:none;user-select:none}.panel-shot-col-btn{cursor:pointer}.panel-shot-col-btn:hover{background:#333}.panel-shot-col-value{font-size:9px;color:#dadada;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.panel-shot-item:hover{background:#353535;border-color:#555}.panel-shot-label{font-size:10px;color:#dadada;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.panel-btn-camera{width:18px;height:18px;padding:0;background:#2a2a2a;border:none;color:#dadada;font-size:10px;border-radius:0;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.panel-btn-camera:hover{background:#3a3a3a}.panel-shot-list::-webkit-scrollbar{width:6px}.panel-shot-list::-webkit-scrollbar-track{background:#2a2a2a}.panel-shot-list::-webkit-scrollbar-thumb{background:#555;border-radius:0}.panel-shot-list::-webkit-scrollbar-thumb:hover{background:#666}
