.dashboard-container{padding:15px;background:#f0f2f5;min-height:100vh;box-sizing:border-box;position:relative;overflow:hidden}.fun-elements{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.rainbow{position:absolute;font-size:60px;animation:floatRainbow 2s ease-in-out infinite}.rainbow.rainbow1{top:5%;left:5%;animation-delay:0s}.rainbow.rainbow2{top:15%;right:10%;animation-delay:2s}.cloud{position:absolute;font-size:40px;animation:floatCloud 4s ease-in-out infinite}.cloud.cloud1{top:25%;left:15%;animation-delay:.3s}.cloud.cloud2{top:35%;right:20%;animation-delay:2s}.sun{font-size:50px;top:10%;right:5%;animation:rotateSun 5s linear infinite}.flower,.sun{position:absolute}.flower{font-size:30px;animation:swayFlower 2s ease-in-out infinite}.flower.flower1{bottom:20%;left:10%;animation-delay:.3s}.flower.flower2{bottom:30%;right:15%;animation-delay:1s}.flower.flower3{bottom:25%;left:50%;animation-delay:2s}.butterfly{position:absolute;font-size:25px;animation:flutterButterfly 4s ease-in-out infinite}.butterfly.butterfly1{top:40%;left:20%;animation-delay:0s}.butterfly.butterfly2{top:50%;right:25%;animation-delay:6s}@keyframes floatRainbow{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-40px) rotate(10deg)}}@keyframes floatCloud{0%,to{transform:translateX(0) scale(1)}50%{transform:translateX(30px) scale(1.1)}}@keyframes rotateSun{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes swayFlower{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}@keyframes flutterButterfly{0%,to{transform:translateY(0) translateX(0) rotate(0deg)}25%{transform:translateY(-20px) translateX(10px) rotate(10deg)}50%{transform:translateY(-10px) translateX(-10px) rotate(-10deg)}75%{transform:translateY(-30px) translateX(5px) rotate(5deg)}}.mt-20{margin-top:8px}.grid-content{max-height:350px;overflow:auto}.grid-content,.left-grid-content{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08);padding:15px;transition:all .3s ease}.grid-content:hover,.left-grid-content:hover{box-shadow:0 4px 16px rgba(0,0,0,.12)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.dashboard-header h1{color:#2c3e50;font-size:1.4em;font-weight:600;margin:0}.header-right-section{display:flex;align-items:center;gap:15px}.plant-status{display:flex;gap:10px;align-items:center}.user-menu-wrapper{position:relative}.user-menu-trigger{width:36px;height:36px;border-radius:50%;background:#f0f2f5;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:#606266;font-size:18px}.user-menu-trigger:hover{background:#e4e7ed;color:#409eff}.user-menu-dropdown{position:absolute;top:45px;right:0;min-width:160px;background:#fff;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.15);padding:8px 0;z-index:1000;overflow:hidden}.user-info{padding:10px 16px;display:flex;align-items:center;gap:8px;color:#606266;font-size:14px}.user-info i{font-size:16px;color:#909399}.menu-divider{height:1px;background:#e4e7ed;margin:4px 0}.menu-item{padding:10px 16px;display:flex;align-items:center;gap:8px;cursor:pointer;transition:background-color .3s;color:#606266;font-size:14px}.menu-item:hover{background:#f5f7fa}.logout-item{color:#f56c6c}.logout-item:hover{background:#fef0f0;color:#f56c6c}.logout-item i{font-size:16px}.user-menu-fade-enter-active,.user-menu-fade-leave-active{transition:opacity .2s,transform .2s}.user-menu-fade-enter,.user-menu-fade-leave-to{opacity:0;transform:translateY(-10px)}.status-badge{color:#fff;padding:5px 12px;border-radius:18px;font-size:.9em;font-weight:500}.status-badge,.status-badge.ok{background:#4caf50}.status-badge.error{background:#f44336}.device-alert{margin:8px 0 0 0;padding:8px 12px;background:#fff3cd;border:1px solid #ffeaa7;color:#8a6d3b;border-radius:6px;display:flex;align-items:center;gap:6px}.status-time{color:#7f8c8d;font-size:.9em}.status-time.clickable{cursor:pointer;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.status-time-wrap{position:relative;display:inline-block}.inline-edit{display:inline-flex;align-items:center;gap:6px}.inline-edit .name-input,.inline-edit .password-input{width:160px;height:26px;line-height:26px;border:1px solid #dcdfe6;border-radius:4px;padding:0 8px;outline:none}.inline-edit .password-input:focus{border-color:#409eff}.inline-edit .confirm-btn{padding:4px 8px}.inline-name-editor .name-input{width:100%;height:28px;line-height:28px;border:1px solid #dcdfe6;border-radius:4px;padding:0 8px;outline:none}.inline-name-editor .name-input:focus{border-color:#409eff}.inline-name-editor .actions{margin-top:6px;display:flex;justify-content:flex-end;gap:6px}.section-container{background:#f8f9fa;border-radius:11px;padding:12px;margin-bottom:12px}.section-container:last-child{margin-bottom:0}.section-title{display:flex;align-items:center;gap:6px;margin-bottom:12px;color:#2c3e50;font-weight:600;font-size:.95em}.section-title i{font-size:1.1em;color:#2196f3}.status-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}.status-item{background:#fff;border-radius:10px;padding:12px;display:flex;align-items:center;gap:10px;transition:all .3s ease;box-shadow:0 1px 3px rgba(0,0,0,.05);min-width:180px;max-width:250px;margin:0 auto}.status-item:hover{transform:translateY(-2px);box-shadow:0 2px 6px rgba(0,0,0,.1)}.status-icon{width:36px;height:36px;background:#e3f2fd;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.status-icon i{font-size:19px;color:#2196f3}.status-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.status-label{color:#7f8c8d;font-size:.85em}.status-label,.status-value{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-value{color:#2c3e50;font-size:1.05em;font-weight:600}.water-level{padding:8px 0}.water-bar{height:18px;background:#e0e0e0}.water-bar,.water-fill{border-radius:9px;overflow:hidden}.water-fill{height:100%;background:linear-gradient(90deg,#2196f3,#1976d2);width:60%;position:relative}.water-fill:after,.water-fill:before{content:"";position:absolute;width:200%;height:200%;background:hsla(0,0%,100%,.3);border-radius:45%;top:-100%;left:-50%;animation:wave 3s linear infinite}.water-fill:after{animation-delay:1.5s;opacity:.5}.fan-container{margin-left:auto}.fan{width:26px;height:26px;position:relative}.fan-blade{background:#2196f3;animation:rotate 2s linear infinite}.fan-blade,.fan-blade:after,.fan-blade:before{position:absolute;width:100%;height:100%;border-radius:50%}.fan-blade:after,.fan-blade:before{content:"";background:#1976d2}.fan-blade:before{transform:rotate(120deg)}.fan-blade:after{transform:rotate(240deg)}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.panel-header h2{color:#2c3e50;font-size:1.2em;margin:0}.overview-content{display:grid;grid-template-columns:320px 1fr;gap:16px;align-items:stretch}.tank-area{display:flex;flex-direction:column;align-items:center;gap:8px}.tank-meta{color:#2c3e50;font-weight:600}.tank{position:relative;width:100%;max-width:300px;height:220px;border-radius:14px 14px 10px 10px;background:linear-gradient(180deg,hsla(0,0%,100%,.9),hsla(0,0%,94.1%,.9));box-shadow:inset 0 0 0 2px rgba(0,0,0,.06),inset 0 8px 16px rgba(0,0,0,.05);overflow:hidden}.tank-glass{position:absolute;inset:0;pointer-events:none;background:linear-gradient(110deg,hsla(0,0%,100%,.55),hsla(0,0%,100%,.15) 30%,hsla(0,0%,100%,0) 60%)}.tank-water{bottom:0;width:100%;background:linear-gradient(180deg,#6ec5ff,#3ea8ff 50%,#1f8ef3);transition:height .6s ease;overflow:hidden;z-index:1}.tank-water,.water-wave{position:absolute;left:0}.water-wave{top:-8px;width:200%;height:16px;background:radial-gradient(circle at 10px 8px,hsla(0,0%,100%,.8) 8px,hsla(0,0%,100%,0) 9px) repeat-x;background-size:20px 16px;opacity:.55;animation:waveSlide 6s linear infinite}.water-wave.second{top:-4px;opacity:.35;animation-duration:9s}.tank-led{top:10px;width:16px;height:16px;border-radius:50%;box-shadow:0 0 0 2px rgba(0,0,0,.06),0 0 12px rgba(255,213,79,.7)}.tank-led,.tank-led-top{position:absolute;right:10px}.tank-led-top{top:6px;left:10px;height:8px;border-radius:6px;background:#9e9e9e;opacity:.6;box-shadow:inset 0 0 0 1px rgba(0,0,0,.06)}.tank-led-top.active{opacity:1;box-shadow:0 0 10px rgba(255,213,79,.8)}.led-beam{top:14px;left:10px;right:10px;bottom:0;pointer-events:none;background:linear-gradient(180deg,rgba(255,235,59,.28),rgba(255,235,59,.06) 40%,transparent 70%);filter:blur(.5px)}.device,.led-beam{position:absolute}.device.fault:after,.small-item b.fault:after,.tank-led-top.fault:after{content:"";position:absolute;right:-4px;top:-4px;width:8px;height:8px;background:#f44336;border-radius:50%;box-shadow:0 0 0 2px hsla(0,0%,100%,.9)}.small-item b.fault{color:#f44336}.device.fault{filter:drop-shadow(0 0 4px rgba(244,67,54,.6))}.tank-led-top.fault{box-shadow:0 0 10px rgba(244,67,54,.9)}.device.buzzer{top:18px;right:16px;width:16px;height:16px}.device.buzzer .sound-wave{position:absolute;top:50%;left:50%;width:4px;height:4px;border-radius:50%;background:#9e9e9e;transform:translate(-50%,-50%);opacity:.5}.device.buzzer.active .sound-wave{animation:ping 1.8s infinite;background:#2196f3}.device.buzzer .sound-wave.second{animation-delay:.9s}@keyframes ping{0%{box-shadow:0 0 0 0 rgba(33,150,243,.6);opacity:1}70%{box-shadow:0 0 0 12px rgba(33,150,243,0);opacity:.4}to{box-shadow:0 0 0 0 rgba(33,150,243,0);opacity:.2}}.device.fan{top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px}.device.fan .fan-blade{position:absolute;inset:0;background:#90caf9;border-radius:50%}.device.fan .icon-fan{width:48px;height:48px}.device.fan.active .blades{transform-origin:50% 50%;animation:rotate var(--fan-rotation,.9s) linear infinite}.device.ultra{top:35%;left:50%;transform:translateX(-50%)}.device.ultra .mist{display:block;width:36px;height:18px;background:radial-gradient(circle,hsla(0,0%,100%,.9),hsla(0,0%,100%,0));border-radius:50%;opacity:0}.device.ultra.active .mist{animation:mistFloat 2.2s ease-in-out infinite}.device.ultra.active .mist-dots circle{animation:mistRise 2.4s ease-in-out infinite}.device.ultra.active .mist-dots circle:nth-child(2){animation-delay:.2s}.device.ultra.active .mist-dots circle:nth-child(3){animation-delay:.4s}.device.ultra.active .mist-dots circle:nth-child(4){animation-delay:.6s}.device.ultra.active .mist-dots circle:nth-child(5){animation-delay:.8s}@keyframes mistRise{0%{transform:translateY(0);opacity:0}20%{opacity:.6}60%{transform:translateY(-10px);opacity:.9}to{transform:translateY(-18px);opacity:0}}@keyframes mistFloat{0%{transform:translate(-50%) scale(.9);opacity:0}20%{opacity:.5}50%{transform:translate(-50%,-14px) scale(1);opacity:.8}to{transform:translate(-50%,-26px) scale(1.05);opacity:0}}.device.pump{bottom:10px;left:50%;transform:translateX(-50%);z-index:2}.device.pump .pump-body{display:inline-block;width:26px;height:12px;background:#90caf9;border-radius:6px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.06)}.device.pump .pump-bubbles{position:absolute;bottom:12px;left:50%;width:6px;height:6px;border-radius:50%;background:hsla(0,0%,100%,.9);transform:translateX(-50%);opacity:0}.bubble-field{position:absolute;bottom:0;left:0;right:0;height:100%;pointer-events:none}.bubble-field .bubble{position:absolute;bottom:6px;width:6px;height:6px;border-radius:50%;background:hsla(0,0%,100%,.95);opacity:0;animation:bubblesRise var(--bubble-speed,2s) linear infinite}.bubble-field .bubble.delay1{animation-delay:.3s}.bubble-field .bubble.delay2{animation-delay:.6s}.bubble-field .bubble.delay3{animation-delay:.9s}.bubble-field .bubble.delay4{animation-delay:1.2s}@keyframes bubblesRise{0%{transform:translateY(0) scale(.9);opacity:0}15%{opacity:.6}60%{transform:translateY(-40%);opacity:.95}to{transform:translateY(-75%);opacity:0}}.level-sensor{position:absolute;top:14px;bottom:10px;left:8px;width:10px;display:flex;align-items:flex-end;z-index:2}.level-sensor .sensor-track{position:absolute;top:0;bottom:0;left:4px;width:2px;background:linear-gradient(180deg,#cfd8dc,#b0bec5);border-radius:2px}.level-sensor .sensor-indicator{position:absolute;left:1px;width:8px;height:8px;border-radius:50%;background:#ff7043;box-shadow:0 0 0 2px rgba(0,0,0,.05);transform:translateY(50%)}.level-sensor .sensor-value{position:absolute;left:18px;transform:translateY(50%);padding:2px 6px;font-size:11px;color:#1f4e79;background:hsla(0,0%,100%,.75);border:1px solid #d1e3f3;border-radius:6px;box-shadow:0 1px 2px rgba(0,0,0,.04)}.level-sensor .sensor-tick{position:absolute;left:0;display:flex;align-items:center;transform:translateY(50%)}.level-sensor .sensor-tick .tick-line{display:inline-block;width:8px;height:1px;background:#b0bec5;margin-left:6px;opacity:.8}.level-sensor .sensor-tick .tick-line.major{width:10px;height:2px;background:#90a4ae}.level-sensor .sensor-tick .tick-label{display:inline-block;margin-left:6px;font-size:10px;color:#607d8b;background:hsla(0,0%,100%,.6);border-radius:3px;padding:1px 3px}.level-sensor .sensor-tick .tick-label.major{font-weight:700;color:#455a64}@keyframes bubbles{0%{transform:translate(-50%) scale(.9);opacity:0}30%{opacity:.8}60%{transform:translate(-50%,-26px) scale(1);opacity:.9}to{transform:translate(-50%,-46px) scale(1.1);opacity:0}}.device.buzzer .icon-buzzer{width:28px;height:28px}.device.buzzer.active .buzzer-arcs{opacity:1;animation:arcPulse 1.8s ease-out infinite}@keyframes arcPulse{0%{opacity:0}20%{opacity:.7}to{opacity:.1}}@keyframes waveSlide{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.readings-area{display:flex;flex-direction:column;gap:20px}.device-section,.sensor-section{display:flex;flex-direction:column;gap:12px}.group-title{font-weight:700;color:#2c3e50;font-size:16px;margin-bottom:8px;padding-bottom:8px;border-bottom:2px solid #e3f2fd}.big-metrics{display:grid;grid-template-columns:repeat(2,minmax(120px,1fr));gap:12px}@media (min-width:1400px){.big-metrics{grid-template-columns:repeat(4,minmax(120px,1fr))}}.metric{background:#fff;border-radius:10px;border:1px solid #eef2f6;padding:12px;box-shadow:0 1px 3px rgba(0,0,0,.03)}.metric .label{color:#7f8c8d;font-size:12px;margin-bottom:4px}.metric .value{color:#2c3e50;font-size:22px;font-weight:700}.small-metrics{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}.small-item{background:#fff;border-radius:10px;padding:10px;display:grid;grid-template-columns:20px 1fr auto;align-items:center;gap:6px;border:1px solid #eef2f6}.small-item i{color:#2196f3}.small-item span{color:#7f8c8d;font-size:12px}.small-item b{color:#2c3e50;font-size:13px}.task-list{display:flex;flex-direction:column;gap:8px}.task-item{background:#f8f9fa;border-radius:8px;padding:10px;display:flex;justify-content:space-between;align-items:center;transition:all .3s ease}.task-item:hover{background:#f0f2f5}.task-content{display:flex;align-items:center;gap:6px}.task-content i{color:#4caf50}.task-link{color:#2196f3;text-decoration:none;font-weight:500;padding:4px 8px;border-radius:4px;transition:all .3s ease}.task-link:hover{background:rgba(33,150,243,.1)}.record-list{display:flex;flex-direction:column;gap:8px}.record-item{background:#f8f9fa;border-radius:8px;padding:10px;display:flex;align-items:center;gap:6px;cursor:pointer;transition:all .3s ease}.record-item:hover{background:#f0f2f5}.record-item i{color:#2196f3}.el-button{border-radius:6px;padding:6px 12px;font-weight:500;display:flex;align-items:center;gap:4px;font-size:13px}.el-button--primary{background:#2196f3;border-color:#2196f3}.el-button--primary:hover{background:#1976d2;border-color:#1976d2}.el-steps{margin:15px 0}.el-step__title{font-size:13px;font-weight:500;color:#2c3e50}.el-step__description{font-size:11px;color:#7f8c8d}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes wave{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:1200px){.dashboard-container{padding:10px}.grid-content{padding:12px}.overview-content{grid-template-columns:1fr}.big-metrics{grid-template-columns:repeat(2,minmax(120px,1fr))}}.section-container:nth-child(2) .status-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.section-container:nth-child(3) .water-level{max-width:400px;margin:0 auto}.crop-select-dialog{border-radius:16px;overflow:hidden}.crop-select-dialog .el-dialog__header{padding:20px;background:#f8f9fa;border-bottom:1px solid #e9ecef}.crop-select-dialog .el-dialog__title{font-size:1.4em;color:#2c3e50;font-weight:600}.crop-select-dialog .el-dialog__body{padding:0}.crop-select-container{padding:20px}.crop-select-header{text-align:center;margin-bottom:20px}.crop-select-header h3{color:#2c3e50;font-size:1.2em;margin:0 0 10px 0}.selected-crop{color:#7f8c8d;font-size:.95em}.selected-crop span{color:#2196f3;font-weight:600}.crop-card{height:100%;background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;padding:20px}.crop-card:hover{transform:translateY(-5px);box-shadow:0 4px 16px rgba(0,0,0,.12)}.crop-image{width:80px;height:80px;background:#e3f2fd;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:15px}.crop-image i{font-size:40px;color:#2196f3}.crop-info{text-align:center}.crop-info h4{color:#2c3e50;font-size:1.2em;margin:0 0 8px 0}.crop-desc{color:#7f8c8d;font-size:.9em;margin:0}.dialog-footer{text-align:center;padding:20px;background:#f8f9fa;border-top:1px solid #e9ecef;position:relative}.button-group{display:flex;justify-content:center;gap:16px;max-width:400px;margin:0 auto}.dialog-footer .el-button{min-width:140px;height:40px;font-size:14px;border-radius:20px;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .3s ease}.dialog-footer .el-button i{font-size:16px}.dialog-footer .cancel-btn{background:#f8f9fa;border:1px solid #dcdfe6;color:#606266}.dialog-footer .cancel-btn:hover{background:#f0f2f5;border-color:#c0c4cc;color:#303133}.dialog-footer .confirm-btn{background:#2196f3;border-color:#2196f3;color:#fff}.dialog-footer .confirm-btn:hover:not(:disabled){background:#1976d2;border-color:#1976d2;transform:translateY(-1px);box-shadow:0 2px 8px rgba(33,150,243,.3)}.dialog-footer .confirm-btn:disabled{background:#a0cfff;border-color:#a0cfff;color:#fff;cursor:not-allowed}.el-carousel__arrow{background-color:rgba(33,150,243,.8);border-radius:50%;width:36px;height:36px}.el-carousel__arrow:hover{background-color:#2196f3}.el-carousel__indicators{bottom:-20px}.el-carousel__indicator--active button{background-color:#2196f3}.el-carousel__item{padding:10px}