.overview-dashboard-container{padding:2rem;background-color:transparent;min-height:100vh;color:var(--text-color);font-family:Inter,system-ui,sans-serif}.overview-header{margin-bottom:2.5rem}.overview-header h1{font-size:2.25rem;font-weight:700;margin:0 0 .5rem;background:linear-gradient(to right,var(--color-primary),var(--color-sage));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.overview-subtitle{color:var(--text-color);opacity:.7;font-size:1.1rem;margin:0}.overview-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;color:var(--text-color);opacity:.7}.overview-spinner{width:50px;height:50px;border:4px solid var(--glass-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.overview-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}.summary-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:1rem;padding:1.5rem;display:flex;align-items:center;transition:transform .2s ease,box-shadow .2s ease}.summary-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px -5px #0000004d}.summary-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-right:1.5rem}.summary-card.total .summary-icon{background:rgba(59,130,246,.2);color:#3b82f6}.summary-card.online .summary-icon{background:rgba(16,185,129,.2);color:#10b981}.summary-card.offline .summary-icon{background:rgba(239,68,68,.2);color:#ef4444}.summary-info h3{font-size:.9rem;color:var(--text-color);opacity:.7;margin:0 0 .5rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.summary-value{font-size:2rem;font-weight:700;color:var(--text-color)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem}.project-card{background:var(--glass-bg);border-radius:1rem;border:1px solid var(--glass-border);overflow:hidden;display:flex;flex-direction:column;transition:all .3s ease}.project-card:hover{border-color:var(--color-primary);box-shadow:0 20px 25px -5px #0000004d}.project-card-header{padding:1.5rem;border-bottom:1px solid var(--glass-border);background:linear-gradient(to bottom,var(--hover-bg),transparent)}.project-card-header h2{font-size:1.5rem;font-weight:600;margin:0 0 .5rem;color:var(--text-color)}.project-desc{color:var(--text-color);opacity:.7;font-size:.9rem;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-stats{display:grid;grid-template-columns:repeat(3,1fr);padding:1.5rem;gap:1rem;background:var(--hover-bg)}.stat-item{display:flex;flex-direction:column;align-items:center;background:var(--bg-color);padding:.75rem;border-radius:.5rem}.stat-label{font-size:.75rem;color:var(--text-color);opacity:.7;text-transform:uppercase;margin-bottom:.25rem;letter-spacing:.05em}.stat-number{font-size:1.5rem;font-weight:600;color:var(--text-color)}.online-stat .stat-number{color:#10b981}.offline-stat .stat-number{color:#ef4444}.project-modules-list{padding:1.5rem;flex-grow:1}.project-modules-list h4{font-size:.9rem;color:var(--text-color);margin:0 0 1rem;font-weight:500}.modules-chips{display:flex;flex-direction:column;gap:.75rem}.module-chip{display:flex;flex-direction:column;align-items:flex-start;width:100%;height:auto;background:var(--bg-color);border:1px solid var(--glass-border);color:var(--text-color);padding:.6rem .8rem;border-radius:.8rem;font-size:.85rem;cursor:pointer;transition:all .2s ease;gap:.4rem}.module-chip:hover{background:var(--hover-bg);transform:translateY(-2px)}.module-chip-icon{margin-right:.5rem;opacity:.7}.module-chip-name{margin-right:.5rem}.module-status-dot{width:8px;height:8px;border-radius:50%;margin-left:auto}.module-status-dot.online{background-color:#10b981;box-shadow:0 0 8px #10b98199}.module-status-dot.offline{background-color:#ef4444}.no-modules-msg{color:var(--text-color);opacity:.7;font-size:.9rem;font-style:italic;text-align:center;padding:1rem 0}:root{--bg-gradient: radial-gradient(circle at 50% 0%, #0c1020 0%, #05070e 100%);--bg-color: #05070e;--glass-bg: rgba(13, 19, 38, .65);--glass-border: rgba(255, 255, 255, .05);--glass-border-hover: rgba(16, 185, 129, .2);--color-primary: #10B981;--color-primary-glow: rgba(16, 185, 129, .25);--color-sage: #34D399;--color-sage-glow: rgba(52, 211, 153, .15);--color-soil-gold: #F59E0B;--color-soil-glow: rgba(245, 158, 11, .2);--color-sun: #EAB308;--color-sun-glow: rgba(234, 179, 8, .2);--color-water: #0ea5e9;--color-water-glow: rgba(14, 165, 233, .2);--color-coral: #EF4444;--color-coral-glow: rgba(239, 68, 68, .2);--font-display: "Outfit", "Sarabun", sans-serif;--font-body: "Inter", "Sarabun", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-color);background-image:var(--bg-gradient);color:var(--text-color, #E2E8F0);font-family:var(--font-body);min-height:100vh;overflow-x:hidden;letter-spacing:-.01em}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:rgba(0,0,0,.02)}::-webkit-scrollbar-thumb{background:rgba(16,185,129,.2);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:rgba(16,185,129,.4)}.dashboard-container{max-width:1400px;margin:0 auto;padding:2.5rem 1.5rem}.auth-wrapper{min-height:90vh;display:flex;justify-content:center;align-items:center;padding:1.5rem}.auth-card{width:100%;max-width:460px;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:32px;padding:2.75rem 2.5rem;box-shadow:0 20px 50px #062c190d,0 0 40px #10b98105;transition:all .4s ease;position:relative;overflow:hidden;animation:scaleIn .5s cubic-bezier(.16,1,.3,1)}.auth-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(to right,var(--color-primary),#34D399)}.auth-header{text-align:center;margin-bottom:2rem}.auth-logo-box{width:56px;height:56px;background:linear-gradient(135deg,var(--color-primary) 0%,#059669 100%);border-radius:18px;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;box-shadow:0 4px 15px #10b98133}.auth-title{font-family:var(--font-display);font-size:1.65rem;font-weight:800;color:#064e3b}.auth-subtitle{font-size:.85rem;color:#059669;margin-top:.35rem;font-weight:500}.auth-tabs{display:flex;background:rgba(16,185,129,.06);border-radius:16px;padding:4px;margin-bottom:2rem;border:1px solid rgba(16,185,129,.08)}.auth-tab-btn{flex:1;background:transparent;border:none;color:#047857;font-family:var(--font-display);font-weight:700;font-size:.85rem;padding:.75rem;border-radius:12px;cursor:pointer;transition:all .25s ease;text-align:center}.auth-tab-btn.active{background:#FFFFFF;color:#064e3b;box-shadow:0 4px 12px #062c190a}.auth-form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}.auth-label{font-size:.75rem;font-weight:700;text-transform:uppercase;color:#064e3b;letter-spacing:.05em}.auth-input{width:100%;background:#FFFFFF;border:1px solid rgba(16,185,129,.25);border-radius:14px;padding:.85rem 1.15rem;color:#0f291e;font-size:.9rem;outline:none;transition:all .3s ease;font-family:var(--font-body)}.auth-input:focus{border-color:var(--color-primary);box-shadow:0 0 12px #10b9811f;background:#FFFFFF}.auth-input::placeholder{color:#93c5fd;opacity:.45}.auth-button{width:100%;background:linear-gradient(135deg,var(--color-primary) 0%,#059669 100%);border:none;color:#fff;padding:.95rem;border-radius:14px;font-family:var(--font-display);font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s ease;margin-top:.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 15px #10b98140}.auth-button:hover{transform:translateY(-1px);box-shadow:0 6px 20px #10b98159}.auth-button:active{transform:translateY(0)}.header-wrapper{display:flex;justify-content:space-between;align-items:center;margin-bottom:2.5rem;padding:1.5rem 2rem;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:24px;animation:fadeInDown .8s cubic-bezier(.16,1,.3,1);box-shadow:0 8px 32px #062c1908}.brand-section{display:flex;align-items:center;gap:1rem}.brand-icon-wrapper{width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,var(--color-primary) 0%,#059669 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #10b98133;position:relative;overflow:hidden}.brand-icon-wrapper:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 45%,rgba(255,255,255,.35) 50%,transparent 55%);animation:shine 4s infinite linear}.brand-name{font-family:var(--font-display);font-size:1.75rem;font-weight:800;background:linear-gradient(to right,#064E3B,#059669);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.brand-tag{font-size:.75rem;color:var(--color-primary);text-transform:uppercase;letter-spacing:.15em;font-weight:700}.header-user-section{display:flex;align-items:center;gap:1rem}.user-profile-badge{display:flex;align-items:center;gap:.65rem;background:rgba(16,185,129,.05);border:1px solid rgba(16,185,129,.15);padding:.5rem 1rem;border-radius:16px;font-size:.85rem;color:#064e3b;font-weight:600}.user-avatar{width:24px;height:24px;border-radius:50%;background:rgba(16,185,129,.15);color:#047857;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.logout-btn{background:rgba(239,68,68,.05);border:1px solid rgba(239,68,68,.15);color:#ef4444;padding:.5rem 1rem;border-radius:16px;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .2s;font-family:var(--font-display)}.logout-btn:hover{background:rgba(239,68,68,.12);color:#dc2626;transform:translateY(-1px)}.status-badge{display:flex;align-items:center;gap:.5rem;background:rgba(16,185,129,.05);border:1px solid rgba(16,185,129,.15);padding:.5rem 1.15rem;border-radius:50px;font-size:.8rem;color:var(--color-sage);font-weight:700;transition:all .3s ease;animation:breathe 4s infinite ease-in-out}.status-badge.disconnected{background:rgba(239,68,68,.05);border:1px solid rgba(239,68,68,.15);color:var(--color-coral);animation:none}.ping-indicator{width:8px;height:8px;border-radius:50%;background:var(--color-primary);box-shadow:0 0 10px #10b98166;animation:pulse 1.8s infinite ease-in-out}.ping-indicator.disconnected{background:var(--color-coral);box-shadow:0 0 10px var(--color-coral-glow)}.main-grid{display:grid;grid-template-columns:2fr 1fr;gap:2rem;animation:fadeInUp .8s cubic-bezier(.16,1,.3,1)}@media (max-width: 1024px){.main-grid{grid-template-columns:1fr}}.glass-card{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:28px;padding:2rem;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;box-shadow:0 12px 40px #00000040}.glass-card:hover{border-color:var(--glass-border-hover);box-shadow:0 20px 50px #10b98126;transform:translateY(-2px)}.glass-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:transparent;transition:background .4s ease}.glass-card.primary-edge:before{background:linear-gradient(to right,var(--color-primary),#34D399)}.glass-card.blue-edge:before{background:linear-gradient(to right,var(--color-water),#38BDF8)}.card-title-wrapper{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.75rem}.card-title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:#fff;display:flex;align-items:center;gap:.5rem}.sensors-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.25rem;margin-bottom:2rem}.sensor-card{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);border-radius:22px;padding:1.5rem 1.25rem;text-align:center;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.75rem;box-shadow:0 4px 15px #0000001a}.sensor-card:hover{background:rgba(255,255,255,.04);transform:translateY(-4px);box-shadow:0 8px 25px #10b98126}.sensor-card.ph:hover{border-color:#10b98159}.sensor-card.ec:hover{border-color:#0ea5e959}.sensor-card.temp:hover{border-color:#eab30859}.sensor-card.humid:hover{border-color:#10b98159}.sensor-icon-wrapper{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:.25rem}.sensor-card.ph{background:rgba(16,185,129,.035)}.sensor-card.ph .sensor-icon-wrapper{background:rgba(16,185,129,.1);color:var(--color-primary)}.sensor-card.ec{background:rgba(2,132,199,.035)}.sensor-card.ec .sensor-icon-wrapper{background:rgba(2,132,199,.1);color:var(--color-water)}.sensor-card.temp{background:rgba(217,119,6,.035)}.sensor-card.temp .sensor-icon-wrapper{background:rgba(217,119,6,.1);color:var(--color-soil-gold)}.sensor-card.humid{background:rgba(34,197,94,.035)}.sensor-card.humid .sensor-icon-wrapper{background:rgba(34,197,94,.1);color:#10b981}.sensor-label{font-size:.75rem;color:#9ca3af;text-transform:uppercase;letter-spacing:.03em;font-weight:700}.sensor-value{font-family:var(--font-display);font-size:1.85rem;font-weight:800;color:#fff}.sensor-unit{font-size:.85rem;color:var(--color-primary);font-weight:600;margin-left:.15rem}.sensor-status{font-size:.72rem;padding:.25rem .65rem;border-radius:50px;font-weight:700;text-transform:uppercase;letter-spacing:.02em}.status-good{background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.3);color:#34d399}.status-warning{background:rgba(217,119,6,.12);border:1px solid rgba(217,119,6,.3);color:#f59e0b}.status-danger{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.3);color:#ef4444}.controls-list{display:flex;flex-direction:column;gap:1rem}.control-item{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);border-radius:22px;padding:1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:center;transition:all .3s ease;box-shadow:0 4px 15px #0000001a}.control-item:hover{background:rgba(255,255,255,.04);box-shadow:0 8px 20px #10b9811a}.control-item.active{border-color:#10b98140;box-shadow:0 4px 20px #10b98114;background:rgba(16,185,129,.03)}.control-info{display:flex;align-items:center;gap:1rem}.control-icon-box{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.04);color:#9ca3af;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.control-item.active .control-icon-box{background:rgba(16,185,129,.15);color:var(--color-primary);box-shadow:0 0 10px #10b98133}.control-item.active.light-relay .control-icon-box{background:rgba(234,179,8,.15);color:#d97706;box-shadow:0 0 10px #eab30833}.control-name{font-family:var(--font-display);font-weight:600;font-size:1rem;color:#fff}.control-meta{font-size:.75rem;color:#9ca3af;font-weight:500}.control-actions{display:flex;align-items:center;gap:1rem}.mode-toggle-btn{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:#9ca3af;padding:.35rem .75rem;border-radius:10px;font-size:.72rem;font-weight:700;cursor:pointer;transition:all .2s;text-transform:uppercase}.mode-toggle-btn.auto{background:rgba(16,185,129,.15);border-color:var(--color-primary);color:#fff}.mode-toggle-btn:hover{background:rgba(255,255,255,.08);color:#fff}.switch-container{position:relative;display:inline-block;width:50px;height:26px}.switch-container input{opacity:0;width:0;height:0}.switch-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#0000000d;border:1px solid rgba(16,185,129,.1);transition:.3s cubic-bezier(.16,1,.3,1);border-radius:34px}.switch-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#a7f3d0;transition:.3s cubic-bezier(.16,1,.3,1);border-radius:50%}input:checked+.switch-slider{background-color:#10b98126;border-color:#10b9814d}input:checked+.switch-slider:before{transform:translate(24px);background-color:var(--color-primary);box-shadow:0 2px 8px #10b9814d}.light-relay input:checked+.switch-slider{background-color:#eab30826;border-color:#eab3084d}.light-relay input:checked+.switch-slider:before{background-color:var(--color-sun);box-shadow:0 2px 8px #eab3084d}.chart-container{height:280px;display:flex;flex-direction:column;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.chart-bars-wrapper{display:flex;justify-content:space-between;align-items:flex-end;height:200px;border-bottom:1px solid rgba(16,185,129,.15);padding-bottom:.5rem;position:relative}.chart-bar-item{display:flex;flex-direction:column;align-items:center;flex-grow:1;max-width:30px}.bar-column{width:12px;background:linear-gradient(to top,rgba(16,185,129,.1),rgba(16,185,129,.85));border-radius:6px 6px 0 0;transition:height .6s cubic-bezier(.16,1,.3,1);position:relative}.bar-column.ec{background:linear-gradient(to top,rgba(2,132,199,.1),rgba(2,132,199,.85))}.bar-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-5px);background:#FFFFFF;color:#064e3b;font-size:.7rem;font-weight:700;padding:.25rem .5rem;border-radius:6px;opacity:0;transition:opacity .2s;pointer-events:none;white-space:nowrap;border:1px solid rgba(16,185,129,.25);box-shadow:0 4px 15px #062c190f}.chart-bar-item:hover .bar-column{filter:brightness(1.1)}.chart-bar-item:hover .bar-tooltip{opacity:1}.chart-label{font-size:.65rem;color:#047857;font-weight:600;margin-top:.5rem;text-transform:uppercase}.chart-legend{display:flex;gap:1.5rem;font-size:.8rem;color:#047857;font-weight:600}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-color{width:12px;height:12px;border-radius:3px}.simulator-panel{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.input-range-group{display:flex;flex-direction:column;gap:.5rem}.range-label-row{display:flex;justify-content:space-between;font-size:.8rem;color:#064e3b;font-weight:700}.slider-input{-webkit-appearance:none;width:100%;height:6px;border-radius:3px;background:rgba(16,185,129,.12);outline:none;transition:background .3s}.slider-input::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;box-shadow:0 2px 6px #10b9814d;transition:transform .1s}.slider-input::-webkit-slider-thumb:hover{transform:scale(1.2)}.action-btn{background:linear-gradient(135deg,var(--color-primary) 0%,#059669 100%);border:none;color:#fff;padding:.85rem 1.5rem;border-radius:14px;font-family:var(--font-display);font-weight:700;font-size:.95rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 15px #10b98140}.action-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98159}.action-btn:active{transform:translateY(0)}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes shine{0%{left:-50%}to{left:125%}}@keyframes pulse{0%{transform:scale(.95);opacity:.8}50%{transform:scale(1.1);opacity:1}to{transform:scale(.95);opacity:.8}}@keyframes breathe{0%{box-shadow:0 0 10px #10b9810d}50%{box-shadow:0 0 20px #10b98126}to{box-shadow:0 0 10px #10b9810d}}.chart-dot-group .chart-svg-tooltip{opacity:0;transition:opacity .25s cubic-bezier(.16,1,.3,1)}.chart-dot-group:hover .chart-svg-tooltip{opacity:1}.chart-dot-group circle{transition:r .2s ease,stroke-width .2s ease}.chart-dot-group:hover circle:first-child{r:7px;stroke-width:4.5px}select option{background-color:#0f172a;color:#fff;font-weight:500}
