.login-container{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-box{background:#fff;border-radius:12px;width:100%;max-width:400px;padding:40px;box-shadow:0 10px 40px #0000001a}.login-header{text-align:center;margin-bottom:30px}.login-header h1{color:#333;margin-bottom:8px;font-size:32px}.login-header p{color:#666;font-size:14px}.login-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:#333;font-size:14px;font-weight:600}.form-group input{border:2px solid #e0e0e0;border-radius:8px;padding:12px 16px;font-size:15px;transition:border-color .2s}.form-group input:focus{border-color:#667eea;outline:none}.btn-primary{color:#fff;cursor:pointer;background:#4caf50;border:none;border-radius:8px;padding:14px;font-size:16px;font-weight:600;transition:background .2s}.btn-primary:hover{background:#45a049}.btn-primary:disabled{cursor:not-allowed;background:#ccc}.error-message{color:#c62828;text-align:center;background:#ffebee;border-radius:6px;padding:12px;font-size:14px}.sidebar{background:#fff;border-right:1px solid #e5e5ea;flex-direction:column;gap:0;width:240px;min-height:100%;padding:32px 20px;display:flex;position:relative}.sidebar-header{color:#1d1d1f;align-items:center;gap:8px;margin-bottom:32px;font-size:15px;font-weight:600;display:flex}.sidebar-section{margin-bottom:24px}.sidebar-section-label{color:#a1a1a6;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding:0 12px;font-size:11px;font-weight:600}.sidebar-nav{flex-direction:column;gap:2px;display:flex}.nav-item{color:#6e6e73;border-radius:8px;align-items:center;gap:10px;padding:8px 12px;font-size:14px;font-weight:400;text-decoration:none;transition:background .15s;display:flex}.nav-item:hover{background:#0000000a}.nav-item svg{flex-shrink:0}.sidebar-footer{color:#a1a1a6;background:0 0;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;transition:all .15s;display:flex;position:absolute;bottom:32px;left:20px}.sidebar-footer:hover{color:#6e6e73;background:#0000000a}.top-bar{justify-content:space-between;align-items:center;height:64px;margin-bottom:24px;display:flex}.search-input-container{width:320px;position:relative}.search-icon{color:var(--text-tertiary);pointer-events:none;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.search-input{border:1px solid var(--border-light);width:100%;height:44px;color:var(--text-primary);background:#fff;border-radius:999px;outline:none;padding:0 16px 0 44px;font-size:14px;transition:all .15s}.search-input:focus{border-color:var(--green-primary);box-shadow:0 0 0 3px #34c7591a}.search-input::placeholder{color:var(--text-tertiary)}.top-bar-actions{align-items:center;gap:12px;display:flex}.icon-button{border:1px solid var(--border-light);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:#fff;border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:flex}.icon-button:hover{background:#0000000a;transform:translateY(-1px)}.btn-primary{background:var(--green-primary);color:#fff;cursor:pointer;border:none;border-radius:999px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .15s;display:flex;box-shadow:0 2px 8px #34c75940}.btn-primary:hover{background:#2fb350;transform:translateY(-1px);box-shadow:0 4px 12px #34c7594d}.btn-primary:active{transform:translateY(0)}.kpi-stripe{gap:40px;margin-bottom:24px;padding:0;display:flex}.kpi-module{align-items:flex-start;gap:12px;display:flex}.kpi-icon-badge{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex}.kpi-content{flex-direction:column;gap:4px;display:flex}.kpi-label{color:var(--text-secondary);font-size:12px;font-weight:500;line-height:1}.kpi-value-row{align-items:baseline;gap:6px;display:flex}.kpi-value{color:var(--text-primary);font-size:32px;font-weight:700;line-height:1}.kpi-trend{font-size:14px;font-weight:600;line-height:1}.kpi-subtext{color:var(--text-tertiary);margin-top:2px;font-size:11px}.sensor-table-container{box-shadow:var(--shadow-soft);background:#fff;border-radius:16px;overflow:hidden}.sensor-table{border-collapse:collapse;width:100%}.sensor-table thead{border-bottom:1px solid var(--border-light);background:0 0}.sensor-table th{text-align:left;color:var(--text-secondary);white-space:nowrap;padding:14px 16px;font-size:12px;font-weight:600;position:relative}.sort-indicator{color:var(--text-tertiary);vertical-align:middle;opacity:.5;margin-left:4px}.sort-indicator.active{color:var(--text-primary);opacity:1}.sensor-table tbody tr{border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .15s}.sensor-table tbody tr:hover{background:#00000005}.sensor-table tbody tr:last-child{border-bottom:none}.sensor-row.highlighted{border-left:3px solid var(--green-primary);background:#34c7590a}.sensor-row.highlighted:hover{background:#34c7590f}.sensor-table td{color:var(--text-primary);padding:16px;font-size:14px}.sensor-table td strong{font-weight:600}.status-badge{font-size:13px;font-weight:500}.moisture-cell{align-items:center;gap:6px;display:flex}.moisture-value{font-weight:600}.moisture-trend{font-size:16px;font-weight:600;line-height:1}.comments-cell,.chevron-icon{color:var(--text-tertiary)}.chart-card{box-shadow:var(--shadow-soft);background:#fff;border-radius:16px;flex-direction:column;padding:24px;display:flex}.chart-header{margin-bottom:20px}.chart-header h3{color:var(--text-primary);font-size:16px;font-weight:600;line-height:1.4}.segmented-control{background:#f5f5f7;border-radius:8px;align-self:flex-start;margin-top:16px;padding:2px;display:inline-flex}.segment-button{color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:6px 16px;font-size:13px;font-weight:500;transition:all .15s}.segment-button:hover{color:var(--text-primary)}.segment-button.active{color:var(--text-primary);background:#fff;font-weight:600;box-shadow:0 1px 3px #0000001a}.map-card{box-shadow:var(--shadow-soft);background:#fff;border-radius:16px;padding:24px}.map-header{margin-bottom:16px}.map-header h3{color:var(--text-primary);font-size:16px;font-weight:600}.map-placeholder{background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);border-radius:12px;justify-content:center;align-items:center;height:300px;display:flex;position:relative;overflow:hidden}.map-grid{pointer-events:none;background-image:linear-gradient(#c8c8c826 1px,#0000 1px),linear-gradient(90deg,#c8c8c826 1px,#0000 1px);background-size:20px 20px;position:absolute;inset:0}.map-marker{z-index:3;filter:drop-shadow(0 4px 8px #ff3b304d);animation:2s ease-in-out infinite bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.map-info-badge{z-index:2;text-align:center;background:#fff;border-radius:8px;padding:12px 20px;position:absolute;bottom:20px;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0000001a}.map-location{color:var(--text-primary);margin-bottom:4px;font-size:14px;font-weight:600}.map-coords{color:var(--text-tertiary);font-size:11px}.map-zoom-button{border:1px solid var(--border-light);cursor:pointer;z-index:4;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:all .15s;display:flex;position:absolute;bottom:16px;right:16px;box-shadow:0 2px 8px #0000001a}.map-zoom-button:hover{background:#f8f9fa;transform:scale(1.05);box-shadow:0 4px 12px #00000026}.map-zoom-button:active{transform:scale(.95)}.dashboard-wrapper{background:#0a0a0a;justify-content:center;align-items:center;width:100vw;min-height:100vh;margin:0;padding:0;display:flex}.dashboard-panel{box-shadow:none;background:#f6f7f9;border-radius:0;width:100vw;max-width:100vw;height:100vh;margin:0;display:flex;overflow:hidden}.dashboard-main{background:#f6f7f9;flex-direction:column;flex:1;gap:24px;padding:32px 40px;display:flex;overflow-y:auto}.charts-grid{grid-template-columns:1fr 1fr;gap:24px;margin-top:8px;display:grid}@media (max-width:1200px){.charts-grid{grid-template-columns:1fr}}.loading-container{color:#fff;background:#0a0a0a;flex-direction:column;justify-content:center;align-items:center;gap:20px;height:100vh;display:flex}.spinner{border:4px solid #ffffff1a;border-top-color:#34c759;border-radius:50%;width:48px;height:48px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}html,body,#root{width:100%;height:100%;margin:0;padding:0;overflow:hidden}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#1d1d1f;background:#0a0a0a;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif}:root{--bg-dark:#0a0a0a;--bg-light:#f6f7f9;--card-bg:#fff;--text-primary:#1d1d1f;--text-secondary:#6e6e73;--text-tertiary:#a1a1a6;--green-primary:#34c759;--green-pastel:#e8f5e9;--orange-primary:#ff9500;--orange-pastel:#fff3e0;--red-primary:#ff3b30;--red-pastel:#ffebee;--blue-primary:#007aff;--blue-pastel:#e3f2fd;--border-light:#e5e5ea;--shadow-soft:0 2px 16px #0000000a;--shadow-panel:0 8px 32px #00000014}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-dark);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600}p{margin:0}button{cursor:pointer;border:none;outline:none;font-family:inherit}:root{--primary-color:#4caf50;--danger-color:#f44336;--warning-color:#ff9800;--info-color:#2196f3;--text-dark:#333;--text-light:#666;--text-muted:#999;--border-color:#e0e0e0;--bg-light:#f8f9fa}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}*{box-sizing:border-box}h1,h2,h3,h4,h5,h6,p{margin:0}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}
