:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;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;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}[data-theme=light]{color:#213547;background-color:#fff}[data-theme=light] a:hover{color:#747bff}[data-theme=light] button{background-color:#f9f9f9}.app{max-width:900px;margin:0 auto;padding:1rem;position:relative;min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1}.help-btn{position:absolute;top:1rem;right:1rem;width:2rem;height:2rem;border-radius:50%;border:1px solid #444;background:transparent;color:#888;font-size:1rem;font-weight:600;cursor:pointer;padding:0;display:grid;place-items:center;z-index:10;box-sizing:border-box}.help-btn:hover{border-color:#2563eb;color:#2563eb;background-color:#2563eb1a}.app-header{display:flex;flex-direction:column;align-items:center;margin-bottom:1.5rem;padding-top:2rem;padding-bottom:1rem;gap:.5rem}.app-header h1{margin:0;font-size:3rem;font-weight:300}.app-icon{width:6rem;height:6rem}.header-actions{display:flex;gap:.5rem;margin-top:.5rem}.header-actions button{flex:1;white-space:nowrap}.add-river-btn,[data-theme=light] .add-river-btn{background-color:#2563eb;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:500}.add-river-btn:hover,[data-theme=light] .add-river-btn:hover{background-color:#1d4ed8}.refresh-btn{background-color:transparent;border:1px solid #444;color:inherit;padding:.5rem 1rem;border-radius:6px;cursor:pointer}.refresh-btn:hover:not(:disabled){border-color:#666}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.error-banner{background-color:#991b1b;color:#fff;padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem}.loading-state,.empty-state{text-align:center;padding:3rem;color:#888}.empty-state p{margin:.5rem 0}.river-table{width:100%;border-collapse:collapse}.river-table th,.river-table td{padding:.75rem;text-align:left;border-bottom:1px solid #333}.river-table th{font-weight:600;color:#888;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.river-table tbody tr:hover{background-color:#ffffff0d}.river-table tbody tr.dragging{background-color:#2563eb33}.drag-handle{cursor:grab;-webkit-user-select:none;user-select:none;color:#666;width:30px}.drag-handle:active{cursor:grabbing}.river-name{font-weight:500;word-wrap:break-word;overflow-wrap:break-word}.expand-icon{font-size:.7rem;margin-right:.5rem;color:#666}.river-row.expanded{background-color:#ffffff08}.forecast-row{background-color:#ffffff05}.forecast-row td{padding:0 .75rem .75rem;border-bottom:1px solid #333}.forecast-row:hover{background-color:#ffffff05}.river-row{cursor:pointer}.river-level{font-family:monospace;font-size:1rem}.badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.85rem;background-color:#88888826}.level-in-range{background-color:#22c55e26;color:#22c55e}.level-out-of-range{background-color:#ef444426;color:#ef4444}.gauge-frozen{color:#38bdf8;font-family:inherit;font-style:italic}.river-trend{font-size:1rem}.trend-rising{background-color:#3b82f626;color:#3b82f6}.trend-falling{background-color:#f9731626;color:#f97316}.trend-stable{background-color:#88888826;color:#888}.river-updated{color:#888;font-size:.875rem}.river-actions{width:40px}.edit-btn{background:transparent;border:none;color:#888;font-size:1.1rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px}.edit-btn:hover{color:#2563eb;background-color:#2563eb1a}.modal-overlay{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:100}.modal-content{background-color:#1a1a1a;border-radius:8px;width:100%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;border:1px solid #333}.modal-content.modal-small{max-width:350px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #333}.modal-header h2{margin:0;font-size:1.25rem}.close-btn{background:transparent;border:none;font-size:1.5rem;cursor:pointer;color:#888;padding:0;line-height:1}.close-btn:hover{color:#fff}.modal-body{padding:1rem;overflow-y:auto;flex:1}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#888}.form-group select,.form-group input{width:100%;padding:.5rem;border:1px solid #444;border-radius:6px;background-color:#242424;color:inherit;font-size:1rem;box-sizing:border-box}.form-group select:focus,.form-group input:focus{outline:none;border-color:#2563eb}.loading,.error{padding:1rem;text-align:center}.error{color:#ef4444}.gauge-list{max-height:300px;overflow-y:auto;border:1px solid #333;border-radius:6px}.gauge-item{padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid #333;display:flex;justify-content:space-between;align-items:center}.gauge-item:last-child{border-bottom:none}.gauge-item:hover:not(.disabled){background-color:#ffffff0d}.gauge-item.selected{background-color:#2563eb33;border-color:#2563eb}.gauge-item.disabled{opacity:.5;cursor:not-allowed}.already-added{font-size:.75rem;color:#888}.no-results{padding:1rem;text-align:center;color:#888}.modal-footer{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-top:1px solid #333}.modal-footer-right{display:flex;gap:.5rem}.delete-btn{background-color:transparent;border:1px solid #991b1b;color:#ef4444;padding:.5rem 1rem;border-radius:6px;cursor:pointer}.delete-btn:hover{background-color:#ef44441a}.forecast-display{padding:.5rem 0}.forecast-loading,.forecast-error,.forecast-empty{text-align:center;padding:1rem;color:#888;font-size:.875rem}.forecast-error{color:#ef4444}.forecast-graph{text-align:center}.forecast-graph img{max-width:100%;border-radius:4px}.gauge-links{display:flex;justify-content:center;gap:.5rem;padding:.5rem 0}.gauge-link-btn{padding:.4rem .75rem;border:1px solid #2563eb;border-radius:6px;font-size:.9rem;font-weight:500;color:#2563eb;text-decoration:none;cursor:pointer}.gauge-link-btn:hover{background-color:#2563eb1a;border-color:#2563eb}[data-theme=light] .gauge-link-btn{border-color:#2563eb}.mobile-edit{display:none}[data-theme=light] .river-row.expanded,[data-theme=light] .forecast-row{background-color:#00000005}[data-theme=light] .forecast-row td{border-bottom-color:#ddd}@media(max-width:600px){.app{padding:.5rem;overflow-x:hidden}.app-header h1{font-size:2rem}.river-table{table-layout:fixed;width:100%}.col-drag{width:24px}.col-updated,.col-actions{width:0}.col-river,.col-level,.col-trend{width:calc((100% - 24px) / 3)}.river-updated,.river-actions,.river-table th:nth-child(5),.river-table th:nth-child(6){overflow:hidden;padding:0;font-size:0;border:none}.drag-handle{padding:.5rem .25rem}.river-table td{overflow:hidden;text-overflow:ellipsis}.forecast-row td{overflow:visible}.river-table th,.river-table td{padding:.5rem .25rem}.river-name{font-size:.85rem;word-wrap:break-word;overflow-wrap:break-word}.river-level,.river-trend{font-size:.85rem}.gauge-frozen{font-size:.75rem}.mobile-edit{display:flex;justify-content:center;padding:.5rem 0}.mobile-edit .edit-btn{font-size:.9rem;padding:.4rem 1rem;border:1px solid #444;border-radius:6px}.modal-content{margin:.5rem}.modal-content.modal-small{max-width:100%}}.cancel-btn{background-color:transparent;border:1px solid #444;color:#fff;padding:.5rem 1rem;border-radius:6px;cursor:pointer}.cancel-btn:hover{border-color:#666}.help-about{text-align:center;padding-top:1.5rem;margin-top:1.5rem;border-top:1px solid #333;color:#888;font-size:.8rem}.help-about p{margin:.25rem 0}.bmc-button{margin-top:.3rem;height:28px;width:auto}.add-btn,[data-theme=light] .add-btn{background-color:#2563eb;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:500}.add-btn:hover:not(:disabled),[data-theme=light] .add-btn:hover:not(:disabled){background-color:#1d4ed8}.add-btn:disabled{opacity:.5;cursor:not-allowed}.mode-toggle{display:flex;border:1px solid #444;border-radius:6px;overflow:hidden;margin-bottom:1rem}.mode-toggle-btn{flex:1;padding:.5rem 1rem;border:none;background-color:transparent;color:#888;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .15s,color .15s}.mode-toggle-btn:not(:last-child){border-right:1px solid #444}.mode-toggle-btn.active{background-color:#2563eb;color:#fff}.mode-toggle-btn:hover:not(.active){background-color:#ffffff0d}.gauge-picker-btn{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.5rem;border:1px solid #444;border-radius:6px;background-color:#242424;color:inherit;font-size:1rem;cursor:pointer;text-align:left}.gauge-picker-btn:hover{border-color:#2563eb}.gauge-picker-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gauge-picker-change{color:#2563eb;font-size:.8rem;flex-shrink:0;margin-left:.5rem}.formula-display{padding:.5rem .75rem;background-color:#2563eb1a;border:1px solid rgba(37,99,235,.25);border-radius:6px;color:#93b4f5;font-size:.9rem;font-weight:500}.help-body h3{margin:1.25rem 0 .5rem;font-size:1rem;font-weight:600}.help-body h4{margin:.75rem 0 .4rem;font-size:.875rem;font-weight:500;color:#888}.help-body p{margin:0 0 .5rem;line-height:1.5;color:#ccc}.help-inline-btn{display:inline-block;background-color:#2563eb;color:#fff;padding:.15rem .5rem;border-radius:5px;font-size:.85rem;font-weight:500;vertical-align:baseline}.help-examples{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.help-example-row{display:flex;align-items:center;gap:.75rem}.help-example-desc{font-size:.85rem;color:#999}.operation-row{border:1px solid #333;border-radius:6px;padding:.75rem;margin-bottom:.75rem}.operation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.operation-label{font-weight:500;font-size:.85rem;color:#888;text-transform:uppercase;letter-spacing:.03em}.operation-remove-btn{background:transparent;border:none;color:#ef4444;cursor:pointer;font-size:.8rem;padding:.15rem .4rem;border-radius:4px}.operation-remove-btn:hover{background-color:#ef44441a}.operation-row .form-group:last-child{margin-bottom:0}.add-operation-btn{width:100%;padding:.5rem;border:1px dashed #444;border-radius:6px;background:transparent;color:#2563eb;cursor:pointer;font-size:.875rem;font-weight:500;margin-bottom:1rem}.add-operation-btn:hover{border-color:#2563eb;background-color:#2563eb0d}[data-theme=light] .app-header,[data-theme=light] .river-table th,[data-theme=light] .river-table td{border-bottom-color:#ddd}[data-theme=light] .modal-content{background-color:#fff;border-color:#ddd}[data-theme=light] .modal-header,[data-theme=light] .modal-footer{border-color:#ddd}[data-theme=light] .form-group select,[data-theme=light] .form-group input{background-color:#fff;border-color:#ddd}[data-theme=light] .gauge-list{border-color:#ddd}[data-theme=light] .gauge-item{border-bottom-color:#ddd}[data-theme=light] .mode-toggle{border-color:#ddd}[data-theme=light] .mode-toggle-btn:not(:last-child){border-right-color:#ddd}[data-theme=light] .mode-toggle-btn:hover:not(.active){background-color:#00000008}[data-theme=light] .gauge-picker-btn{background-color:#fff;border-color:#ddd}[data-theme=light] .formula-display{background-color:#2563eb0f;border-color:#2563eb33;color:#1d4ed8}[data-theme=light] .operation-row{border-color:#ddd}[data-theme=light] .add-operation-btn{border-color:#ccc}[data-theme=light] .add-operation-btn:hover{border-color:#2563eb;background-color:#2563eb08}[data-theme=light] .refresh-btn,[data-theme=light] .help-btn{border-color:#ddd}[data-theme=light] .help-body p{color:#444}[data-theme=light] .help-example-desc{color:#666}.theme-toggle-row{display:flex;justify-content:space-between;align-items:center;padding-bottom:.75rem;margin-bottom:.75rem;border-bottom:1px solid #333}.theme-toggle-label{font-weight:500}.toggle-switch{position:relative;width:2.75rem;height:1.5rem;border-radius:1rem;border:none;background-color:#444;cursor:pointer;padding:0;transition:background-color .2s}.toggle-switch.active{background-color:#2563eb}.toggle-knob{position:absolute;top:3px;left:3px;width:calc(1.5rem - 6px);height:calc(1.5rem - 6px);border-radius:50%;background-color:#fff;transition:transform .2s}.toggle-switch.active .toggle-knob{transform:translate(1.25rem)}[data-theme=light] .theme-toggle-row{border-bottom-color:#ddd}[data-theme=light] .toggle-switch{background-color:#ccc}[data-theme=light] .toggle-switch.active{background-color:#2563eb}
