@import url("https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap");:root{--font:"Inter",system-ui,-apple-system,sans-serif;--head:"Inter",system-ui,sans-serif;--mono:"JetBrains Mono","Fira Code","Consolas",monospace;--r:12px;--bg:#dce3e6;--surface:#f4f7f9;--sidebar:#f4f7f9;--card:#fff;--border:#c8d4d8;--accent:#58c9e5;--accent-lt:#007d9c;--accent2:#a6e22e;--danger:#e04f5f;--text:#1e2b33;--muted:#5a6b76;--muted2:rgba(90,107,118,.08)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;overflow:hidden}body{font-family:var(--font);font-size:14px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}.app-shell{height:100dvh}.app-shell,.sidebar{display:flex;overflow:hidden;position:relative}.sidebar{width:220px;min-width:220px;background:var(--sidebar);border-right:1px solid var(--border);flex-direction:column;height:100%;transition:width .22s ease,min-width .22s ease;flex-shrink:0;z-index:20}.sidebar.collapsed{width:60px;min-width:60px}.sidebar-logo{padding:20px 16px 16px;border-bottom:1px solid var(--border);flex-direction:column;gap:8px}.logo-mark,.sidebar-logo{display:flex;align-items:center;flex-shrink:0}.logo-mark{width:52px;height:52px;justify-content:center}.logo-text{font-family:var(--head);font-size:15px;font-weight:800;color:var(--text);letter-spacing:-.2px;white-space:nowrap}.logo-text span{color:var(--accent)}.sidebar-nav{flex:1 1;overflow-y:auto;padding:8px 8px 0}.nav-item{display:flex;align-items:center;gap:10px;padding:10px;border:none;background:none;cursor:pointer;font-family:var(--font);font-size:13px;font-weight:500;color:var(--muted);border-radius:8px;width:100%;text-align:left;white-space:nowrap;overflow:hidden;transition:background .13s,color .13s;margin-bottom:2px}.nav-item:hover{background:rgba(0,125,156,.08);color:var(--accent)}.nav-item.active{background:rgba(0,125,156,.12);color:var(--accent)}.nav-item-icon{flex-shrink:0;width:20px;display:flex;align-items:center;justify-content:center}.nav-item-label{overflow:hidden;text-overflow:ellipsis}.sidebar-bottom{padding:12px 8px;border-top:1px solid var(--border);flex-shrink:0}.sidebar-fab{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;border:none;cursor:pointer;width:100%;font-family:var(--font);font-size:13px;font-weight:600;transition:background .13s,opacity .13s;white-space:nowrap;overflow:hidden}.sidebar-fab.primary{background:var(--accent);color:#1e2b33}.sidebar-fab.primary:hover{background:#4ab8d4}.sidebar-fab.secondary{background:var(--card);border:1px solid var(--border);color:var(--muted);margin-top:6px}.sidebar-fab.secondary:hover{background:var(--muted2)}.fab-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px}.fab-label{overflow:hidden;text-overflow:ellipsis}.sidebar-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:19;opacity:0;pointer-events:none;transition:opacity .22s ease}.sidebar-backdrop.open{opacity:1;pointer-events:auto}@media (max-width:699px){.sidebar{position:fixed;left:-220px;top:0;bottom:0;transition:left .22s ease,width .22s ease;width:220px!important;min-width:220px!important;z-index:30}.sidebar.open{left:0}}.sidebar-collapse-btn{display:none;padding:6px 8px;border-top:1px solid var(--border);flex-shrink:0}@media (min-width:700px){.sidebar-collapse-btn{display:flex}}.collapse-toggle{background:none;border:none;cursor:pointer;padding:6px 8px;border-radius:6px;color:var(--muted);font-size:11px;width:100%;text-align:center}.collapse-toggle:hover{background:var(--muted2)}.content{flex:1 1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.content-header{display:none;min-height:56px;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;gap:12px;padding:8px 24px}@media (min-width:700px){.content-header{display:flex}}.header-title{font-family:var(--head);font-size:18px;font-weight:800;line-height:1.2}.header-sub{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:2px;line-height:1.3}.content-body{flex:1 1;overflow-y:auto;padding:20px 20px 100px}@media (min-width:700px){.content-body{padding:24px 28px 40px}}.mobile-topbar{display:flex;align-items:center;gap:12px;padding:0 16px;height:52px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}@media (min-width:700px){.mobile-topbar{display:none}}.mobile-menu-btn{background:none;border:none;cursor:pointer;padding:6px;font-size:20px;color:var(--muted)}.mobile-logo{font-family:var(--head);font-size:16px;font-weight:800;color:var(--text)}.mobile-logo span{color:var(--accent)}.mobile-fab{display:none;position:fixed;bottom:24px;right:20px;width:58px;height:58px;border-radius:50%;background:var(--accent);color:#1e2b33;border:none;cursor:pointer;font-size:28px;font-weight:300;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(88,201,229,.45);z-index:10;transition:transform .13s,box-shadow .13s}.mobile-fab:active{transform:scale(.93)}@media (max-width:699px){.mobile-fab{display:flex}}.overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);z-index:100;padding:20px;align-items:center;justify-content:center;animation:overlay-fade-in .25s ease}.modal,.overlay{display:flex;overflow:hidden}.modal{background:var(--card);border-radius:16px;width:100%;max-width:560px;margin:auto;box-shadow:0 8px 40px rgba(0,0,0,.22);flex-direction:column;max-height:calc(100vh - 40px);animation:modal-slide-up .28s cubic-bezier(.32,.72,0,1)}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-title{font-family:var(--head);font-size:17px;font-weight:700}.modal-body{padding:16px;display:flex;flex-direction:column;gap:0;overflow-y:auto;flex:1 1}.modal-footer{padding:16px 20px;border-top:1px solid var(--border);flex-shrink:0;display:flex;gap:10px}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:8px;border:none;font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:opacity .13s,background .13s;white-space:nowrap}.btn:disabled{opacity:.45;cursor:default}.btn-primary{background:var(--accent);color:#1e2b33}.btn-primary:hover{background:#4ab8d4}.btn-secondary{background:var(--card);border:1px solid var(--border);color:var(--text)}.btn-secondary:hover{background:var(--muted2)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#c9404f}.btn-sm{padding:5px 11px;font-size:12px}.btn-icon{background:none;border:none;cursor:pointer;padding:5px;border-radius:6px;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:background .13s,color .13s}.btn-icon:hover{background:var(--muted2);color:var(--text)}.form-section{margin-bottom:14px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px}.form-input{width:100%;padding:9px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg);font-family:var(--font);font-size:14px;color:var(--text);outline:none;transition:border-color .13s}.form-input:focus{border-color:var(--accent)}textarea.form-input{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-title{font-family:var(--head);font-size:14px;font-weight:700}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:16px;box-shadow:0 1px 3px rgba(30,43,51,.06)}.empty{flex-direction:column;text-align:center;padding:40px 20px}.empty,.empty-icon{display:flex;align-items:center}.empty-icon{margin-bottom:12px;justify-content:center;color:var(--accent)}.empty-title{font-family:var(--head);font-size:17px;font-weight:700;margin-bottom:6px}.empty-sub{font-size:13px;color:var(--muted);max-width:320px;line-height:1.5}.gauge-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-gap:10px;gap:10px}@media (min-width:600px){.gauge-grid{gap:12px}}.hgauge-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;box-shadow:0 1px 3px rgba(30,43,51,.06);min-width:0;overflow:hidden}.hgauge-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;min-width:0}.hgauge-label{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;flex-shrink:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hgauge-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.hgauge-value{font-family:var(--head);font-size:16px;font-weight:800;white-space:nowrap}.hgauge-unit{font-size:11px;font-weight:400;color:var(--muted)}.hgauge-pill{font-family:var(--mono);font-size:10px;padding:2px 8px;border-radius:20px;border:1px solid;font-weight:700}.hgauge-track-wrap{display:flex;flex-direction:column;gap:4px}.hgauge-track{position:relative;height:10px;border-radius:5px;background:var(--bg)}.hgauge-track-inner{position:absolute;inset:0;border-radius:5px;overflow:hidden}.hgauge-zone{position:absolute;top:0;bottom:0}.hgauge-tick{position:absolute;top:-1px;bottom:-1px;width:2px;background:var(--card);z-index:1}.hgauge-dot{position:absolute;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;border-radius:50%;background:#fff;border:2.5px solid #1e2b33;z-index:10;box-shadow:none}.hgauge-range{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:9px;color:var(--muted)}.hgauge-ideal-lbl{font-style:italic}.pool-list{display:flex;flex-direction:column;gap:10px}.pool-row{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;cursor:pointer;transition:border-color .13s,box-shadow .13s}.pool-row:hover{border-color:var(--accent);box-shadow:0 2px 8px rgba(88,201,229,.12)}.pool-row-img{width:44px;height:44px;border-radius:10px;background:var(--bg);flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:22px}.pool-row-info{flex:1 1;min-width:0}.pool-row-name{font-weight:700;font-size:14px}.pool-row-addr,.pool-row-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pool-row-addr{font-size:11px;color:var(--muted);margin-top:2px}.pool-row-tags{display:flex;gap:6px;margin-top:5px;flex-wrap:wrap}.pool-row-tag{font-family:var(--mono);font-size:10px;padding:2px 8px;border-radius:20px;background:var(--bg);border:1px solid var(--border);color:var(--muted)}.pool-row-tag.salt{background:rgba(88,201,229,.1);border-color:rgba(88,201,229,.3);color:var(--accent-lt)}.pool-row-actions{display:flex;gap:4px}.pool-row-btn{background:none;border:none;font-size:18px;cursor:pointer;padding:6px;border-radius:8px;flex-shrink:0;transition:background .13s,color .13s;display:flex;align-items:center;justify-content:center;color:var(--muted)}.pool-row-btn:hover{background:var(--muted2);color:var(--text)}.pool-row-btn:active{transform:scale(.93)}.history-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:8px;box-shadow:0 1px 3px rgba(30,43,51,.06)}.history-card-head{display:flex;align-items:center;gap:12px;padding:12px 14px;cursor:pointer}.chem-grid{display:grid;grid-gap:6px;gap:6px;padding:0 14px 12px}.chem-cell{background:var(--bg);border-radius:6px;padding:7px 10px}.chem-lbl{font-family:var(--mono);font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.chem-val{font-family:var(--head);font-size:15px;font-weight:700}.chem-unit{font-size:10px;color:var(--muted);font-weight:400}.calc-layout{display:flex;gap:0;height:100%}@media (min-width:700px){.calc-layout{gap:24px}}.calc-sidebar{width:180px;min-width:180px;flex-shrink:0;display:none}@media (min-width:700px){.calc-sidebar{display:block}}.calc-nav-item{display:block;width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:8px 12px;border-radius:8px;font-family:var(--font);font-size:13px;color:var(--muted);transition:background .13s,color .13s;margin-bottom:2px}.calc-nav-item:hover{background:var(--muted2);color:var(--text)}.calc-nav-item.active{background:rgba(0,125,156,.12);color:var(--accent);font-weight:600}.calc-panel{flex:1 1;min-width:0;max-width:520px}.check-box{width:18px;height:18px;border-radius:4px;border:2px solid var(--border);background:var(--bg)}.pool-strip{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;margin-bottom:16px}.pool-chip{border:1.5px solid var(--border);border-radius:20px;padding:5px 14px;background:var(--card);font-size:12px;font-weight:600;white-space:nowrap;cursor:pointer;transition:border-color .13s,background .13s}.pool-chip.selected{border-color:var(--accent);background:rgba(88,201,229,.08);color:var(--accent-lt)}.badge{font-family:var(--mono);font-size:10px;padding:2px 8px;border-radius:20px;font-weight:600}.badge-salt{background:rgba(88,201,229,.12);color:var(--accent-lt);border:1px solid rgba(88,201,229,.3)}.badge-chlorine{background:rgba(166,226,46,.12);color:#5a7a00;border:1px solid rgba(166,226,46,.3)}.chem-input-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:10px;gap:10px}@media (min-width:500px){.chem-input-grid{grid-template-columns:repeat(4,1fr)}}.chem-input-label{font-family:var(--mono);font-size:10px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px;display:flex;justify-content:space-between}.ideal-hint{font-family:var(--mono);font-size:9px;color:rgba(88,201,229,.5);font-weight:400}.form-input.chem{padding:8px 6px;font-family:var(--mono);font-size:15px;text-align:center}.check-toggle{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.check-toggle:last-child{border-bottom:none}.check-box{width:20px;height:20px;border-radius:5px;border:2px solid #c8d4d8;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .13s}.check-box.checked{background:var(--accent);border-color:var(--accent)}.check-box-inner{color:#1e2b33;font-size:11px;font-weight:700}.check-name{font-size:13.5px;font-weight:500}.photo-upload-btn{display:inline-flex;align-items:center;padding:8px 14px;border-radius:8px;background:var(--card);border:1px solid var(--border);color:var(--text);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:border-color .13s,color .13s}.photo-upload-btn:hover{border-color:var(--accent);color:var(--accent)}@keyframes overlay-fade-in{0%{opacity:0;backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0)}to{opacity:1;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes sheet-slide-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes overlay-fade-out{0%{opacity:1;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}to{opacity:0;backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0)}}@keyframes modal-slide-down{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(16px) scale(.97)}}@keyframes sheet-slide-down{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(100%)}}input[type=number].stepper-input::-webkit-inner-spin-button,input[type=number].stepper-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number].stepper-input{-moz-appearance:textfield}@keyframes drawer-slide-in{0%{transform:translateX(100%)}to{transform:translateX(0)}}@keyframes radial-pop{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}@keyframes fb-toast-in{0%{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.mobile-fab-group{display:flex;flex-direction:column;align-items:center;gap:10px}@media (min-width:700px){.mobile-fab-group{display:none}.desktop-fab-group{display:flex!important}.radial-item-wrap{display:flex}}@media (max-width:699px){.desktop-fab-group{display:none!important}}.fb-fab-group{position:fixed;bottom:1.25rem;right:1.25rem;z-index:52;display:flex;flex-direction:column;align-items:center;gap:10px;pointer-events:auto}