@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&family=Space+Mono:wght@400;700&display=swap";:root{--bg-color: #edf6fb;--bg-deep: #daeef7;--surface-color: #ffffff;--surface-alt: #f2fafd;--text-main: #0c2a3a;--text-muted: #4d7d92;--border-color: #b8dcea;--input-bg: #ffffff;--input-disabled: #e6f3f9;--grain-opacity: .03;--primary: #0b6e8a;--primary-light: #0d91b5;--primary-glow: rgba(11, 110, 138, .16);--info: #0369a1;--info-light: #0ea5e9;--info-glow: rgba(3, 105, 161, .16);--danger: #b91c1c;--danger-light: #ef4444;--danger-glow: rgba(185, 28, 28, .14);--cancel: #6b8fa0;--cancel-hover: #4e7082;--shadow-sm: 0 2px 8px rgba(11, 46, 68, .07);--shadow-md: 0 8px 24px rgba(11, 46, 68, .11);--shadow-lg: 0 16px 40px rgba(11, 46, 68, .16);--radius: 16px;--radius-sm: 10px;--radius-pill: 100px;--sal-normal-bg: rgba(22, 163, 74, .1);--sal-normal-text: #15803d;--sal-normal-border: #22c55e;--sal-moderate-bg: rgba(217, 119, 6, .1);--sal-moderate-text: #b45309;--sal-moderate-border: #f59e0b;--sal-high-bg: rgba(185, 28, 28, .12);--sal-high-text: #dc2626;--sal-high-border: #ef4444;--sal-unread-bg: rgba(77, 125, 146, .1);--sal-unread-text: #4d7d92;--sal-unread-border: #b8dcea;--salinity-accent: #7c3aed;--salinity-accent-light: #a78bfa;--salinity-accent-glow: rgba(124, 58, 237, .14);--nav-bg: rgba(255, 255, 255, .93);--nav-border: rgba(184, 220, 234, .8);--nav-link: #4d7d92;--nav-link-active: #0b6e8a;--nav-link-hover-bg: rgba(11, 110, 138, .07);--nav-active-bg: rgba(11, 110, 138, .11);--nav-height: 60px;--page-pad: clamp(14px, 3.5vw, 32px)}[data-theme=dark]{--bg-color: #0f172a;--bg-deep: #020617;--surface-color: #1e293b;--surface-alt: #334155;--text-main: #f8fafc;--text-muted: #94a3b8;--border-color: #334155;--input-bg: #0f172a;--input-disabled: #1e293b;--grain-opacity: .025;--primary: #0284c7;--primary-light: #38bdf8;--primary-glow: rgba(2, 132, 199, .18);--info: #0d9488;--info-light: #2dd4bf;--info-glow: rgba(13, 148, 136, .15);--danger: #dc2626;--danger-light: #f87171;--danger-glow: rgba(220, 38, 38, .15);--cancel: #64748b;--cancel-hover: #94a3b8;--shadow-sm: 0 4px 6px -1px rgba(0, 0, 0, .3);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .4);--shadow-lg: 0 20px 40px rgba(0, 0, 0, .55);--sal-normal-bg: rgba(2, 132, 199, .15);--sal-normal-text: #38bdf8;--sal-normal-border: #0284c7;--sal-moderate-bg: rgba(217, 119, 6, .15);--sal-moderate-text: #fbbf24;--sal-moderate-border: #d97706;--sal-high-bg: rgba(220, 38, 38, .15);--sal-high-text: #f87171;--sal-high-border: #dc2626;--sal-unread-bg: rgba(100, 116, 139, .15);--sal-unread-text: #94a3b8;--sal-unread-border: #64748b;--salinity-accent: #4f46e5;--salinity-accent-light: #818cf8;--salinity-accent-glow: rgba(79, 70, 229, .15);--nav-bg: rgba(15, 23, 42, .97);--nav-border: rgba(51, 65, 85, .9);--nav-link: #94a3b8;--nav-link-active: #38bdf8;--nav-link-hover-bg: rgba(2, 132, 199, .1);--nav-active-bg: rgba(2, 132, 199, .15)}*,*:before,*:after{box-sizing:border-box;transition:background-color .3s ease,color .3s ease,border-color .3s ease}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:DM Sans,sans-serif;background:var(--bg-color);color:var(--text-main);margin:0;padding:0 0 60px;min-height:100dvh;overflow-x:hidden;line-height:1.6}body.fullscreen-active{overflow:hidden!important}body:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:var(--grain-opacity);pointer-events:none;z-index:9999}body:after{content:"";position:fixed;top:-240px;right:-240px;width:clamp(320px,50vw,640px);height:clamp(320px,50vw,640px);background:radial-gradient(circle,var(--primary-glow) 0%,transparent 70%);pointer-events:none;z-index:0}h1{font-family:"DM Serif Display",serif;font-size:clamp(1.5rem,3.5vw,2.1rem);margin:0;letter-spacing:-.5px;color:var(--text-main);line-height:1.2}h2{font-family:"DM Serif Display",serif;font-size:clamp(1rem,2vw,1.15rem);margin-top:0;color:var(--primary);border-bottom:1px solid var(--border-color);padding-bottom:12px;letter-spacing:-.2px}h3{font-family:"DM Serif Display",serif;font-size:clamp(.9rem,1.8vw,1rem);margin-top:0;color:var(--info)}.subtitle{font-size:clamp(.8rem,1.8vw,.875rem);color:var(--text-muted);margin-top:-4px;margin-bottom:18px;line-height:1.55}.container{max-width:880px;width:100%;margin:0 auto;padding:clamp(16px,3vw,28px) var(--page-pad) 0;position:relative;z-index:1}.container-wide{max-width:1140px;width:100%;margin:0 auto;padding:clamp(16px,3vw,28px) var(--page-pad) 0;position:relative;z-index:1}.navbar{position:sticky;top:0;z-index:1000;background:var(--nav-bg);border-bottom:1px solid var(--nav-border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:0 var(--page-pad);height:var(--nav-height);box-shadow:0 2px 20px #00000012;display:flex;align-items:center;transition:transform .32s cubic-bezier(.4,0,.2,1),background-color .3s ease!important}.navbar:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--primary),var(--info-light),var(--primary));background-size:200% 100%;animation:waveFlow 5s linear infinite;pointer-events:none}@keyframes waveFlow{0%{background-position:0% 0%}to{background-position:200% 0%}}.navbar--hidden{transform:translateY(-110%);box-shadow:none}.nav-break{display:none}.nav-brand{order:1;display:flex;align-items:center;gap:8px;cursor:pointer;margin-right:20px}.nav-brand-icon{font-size:1.4rem;line-height:1}.nav-brand-text{font-family:"DM Serif Display",serif;font-size:1.1rem;color:var(--text-main);white-space:nowrap}.device-selector{order:2;display:flex;align-items:center;gap:8px;margin-right:auto}.device-selector select{padding:7px 30px 7px 12px;background-color:var(--surface-alt);font-weight:600;border-color:var(--primary);color:var(--primary);width:clamp(140px,18vw,210px);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.btn-icon{background:var(--primary-glow);color:var(--primary);border:1px solid var(--primary);border-radius:50%;width:34px;height:34px;flex:0 0 34px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;padding:0;transition:all .2s ease}.btn-icon:hover{transform:scale(1.08);background:var(--primary);color:#fff}.nav-links{order:3;display:flex;align-items:center;gap:4px;list-style:none;margin:0 20px 0 0;padding:0}.nav-links a{display:flex;align-items:center;gap:6px;text-decoration:none;color:var(--nav-link);font-weight:600;font-size:.875rem;padding:7px 14px;border-radius:var(--radius-sm);transition:all .2s ease;white-space:nowrap}.nav-links a:hover{background:var(--nav-link-hover-bg);color:var(--nav-link-active)}.nav-links a.active{background:var(--nav-active-bg);color:var(--nav-link-active);box-shadow:inset 0 0 0 1.5px var(--primary)}.nav-links .nav-icon{font-size:1.05rem;display:flex;align-items:center}.nav-right{order:4;display:flex;align-items:center;gap:6px;margin-right:16px}.nav-action-btn{background:var(--surface-alt);border:1px solid var(--border-color);color:var(--text-main);height:34px;padding:0 12px;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;font-family:DM Sans,sans-serif;display:flex;align-items:center;gap:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.nav-action-btn:hover{background:var(--primary-glow);color:var(--primary);border-color:var(--primary);transform:translateY(-1px)}.nav-action-btn--logout:hover{background:var(--danger-glow);color:var(--danger);border-color:var(--danger)}.nav-action-icon{font-size:.95rem;line-height:1;flex-shrink:0;display:flex;align-items:center}.logout-react-icon{display:flex;align-items:center;justify-content:center}.theme-switch-wrapper{order:5;display:flex;align-items:center;height:34px}.theme-switch{display:inline-block;width:54px;height:28px;position:relative}.theme-switch input{display:none}.slider{position:absolute;inset:0;background:var(--bg-deep);border:1.5px solid var(--border-color);border-radius:var(--radius-pill);cursor:pointer;display:flex;align-items:center;justify-content:space-between;padding:0 6px;transition:background .35s ease,border-color .35s ease}.slider:before{content:"";position:absolute;height:20px;width:20px;left:3px;bottom:3px;background:linear-gradient(135deg,var(--primary),var(--info-light));border-radius:50%;transition:.35s cubic-bezier(.34,1.56,.64,1);z-index:2;box-shadow:0 2px 6px var(--primary-glow)}input:checked+.slider{border-color:var(--info)}input:checked+.slider:before{transform:translate(25px);background:linear-gradient(135deg,var(--info),var(--primary-light))}.icon{font-size:10px;z-index:1}.hamburger,.close-sidebar,.sidebar-overlay{display:none}.card{background:var(--surface-color);padding:clamp(18px,2.5vw,28px);border-radius:var(--radius);box-shadow:var(--shadow-md);margin-bottom:clamp(14px,2.5vw,20px);border:1px solid var(--border-color);position:relative;overflow:hidden;animation:cardReveal .45s ease backwards;transition:box-shadow .25s ease,transform .25s ease}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.card:nth-child(1){animation-delay:.04s}.card:nth-child(2){animation-delay:.09s}.card:nth-child(3){animation-delay:.14s}@keyframes cardReveal{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--info-light));opacity:0;transition:opacity .3s ease}.card:hover:before{opacity:1}.card-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;border-bottom:1px solid var(--border-color);margin-bottom:20px;padding-bottom:14px}.card-header h2{border:none;padding:0;margin:0}.auto-card{border:1px solid var(--info);background:linear-gradient(140deg,var(--surface-color) 0%,rgba(3,105,161,.04) 100%)}.auto-card:before{background:linear-gradient(90deg,var(--info),var(--info-light));opacity:1}.override-card{border-color:var(--danger-light);background:linear-gradient(140deg,var(--surface-color) 0%,rgba(239,68,68,.04) 100%)}.override-card:before{background:linear-gradient(90deg,var(--danger),var(--danger-light));opacity:1}.override-card h2{color:var(--danger)}.salinity-card{border:1px solid var(--border-color);background:linear-gradient(140deg,var(--surface-color) 0%,rgba(124,58,237,.04) 100%)}.salinity-card:before{background:linear-gradient(90deg,var(--salinity-accent),var(--salinity-accent-light));opacity:1}.salinity-card h2{color:var(--salinity-accent)}.smart-guide{border-left:4px solid var(--info);background:linear-gradient(135deg,var(--surface-color),rgba(14,165,233,.05))}.input-section{margin-bottom:16px;padding:clamp(14px,2vw,18px);background:var(--surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:border-color .2s ease}.input-section:focus-within{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow)}.master-toggle{display:flex;background:var(--bg-deep);border-radius:var(--radius-sm);border:1.5px solid var(--border-color);padding:5px;gap:5px}.master-toggle input[type=radio]{display:none!important;position:absolute!important;opacity:0!important;width:0!important;height:0!important;pointer-events:none!important}.master-toggle label{flex:1;display:flex!important;align-items:center;justify-content:center;gap:8px;text-align:center;padding:clamp(10px,1.8vw,13px) clamp(12px,2vw,18px);cursor:pointer;font-weight:600;font-size:clamp(.85rem,1.8vw,.95rem);color:var(--text-muted);border-radius:8px;transition:all .3s ease;margin:0;white-space:nowrap;border:1.5px solid transparent;-webkit-user-select:none;user-select:none}.master-toggle label:hover{color:var(--text-main);background:var(--surface-color);border-color:var(--border-color)}.master-toggle input[type=radio]:checked+label{color:#fff;box-shadow:0 4px 14px #0000002e;border-color:transparent}#modeManual:checked+label{background:linear-gradient(135deg,var(--primary),var(--primary-light));box-shadow:0 4px 14px var(--primary-glow)}#modeAuto:checked+label{background:linear-gradient(135deg,var(--info),var(--info-light));box-shadow:0 4px 14px var(--info-glow)}.form-group{margin-bottom:16px}label{display:block;margin-bottom:8px;font-weight:600;font-size:.875rem;color:var(--text-main)}.radio-group,.checkbox-label{display:flex!important;align-items:center;gap:10px;cursor:pointer;font-weight:500;color:var(--text-muted);font-size:.9rem;margin-bottom:0}.radio-group-box{display:flex;flex-wrap:wrap;gap:8px;background:var(--bg-deep);padding:5px;border-radius:var(--radius-pill);border:1.5px solid var(--border-color);width:fit-content;max-width:100%}.radio-group-box label.radio-group{position:relative;margin:0;padding:0;font-weight:600;font-size:.875rem;color:var(--text-muted);cursor:pointer;display:block!important}.radio-group-box label.radio-group input[type=radio]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.radio-group-box label.radio-group .pill-label{display:flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--radius-pill);transition:all .25s ease;white-space:nowrap}.radio-group-box label.radio-group .pill-label:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--text-muted);opacity:.4;transition:all .25s ease;flex-shrink:0}.radio-group-box label.radio-group input[type=radio]:checked~.pill-label{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;box-shadow:0 3px 10px var(--primary-glow)}.radio-group-box label.radio-group input[type=radio]:checked~.pill-label:before{background:#fff;opacity:1;box-shadow:0 0 0 2px #fff6}input[type=time],input[type=number],input[type=text],input[type=email],input[type=password],select{width:100%;padding:11px 16px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);font-size:.95rem;font-family:DM Sans,sans-serif;background:var(--input-bg);color:var(--text-main);appearance:none;-webkit-appearance:none;transition:border-color .2s ease,box-shadow .2s ease}input:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}input:disabled,select:disabled{background-color:var(--input-disabled);color:var(--text-muted);cursor:not-allowed;opacity:.6}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234d7d92' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px}input[type=radio],input[type=checkbox],input[type=range]{accent-color:var(--primary);cursor:pointer;flex-shrink:0}input[type=range]{width:100%;height:6px;border-radius:3px;padding:0;border:none;background:var(--bg-deep)}.btn-group{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}.btn-group-row{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}button{flex:1;color:#fff;border:none;padding:clamp(10px,1.8vw,13px) clamp(14px,2.2vw,20px);cursor:pointer;border-radius:var(--radius-sm);font-size:clamp(.85rem,1.8vw,.93rem);font-weight:600;font-family:DM Sans,sans-serif;position:relative;overflow:hidden;transition:transform .15s ease,box-shadow .2s ease,background .2s ease;white-space:nowrap}button:after{content:"";position:absolute;inset:0;background:#fff;opacity:0;transition:opacity .2s ease}button:hover:after{opacity:.08}button:active{transform:scale(.97)!important}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-light));box-shadow:0 4px 14px var(--primary-glow)}.btn-primary:hover{box-shadow:0 6px 22px #0b6e8a5c;transform:translateY(-1px)}.btn-auto{background:linear-gradient(135deg,var(--info),var(--info-light));box-shadow:0 4px 14px var(--info-glow)}.btn-auto:hover{box-shadow:0 6px 22px var(--info-glow);transform:translateY(-1px)}.btn-danger{background:linear-gradient(135deg,var(--danger),var(--danger-light));box-shadow:0 4px 14px var(--danger-glow)}.btn-danger:hover{box-shadow:0 6px 22px var(--danger-glow);transform:translateY(-1px)}.btn-cancel{background:var(--cancel);box-shadow:none;opacity:.85}.btn-cancel:hover{background:var(--cancel-hover);opacity:1;transform:translateY(-1px)}.btn-secondary{background:var(--surface-alt);color:var(--text-main);border:1px solid var(--border-color);box-shadow:none}.btn-secondary:hover{background:var(--bg-deep);border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}.btn-salinity{flex:unset;width:100%;background:linear-gradient(135deg,var(--salinity-accent),var(--salinity-accent-light));box-shadow:0 4px 14px var(--salinity-accent-glow)}.btn-salinity:hover{box-shadow:0 6px 22px var(--salinity-accent-glow);transform:translateY(-1px)}.sensor-container{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(10px,1.8vw,14px)}.salinity-live-box{grid-column:span 1}.sensor-box{background:linear-gradient(160deg,var(--surface-alt) 0%,var(--bg-deep) 100%);padding:clamp(14px,2vw,20px) clamp(12px,1.5vw,16px);border-radius:var(--radius-sm);border:1px solid var(--border-color);text-align:center;position:relative;overflow:hidden;transition:transform .22s ease,box-shadow .22s ease}.sensor-box:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:0 4px 20px var(--primary-glow),var(--shadow-lg)}.sensor-box:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--primary-light),transparent);opacity:.7}.sensor-label{font-size:clamp(.6rem,1.1vw,.7rem);color:var(--text-muted);text-transform:uppercase;letter-spacing:1.6px;font-weight:700;margin-bottom:8px}.sensor-val{font-family:Space Mono,monospace;font-size:clamp(1.4rem,2.5vw,1.8rem);font-weight:700;color:var(--primary);line-height:1}.sensor-sublabel{font-size:.65rem;margin-top:6px;font-weight:600;opacity:.85}.sal-normal-text{color:var(--sal-normal-text)}.sal-moderate-text{color:var(--sal-moderate-text)}.sal-high-text{color:var(--sal-high-text)}.badge{font-size:.72rem;padding:5px 12px;border-radius:var(--radius-pill);font-weight:700;border:1.5px solid;font-family:Space Mono,monospace;white-space:nowrap;display:inline-block;letter-spacing:.2px}.online{background:var(--primary-glow);color:var(--primary-light);border-color:var(--primary)}.offline{background:var(--danger-glow);color:var(--danger-light);border-color:var(--danger)}.sal-normal{background:var(--sal-normal-bg);color:var(--sal-normal-text);border-color:var(--sal-normal-border)}.sal-moderate{background:var(--sal-moderate-bg);color:var(--sal-moderate-text);border-color:var(--sal-moderate-border)}.sal-high{background:var(--sal-high-bg);color:var(--sal-high-text);border-color:var(--sal-high-border)}.sal-unread{background:var(--sal-unread-bg);color:var(--sal-unread-text);border-color:var(--sal-unread-border)}.live-warning{color:var(--danger);background:var(--danger-glow);border:1px solid var(--danger-light);font-weight:600;font-size:.9rem;text-align:center;margin:20px 0 0;padding:14px 18px;border-radius:var(--radius-sm);animation:pulse 2.2s ease-in-out infinite}.sal-warning{color:var(--sal-high-text);background:var(--sal-high-bg);border-color:var(--sal-high-border)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.salinity-info-panel{margin-top:20px;padding:clamp(14px,2vw,18px);background:var(--surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-sm);animation:statusIn .35s ease}@keyframes statusIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sal-ec-display{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:14px}.sal-ec-label{font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);font-weight:700}.sal-ec-value{font-family:Space Mono,monospace;font-size:clamp(1.3rem,2.5vw,1.6rem);font-weight:700;color:var(--salinity-accent)}.sal-impact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:14px}.sal-impact-box{background:var(--bg-deep);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:12px 14px;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.sal-impact-box:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.sal-impact-label{font-size:.72rem;color:var(--text-muted);font-weight:700;margin-bottom:6px;text-transform:uppercase;letter-spacing:.8px}.sal-impact-val{font-family:Space Mono,monospace;font-size:1rem;font-weight:700;color:var(--primary)}.status{padding:12px 16px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;display:none}.status[style*=block]{animation:statusIn .3s ease}.status.error{background:var(--danger-glow);color:var(--danger);border:1px solid var(--danger-light);display:block;margin-top:16px}.status.success{background:var(--sal-normal-bg);color:var(--sal-normal-text);border:1px solid var(--sal-normal-border);display:block;margin-top:16px}.auth-container{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:16px;background:var(--bg-color);z-index:10000}[data-theme=dark] .auth-container{background:radial-gradient(ellipse at 60% 0%,rgba(2,132,199,.12) 0%,var(--bg-color) 60%)}.auth-card{width:100%;max-width:424px;padding:clamp(26px,5vw,42px) clamp(22px,4vw,34px);background:var(--surface-color);border-radius:var(--radius);border:1px solid var(--border-color);box-shadow:var(--shadow-lg),0 0 0 1px #0b6e8a0f;z-index:10001;position:relative}.auth-card h2{border-bottom:none;text-align:center;margin-bottom:6px;font-size:clamp(1.2rem,3vw,1.5rem)}.modal-overlay{position:fixed;inset:0;background:#081020d1;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:10005;display:flex;align-items:center;justify-content:center;padding:clamp(12px,3vw,24px);animation:fadeIn .2s ease}.settings-card{background:var(--surface-color);width:100%;max-width:500px;border-radius:var(--radius);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);padding:clamp(22px,3.5vw,34px);animation:popIn .3s cubic-bezier(.34,1.56,.64,1);max-height:90dvh;overflow-y:auto}.settings-card::-webkit-scrollbar{width:4px}.settings-card::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.settings-header h2{margin:0;border:none;padding:0;font-family:"DM Serif Display",serif;font-size:clamp(1.15rem,2.5vw,1.5rem);color:var(--text-main)}.modal-close-btn{background:var(--surface-alt);border:1px solid var(--border-color);color:var(--text-muted);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:0 0 36px;padding:0;cursor:pointer;font-size:1rem;font-weight:700;transition:all .2s ease}.modal-close-btn:hover{background:var(--danger-glow);color:var(--danger);border-color:var(--danger);transform:scale(1.08) rotate(90deg)}.settings-section{margin-bottom:24px}.section-label{display:block;font-size:.68rem;text-transform:uppercase;letter-spacing:1.2px;font-weight:800;color:var(--text-muted);margin-bottom:12px}.settings-item{background:var(--surface-alt);padding:16px;border-radius:var(--radius-sm);border:1px solid var(--border-color);display:flex;flex-direction:column;gap:4px}.settings-item p{margin:0 0 4px;font-size:.9rem;color:var(--text-muted)}.settings-item strong{color:var(--text-main)}.btn-unlink,.btn-device-edit{width:100%;color:#fff;margin-top:12px;font-weight:600}.btn-unlink{background:var(--cancel)}.btn-unlink:hover{background:var(--cancel-hover);transform:translateY(-1px)}.btn-device-edit{background:var(--primary)}.btn-device-edit:hover{transform:translateY(-1px);background:var(--info)}.danger-zone{border-top:1px dashed var(--border-color);padding-top:20px;margin-top:20px}.btn-delete-account{width:100%;background:transparent;border:1.5px solid var(--danger);color:var(--danger);transition:all .2s ease;font-weight:600}.btn-delete-account:hover{background:var(--danger-glow);transform:translateY(-1px)}.confirm-delete-box{background:var(--surface-alt);border:1px dashed var(--danger-light);border-radius:var(--radius-sm);padding:16px;animation:statusIn .25s ease}.confirm-delete-box p{font-size:.875rem;color:var(--text-muted);margin:0 0 4px}.settings-input{margin-top:8px}.settings-input:focus{border-color:var(--danger);box-shadow:0 0 0 3px var(--danger-glow)}.btn-final-delete{flex:1;background:linear-gradient(135deg,var(--danger),var(--danger-light));color:#fff;box-shadow:0 4px 14px var(--danger-glow);border:none}.btn-final-delete:hover{box-shadow:0 6px 22px var(--danger-glow);transform:translateY(-1px)}.btn-final-delete:disabled{opacity:.55;cursor:not-allowed;transform:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:scale(.93) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.ts-page-hero{margin-bottom:clamp(16px,2.5vw,24px)}.ts-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:clamp(16px,2.5vw,24px);background:var(--surface-color);padding:clamp(10px,1.8vw,14px) clamp(14px,2.2vw,20px);border-radius:var(--radius-sm);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.ts-toolbar-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex:1;min-width:0}.ts-channel-pill{background:var(--primary-glow);color:var(--primary);border:1px solid var(--primary);border-radius:var(--radius-pill);padding:5px 14px;font-size:.76rem;font-weight:700;font-family:Space Mono,monospace;white-space:nowrap;flex-shrink:0}.ts-toolbar label{font-size:.82rem;font-weight:600;color:var(--text-muted);margin:0;white-space:nowrap}.ts-toolbar select{width:auto;min-width:80px;padding:7px 28px 7px 10px}.btn-ts-refresh{display:flex;align-items:center;gap:7px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;border:none;border-radius:var(--radius-sm);padding:8px 18px;font-size:.85rem;font-weight:600;font-family:DM Sans,sans-serif;cursor:pointer;flex:0 0 auto;transition:all .2s ease;box-shadow:0 3px 10px var(--primary-glow)}.btn-ts-refresh:hover{box-shadow:0 5px 16px #0b6e8a59;transform:translateY(-1px)}.ts-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(10px,1.8vw,16px);margin-bottom:clamp(16px,2.5vw,24px)}.ts-stat-box{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:clamp(12px,1.8vw,18px) clamp(10px,1.5vw,14px);text-align:center;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease;position:relative;overflow:hidden}.ts-stat-box:after{content:"";position:absolute;bottom:0;left:20%;right:20%;height:2px;background:var(--primary);border-radius:2px;opacity:.4}.ts-stat-box:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.ts-stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);font-weight:700;margin-bottom:6px}.ts-stat-val{font-family:Space Mono,monospace;font-size:clamp(1.1rem,2.2vw,1.4rem);font-weight:700;color:var(--primary)}.ts-stat-val.dry{color:var(--sal-high-text)}.ts-stat-val.wet{color:var(--sal-normal-text)}.ts-stat-val.pump-on{color:var(--info-light)}.ts-stat-val.pump-off{color:var(--text-muted)}.ts-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(14px,2vw,20px);margin-bottom:clamp(20px,2.5vw,28px)}.ts-chart-card{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius);padding:clamp(14px,2vw,22px);box-shadow:var(--shadow-sm);position:relative;overflow:hidden;display:flex;flex-direction:column;min-width:0;transition:box-shadow .25s ease,transform .25s ease}.ts-chart-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.ts-chart-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.ts-chart-card:nth-child(1):before{background:linear-gradient(90deg,#ef4444,#f97316)}.ts-chart-card:nth-child(2):before{background:linear-gradient(90deg,#0ea5e9,#22d3ee)}.ts-chart-card:nth-child(3):before{background:linear-gradient(90deg,#a78bfa,#818cf8)}.ts-chart-card:nth-child(4):before{background:linear-gradient(90deg,#f59e0b,#84cc16)}.ts-chart-card:nth-child(5):before{background:linear-gradient(90deg,#22c55e,#4ade80)}.ts-chart-card:nth-child(6):before{background:linear-gradient(90deg,#0b6e8a,#0ea5e9)}.ts-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-shrink:0}.ts-chart-title{font-family:"DM Serif Display",serif;font-size:clamp(.9rem,1.5vw,1rem);color:var(--text-main);margin:0;font-weight:700}.ts-chart-wrap{position:relative;flex:1;height:clamp(160px,18vw,200px);min-height:160px}.chart-maximize-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-muted);width:30px;height:30px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;flex:0 0 30px;padding:0;transition:all .2s ease}.chart-maximize-btn:hover{background:var(--primary-glow);border-color:var(--primary);color:var(--primary);transform:scale(1.1)}.chart-modal-overlay{position:fixed!important;top:0!important;left:0!important;width:100vw!important;height:100vh!important;background:#081020d9;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);z-index:99999!important;display:flex;align-items:center;justify-content:center;padding:clamp(12px,3vw,32px);margin:0!important;animation:fadeIn .22s ease}.chart-modal-content{background:var(--surface-color);border-radius:var(--radius);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);width:min(920px,96vw);height:min(560px,86dvh);display:flex;flex-direction:column;animation:popIn .28s cubic-bezier(.34,1.56,.64,1);overflow:hidden}.chart-modal-header{display:flex;justify-content:space-between;align-items:center;padding:clamp(14px,2vw,22px) clamp(18px,2.5vw,28px);border-bottom:1px solid var(--border-color);background:var(--surface-color);flex-shrink:0;gap:14px}.chart-modal-header h2{margin:0;border:none;padding:0;font-family:"DM Serif Display",serif;font-size:clamp(1rem,2.2vw,1.3rem);color:var(--text-main);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chart-modal-body{flex:1;min-height:0;padding:clamp(16px,2.5vw,28px);display:flex;flex-direction:column}.chart-modal-body>div{flex:1;min-height:0;display:flex;flex-direction:column}.chart-modal-body .ts-chart-wrap{flex:1!important;min-height:0!important;height:100%!important}.ts-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-muted)}.ts-loading>div{display:flex;gap:8px;align-items:center}.ts-loading-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--primary);animation:dotBounce 1.2s ease-in-out infinite}.ts-loading-dot:nth-child(2){animation-delay:.2s;background:var(--info-light)}.ts-loading-dot:nth-child(3){animation-delay:.4s;background:var(--primary-light)}@keyframes dotBounce{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.2);opacity:1}}.ts-error{display:none;background:var(--danger-glow);color:var(--danger);border:1px solid var(--danger-light);border-radius:var(--radius-sm);padding:14px 18px;font-size:.9rem;font-weight:500;margin-bottom:20px}[data-theme=dark] .btn-primary{background:linear-gradient(135deg,#1e40af,#2563eb);border:1px solid #3b82f6;box-shadow:0 4px 14px #2563eb4d}[data-theme=dark] .btn-primary:hover{box-shadow:0 6px 20px #2563eb73}[data-theme=dark] .btn-auto{background:linear-gradient(135deg,#115e59,#0d9488);border:1px solid #14b8a6;box-shadow:0 4px 14px #14b8a640}[data-theme=dark] .btn-danger{background:linear-gradient(135deg,#7f1d1d,#b91c1c);border:1px solid #ef4444;box-shadow:0 4px 14px #ef444440}[data-theme=dark] .btn-secondary{background:#334155;border:1px solid #475569;color:#94a3b8}[data-theme=dark] .btn-secondary:hover{background:#475569;color:#f8fafc}[data-theme=dark] .btn-final-delete{background:linear-gradient(135deg,#7f1d1d,#b91c1c);border:1px solid #ef4444}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-deep)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-pill)}::-webkit-scrollbar-thumb:hover{background:var(--primary)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:4px}::selection{background:var(--primary-glow);color:var(--primary)}body.modal-open{overflow:hidden;padding-right:6px}@media(max-width:1024px){.ts-charts-grid,.sensor-container{grid-template-columns:repeat(2,1fr)}.salinity-live-box{grid-column:span 2}}@media(max-width:768px){:root{--nav-height: auto}.navbar{flex-wrap:wrap;height:auto;padding:10px var(--page-pad);gap:12px 0;transform:translateY(0)}.navbar--hidden{transform:translateY(-110%);box-shadow:none}.nav-brand{order:1;margin-right:0;flex:0 0 auto}.nav-brand-text{display:none}.device-selector{order:2;margin:0 auto;gap:6px}.device-selector select{width:clamp(110px,30vw,180px);font-size:.82rem;padding-left:8px;padding-right:28px}.theme-switch-wrapper{order:3;margin:0;flex:0 0 auto}.nav-break{order:4;display:block;width:100%;height:1px;background:var(--border-color);margin:0}.nav-links{order:5;margin-right:auto;gap:8px;margin-left:0}.nav-right{order:6;margin-left:auto;gap:8px;margin-right:0}.nav-label,.nav-action-label{display:none!important}.nav-action-btn,.nav-links a{width:42px;height:42px;padding:0;border-radius:50%;justify-content:center;gap:0}.nav-icon,.nav-action-icon{font-size:1.3rem;margin:0;display:flex;align-items:center;justify-content:center}}@media(max-width:480px){.sensor-container{grid-template-columns:1fr}.salinity-live-box{grid-column:span 1}.ts-charts-grid{grid-template-columns:1fr}.ts-stats-row{grid-template-columns:repeat(2,1fr)}.radio-group-box{border-radius:12px;flex-direction:column;width:100%;align-items:stretch}.radio-group-box label.radio-group .pill-label{width:100%;border-radius:12px;justify-content:flex-start}.btn-group,.btn-group-row{flex-direction:column}.ts-toolbar{flex-direction:column;align-items:stretch}.ts-toolbar-left{justify-content:space-between}.nav-action-btn,.nav-links a{width:38px;height:38px}.nav-icon,.nav-action-icon{font-size:1.15rem}.device-selector select{width:clamp(90px,25vw,130px)}.btn-ts-refresh{width:100%;justify-content:center}.container,.container-wide{padding-left:12px;padding-right:12px}.card{padding:16px 13px}.auth-card{padding:20px 14px;border-radius:var(--radius-sm)}.settings-card{border-radius:var(--radius-sm)}.chart-modal-content{height:min(440px,90dvh);width:98vw;border-radius:var(--radius-sm)}.chart-modal-header{padding:14px 16px}.chart-modal-body{padding:12px}}@media(max-width:380px){.nav-links a{padding:7px 8px}.nav-action-btn{width:32px;height:32px}}.chart-modal-close{background:var(--surface-alt)!important;border:1px solid var(--border-color)!important;color:var(--text-main)!important;width:36px!important;height:36px!important;min-width:36px!important;flex:0 0 36px!important;padding:0!important;border-radius:50%!important;display:flex!important;align-items:center!important;justify-content:center!important;cursor:pointer!important}.chart-modal-close:hover{background:var(--danger-glow)!important;color:var(--danger)!important;border-color:var(--danger)!important}.text-center{text-align:center}.btn-block{width:100%}.modal-tabs{display:flex;margin-bottom:20px;border-bottom:2px solid var(--border-color)}.modal-tab-btn{flex:1;padding:12px 10px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-weight:500;font-size:.95rem;cursor:pointer;transition:all .2s ease;margin-bottom:-2px}.modal-tab-btn:hover{color:var(--primary);background:var(--nav-link-hover-bg)}.modal-tab-btn.active{color:var(--primary);font-weight:700;border-bottom:2px solid var(--primary)}.success-id-box{background:var(--surface-alt);padding:18px;border-radius:var(--radius-sm);border:1px dashed var(--primary);margin:20px 0}.success-id-text{margin:0;color:var(--primary);letter-spacing:2px;font-family:Space Mono,monospace}.device-id-text{font-size:.8rem;opacity:.7;margin:0 0 12px}.edit-device-form{margin-top:14px}.btn-permanent-delete{margin-bottom:14px}.ts-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;padding:12px 16px}.ts-toolbar-left{display:flex;align-items:center;gap:14px;flex-wrap:wrap;flex:1;min-width:0}.ts-toolbar-right{display:flex;align-items:center;gap:10px;flex-shrink:0;flex-wrap:wrap}.ts-channel-pill{display:inline-flex;align-items:center;white-space:nowrap;flex-shrink:0}.ts-toolbar-group{display:flex;align-items:center;gap:8px;flex-shrink:0}.ts-toolbar-group label{white-space:nowrap;font-size:.85rem}.ts-toolbar-group select{padding:6px 10px;border-radius:6px;border:1.5px solid var(--border-color);background:var(--input-bg);color:var(--text-main);font-family:inherit;font-size:.85rem;cursor:pointer}.ts-toolbar-dates{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.date-field{display:flex;align-items:center;gap:8px}.date-field label{white-space:nowrap;font-size:.85rem}.date-field input[type=date]{padding:6px 12px;border-radius:6px;border:1.5px solid var(--border-color);background:var(--input-bg);color:var(--text-main);font-family:inherit;font-size:.85rem;min-width:130px}@media(max-width:1024px){.ts-toolbar{gap:12px}.ts-toolbar-left{gap:10px}.date-field input[type=date]{min-width:120px}}@media(max-width:768px){.ts-toolbar{flex-direction:column;align-items:stretch;gap:14px;padding:12px}.ts-toolbar-left{flex-direction:column;align-items:stretch;gap:12px;width:100%}.ts-toolbar-right{flex-direction:column;align-items:stretch;width:100%;gap:10px}.ts-channel-pill{width:fit-content}.ts-toolbar-group{justify-content:flex-start}.ts-toolbar-dates{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%}.date-field{flex-direction:column;align-items:flex-start;gap:4px}.date-field input[type=date]{width:100%;min-width:unset;box-sizing:border-box}.ts-toolbar-right button{width:100%;justify-content:center}}@media(max-width:480px){.ts-toolbar{padding:10px;gap:12px}.ts-toolbar-dates{grid-template-columns:1fr;gap:8px}.ts-toolbar-group label,.date-field label{font-size:.8rem}.date-field input[type=date],.ts-toolbar-group select{font-size:.8rem;padding:5px 10px}}.chart-actions{display:flex;align-items:center;gap:8px}.chart-action-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-muted);width:30px;height:30px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;flex:0 0 30px;padding:0;transition:all .2s ease}.chart-action-btn:hover{background:var(--primary-glow);border-color:var(--primary);color:var(--primary);transform:scale(1.1)}.info-modal-content{background:var(--surface-color);border-radius:var(--radius);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);width:min(420px,92vw);display:flex;flex-direction:column;animation:popIn .28s cubic-bezier(.34,1.56,.64,1);overflow:hidden}.info-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border-color);background:var(--surface-color)}.info-modal-header h2{margin:0;font-family:"DM Serif Display",serif;font-size:1.25rem;color:var(--text-main);border:none;padding:0}.info-modal-body{padding:24px}.info-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.info-stat-box{background:var(--bg-deep);border:1px solid var(--border-color);padding:16px;border-radius:var(--radius-sm);text-align:center;transition:transform .2s ease}.info-stat-box:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:0 4px 14px var(--primary-glow)}.info-stat-label{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-bottom:6px}.info-stat-value{font-family:Space Mono,monospace;font-size:1.4rem;color:var(--primary);font-weight:700}.crop-section-divider{display:flex;align-items:center;gap:8px;margin:20px 0 12px;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.crop-section-divider:before,.crop-section-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.form-hint{display:block;font-size:.72rem;font-weight:400;color:var(--text-muted);margin-top:3px;line-height:1.45}.speed-level-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px}.speed-level-btn{flex:unset;width:100%;white-space:normal;overflow:hidden;display:flex;flex-direction:column;align-items:center;gap:3px;padding:12px 8px 10px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);background:var(--surface-alt);color:var(--text-main);cursor:pointer;text-align:center;position:relative;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease,transform .12s ease}.speed-level-btn:after{display:none}.speed-level-btn:hover{border-color:var(--primary);background:var(--primary-glow);transform:translateY(-2px);box-shadow:0 4px 12px var(--primary-glow)}.speed-level-btn.active{border-color:var(--primary);background:var(--primary-glow);box-shadow:0 0 0 2px var(--primary),0 4px 14px var(--primary-glow);transform:translateY(-2px)}.slb-label{font-size:.8rem;font-weight:700;color:var(--text-main);line-height:1.2;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.slb-speed{font-family:Space Mono,monospace;font-size:1.1rem;font-weight:700;color:var(--primary);line-height:1}.speed-level-btn.active .slb-speed{color:var(--primary-light)}.slb-desc{font-size:.63rem;font-weight:400;color:var(--text-muted);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;width:100%;word-break:break-word}[data-theme=dark] .speed-level-btn{background:var(--surface-color);border-color:var(--border-color)}[data-theme=dark] .speed-level-btn:hover,[data-theme=dark] .speed-level-btn.active{background:#0284c71f;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary),0 4px 14px var(--primary-glow)}[data-theme=dark] .speed-level-btn.active .slb-speed{color:var(--primary-light)}@media(max-width:360px){.speed-level-picker{grid-template-columns:1fr}.speed-level-btn{flex-direction:row;justify-content:flex-start;gap:12px;padding:10px 14px;text-align:left}.slb-label{white-space:normal}.slb-desc{-webkit-line-clamp:1}}.active-action-banner{background:linear-gradient(135deg,var(--info-glow),rgba(14,165,233,.05));border:1px solid var(--info);border-radius:var(--radius-sm);padding:16px 20px;margin-bottom:24px;display:flex;align-items:center;justify-content:space-between;gap:16px;animation:popIn .3s ease;box-shadow:0 4px 15px var(--info-glow)}.banner-info{display:flex;align-items:center;gap:14px}.banner-icon{font-size:2rem;animation:pulse 2s ease-in-out infinite}.banner-info strong{display:block;color:var(--info);font-size:1.1rem;margin-bottom:4px}.banner-info p{margin:0;color:var(--text-muted);font-size:.9rem;font-weight:500}.banner-cancel-btn{flex:0 0 auto;padding:10px 18px;display:flex;align-items:center;gap:6px}@media(max-width:480px){.active-action-banner{flex-direction:column;align-items:stretch;text-align:center}.banner-info{flex-direction:column;gap:8px}}
