.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:radial-gradient(ellipse 100% 80% at 50% -30%,rgba(34,211,238,.2),transparent 55%),linear-gradient(165deg,#030712,#0a1628 45%,#051525)}.login-container:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(56,189,248,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(56,189,248,.06) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000 20%,transparent 70%);mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000 20%,transparent 70%);pointer-events:none}.login-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;opacity:.25}.farm-field{position:absolute;bottom:0;left:0;width:100%;height:38%;background:linear-gradient(to top,rgba(14,116,144,.35) 0%,transparent 100%);clip-path:polygon(0 30%,100% 0%,100% 100%,0% 100%)}.sensor-icon{position:absolute;top:20%;right:15%;width:56px;height:56px;background:#0f2344cc;border-radius:50%;border:1px solid rgba(34,211,238,.35);box-shadow:0 0 24px #22d3ee40}.data-flow{position:absolute;top:12%;left:8%;width:220px;height:2px;background:linear-gradient(90deg,transparent,rgba(34,211,238,.9),transparent);animation:flow 2.8s ease-in-out infinite}.login-card{position:relative;z-index:1;background:#081630d1;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:48px 40px;border-radius:var(--radius-xl);border:1px solid var(--cockpit-border-strong);box-shadow:var(--shadow-lg),0 0 48px #22d3ee1f;width:100%;max-width:420px;animation:slideUp .5s ease-out}.login-header{text-align:center;margin-bottom:36px}.logo{font-size:52px;margin-bottom:8px;filter:drop-shadow(0 0 12px rgba(34,211,238,.45))}.login-header h1{color:var(--cockpit-heading);font-size:26px;font-weight:700;margin:0;letter-spacing:.06em}.login-form{display:flex;flex-direction:column;gap:18px}.input-group input{width:100%;padding:14px 18px;border:1px solid var(--cockpit-border);border-radius:var(--radius-md);font-size:15px;transition:border-color .2s,box-shadow .2s;background:#040c1cd9;color:var(--cockpit-text)}.input-group input:focus{outline:none;border-color:var(--cockpit-border-strong);box-shadow:0 0 0 3px #22d3ee26}.login-button{width:100%;padding:14px;background:linear-gradient(135deg,#0e7490,#0891b2 45%,#22d3ee);color:#f0fdfa;border:1px solid rgba(34,211,238,.45);border-radius:var(--radius-md);font-size:17px;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:8px;box-shadow:0 0 24px #22d3ee40}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 0 32px #22d3ee59}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.55;cursor:not-allowed}.login-footer{margin-top:28px;display:flex;justify-content:space-between;font-size:14px}.register-container{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:radial-gradient(ellipse 100% 80% at 50% -30%,rgba(34,211,238,.18),transparent 55%),linear-gradient(165deg,#030712,#0a1628 45%,#051525);padding:20px}.register-container:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(56,189,248,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(56,189,248,.05) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000 20%,transparent 70%);mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000 20%,transparent 70%);pointer-events:none}.register-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;opacity:.22}.agriculture-illustration{position:relative;width:100%;height:100%}.farm-field{position:absolute;bottom:0;left:0;width:100%;height:40%;background:linear-gradient(to top,rgba(14,116,144,.3) 0%,transparent 100%);clip-path:polygon(0 30%,100% 0%,100% 100%,0% 100%)}.sensor-icon{position:absolute;top:20%;right:15%;width:56px;height:56px;background:#0f2344cc;border-radius:50%;border:1px solid rgba(34,211,238,.35);box-shadow:0 0 24px #22d3ee33}.sensor-icon:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:22px;height:22px;background:radial-gradient(circle,#22d3ee,#0891b2);border-radius:50%}.data-flow{position:absolute;top:10%;left:10%;width:200px;height:2px;background:linear-gradient(90deg,transparent,rgba(34,211,238,.85),transparent);animation:flow 2.8s ease-in-out infinite}@keyframes flow{0%,to{opacity:.25}50%{opacity:1}}.register-card{position:relative;z-index:1;background:#081630d9;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:44px 36px;border-radius:var(--radius-xl);border:1px solid var(--cockpit-border-strong);box-shadow:var(--shadow-lg),0 0 48px #22d3ee1a;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.register-header{text-align:center;margin-bottom:28px}.logo{font-size:52px;margin-bottom:8px;filter:drop-shadow(0 0 12px rgba(34,211,238,.4))}.register-header h1{color:var(--cockpit-heading);font-size:26px;font-weight:700;margin:0;letter-spacing:.04em}.register-form{display:flex;flex-direction:column;gap:18px}.input-group{position:relative}.input-group input{width:100%;padding:14px 18px;border:1px solid var(--cockpit-border);border-radius:var(--radius-md);font-size:15px;transition:border-color .2s,box-shadow .2s;background:#040c1ce0;color:var(--cockpit-text)}.input-group input:focus{outline:none;border-color:var(--cockpit-border-strong);box-shadow:0 0 0 3px #22d3ee1f}.role-selection{margin:8px 0}.role-selection label{display:block;margin-bottom:12px;color:var(--cockpit-text-secondary);font-weight:600;font-size:15px}.role-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.role-card{padding:16px 12px;border:1px solid var(--cockpit-border);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:all .25s;background:#061226a6}.role-card:hover{border-color:var(--cockpit-border-strong);transform:translateY(-2px);box-shadow:0 0 20px #22d3ee1f}.role-card.selected{border-color:var(--cockpit-accent);background:linear-gradient(135deg,#0e749059,#22d3ee1f);box-shadow:0 0 24px #22d3ee33}.role-icon{font-size:36px;margin-bottom:8px}.role-name{color:var(--cockpit-text);font-weight:600;font-size:13px}.register-button{width:100%;padding:14px;background:linear-gradient(135deg,#0e7490,#0891b2 45%,#22d3ee);color:#f0fdfa;border:1px solid rgba(34,211,238,.45);border-radius:var(--radius-md);font-size:17px;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:8px;box-shadow:0 0 24px #22d3ee38}.register-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 0 32px #22d3ee52}.register-button:active:not(:disabled){transform:translateY(0)}.register-button:disabled{opacity:.55;cursor:not-allowed}.error-message{background:#3c1419bf;color:#fecaca;padding:12px;border-radius:var(--radius-md);font-size:14px;text-align:center;border:1px solid rgba(248,113,113,.35)}.register-note{margin:16px 0;padding:12px;background:#0e749033;border-radius:var(--radius-md);text-align:center;border:1px solid rgba(34,211,238,.25)}.register-note p{color:var(--cockpit-accent-soft);font-size:14px;margin:0}.register-footer{margin-top:24px;text-align:center;font-size:14px;color:var(--cockpit-text-muted)}.link{color:var(--cockpit-accent-soft);text-decoration:none;transition:color .2s}.link:hover{color:#a5f3fc;text-decoration:underline}.dashboard{animation:fadeIn .55s ease-out}.welcome-section{background:var(--cockpit-panel);padding:28px 32px;border-radius:var(--radius-lg);border:1px solid var(--cockpit-border);box-shadow:var(--shadow-sm),0 0 32px #22d3ee0f;margin-bottom:28px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:relative;overflow:hidden}.welcome-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--cockpit-accent),transparent);opacity:.85}.welcome-section h1{color:var(--cockpit-heading);font-size:26px;margin-bottom:10px;font-weight:700;letter-spacing:.03em}.welcome-section p{color:var(--cockpit-text-secondary);font-size:15px;line-height:1.65}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px}.dashboard-card{background:var(--cockpit-panel);padding:28px 24px;border-radius:var(--radius-lg);border:1px solid var(--cockpit-border);box-shadow:var(--shadow-sm);transition:transform .25s,box-shadow .25s,border-color .25s;cursor:pointer;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.dashboard-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md),0 0 28px #22d3ee26;border-color:var(--cockpit-border-strong)}.card-icon{font-size:48px;margin-bottom:14px;filter:drop-shadow(0 0 10px rgba(34,211,238,.35))}.dashboard-card h3{color:var(--cockpit-heading);font-size:18px;margin-bottom:8px;font-weight:700}.dashboard-card p{color:var(--cockpit-text-muted);font-size:14px;line-height:1.6}.homepage{padding:0;background:radial-gradient(1000px 520px at 20% 0%,rgba(34,211,238,.12),transparent 58%),radial-gradient(800px 480px at 92% 12%,rgba(56,189,248,.08),transparent 55%),linear-gradient(180deg,transparent,rgba(3,7,18,.35))}.homepage-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:20px;align-items:stretch}.homepage-card{background:var(--cockpit-panel);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm),0 0 40px #22d3ee0f;overflow:hidden;border:1px solid var(--cockpit-border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.card-header{padding:18px 20px;border-bottom:1px solid var(--cockpit-border);background:linear-gradient(90deg,#081630f2,#0c203ee0);position:relative}.card-header:after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:linear-gradient(90deg,transparent,rgba(34,211,238,.45),transparent);opacity:.7}.card-header h3{margin:0;font-size:17px;font-weight:700;color:var(--cockpit-heading);letter-spacing:.04em}.card-content{padding:20px}.weather-header{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.weather-top{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.weather-range-toggle{display:inline-flex;background:#061226bf;border-radius:20px;padding:3px;gap:4px;border:1px solid var(--cockpit-border)}.weather-range-toggle button{border:none;background:transparent;padding:6px 14px;border-radius:16px;font-size:12px;cursor:pointer;color:var(--cockpit-text-secondary);font-weight:600;transition:all .2s}.weather-range-toggle button.active{background:linear-gradient(135deg,#0891b2,#22d3ee);color:#042f2e;box-shadow:0 0 14px #22d3ee59}.weather-kpis{display:grid;grid-template-columns:1fr 1fr 1.6fr;gap:12px;align-items:stretch;width:100%}.kpi{background:#0612268c;border:1px solid var(--cockpit-border);border-radius:10px;padding:10px 12px}.kpi-label{font-size:12px;color:var(--cockpit-text-muted);margin-bottom:6px}.kpi-value{font-weight:800;font-size:28px;letter-spacing:.2px;line-height:1.1;font-variant-numeric:tabular-nums}.kpi-value.temp{color:#fb923c;text-shadow:0 0 20px rgba(251,146,60,.35)}.kpi-value.hum{color:var(--cockpit-accent-soft);text-shadow:0 0 18px rgba(34,211,238,.25)}.kpi-meta{display:flex;flex-direction:column;justify-content:center}.kpi-meta-line{font-size:14px;font-weight:700;color:var(--cockpit-text)}.kpi-meta-sub{margin-top:6px;font-size:12px;color:var(--cockpit-text-muted)}.weather-charts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.simple-chart{background:#06122680;border-radius:8px;padding:10px 10px 6px;border:1px solid var(--cockpit-border)}.simple-chart-title{font-size:13px;font-weight:600;margin-bottom:4px;color:var(--cockpit-text);display:flex;align-items:center;justify-content:space-between;gap:10px}.simple-chart-badges{display:inline-flex;align-items:center;gap:6px}.badge{font-size:11px;padding:2px 6px;border-radius:999px;border:1px solid var(--cockpit-border);background:#081630a6;color:var(--cockpit-text-secondary)}.chart-ref{stroke:#0f172a47;stroke-width:1;stroke-dasharray:3 3}.chart-ref.ref-avg{stroke:#3b82f6a6}.chart-ref.ref-th{stroke:#f59e0b8c}.simple-chart-svg{width:100%;height:80px}.simple-chart-footer{display:flex;justify-content:space-between;font-size:11px;color:var(--cockpit-text-muted)}.simple-chart-empty{font-size:12px;color:var(--cockpit-text-muted);text-align:center;padding:16px 0}.device-stats{display:flex;flex-direction:column;gap:16px}.stat-item{padding:12px;background:#06122680;border-radius:8px;border-left:3px solid var(--cockpit-accent);border:1px solid var(--cockpit-border);border-left-width:3px}.stat-category-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.stat-rate{font-size:12px;font-weight:700;color:#0f172ab8;font-variant-numeric:tabular-nums}.stat-bar{height:8px;border-radius:999px;background:#0f172a14;overflow:hidden;margin:10px 0 8px}.stat-bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#0891b2,#22d3ee 55%,#67e8f9);box-shadow:0 0 12px #22d3ee59}.stat-category{font-weight:600;color:var(--cockpit-heading);margin-bottom:8px;font-size:15px}.stat-details{display:flex;gap:16px;flex-wrap:wrap;font-size:13px}.stat-total{color:var(--cockpit-text)}.stat-online{color:#4caf50}.stat-offline{color:#999}.stat-fault{color:#f44336}.warning-card-header{position:relative}.warning-title-row{display:inline-flex;align-items:center;gap:10px;margin:0;font-size:18px;font-weight:600;color:var(--cockpit-heading)}.header-badge-dot{width:10px;height:10px;border-radius:50%;background:#f56c6c;box-shadow:0 0 0 3px #f56c6c59;animation:pulse-dot 1.8s ease-in-out infinite}@keyframes pulse-dot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:.85}}.warning-summary{padding:12px 16px 10px;font-size:14px;color:var(--cockpit-text-secondary);line-height:1.5}.stock-summary-line{display:block;margin-top:6px;font-size:13px;color:var(--cockpit-text-muted)}.stock-count-highlight{color:#e6a23c;font-size:16px}.tag-severe{display:inline-block;margin-left:8px;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:600;background:#fef0f0;color:#f56c6c;border:1px solid #fde2e2}.tag-low{display:inline-block;margin-left:6px;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:600;background:#fff7e6;color:#b88230;border:1px solid #f5dab1}.unified-alert-list{padding:0 16px 12px;display:flex;flex-direction:column;gap:0}.unified-alert-card{display:block;width:100%;margin:0 0 10px;padding:9px 12px;border-radius:10px;border:1px solid var(--cockpit-border);border-left:4px solid rgba(56,189,248,.35);background:#061226a6;cursor:pointer;font-family:inherit;line-height:1.35;transition:box-shadow .2s,transform .15s,border-color .2s;position:relative;box-sizing:border-box;-moz-appearance:none;appearance:none;-webkit-appearance:none;text-align:left}.unified-alert-card.is-unread .u-alert-top{padding-right:48px}.unified-alert-card:hover{box-shadow:0 0 20px #22d3ee1f;transform:translate(2px);border-color:var(--cockpit-border-strong)}.unified-alert-card:focus-visible{outline:2px solid var(--cockpit-accent);outline-offset:2px}.unified-alert-card.tier-critical{border-left-color:#f56c6c}.unified-alert-card.tier-warn{border-left-color:#e6a23c}.unified-alert-card.tier-info{border-left-color:#409eff}.unified-alert-card.is-unread{background:#32141c73;border-color:#f8717159}.unified-alert-card.tier-critical,.unified-alert-card.tier-warn,.unified-alert-card.tier-info{background:#061226a6}.u-alert-topline{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:7px}.u-alert-title{display:flex;align-items:center;gap:8px;min-width:0;flex:1}.u-alert-type{font-size:13px;font-weight:800;color:var(--cockpit-heading);letter-spacing:.2px}.homepage .tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:800;border:1px solid var(--cockpit-border);background:#081630bf;color:var(--cockpit-text-secondary)}.homepage .tag.ok{background:#22c55e2e;border-color:#4ade8059;color:#86efac}.homepage .tag.todo,.homepage .tag-level.tier-critical{background:#f8717126;border-color:#f8717159;color:#fecaca}.homepage .tag-level.tier-warn{background:#fbbf2426;border-color:#fbbf2459;color:#fde68a}.homepage .tag-level.tier-info{background:#38bdf826;border-color:#38bdf859;color:#7dd3fc}.u-alert-timebox{text-align:right;display:flex;flex-direction:column;gap:2px;flex-shrink:0}.u-alert-time{font-size:11px;font-weight:500;color:var(--cockpit-text-muted);white-space:nowrap;flex-shrink:0;font-variant-numeric:tabular-nums}.u-alert-rel{font-size:10px;color:#0f172a8c}.u-alert-lines{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px 10px}.u-line{display:grid;grid-template-columns:34px 1fr;gap:6px;font-size:11px;color:var(--cockpit-text-secondary)}.u-line.main .u-v{font-weight:700;color:var(--cockpit-text)}.u-line.main,.u-line.span-2{grid-column:1 / -1}.u-k{color:var(--cockpit-text-muted)}.u-v{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.risk-kpis{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.risk-kpi{background:#0612268c;border:1px solid var(--cockpit-border);border-radius:10px;padding:10px 12px}.risk-kpi-label{font-size:12px;color:var(--cockpit-text-muted);margin-bottom:6px}.risk-kpi-value{font-weight:900;font-size:26px;line-height:1.1;font-variant-numeric:tabular-nums}.risk-area-list{border:1px solid var(--cockpit-border);border-radius:10px;overflow:hidden}.risk-area-row{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;border-bottom:1px solid rgba(56,189,248,.1);background:#06122666}.risk-area-row:last-child{border-bottom:0}.risk-area-name{font-size:13px;font-weight:800;color:var(--cockpit-heading)}.risk-area-prob{font-size:13px;font-weight:900}.risk-note{margin-top:10px;font-size:12px;color:var(--cockpit-text-muted)}.u-alert-detail{margin:6px 0 0;font-size:11px;color:var(--cockpit-text-muted);line-height:1.35;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.u-alert-unread{position:absolute;top:10px;right:12px;background:#f44336;color:#fff;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;line-height:1.3}.warning-list{max-height:360px;overflow-y:auto;padding:0}@media (max-width: 1100px){.warning-card,.risk-card{grid-column:span 2}}.loading-more,.no-more{text-align:center;padding:16px;color:var(--cockpit-text-muted);font-size:14px}.video-card{grid-column:span 2}.video-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.video-item{border:1px solid var(--cockpit-border);border-radius:8px;overflow:hidden;background:#06122673}.video-wrapper{width:100%;height:200px;background:#000;position:relative}.video-player{width:100%;height:100%;object-fit:contain}.video-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--cockpit-text-muted);background:#040a18e6}.video-info{padding:12px;background:#081630bf}.video-name-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.video-name{font-weight:600;color:var(--cockpit-heading);margin-bottom:4px}.video-location{font-size:12px;color:var(--cockpit-text-muted)}.video-meta{margin-top:8px;display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:12px;color:#0f172a9e}.video-farm{font-weight:700;color:#0f172ab3}.map-card{grid-column:span 2}.area-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.area-card{border:1px solid var(--cockpit-border);background:#0612268c;border-radius:12px;padding:12px;text-align:left;cursor:pointer;transition:transform .15s,box-shadow .2s,border-color .2s}.area-card:hover{transform:translateY(-2px);box-shadow:0 0 24px #22d3ee1f;border-color:var(--cockpit-border-strong)}.area-card.good{border-left:4px solid #22c55e}.area-card.bad{border-left:4px solid #ef4444}.area-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.area-name{font-size:14px;font-weight:900;color:var(--cockpit-heading);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.area-line{font-size:12px;color:var(--cockpit-text-secondary);line-height:1.6}.area-line.dim{color:var(--cockpit-text-muted)}.empty-state{text-align:center;padding:40px 20px;color:var(--cockpit-text-muted);font-size:14px}.warning-list::-webkit-scrollbar{width:6px}.warning-list::-webkit-scrollbar-track{background:#06122680;border-radius:3px}.warning-list::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--cockpit-accent-deep),var(--cockpit-accent));border-radius:3px}.warning-list::-webkit-scrollbar-thumb:hover{background:var(--cockpit-accent-soft)}@media (max-width: 1200px){.homepage-grid{grid-template-columns:1fr}.warning-card,.map-card{grid-column:span 1}.weather-kpis{grid-template-columns:1fr}.area-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.overview-page{width:100%}.overview-title{margin-bottom:12px}.overview-title h2{margin:0 0 6px;color:var(--cockpit-heading);font-size:22px}.overview-title p{margin:0;color:var(--cockpit-text-muted);font-size:13px}.overview-meta{margin-left:10px;color:var(--cockpit-text-muted);font-size:12px}.overview-offline-banner{margin:0 0 12px;padding:10px 12px;border:1px solid rgba(251,191,36,.45);background:#54340a47;border-radius:10px;color:#fde68a;font-size:13px}.overview-actions{margin:0 0 12px;display:flex;justify-content:flex-end}.overview-btn{border:1px solid var(--cockpit-border);background:#081630a6;color:var(--cockpit-text-secondary);border-radius:999px;padding:8px 12px;font-size:12px;cursor:pointer}.overview-btn.primary{border-color:var(--cockpit-border-strong);color:var(--cockpit-accent-soft);box-shadow:0 0 14px #22d3ee2e}.overview-grid{display:flex;gap:18px;align-items:start}.overview-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:18px}.overview-card{background:var(--cockpit-panel);border:1px solid var(--cockpit-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;height:fit-content}.overview-card.card-md{min-height:320px}.overview-card.card-lg{height:460px;display:flex;flex-direction:column}.overview-card-header{padding:14px 16px;border-bottom:1px solid var(--cockpit-border);background:#081630e6}.overview-card-header h3{margin:0;color:var(--cockpit-heading);font-size:16px}.badge-est{margin-left:10px;display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:800;border:1px solid rgba(251,191,36,.45);color:#fde68a;background:#54340a38}.overview-card-body{padding:16px;display:flex;flex-direction:column;gap:12px}.overview-card-body.scroll-body{flex:1;min-height:0;overflow-y:auto;padding-right:12px}.overview-kpi-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.mini-kpi{border:1px solid var(--cockpit-border);background:#06122685;border-radius:10px;padding:10px 12px}.mini-kpi span{display:block;font-size:12px;color:var(--cockpit-text-muted);margin-bottom:6px}.mini-kpi strong{font-size:22px;color:var(--cockpit-heading)}.overview-empty{color:var(--cockpit-text-muted);font-size:13px}.overview-note{border-left:3px solid var(--cockpit-accent);background:#0612268c;border-radius:8px;padding:8px 10px;font-size:13px;color:var(--cockpit-text)}.overview-explain{border-left:3px solid rgba(34,211,238,.6);background:#06122659;border-radius:8px;padding:8px 10px;font-size:12px;color:var(--cockpit-text-secondary)}.overview-explain summary{cursor:pointer;color:var(--cockpit-accent-soft);font-weight:700;list-style:none}.overview-explain summary::-webkit-details-marker{display:none}.overview-explain .explain-body{margin-top:8px;display:grid;gap:6px}.overview-stock-summary{padding:8px 10px;border:1px solid rgba(244,63,94,.4);background:#7f1d1d47;border-radius:8px;color:#fecdd3;font-size:13px}.overview-reco{border:1px solid var(--cockpit-border);background:#06122659;border-radius:10px;padding:10px}.overview-reco-title{font-size:12px;color:var(--cockpit-text-muted);margin-bottom:8px}.overview-reco-list{display:flex;flex-direction:column;gap:6px}.overview-reco-item{display:flex;align-items:center;gap:8px;color:var(--cockpit-text-secondary);font-size:12px}.overview-reco-item .name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--cockpit-heading);font-weight:700}.overview-reco-item .qty{font-variant-numeric:tabular-nums;color:var(--cockpit-text-secondary)}.overview-reco-item .tag{border:1px solid var(--cockpit-border);border-radius:999px;padding:2px 8px;font-weight:700}.overview-reco-item .tag.danger{border-color:#f8717173;color:#fecaca;background:#50181c40}.overview-reco-item .tag.warn{border-color:#fbbf2473;color:#fde68a;background:#54340a38}.overview-reco-item .tag.ok{border-color:#22c55e66;color:#bbf7d0;background:#14532d38}.overview-list{display:flex;flex-direction:column;border:1px solid var(--cockpit-border);border-radius:10px;overflow:hidden}.overview-list-row{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-bottom:1px solid rgba(56,189,248,.1);color:var(--cockpit-text-secondary)}.overview-list-row:last-child{border-bottom:0}.overview-list-row strong{color:var(--cockpit-heading)}.kpi-danger{color:#fca5a5!important}.risk-high{color:#ef4444!important}.risk-mid{color:#f59e0b!important}.risk-low{color:#16a34a!important}.overview-card-actions{display:flex;gap:8px;flex-wrap:wrap}.growth-list{display:flex;flex-direction:column;gap:10px}.growth-item{border:1px solid var(--cockpit-border);background:#06122673;border-radius:10px;padding:10px}.growth-item.behind{border-color:#fbbf2473;background:#4a300847}.growth-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:8px}.growth-name{color:var(--cockpit-heading);font-size:14px;font-weight:700}.growth-meta{font-size:12px;color:var(--cockpit-text-muted)}.growth-progress-row{display:grid;grid-template-columns:62px 1fr 48px;gap:8px;align-items:center;margin-bottom:6px}.growth-progress-row .label{font-size:12px;color:var(--cockpit-text-muted)}.growth-progress-row .bar{height:8px;border-radius:999px;overflow:hidden;background:#94a3b82e}.growth-progress-row .fill{height:100%;border-radius:999px}.growth-progress-row .fill.gdd{background:linear-gradient(90deg,#22d3ee,#0891b2)}.growth-progress-row .fill.cal{background:linear-gradient(90deg,#cbd5e1,#94a3b8)}.growth-progress-row .value{text-align:right;font-size:12px;color:var(--cockpit-text-secondary)}.growth-foot{margin-top:4px;font-size:12px;color:var(--cockpit-text-muted)}.growth-foot .warn{margin-left:8px;color:#fde68a;font-weight:700}@media (max-width: 1100px){.overview-grid{flex-direction:column}}.farm-list-page{display:flex;flex-direction:column;gap:16px}.farm-list-header{display:flex;justify-content:space-between;align-items:center}.farm-list-header h2{font-size:22px;font-weight:600;color:#333}.farm-list-actions{display:flex;gap:8px}.farm-list-actions button{padding:8px 16px;border-radius:999px;border:none;background:transparent;cursor:pointer;font-size:13px;transition:all .2s;display:inline-flex;align-items:center;gap:6px}.farm-list-actions .primary-btn{background:linear-gradient(135deg,#4caf50,#1b5e20);color:#fff;box-shadow:0 3px 8px #4caf5066}.farm-list-actions .primary-outline-btn{border:1px solid #4caf50;color:#4caf50;background:#fff}.farm-list-actions button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.filter-item.buttons button{padding:6px 14px;border-radius:999px;border:1px solid #4caf50;background:transparent;cursor:pointer;font-size:13px;margin-right:8px;color:#388e3c}.farm-table-wrapper{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000008;border:1px solid #e0e0e0;overflow:hidden}.farm-table thead{background:linear-gradient(135deg,#f1f8e9,#e8f5e9)}.farm-table th,.farm-table td{padding:10px 12px;font-size:13px;border-bottom:1px solid #f0f0f0;text-align:left}.farm-table th{color:#666;font-weight:500;-webkit-user-select:none;user-select:none}.farm-table tbody tr:hover{background:#f9fbff}.farm-table th:hover{background:#eef5ff}.farm-name-cell{position:relative;color:#1b5e20;cursor:pointer}.farm-name-cell:hover{text-decoration:underline;text-underline-offset:2px}.sort-indicator{margin-left:4px;font-size:11px}.status-tag{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px}.status-normal{background:linear-gradient(135deg,#66bb6a,#2e7d32);color:#fff}.status-warning{background:linear-gradient(135deg,#fff8e1,#ffecb3);color:#f9a825}.status-alarm{background:linear-gradient(135deg,#ef5350,#c62828);color:#fff}.danger-link{color:#c62828}.farm-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:10px}.farm-pagination .page-info{font-size:13px;color:#666}.farm-pagination .page-controls{display:flex;align-items:center;gap:8px}.farm-pagination button{padding:4px 10px;border-radius:999px;border:1px solid #e0e0e0;background:#fff;cursor:pointer;font-size:12px}.page-btn{min-width:60px}.page-current{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#4caf50,#2e7d32);color:#fff;font-size:13px;font-weight:600}.farm-pagination select{height:28px;border-radius:4px;border:1px solid #dcdcdc;font-size:12px;padding:2px 6px}.farm-overview-popover{position:absolute;top:24px;left:0;z-index:10;min-width:260px;background:#fff;border-radius:8px;box-shadow:0 8px 20px #0000002e;padding:10px 12px}.overview-section{margin-bottom:6px}.overview-title{font-size:12px;font-weight:600;color:#333;margin-bottom:2px}.overview-env,.overview-device,.overview-warning{font-size:12px;color:#555;display:flex;gap:8px;flex-wrap:wrap}.overview-empty{font-size:12px;color:#999}.batch-bar{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#f1f8e9;border-bottom:1px solid #e0e0e0;font-size:13px}.batch-bar button{padding:4px 10px;border-radius:999px;border:1px solid #4caf50;background:#fff;cursor:pointer;font-size:12px;margin-left:6px;color:#388e3c}.btn-icon{font-size:14px}.table-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;border:1px solid #e0e0e0;background:#fff;cursor:pointer;font-size:12px;margin-right:4px}.table-btn:hover{background:#f5f7fa}.outline-btn{padding:6px 14px;border-radius:999px;border:1px solid #4caf50;background:transparent;color:#388e3c;cursor:pointer;font-size:13px}.advanced-toggle .advanced-link{font-size:12px;color:#388e3c;cursor:pointer}.advanced-row{border-top:1px dashed #e0e0e0;padding-top:8px}.filter-actions-row{margin-top:4px}.farm-form-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;justify-content:center;align-items:center;z-index:1000}.farm-form-modal{width:520px;max-width:96vw;background:#fff;border-radius:12px;box-shadow:0 8px 30px #0003;padding:18px 20px 14px}.farm-form-modal h3{margin:0 0 10px;font-size:18px;color:#333}.farm-form-body{max-height:380px;overflow-y:auto;padding-right:4px}.farm-form-row{display:flex;flex-direction:column;margin-bottom:10px}.farm-form-row label{font-size:13px;color:#555;margin-bottom:4px}.farm-form-row input,.farm-form-row select{height:32px;border-radius:6px;border:1px solid #dcdcdc;padding:4px 8px;font-size:13px}.coord-inputs{display:flex;gap:8px}.coord-inputs input{flex:1}.coord-tip{font-size:12px;color:#999;margin-top:4px}.farm-form-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:10px}.farm-form-footer button{padding:6px 14px;border-radius:6px;border:1px solid #e0e0e0;background:#fff;cursor:pointer;font-size:13px}.farm-form-footer .primary-btn{background:linear-gradient(135deg,#4caf50,#45a049);border-color:#4caf50;color:#fff}.required{color:#e53935;margin-left:2px}@media (max-width: 1200px){.farm-filter-panel{padding:12px}.filter-row{flex-direction:column}.filter-item.buttons{margin-left:0}}.farm-detail-page{padding:0;display:flex;flex-direction:column;gap:16px}.farm-detail-header{display:flex;justify-content:space-between;align-items:center;gap:16px}.farm-header-left{flex:1}.farm-header-actions{display:flex;gap:8px}.farm-detail-header h2{margin:0;font-size:22px;color:#333}.farm-name-wrapper{position:relative;display:inline-block}.farm-name-trigger{position:relative;display:inline-flex;align-items:center;gap:8px;padding:8px 0;cursor:pointer;font-size:24px;font-weight:600;color:#2e7d32;transition:all .3s ease}.farm-name-trigger:hover,.farm-name-trigger.active{color:#1b5e20}.farm-name-text{position:relative;display:inline-flex;align-items:center;gap:8px}.farm-name-underline{position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,#4caf50,#1b5e20);transition:width .3s ease}.farm-name-trigger:hover .farm-name-underline{width:100%}.farm-name-arrow{font-size:14px;color:#999;transition:transform .3s ease}.farm-name-arrow.rotated{transform:rotate(180deg)}.farm-status-badge{display:inline-block;width:10px;height:10px;border-radius:50%;margin-left:8px;animation:pulse 2s infinite}.farm-status-badge.status-normal{background:#4caf50;box-shadow:0 0 #4caf50b3}.farm-status-badge.status-warning{background:#ff9800;box-shadow:0 0 #ff9800b3}.farm-status-badge.status-alarm{background:#f44336;box-shadow:0 0 #f44336b3}.farm-status-badge-circle{display:inline-flex;align-items:center;justify-content:center;min-width:48px;height:24px;padding:0 10px;border-radius:12px;font-size:12px;font-weight:500;color:#fff;flex-shrink:0}.farm-status-badge-circle.status-normal{background:linear-gradient(135deg,#4caf50,#1b5e20)}.farm-status-badge-circle.status-warning{background:linear-gradient(135deg,#ff9800,#f57c00)}.farm-status-badge-circle.status-alarm{background:linear-gradient(135deg,#f44336,#c62828)}@keyframes pulse{0%{box-shadow:0 0 #4caf50b3}70%{box-shadow:0 0 0 6px #4caf5000}to{box-shadow:0 0 #4caf5000}}.farm-panel{position:absolute;top:calc(100% + 10px);left:0;width:300px;background:linear-gradient(180deg,#f1f8f4,#fff 20%);border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 4px 12px #0000000f,0 8px 24px #0000000a;z-index:1000;overflow:hidden;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.farm-panel-search{position:relative;padding:12px;border-bottom:1px solid #f0f0f0}.search-icon{position:absolute;left:20px;top:50%;transform:translateY(-50%);font-size:16px;color:#999;transition:transform .2s ease;pointer-events:none}.farm-panel-search:hover .search-icon{transform:translateY(-50%) scale(1.1)}.farm-panel-search input{width:100%;padding:8px 12px 8px 36px;border:1px solid #dcdcdc;border-radius:8px;font-size:14px;transition:all .2s}.farm-panel-search input:hover{border-color:#4caf50}.farm-panel-search input:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.search-highlight{background:#fff9c4;color:#f57f17;padding:0 2px;border-radius:2px;font-weight:600}.farm-panel-status-filter{display:flex;gap:8px;padding:8px 12px;border-bottom:1px solid #f0f0f0;background:#fafafa}.status-filter-btn{flex:1;padding:6px 12px;border:1px solid #e0e0e0;border-radius:6px;background:#fff;color:#666;font-size:12px;cursor:pointer;transition:all .2s}.status-filter-btn:hover{border-color:#4caf50;color:#4caf50}.status-filter-btn.active{background:linear-gradient(135deg,#4caf50,#1b5e20);color:#fff;border-color:#4caf50}.status-filter-btn.status-normal.active{background:linear-gradient(135deg,#4caf50,#1b5e20)}.status-filter-btn.status-warning.active{background:linear-gradient(135deg,#ff9800,#f57c00)}.status-filter-btn.status-alarm.active{background:linear-gradient(135deg,#f44336,#c62828)}.farm-panel-list{max-height:400px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#c0c0c0 transparent}.farm-panel-list::-webkit-scrollbar{width:2px}.farm-panel-list::-webkit-scrollbar-track{background:transparent}.farm-panel-list::-webkit-scrollbar-thumb{background:silver;border-radius:10px;transition:width .2s}.farm-panel-list:hover::-webkit-scrollbar{width:4px}.farm-panel-list:hover::-webkit-scrollbar-thumb{background:#999}.farm-group{padding:8px 0}.farm-group-title{padding:8px 16px;font-size:12px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px}.farm-panel-item{display:flex;align-items:center;gap:8px;padding:12px 16px;cursor:pointer;transition:all .2s ease;border-left:3px solid transparent}.farm-panel-item:hover{background:#f8f9fa;transform:scale(1.02);border-left-color:#4caf50}.farm-panel-item.active{background:linear-gradient(135deg,#1b5e20,#2e7d32);color:#fff;border-left-color:#1b5e20;box-shadow:inset 0 0 0 1px #ffffff1a}.farm-panel-item.active .farm-item-name,.farm-panel-item.active .farm-item-address{color:#fff}.farm-panel-item.active .farm-status-badge-circle{background:#fff3;border:1px solid rgba(255,255,255,.3)}.farm-panel-item.active .farm-item-checkmark{color:#fff}.farm-panel-item.selected{background:#f0f7ff}.farm-item-checkbox{flex-shrink:0}.farm-item-checkbox input{cursor:pointer}.farm-item-content{flex:1;min-width:0}.farm-item-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.farm-item-name{flex:1;font-size:14px;font-weight:500;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.farm-item-checkmark{color:#4caf50;font-weight:700;font-size:16px}.farm-item-address{font-size:12px;color:#999;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.farm-item-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.quick-switch-btn{padding:4px 8px;font-size:12px;background:linear-gradient(135deg,#4caf50,#1b5e20);color:#fff;border:none;border-radius:4px;cursor:pointer;transition:all .2s}.quick-switch-btn:hover{transform:scale(1.05);box-shadow:0 2px 8px #4caf504d}.more-menu-wrapper{position:relative;opacity:0;transition:opacity .2s}.farm-panel-item.hovered .more-menu-wrapper{opacity:1}.more-btn{padding:4px 8px;font-size:14px;background:transparent;border:none;color:#999;cursor:pointer;transition:all .2s;border-radius:4px}.more-btn:hover{color:#666;background:#0000000d}.more-menu{position:absolute;top:100%;right:0;margin-top:4px;min-width:160px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1001;overflow:hidden}.more-menu-item{padding:10px 16px;font-size:14px;color:#333;cursor:pointer;transition:background .2s}.more-menu-item:hover{background:#f5f5f5}.more-menu-item.danger{color:#f44336}.more-menu-item.danger:hover{background:#ffebee}.farm-panel-empty{padding:40px 20px;text-align:center;color:#999;font-size:14px}.farm-panel-footer{padding:12px;border-top:1px solid #f0f0f0;display:flex;gap:8px;justify-content:space-between}.batch-export-btn{flex:1;padding:8px 12px;font-size:13px;background:linear-gradient(135deg,#4caf50,#1b5e20);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .2s}.batch-export-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #4caf504d}.view-all-btn{flex:1;padding:8px 12px;font-size:13px;background:#fff;color:#4caf50;border:1px solid #4caf50;border-radius:6px;cursor:pointer;transition:all .2s}.view-all-btn:hover{background:#f1f8f4}.empty-state-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px}.empty-action-btn{padding:8px 16px;background:linear-gradient(135deg,#4caf50,#1b5e20);color:#fff;border:none;border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s}.empty-action-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #4caf504d}.btn-secondary{padding:8px 16px;border:1px solid #dcdcdc;border-radius:6px;background:#fff;color:#666;cursor:pointer;font-size:14px;transition:all .2s}.btn-secondary:hover{border-color:#4caf50;color:#4caf50;background:#f1f8f4}.back-menu-wrapper{position:relative}.back-btn{display:flex;align-items:center;gap:4px}.back-arrow{font-size:10px;transition:transform .2s}.back-menu-wrapper:hover .back-arrow,.back-menu-wrapper:has(.back-menu) .back-arrow{transform:rotate(180deg)}.back-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:140px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;overflow:hidden;animation:slideDown .2s ease-out}.back-menu-item{padding:10px 16px;font-size:14px;color:#333;cursor:pointer;transition:background .2s}.back-menu-item:hover{background:#f5f5f5}.loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.loading-spinner{width:40px;height:40px;border:4px solid #f0f0f0;border-top-color:#4caf50;border-radius:50%;animation:spin 1s linear infinite}.loading-text{color:#666;font-size:14px}@keyframes spin{to{transform:rotate(360deg)}}.farm-detail-page.switching{animation:fadeOut .2s ease-out}@keyframes fadeOut{0%{opacity:1}to{opacity:.3}}.farm-detail-page:not(.switching){animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:.3}to{opacity:1}}.switch-notification{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:2000;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.notification-content{display:flex;align-items:center;gap:8px;padding:12px 20px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #00000026;font-size:14px;color:#333}.notification-content .farm-status-badge{margin-left:0}@media (max-width: 768px){.farm-panel{position:fixed;bottom:0;left:0;right:0;top:auto;width:100%;border-radius:16px 16px 0 0;max-height:70vh;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.farm-panel-list{max-height:calc(70vh - 180px)}.farm-panel-status-filter{flex-wrap:wrap}.status-filter-btn{min-width:60px;font-size:11px;padding:4px 8px}}.sub-text{color:#777;font-size:13px;margin-top:4px}.farm-tabs{display:flex;gap:10px;border-bottom:1px solid #eee}.farm-tab{padding:10px 14px;cursor:pointer;border-radius:8px 8px 0 0;color:#555}.farm-tab.active{background:#fff;border:1px solid #e0e0e0;border-bottom:none;color:#2e7d32;font-weight:600}.farm-tab-panel{background:#fff;border:1px solid #e0e0e0;border-radius:0 8px 8px;padding:16px}.card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:14px;margin-bottom:12px}.card-title{font-size:16px;font-weight:600;color:#333;margin-bottom:10px}.card-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.form-grid{display:grid;grid-template-columns:120px 1fr;gap:10px 12px;align-items:center}.form-grid label{text-align:right;font-size:14px;color:#555}.form-grid input,.form-grid select{box-sizing:border-box;min-height:40px;height:auto;border-radius:6px;border:1px solid #dcdcdc;padding:8px 10px;font-size:14px;line-height:1.45;transition:all .2s}.double-input{display:flex;gap:8px}.coord-input-row{display:flex;align-items:center;gap:8px}.coord-input-row input{flex:1}.coord-separator{color:#999;font-size:16px;font-weight:500;padding:0 4px}.actions{margin-top:10px;display:flex;gap:8px}.actions button{padding:6px 12px;border-radius:6px;border:1px solid #e0e0e0;background:#fff;cursor:pointer}.actions .primary,.submit-btn{background:linear-gradient(135deg,#4caf50,#1b5e20);color:#fff;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #4caf504d}.submit-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #4caf5066}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.simple-table table{width:100%;border-collapse:collapse}.simple-table th,.simple-table td{border-bottom:1px solid #f0f0f0;padding:8px 10px;font-size:13px;text-align:left}.simple-table th{background:#f8f9fb;color:#666;font-weight:500}.simple-table button{padding:4px 8px;border-radius:4px;border:1px solid #e0e0e0;background:#fff;cursor:pointer;margin-right:4px}.simple-table button.danger{color:#c62828}.form-inline{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.form-inline input,.form-inline select{box-sizing:border-box;min-height:40px;height:auto;border-radius:6px;border:1px solid #dcdcdc;padding:8px 10px;font-size:14px;line-height:1.45}.form-inline button{padding:6px 12px;border-radius:6px;border:1px solid #e0e0e0;background:#fff;cursor:pointer}.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.mini-chart{border:1px solid #e0e0e0;border-radius:8px;padding:10px;background:#fafafa}.chart-title{font-size:13px;font-weight:600;margin-bottom:6px}.chart-svg{width:100%;height:100px}.chart-footer{display:flex;justify-content:space-between;font-size:11px;color:#777}.chart-empty{text-align:center;color:#999;font-size:12px;padding:10px 0}.bar-list{display:flex;gap:6px;align-items:flex-end;height:120px}.bar-item{flex:1;text-align:center}.bar{border-radius:4px 4px 0 0;width:100%}.bar-label{font-size:10px;color:#777;margin-top:4px}.pie{width:120px;height:120px;display:block;margin:0 auto}.health-row{display:flex;gap:16px;align-items:center}.ring{width:140px;height:140px;border-radius:50%;background:conic-gradient(#4caf50,#4caf50 70%,#e0e0e0 70%);display:flex;align-items:center;justify-content:center}.ring-inner{width:100px;height:100px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;color:#2e7d32}.health-factors{display:flex;flex-direction:column;gap:6px}.factor-item{padding:8px 10px;background:#f5f7fa;border-radius:6px;font-size:13px;color:#555}.advice-list{margin:0;padding-left:18px;color:#444}.advice-list li{margin-bottom:6px}@media (max-width: 768px){.form-grid{grid-template-columns:100px 1fr}.health-row{flex-direction:column;align-items:flex-start}}.farm-manager-page{display:flex;flex-direction:column;gap:16px}.farm-manager-header{display:flex;justify-content:space-between;align-items:center}.farm-manager-header h2{font-size:22px;font-weight:600;color:#333}.farm-manager-tabs{display:flex;gap:8px}.tab-btn{padding:8px 16px;border-radius:8px;border:1px solid #dcdcdc;background:#fff;cursor:pointer;font-size:14px;transition:all .2s}.tab-btn:hover{border-color:#4caf50;color:#4caf50}.tab-btn.active{background:linear-gradient(135deg,#4caf50,#1b5e20);color:#fff;border-color:#4caf50}.farm-manager-actions{display:flex;gap:8px}.farm-manager-actions button{padding:8px 16px;border-radius:999px;border:none;background:transparent;cursor:pointer;font-size:13px;transition:all .2s;display:inline-flex;align-items:center;gap:6px}.farm-manager-actions .primary-btn{background:linear-gradient(135deg,#4caf50,#1b5e20);color:#fff;box-shadow:0 3px 8px #4caf5066}.farm-manager-actions .outline-btn{border:1px solid #4caf50;color:#4caf50;background:#fff}.farm-manager-actions button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000008}.empty-state p{font-size:16px;color:#999;margin-bottom:20px}.farm-filter-panel{background:#fff;border-radius:12px;padding:16px 20px;box-shadow:0 2px 8px #00000008}.filter-row{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:8px}.filter-item label{font-size:13px;color:#555;white-space:nowrap}.filter-item input,.filter-item select{height:30px;padding:4px 8px;border-radius:6px;border:1px solid #dcdcdc;font-size:13px}.filter-item.buttons{margin-left:auto}.filter-item.buttons button{padding:6px 14px;border-radius:999px;border:1px solid #4caf50;background:transparent;cursor:pointer;font-size:13px;margin-right:8px;color:#4caf50}.filter-item.buttons button:hover{background:#f1f8f4}.filter-sep{margin:0 8px;color:#999}.farm-table-wrapper{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000008}.farm-table{width:100%;border-collapse:collapse}.farm-table thead{background:#f5f5f5}.farm-table th{padding:12px 16px;text-align:left;font-size:13px;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.farm-table td{padding:12px 16px;font-size:13px;color:#555;border-bottom:1px solid #f0f0f0}.farm-table tbody tr:hover{background:#f1f8f4}.table-btn{padding:4px 8px;border:none;background:transparent;cursor:pointer;font-size:12px;color:#4caf50;margin-right:8px;display:inline-flex;align-items:center;gap:4px;border-radius:4px;transition:all .2s}.table-btn:hover{background:#f1f8f4}.table-btn.danger-link{color:#f44336}.table-btn.danger-link:hover{background:#ffebee}.btn-icon{font-size:12px}.principal-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:500}.principal-tag.main{background:#ffebee;color:#c62828}.principal-tag.sub{background:#e3f2fd;color:#1565c0}.scope-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;background:#f5f5f5;color:#666}.scope-tag.single{background:#e8f5e9;color:#2e7d32}.scope-tag.multiple{background:#fff3e0;color:#e65100}.permission-tags{display:flex;flex-wrap:wrap;gap:4px}.permission-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;background:#f5f5f5;color:#666}.permission-empty{color:#999;font-size:12px}.log-type{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:500}.log-type-绑定{background:#e8f5e9;color:#2e7d32}.log-type-解绑{background:#ffebee;color:#c62828}.log-type-改权限{background:#e3f2fd;color:#1565c0}.farm-pagination{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000008}.page-info{font-size:13px;color:#666}.page-btn{padding:6px 12px;border:1px solid #dcdcdc;background:#fff;border-radius:6px;cursor:pointer;font-size:13px;transition:all .2s}.page-current{padding:6px 12px;background:linear-gradient(135deg,#4caf50,#1b5e20);color:#fff;border-radius:6px;font-size:13px;font-weight:600}.page-controls select{padding:6px 12px;border:1px solid #dcdcdc;border-radius:6px;font-size:13px;cursor:pointer}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;padding:24px;min-width:500px;max-width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.modal-content h3{font-size:18px;font-weight:600;color:#333;margin-bottom:20px}.modal-body{margin-bottom:20px}.form-row{margin-bottom:16px}.form-row label{display:block;font-size:14px;color:#555;margin-bottom:8px}.form-row input,.form-row select{width:100%;padding:8px 12px;border:1px solid #dcdcdc;border-radius:6px;font-size:14px}.form-row select{cursor:pointer}.checkbox-group{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto;padding:8px;border:1px solid #e0e0e0;border-radius:6px}.empty-hint{color:#999;font-size:14px;padding:12px;text-align:center}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto}.warning-text{color:#f44336;font-size:12px}.permission-table{display:flex;flex-direction:column;gap:8px}.permission-row{display:flex;align-items:center;gap:12px}.permission-module{min-width:80px;font-size:14px;color:#555}.permission-row select{width:auto;min-width:120px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding-top:20px;border-top:1px solid #f0f0f0}.modal-footer button{padding:8px 16px;border-radius:6px;border:none;cursor:pointer;font-size:14px;transition:all .2s}.modal-footer .primary-btn{background:linear-gradient(135deg,#4caf50,#1b5e20);color:#fff}.modal-footer .outline-btn{background:#fff;border:1px solid #dcdcdc;color:#666}.modal-footer button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.modal-footer button:disabled{opacity:.6;cursor:not-allowed}.toast{position:fixed;top:20px;right:20px;padding:12px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:2000;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.crop-list-page{padding:20px;background:#f5f5f5;min-height:calc(100vh - 60px)}.crop-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.crop-list-header h2{font-size:20px;font-weight:600;color:#333;margin:0}.crop-list-actions{display:flex;gap:12px}.primary-btn,.primary-outline-btn{display:flex;align-items:center;gap:6px;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.primary-btn{background:linear-gradient(135deg,#4caf50,#1b5e20);color:#fff;box-shadow:0 2px 8px #4caf504d}.primary-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #4caf5066}.primary-outline-btn{background:#fff;color:#4caf50;border:1px solid #4caf50}.primary-outline-btn:hover{background:#f1f8f4;border-color:#1b5e20}.btn-icon{font-size:16px}.quick-farm-filter{display:flex;align-items:center;gap:8px;margin-bottom:16px;padding:12px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d}.quick-filter-label{font-size:14px;color:#666;font-weight:500}.quick-filter-btn{padding:6px 16px;border:1px solid #e0e0e0;border-radius:6px;background:#fff;color:#666;font-size:13px;cursor:pointer;transition:all .2s}.quick-filter-btn:hover{border-color:#4caf50;color:#4caf50}.quick-filter-btn.active{background:linear-gradient(135deg,#4caf50,#1b5e20);color:#fff;border-color:#4caf50}.crop-filter-panel{background:#fff;border-radius:12px;padding:16px;margin-bottom:20px;box-shadow:0 2px 8px #00000008;border:1px solid #e0e0e0}.filter-row{display:flex;gap:16px;margin-bottom:12px;flex-wrap:wrap}.filter-item{display:flex;align-items:center;gap:8px}.filter-item label{font-size:13px;color:#666;white-space:nowrap}.filter-item input,.filter-item select{padding:6px 12px;border:1px solid #dcdcdc;border-radius:6px;font-size:13px;min-width:150px;transition:all .2s}.filter-item input:hover,.filter-item select:hover{border-color:#4caf50}.filter-item input:focus,.filter-item select:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.filter-sep{margin:0 4px;color:#999}.advanced-toggle{margin-left:auto}.advanced-link{color:#4caf50;cursor:pointer;font-size:13px;transition:color .2s}.advanced-link:hover{color:#1b5e20;text-decoration:underline}.filter-actions-row{margin-top:8px;padding-top:12px;border-top:1px solid #f0f0f0}.filter-item.buttons{gap:8px}.outline-btn{padding:8px 16px;border:1px solid #dcdcdc;border-radius:6px;background:#fff;color:#666;font-size:13px;cursor:pointer;transition:all .2s}.outline-btn:hover{border-color:#4caf50;color:#4caf50;background:#f1f8f4}.crop-table-wrapper{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000008;border:1px solid #e0e0e0;overflow:hidden}.batch-bar{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f1f8f4;border-bottom:1px solid #e0e0e0}.batch-bar span{font-size:14px;color:#666}.batch-bar button{padding:6px 12px;border:1px solid #4caf50;border-radius:6px;background:#fff;color:#4caf50;font-size:13px;cursor:pointer;transition:all .2s}.batch-bar button:hover{background:#4caf50;color:#fff}.crop-table{width:100%;border-collapse:collapse}.crop-table thead{background:linear-gradient(135deg,#f1f8e9,#e8f5e9)}.crop-table th,.crop-table td{padding:12px;font-size:13px;border-bottom:1px solid #f0f0f0;text-align:left}.crop-table th{color:#666;font-weight:600;-webkit-user-select:none;user-select:none}.crop-table th.sortable{cursor:pointer;transition:background .2s}.crop-table th.sortable:hover{background:#eef5ff}.sort-indicator{margin-left:4px;font-size:11px;color:#4caf50}.crop-table tbody tr{transition:background .2s}.crop-table tbody tr:hover{background:#f9fbff}.col-center{text-align:center}.empty-cell{padding:60px 20px;text-align:center}.empty-state-panel{display:flex;flex-direction:column;align-items:center;gap:12px}.empty-icon{font-size:48px;opacity:.5}.empty-text{font-size:14px;color:#999}.crop-name-cell{position:relative;color:#1b5e20;cursor:pointer;font-weight:500}.crop-name-cell:hover{text-decoration:underline;text-underline-offset:2px}.crop-overview-card{position:absolute;top:100%;left:0;z-index:1000;min-width:320px;max-width:400px;margin-top:8px;padding:16px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #00000026;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.overview-title{font-size:15px;font-weight:600;color:#333;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #f0f0f0}.overview-section{margin-bottom:12px}.overview-section:last-child{margin-bottom:0}.overview-label{font-size:12px;color:#999;margin-bottom:6px}.overview-data{font-size:13px;color:#333;display:flex;flex-direction:column;gap:4px}.overview-data span{display:inline-block}.overview-data.highlight{color:#4caf50;font-weight:500}.overview-section.warning .overview-label{color:#f44336}.overview-section.warning .overview-data{color:#f44336;font-size:12px}.health-score-ring{position:relative;width:60px;height:60px;margin:8px auto}.health-score-ring .ring{width:100%;height:100%;transform:rotate(-90deg)}.health-score-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:14px;font-weight:600;color:#333}.status-badge-circle{display:inline-flex;align-items:center;justify-content:center;min-width:56px;height:24px;padding:0 10px;border-radius:12px;font-size:12px;font-weight:500;color:#fff}.status-badge-circle.status-normal{background:linear-gradient(135deg,#4caf50,#1b5e20)}.status-badge-circle.status-warning{background:linear-gradient(135deg,#ff9800,#f57c00)}.status-badge-circle.status-alarm{background:linear-gradient(135deg,#f44336,#c62828)}.status-clickable{cursor:pointer;transition:transform .2s}.status-clickable:hover{transform:scale(1.1)}.action-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;margin:0 4px;border:none;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s}.edit-btn{background:#e3f2fd;color:#1976d2}.edit-btn:hover{background:#bbdefb;transform:scale(1.05)}.delete-btn{background:#ffebee;color:#c62828}.delete-btn:hover{background:#ffcdd2;transform:scale(1.05)}.skeleton-screen{padding:20px}.skeleton-row{height:48px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:4px;margin-bottom:12px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.crop-pagination{display:flex;justify-content:space-between;align-items:center;padding:16px;border-top:1px solid #f0f0f0}.pagination-info{font-size:13px;color:#666}.pagination-controls{display:flex;gap:4px;align-items:center}.page-btn{padding:6px 12px;border:1px solid #dcdcdc;border-radius:6px;background:#fff;color:#666;font-size:13px;cursor:pointer;transition:all .2s}.page-btn:hover:not(:disabled){border-color:#4caf50;color:#4caf50}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-btn.active{background:linear-gradient(135deg,#4caf50,#1b5e20);color:#fff;border-color:#4caf50}.page-ellipsis{padding:6px 4px;color:#999}.pagination-size select{padding:6px 12px;border:1px solid #dcdcdc;border-radius:6px;font-size:13px;cursor:pointer}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:12px;box-shadow:0 8px 24px #0003;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}.modal-content.small{max-width:400px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #f0f0f0}.modal-header h3{font-size:18px;font-weight:600;color:#333;margin:0}.modal-close{width:32px;height:32px;border:none;background:transparent;font-size:24px;color:#999;cursor:pointer;border-radius:4px;transition:all .2s}.modal-close:hover{background:#f5f5f5;color:#333}.modal-body{padding:20px}.form-grid{display:grid;grid-template-columns:120px 1fr;gap:16px 12px;align-items:center}.form-grid label{text-align:right;font-size:14px;color:#555;font-weight:500}.form-grid input,.form-grid select{padding:8px 12px;border:1px solid #dcdcdc;border-radius:6px;font-size:13px;transition:all .2s}.form-grid input:hover,.form-grid select:hover{border-color:#4caf50}.form-grid input:focus,.form-grid select:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.range-input-row{display:flex;align-items:center;gap:8px}.range-input-row input{flex:1}.range-separator{color:#999;font-size:16px;font-weight:500;padding:0 4px}.form-item{display:flex;flex-direction:column;gap:8px}.form-item label{font-size:14px;color:#555;font-weight:500}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px;border-top:1px solid #f0f0f0}.toast{position:fixed;top:20px;right:20px;padding:12px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;gap:12px;z-index:3000;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-success{background:#4caf50;color:#fff}.toast-error{background:#f44336;color:#fff}.toast-close{background:transparent;border:none;color:inherit;font-size:18px;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.toast-close:hover{background:#fff3}.crop-area-page{padding:16px;color:var(--cockpit-text)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.page-header h2{color:var(--cockpit-heading)}.filter-card,.table-card,.crop-area-page .card{background:var(--cockpit-panel);border-radius:var(--radius-lg);padding:12px;margin-bottom:12px;border:1px solid var(--cockpit-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-sm)}.filter-card{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr auto;gap:8px}.crop-area-page .primary-btn{background:linear-gradient(135deg,#0e7490,#22d3ee);color:#f0fdfa;border:0;padding:8px 12px;border-radius:6px;cursor:pointer;font-weight:600}.crop-area-page button{border:1px solid var(--cockpit-border);background:#081630a6;border-radius:6px;padding:6px 10px;cursor:pointer;color:var(--cockpit-text-secondary)}.crop-area-page button.danger{color:#fecaca;border-color:#f8717166}.crop-area-page table{width:100%;border-collapse:collapse;font-size:14px}.crop-area-page th,.crop-area-page td{border-bottom:1px solid rgba(56,189,248,.12);padding:8px;text-align:left;color:var(--cockpit-text)}.crop-area-page th{color:var(--cockpit-text-secondary);font-weight:600}.abnormal-row{background:#32141959}.pagination{display:flex;align-items:center;gap:8px;margin-top:8px;color:var(--cockpit-text-muted)}.crop-area-page .modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#020617b8;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.crop-area-page .modal-panel{width:720px;max-height:90vh;overflow:auto;background:var(--cockpit-panel-solid);border-radius:12px;padding:16px;border:1px solid var(--cockpit-border-strong);box-shadow:var(--shadow-lg)}.crop-area-page .modal-panel.detail{width:1000px}.crop-area-page .form-grid{display:grid;grid-template-columns:120px 1fr;gap:8px;align-items:center}.crop-area-page .form-grid label{color:var(--cockpit-text-secondary)}.crop-area-page .form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.card-title{font-weight:600;margin-bottom:8px;color:var(--cockpit-heading)}.card-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.realtime-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.alert-item{color:var(--cockpit-warning);margin-bottom:4px}.history-list{margin:0;padding-left:18px;max-height:180px;overflow:auto;color:var(--cockpit-text-secondary)}.device-row{display:flex;justify-content:space-between;padding:4px 0;color:var(--cockpit-text)}.chart-empty,.loading{color:var(--cockpit-text-muted);padding:16px;text-align:center}@media (max-width: 1100px){.filter-card{grid-template-columns:1fr 1fr}}.cycle-page,.cycle-detail-page{padding:16px;color:var(--cockpit-text)}.cycle-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:12px}.cycle-sub,.cycle-muted{color:var(--cockpit-text-muted);font-size:13px;margin-top:6px}.cycle-table-card,.panel-card,.cycle-detail-card{background:var(--cockpit-panel);border:1px solid var(--cockpit-border);border-radius:var(--radius-lg);padding:12px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-sm)}.cycle-table{width:100%;border-collapse:collapse;font-size:14px}.cycle-table th,.cycle-table td{border-bottom:1px solid rgba(56,189,248,.12);padding:10px;text-align:left;vertical-align:top}.cycle-table th{color:var(--cockpit-text-secondary);font-weight:600}.cycle-table td{color:var(--cockpit-text)}.primary-btn{background:linear-gradient(135deg,#0e7490,#22d3ee);color:#f0fdfa;border:0;padding:8px 12px;border-radius:6px;cursor:pointer;font-weight:600;box-shadow:0 0 14px #22d3ee33}.outline-btn{background:#081630a6;border:1px solid var(--cockpit-border);padding:8px 12px;border-radius:6px;cursor:pointer;color:var(--cockpit-text-secondary)}.outline-btn:disabled{cursor:not-allowed;opacity:.6}.loading,.empty-state-panel{padding:16px;text-align:center;color:var(--cockpit-text-muted)}.stage-chip{display:inline-block;padding:4px 10px;border-radius:999px;background:#38bdf826;color:var(--cockpit-accent-soft);border:1px solid rgba(56,189,248,.3)}.badge-normal{color:var(--cockpit-success)}.badge-danger{color:var(--cockpit-danger)}.cycle-detail-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:12px}.cycle-detail-actions{display:flex;gap:8px;align-items:center;padding-top:8px}.cycle-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.cycle-h2{font-size:20px;font-weight:700;color:var(--cockpit-heading)}.cycle-kv{display:grid;grid-template-columns:repeat(4,minmax(120px,1fr));gap:10px;margin-top:12px}.kv-item{background:#0612268c;border-radius:8px;padding:10px;border:1px solid var(--cockpit-border)}.kv-label{color:var(--cockpit-text-muted);font-size:12px;margin-bottom:6px}.kv-value{font-weight:700;font-size:14px;color:var(--cockpit-text)}.status-pill{padding:8px 14px;border-radius:999px;font-weight:700}.status-normal{background:#4ade8026;color:#86efac;border:1px solid rgba(74,222,128,.35)}.status-danger{background:#f8717126;color:#fecaca;border:1px solid rgba(248,113,113,.35)}.status-gray{background:#0f234499;color:var(--cockpit-text-muted);border:1px solid var(--cockpit-border)}.cycle-grid{display:grid;grid-template-columns:1fr 420px;gap:12px;align-items:start}.cycle-left,.cycle-right{display:flex;flex-direction:column;gap:12px}.panel-title{font-weight:700;margin-bottom:10px;color:var(--cockpit-heading)}.panel-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:10px}.stage-progress-wrap{margin-bottom:12px}.stage-progress-bar{height:10px;background:#061226cc;border-radius:999px;overflow:hidden;border:1px solid var(--cockpit-border)}.stage-progress-fill{height:100%;background:linear-gradient(90deg,#0891b2,#22d3ee,#4ade80)}.stage-progress-text{color:var(--cockpit-text-muted);font-size:13px;margin-top:8px}.stage-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.stage-step{background:#06122680;border:1px solid var(--cockpit-border);border-radius:10px;padding:10px;cursor:default}.stage-step.clickable{cursor:pointer}.stage-step.active{border-color:var(--cockpit-accent);background:#22d3ee1a;box-shadow:0 0 16px #22d3ee1a}.stage-step-title{font-weight:700;color:var(--cockpit-text)}.stage-step-time{margin-top:6px;color:var(--cockpit-text-muted);font-size:12px}.timeline-list{display:flex;flex-direction:column;gap:10px}.timeline-item{border:1px solid var(--cockpit-border);border-radius:10px;padding:10px;background:#06122673;display:grid;grid-template-columns:170px 1fr 200px;gap:10px;align-items:start}.timeline-time{color:var(--cockpit-text-muted);font-size:13px;white-space:nowrap}.timeline-kind{font-weight:700;color:var(--cockpit-text-secondary);margin-bottom:4px}.timeline-content{white-space:normal;color:var(--cockpit-text)}.timeline-operator{color:var(--cockpit-text-muted);font-size:12px;margin-top:6px}.timeline-actions{display:flex;gap:8px;justify-content:flex-end;align-items:center}.mini-btn{border:1px solid var(--cockpit-border);background:#081630a6;border-radius:6px;padding:6px 10px;cursor:pointer;color:var(--cockpit-text-secondary)}.mini-btn.danger{border-color:#f8717166;color:#fecaca}.mini-btn:disabled{cursor:not-allowed;opacity:.6}.chart-controls{display:flex;gap:10px;align-items:center}.chart-controls select{border:1px solid var(--cockpit-border);border-radius:6px;padding:8px 10px;background:#040c1ce6;color:var(--cockpit-text)}.chart-latest{color:var(--cockpit-text-secondary);font-size:13px;margin-bottom:10px}.cycle-detail-page .chart-wrap{height:280px;width:100%;border-radius:10px;border:1px solid var(--cockpit-border);background:#040c1c66}.alert-box{border-radius:10px;padding:12px;border:1px solid var(--cockpit-border);background:#06122680}.alert-normal{border-color:#4ade8059;background:#14322366}.alert-danger{border-color:#f8717159;background:#32141973}.alert-gray{border-color:var(--cockpit-border);background:#0612268c}.alert-status{font-weight:700;margin-bottom:10px;color:var(--cockpit-heading)}.alert-item{color:var(--cockpit-text-secondary)}.muted{color:var(--cockpit-text-muted)}.exceptions-box,.suggestions-box{margin-top:12px}.exceptions-title,.suggestions-title{font-weight:700;margin-bottom:8px;color:var(--cockpit-heading)}.exception-item,.suggestion-item{margin-bottom:6px;color:var(--cockpit-text-secondary)}.cycle-detail-page .modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#020617b8;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cycle-detail-page .modal-panel{width:720px;max-width:100%;background:var(--cockpit-panel-solid);border-radius:12px;padding:16px;border:1px solid var(--cockpit-border-strong);box-shadow:var(--shadow-lg)}.cycle-detail-page .form-grid{display:grid;grid-template-columns:120px 1fr;gap:10px;align-items:start;margin-top:10px}.cycle-detail-page .form-grid label{color:var(--cockpit-text-secondary);font-size:13px}.cycle-detail-page .form-grid select,.cycle-detail-page .form-grid input,.cycle-detail-page .form-grid textarea{border:1px solid var(--cockpit-border);border-radius:8px;padding:10px;width:100%;background:#040c1ce6;color:var(--cockpit-text)}.trend-svg{width:100%;height:220px;background:#0412288c;border-radius:8px;border:1px solid var(--cockpit-border)}textarea{resize:vertical;min-height:110px}@media (max-width: 1100px){.cycle-grid{grid-template-columns:1fr}.cycle-kv{grid-template-columns:repeat(2,1fr)}.timeline-item{grid-template-columns:1fr}}.material-list-page{padding:16px}.material-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.material-sub{color:#909399;font-size:13px;margin-top:6px}.material-actions{display:flex;gap:10px;align-items:center}.outline-btn{background:#fff;border:1px solid #dcdfe6;padding:8px 12px;border-radius:6px;cursor:pointer;color:#606266}.outline-btn:disabled,.primary-btn:disabled{cursor:not-allowed;opacity:.6}.mini-btn{border:1px solid #dcdfe6;background:#fff;border-radius:6px;padding:6px 10px;cursor:pointer;color:#606266}.mini-btn.danger{border-color:#fbc4c4;color:#f56c6c}.material-filter-card{background:#fff;border:1px solid #ebeef5;border-radius:10px;padding:12px;overflow:visible!important;position:relative;z-index:20}.filter-item{position:relative;z-index:10;min-width:220px;flex:1 1 220px}.material-filter-card select{position:relative;z-index:30}.filter-item label{display:block;color:#606266;font-weight:600;font-size:13px;margin-bottom:6px}.filter-item input,.filter-item select{width:100%;border:1px solid #dcdfe6;border-radius:8px;padding:10px 12px;background:#fff;min-height:40px;line-height:20px}.filter-actions{display:flex;gap:10px;justify-content:flex-end;margin-left:auto}.table-card{margin-top:12px;background:#fff;border:1px solid #ebeef5;border-radius:10px;padding:12px;overflow:visible!important}.material-table{width:100%;border-collapse:collapse;font-size:14px}.material-table th,.material-table td{border-bottom:1px solid #f0f2f5;padding:10px;text-align:left;vertical-align:top}.material-table th{color:#606266;font-weight:700}.tag{display:inline-block;padding:3px 10px;border-radius:999px;font-weight:700;font-size:12px}.tag-link{border:0;cursor:pointer}.tag-warn{background:#fef0f0;color:#f59e0b;border:1px solid #fde2e2}.loading,.empty-state-panel{padding:16px;text-align:center;color:#909399}.page-info{color:#909399;font-size:13px}.page-controls{display:flex;gap:10px;align-items:center;justify-content:flex-end}.page-btn{border:1px solid #dcdfe6;background:#fff;border-radius:6px;padding:6px 10px;cursor:pointer;color:#606266}.page-btn:disabled{cursor:not-allowed;opacity:.6}.page-current{color:#409eff;font-weight:700;padding:0 8px}.page-controls select{border:1px solid #dcdfe6;border-radius:6px;padding:6px 10px;background:#fff}.modal-panel{width:760px;max-width:100%;background:#fff;border-radius:12px;padding:16px;border:1px solid #ebeef5}.detail-panel{width:860px}.form-grid label{color:#606266;font-size:13px;padding-top:10px}.form-grid input,.form-grid select{border:1px solid #dcdfe6;border-radius:8px;padding:10px;width:100%;background:#fff}.detail-kv{margin-top:12px;display:grid;grid-template-columns:1fr 1fr;gap:10px 18px}.kv-row{display:flex;gap:12px;align-items:center;background:#fafafa;border:1px solid #f2f2f2;border-radius:10px;padding:10px}.kv-label{color:#909399;font-weight:700;font-size:13px;width:92px}.kv-value{color:#606266;font-weight:700;font-size:14px}.detail-logs{margin-top:14px;border-top:1px solid #f0f2f5;padding-top:14px}.detail-logs-title{font-weight:800;color:#606266;margin-bottom:10px}.muted{color:#909399}.logs-list{display:flex;flex-direction:column;gap:10px}.log-item{display:grid;grid-template-columns:170px 1fr;gap:12px;align-items:start;background:#fafafa;border:1px solid #f2f2f2;border-radius:10px;padding:10px}.log-time{color:#909399;font-size:13px;white-space:nowrap}.log-type{font-weight:800;color:#606266;margin-bottom:6px}.log-reason{color:#606266}.log-operator{color:#909399;font-size:12px;margin-top:6px}.material-warning-page{padding:16px}.warning-header{margin-bottom:12px}.warning-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px}.stat-card.warn{border-color:#fde8c3;background:#fffaf0}.stat-card.danger{border-color:#fde2e2;background:#fef0f0}.stat-label{color:#909399;font-size:13px}.stat-value{font-size:28px;font-weight:700;margin-top:6px;color:#303133}.warning-filter-card{background:#fff;border:1px solid #ebeef5;border-radius:10px;padding:12px;margin-bottom:12px}.filter-item{min-width:220px;flex:1 1 220px}.filter-item label{display:block;color:#606266;font-size:13px;font-weight:600;margin-bottom:6px}.filter-item select{width:100%;border:1px solid #dcdfe6;border-radius:8px;padding:10px 12px;min-height:40px}.table-card{background:#fff;border:1px solid #ebeef5;border-radius:10px;padding:12px}.warning-table{width:100%;border-collapse:collapse;font-size:14px}.warning-table th,.warning-table td{border-bottom:1px solid #f0f2f5;padding:10px;text-align:left}.warning-table th{color:#606266;font-weight:700}.row-danger{background:#fff5f5}.tag-danger{background:#fef0f0;color:#f56c6c;border:1px solid #fde2e2}.row-actions{display:flex;gap:8px}.outline-btn{background:#fff;border:1px solid #dcdfe6;padding:8px 12px;border-radius:6px;color:#606266;cursor:pointer}.pagination{margin-top:14px;display:flex;justify-content:space-between;align-items:center;gap:12px}.page-controls{display:flex;align-items:center;gap:8px}.loading,.empty-state-panel{text-align:center;color:#909399;padding:16px}.modal-panel{width:720px;max-width:100%;background:#fff;border-radius:12px;padding:16px;border:1px solid #ebeef5}.stock-meta{margin-top:6px;color:#606266;font-size:13px}.form-grid{display:grid;grid-template-columns:120px 1fr;gap:12px;margin-top:10px;align-items:start}.form-grid input{border:1px solid #dcdfe6;border-radius:8px;padding:10px;width:100%}.stock-error{margin-top:10px;padding:8px 10px;border-radius:8px;background:#fef0f0;border:1px solid #fde2e2;color:#f56c6c;font-size:13px}.material-purchase-page{padding:16px}.purchase-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.purchase-hint{color:#909399;font-size:13px;margin:0 0 12px;line-height:1.5}.purchase-hint strong{color:#606266;font-weight:600}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px}.stat-card.warn{background:#fffaf0;border-color:#fde8c3}.stat-card .value{margin-top:6px;font-size:28px;font-weight:700}.filter-item{min-width:200px;flex:1 1 200px}.purchase-table{width:100%;border-collapse:collapse;font-size:14px}.purchase-table th,.purchase-table td{border-bottom:1px solid #f0f2f5;padding:10px;text-align:left;vertical-align:top}.purchase-table th{color:#606266;font-weight:700}.th-check,.td-check{width:44px}.th-check input,.td-check input{width:16px;height:16px}.batch-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;margin-bottom:10px;border:1px solid #e4e7ed;border-radius:10px;background:#f5f7fa}.batch-left{color:#303133;font-size:13px}.batch-left strong{color:#409eff}.batch-sub{margin-left:8px;color:#909399}.batch-actions{display:flex;gap:8px;flex-wrap:wrap}.tag{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700}.tag-normal{background:#f0f9eb;color:#67c23a;border:1px solid #e1f3d8}.tag-warn{background:#fff7e6;color:#e6a23c;border:1px solid #f5dab1}.tag-off{background:#f5f5f5;color:#909399;border:1px solid #eee}.modal-panel{width:760px;max-width:100%;background:#fff;border-radius:12px;border:1px solid #ebeef5;padding:16px}.modal-panel.batch-report-panel{width:820px}.batch-report-text{width:100%;min-height:260px;resize:vertical;border:1px solid #dcdfe6;border-radius:8px;padding:10px 12px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px;line-height:1.5;color:#303133;background:#fafafa}.form-grid{display:grid;grid-template-columns:120px 1fr;gap:12px;align-items:start;margin-top:10px}.helper-text{color:#909399;font-size:12px;padding-top:4px}.calc-val{padding-top:10px;font-weight:700}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.material-field-row{grid-column:1 / -1;display:flex;gap:10px;align-items:flex-start;flex-wrap:wrap}.material-field-row select{flex:1 1 200px;min-width:0}.material-field-row .linkish-btn{flex:0 0 auto;white-space:nowrap;border:1px solid #409eff;background:#ecf5ff;color:#409eff;padding:10px 14px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600}.material-field-row .linkish-btn:disabled{opacity:.45;cursor:not-allowed}.modal.nested-modal{z-index:1100}.modal-panel.nested-panel{max-width:480px;width:100%}.stock-flow-page{padding:16px}.stock-flow-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.stock-flow-header h2{margin:0;font-size:20px}.stock-flow-hint{color:#909399;font-size:13px;margin-top:4px}.filter-item{min-width:160px;flex:1 1 160px}.flow-table{width:100%;border-collapse:collapse;font-size:14px}.flow-table th,.flow-table td{border-bottom:1px solid #f0f2f5;padding:10px;text-align:left;vertical-align:top}.flow-table th{color:#606266;font-weight:700}.qty-in{color:#67c23a;font-weight:700}.qty-out{color:#f56c6c;font-weight:700}.tag-flow{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700}.tag-flow-in{background:#f0f9eb;color:#67c23a;border:1px solid #e1f3d8}.tag-flow-out{background:#fef0f0;color:#f56c6c;border:1px solid #fde2e2}.operation-page{padding:16px}.op-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.op-sub{color:#909399;font-size:13px;margin-top:4px;font-weight:400}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:12px}.stat-card{background:#fff;border:1px solid #ebeef5;border-radius:10px;padding:12px}.stat-card .label{color:#909399;font-size:13px}.stat-card .value{margin-top:6px;font-size:24px;font-weight:700}.stats-row.cols-2{grid-template-columns:repeat(2,1fr)}.filter-card,.table-card{background:#fff;border:1px solid #ebeef5;border-radius:10px;padding:12px}.filter-card{margin-bottom:12px}.filter-row{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.filter-item{min-width:180px;flex:1 1 180px}.filter-item input,.filter-item select{width:100%;border:1px solid #dcdfe6;border-radius:8px;padding:10px 12px;min-height:40px}.filter-actions{margin-left:auto}.op-table{width:100%;border-collapse:collapse;font-size:14px}.op-table th,.op-table td{border-bottom:1px solid #f0f2f5;padding:10px;text-align:left}.op-table th{color:#606266;font-weight:700}.row-actions{display:flex;gap:8px;flex-wrap:wrap}.primary-btn{background:#409eff;color:#fff;border:0;padding:8px 12px;border-radius:6px;cursor:pointer}.outline-btn{background:#fff;border:1px solid #dcdfe6;color:#606266;padding:8px 12px;border-radius:6px;cursor:pointer}.mini-btn{border:1px solid #dcdfe6;background:#fff;border-radius:6px;padding:6px 10px;cursor:pointer}.mini-btn.danger{border-color:#fde2e2;color:#f56c6c}.pagination{margin-top:14px;display:flex;justify-content:space-between;align-items:center}.page-controls{display:flex;gap:8px;align-items:center}.page-btn{border:1px solid #dcdfe6;background:#fff;border-radius:6px;padding:6px 10px;cursor:pointer}.page-current{color:#409eff;font-weight:700}.loading{color:#909399;text-align:center;padding:16px}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal-panel{width:820px;max-width:100%;background:#fff;border-radius:12px;border:1px solid #ebeef5;padding:16px}.tips-box{margin-top:8px;margin-bottom:8px}.tip{padding:6px 10px;border-radius:8px;margin-bottom:6px;font-size:13px}.tip.info{background:#f0f7ff;color:#409eff;border:1px solid #d9ecff}.tip.warn{background:#fff7e6;color:#e6a23c;border:1px solid #f5dab1}.form-grid{display:grid;grid-template-columns:120px 1fr;gap:10px;margin-top:8px;align-items:start}.form-grid input,.form-grid select{width:100%;border:1px solid #dcdfe6;border-radius:8px;padding:10px}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}.toast{position:fixed;right:24px;top:72px;background:#fff;color:#303133;padding:10px 14px;border-radius:10px;border:1px solid #e4e7ed;box-shadow:0 6px 18px #0000001f;z-index:2000;font-size:13px;min-width:220px;max-width:420px}.monitor-page{padding:16px}.monitor-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px;margin-bottom:12px}.monitor-header h2{margin:0 0 4px;font-size:20px}.monitor-sub{color:#909399;font-size:13px;max-width:720px}.filter-bar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:16px;background:#fff;border:1px solid #ebeef5;border-radius:10px;padding:12px}.filter-item{min-width:160px}.filter-item label{display:block;margin-bottom:6px;color:#606266;font-size:13px;font-weight:600}.filter-item select,.filter-item input{width:100%;border:1px solid #dcdfe6;border-radius:8px;padding:10px 12px;min-height:40px}.alert-strip{margin-bottom:14px;display:flex;flex-direction:column;gap:8px}.alert-item{padding:10px 14px;border-radius:10px;font-size:14px;border:1px solid #fde2e2;background:#fef0f0;color:#c45656}.alert-item.info{border-color:#b3d8ff;background:#ecf5ff;color:#409eff}.alert-item.warn{border-color:#f5dab1;background:#fff7e6;color:#b88230}.panels-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.panel-card{background:#fff;border:1px solid #ebeef5;border-radius:12px;padding:14px;box-shadow:0 1px 4px #0000000a}.panel-card.abnormal{border-color:#fbc4c4;background:#fffbfb}.panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid #f0f2f5}.panel-title{font-weight:700;color:#303133;font-size:15px}.panel-meta{font-size:12px;color:#909399;margin-top:4px}.badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:12px;font-weight:700}.badge-ok{background:#f0f9eb;color:#67c23a;border:1px solid #e1f3d8}.badge-bad{background:#fef0f0;color:#f56c6c;border:1px solid #fde2e2}.metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.metric-cell{background:#fafafa;border-radius:10px;padding:10px;border:1px solid #f0f2f5}.metric-cell.bad{border-color:#fde2e2;background:#fff5f5}.metric-label{font-size:12px;color:#909399}.metric-value{font-size:22px;font-weight:800;color:#303133;margin-top:4px}.metric-unit{font-size:13px;font-weight:600;color:#606266;margin-left:2px}.metric-tip{font-size:12px;color:#e6a23c;margin-top:6px}.irrigation-banner{margin-top:10px;padding:8px 10px;border-radius:8px;background:#ecf5ff;color:#409eff;font-size:13px;border:1px solid #d9ecff}.chart-wrap{width:100%;height:420px;background:#fff;border:1px solid #ebeef5;border-radius:12px;padding:8px}.report-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-bottom:16px}.report-card{background:#fff;border:1px solid #ebeef5;border-radius:10px;padding:14px}.report-card h4{margin:0 0 8px;font-size:14px;color:#606266}.report-card .big{font-size:26px;font-weight:800;color:#303133}.report-card .sub{font-size:13px;color:#909399;margin-top:6px}.trend-block{background:#fff;border:1px solid #ebeef5;border-radius:10px;padding:14px;margin-bottom:12px}.trend-block h4{margin:0 0 10px;font-size:15px}.trend-line{font-size:14px;color:#606266;line-height:1.6}.anomaly-table{width:100%;border-collapse:collapse;font-size:14px}.anomaly-table th,.anomaly-table td{border-bottom:1px solid #f0f2f5;padding:10px;text-align:left}.primary-btn{background:#409eff;color:#fff;border:0;padding:8px 14px;border-radius:8px;cursor:pointer}.outline-btn{background:#fff;border:1px solid #dcdfe6;color:#606266;padding:8px 14px;border-radius:8px;cursor:pointer}.refresh-hint{font-size:12px;color:#909399}.toast{position:fixed;right:24px;top:72px;background:#fff;color:#303133;padding:10px 14px;border-radius:10px;border:1px solid #e4e7ed;box-shadow:0 6px 18px #0000001f;z-index:2000;font-size:13px}.toast.error{border-color:#fde2e2;background:#fef0f0;color:#f56c6c}.warning-module-page{padding:16px;width:100%;max-width:none;margin:0}.warning-module-header{margin-bottom:14px}.warning-module-header h2{margin:0 0 6px;font-size:20px;color:#303133}.warning-module-sub{color:#909399;font-size:13px;margin:0;max-width:800px;line-height:1.5}.warning-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:14px;background:#fff;border:1px solid #ebeef5;border-radius:10px;padding:12px}.warning-toolbar .field{min-width:140px}.warning-toolbar .field.grow{flex:1 1 220px}.warning-toolbar .field label{display:block;font-size:12px;font-weight:600;color:#606266;margin-bottom:4px}.warning-toolbar .field input,.warning-toolbar .field select{width:100%;border:1px solid #dcdfe6;border-radius:8px;padding:8px 10px;min-height:36px}.warning-toolbar-actions{margin-left:auto;display:flex;gap:8px;align-items:center;flex-wrap:wrap}.warning-table-card{background:#fff;border:1px solid #ebeef5;border-radius:10px;overflow:auto}.warning-data-table{width:100%;border-collapse:collapse;font-size:14px;min-width:720px}.warning-data-table th,.warning-data-table td{border-bottom:1px solid #f0f2f5;padding:10px 12px;text-align:left;vertical-align:middle}.warning-data-table th{color:#606266;font-weight:700;background:#fafafa;white-space:nowrap}.warning-data-table tr:hover td{background:#fafcff}.type-cell{display:inline-flex;align-items:center;gap:8px}.badge-ml{display:inline-flex;align-items:center;font-size:11px;padding:2px 8px;border-radius:999px;border:1px solid rgba(99,102,241,.22);background:#6366f11a;color:#4338caf2;font-weight:800}.detail-cell{max-width:320px}.detail-plain{display:block;max-width:320px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#0f172ad1}.ml-row{display:flex;align-items:baseline;gap:10px;margin-bottom:2px}.ml-row.compare{margin-top:2px}.ml-k{font-size:12px;color:#0f172a9e;min-width:56px}.ml-v{font-size:12px;font-weight:800;color:#0f172ae0}.ml-v.risk-high{color:#ef4444}.ml-v.risk-mid{color:#f59e0b}.ml-v.risk-low{color:#16a34a}.badge-status{display:inline-block;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:600}.badge-status.online{background:#f0f9eb;color:#67c23a}.badge-status.offline{background:#f4f4f5;color:#909399}.badge-status.fault{background:#fef0f0;color:#f56c6c}.badge-status.pending{background:#fdf6ec;color:#e6a23c}.badge-status.done{background:#ecf5ff;color:#409eff}.warning-actions{display:flex;flex-wrap:wrap;gap:8px}.warning-actions button{border:0;border-radius:8px;padding:6px 12px;font-size:13px;cursor:pointer}.btn-primary{background:#409eff;color:#fff}.btn-ghost{background:#fff;border:1px solid #dcdfe6!important;color:#606266}.btn-danger{background:#fef0f0;color:#f56c6c;border:1px solid #fde2e2!important}.warning-toolbar .btn-primary,.warning-toolbar .btn-ghost{min-height:36px;padding:7px 14px;border-radius:8px;font-size:13px}.warning-pagination{display:flex;align-items:center;gap:12px;margin-top:12px;flex-wrap:wrap;font-size:14px;color:#606266}.warning-pagination button{padding:6px 12px;border-radius:8px;border:1px solid #dcdfe6;background:#fff;cursor:pointer}.warning-pagination button:disabled{opacity:.45;cursor:not-allowed}.warning-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:2100;display:flex;align-items:center;justify-content:center;padding:16px}.warning-modal{background:#fff;border-radius:12px;width:100%;max-width:520px;max-height:90vh;overflow:auto;box-shadow:0 12px 40px #00000026;padding:20px}.warning-modal h3{margin:0 0 16px;font-size:17px}.warning-form-grid{display:grid;gap:12px}.warning-form-grid label{display:block;font-size:13px;font-weight:600;color:#606266;margin-bottom:4px}.warning-form-grid input,.warning-form-grid select,.warning-form-grid textarea{width:100%;border:1px solid #dcdfe6;border-radius:8px;padding:8px 10px;font-size:14px;box-sizing:border-box}.warning-form-grid textarea{min-height:72px;resize:vertical}.warning-modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.warning-toast{position:fixed;right:20px;top:72px;z-index:2200;padding:10px 14px;border-radius:10px;font-size:13px;box-shadow:0 6px 18px #0000001f;border:1px solid #e4e7ed;background:#fff;color:#303133}.warning-toast.error{border-color:#fde2e2;background:#fef0f0;color:#c45656}.warning-stats-summary{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:16px}.warning-stat-card{background:#fff;border:1px solid #ebeef5;border-radius:10px;padding:14px}.warning-stat-card .num{font-size:26px;font-weight:800;color:#303133}.warning-stat-card .lbl{font-size:13px;color:#909399;margin-top:4px}.warning-chart-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px;margin-bottom:16px}.warning-chart-box{background:#fff;border:1px solid #ebeef5;border-radius:10px;padding:12px}.warning-chart-box h4{margin:0 0 8px;font-size:15px;color:#303133}.warning-chart-el{width:100%;height:280px}@media (max-width: 900px){.warning-toolbar-actions{margin-left:0;width:100%;justify-content:flex-start}}.warning-empty{text-align:center;color:#909399;padding:40px 16px;font-size:14px}.system-page{padding:16px}.system-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.system-sub{color:#909399;font-size:13px;margin:0 0 12px}.system-card{background:#fff;border:1px solid #ebeef5;border-radius:10px;padding:12px}.system-filter{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;margin-bottom:12px}.system-filter .field{min-width:160px}.system-filter label{display:block;margin-bottom:4px;color:#606266;font-size:12px;font-weight:600}.system-filter input,.system-filter select{width:100%;border:1px solid #dcdfe6;border-radius:8px;padding:8px 10px;min-height:36px}.system-table{width:100%;border-collapse:collapse;font-size:14px}.system-table th,.system-table td{border-bottom:1px solid #f0f2f5;padding:10px;text-align:left;vertical-align:middle}.system-table th{color:#606266;font-weight:700;background:#fafafa}.system-actions{display:flex;flex-wrap:wrap;gap:8px}.sys-btn{border-radius:8px;padding:6px 12px;border:1px solid #dcdfe6;background:#fff;cursor:pointer}.sys-btn.primary{background:#409eff;border-color:#409eff;color:#fff}.sys-btn.danger{border-color:#fde2e2;background:#fef0f0;color:#f56c6c}.sys-pagebar{margin-top:12px;display:flex;gap:10px;align-items:center;color:#606266}.sys-modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:2100;display:flex;align-items:center;justify-content:center;padding:16px}.sys-modal{width:100%;max-width:520px;background:#fff;border-radius:12px;padding:16px}.sys-form{display:grid;gap:10px}.sys-form label{display:block;margin-bottom:4px;color:#606266;font-size:13px;font-weight:600}.sys-form input,.sys-form select{width:100%;border:1px solid #dcdfe6;border-radius:8px;padding:8px 10px}.sys-roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.sys-role-card{border:1px solid #ebeef5;border-radius:10px;padding:12px;background:#fff}.sys-role-title{font-size:16px;font-weight:700;margin-bottom:8px;color:#303133}.sys-kv{font-size:13px;color:#606266;line-height:1.7}.sys-toast{position:fixed;right:20px;top:72px;z-index:2200;background:#fff;border:1px solid #dcdfe6;border-radius:10px;padding:10px 14px;box-shadow:0 6px 18px #0000001f}.sidebar{width:var(--sidebar-width);height:100vh;background:linear-gradient(180deg,#050c18,#0a1628 40%,#071018);border-right:1px solid var(--cockpit-border);overflow-y:auto;overflow-x:hidden;position:fixed;left:0;top:0;z-index:100;box-shadow:4px 0 32px #0006}.sidebar:before{content:"";position:absolute;top:0;right:0;width:1px;height:100%;background:linear-gradient(180deg,transparent,rgba(34,211,238,.35) 40%,rgba(34,211,238,.35) 60%,transparent);pointer-events:none}.sidebar-content{padding:24px 0 32px}.menu-item{margin-bottom:2px}.menu-title{display:flex;align-items:center;padding:12px 18px;margin:0 10px;cursor:pointer;transition:all .25s;color:var(--cockpit-text-secondary);font-size:14px;-webkit-user-select:none;user-select:none;border-radius:var(--radius-md);border:1px solid transparent}.menu-title:hover{background:#22d3ee14;color:var(--cockpit-accent-soft);border-color:#38bdf826}.menu-title.active{background:linear-gradient(90deg,#22d3ee2e,#22d3ee0a);color:var(--cockpit-accent-soft);border-left:3px solid var(--cockpit-accent);border-color:#38bdf840;box-shadow:0 0 20px #22d3ee14}.menu-icon{font-size:18px;margin-right:10px;width:22px;text-align:center;filter:drop-shadow(0 0 4px rgba(34,211,238,.25))}.menu-text{flex:1;font-weight:600;letter-spacing:.02em}.sidebar-nav-dot{width:8px;height:8px;border-radius:50%;background:var(--cockpit-danger);flex-shrink:0;margin-right:6px;box-shadow:0 0 10px #f87171a6;animation:pulse-sidebar-dot 2s ease-in-out infinite}@keyframes pulse-sidebar-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.08)}}.menu-arrow{font-size:10px;transition:transform .25s;color:var(--cockpit-text-muted)}.menu-arrow.expanded{transform:rotate(180deg);color:var(--cockpit-accent)}.menu-children{background:#02081473;padding:6px 0;margin:4px 10px 8px;border-radius:var(--radius-md);border:1px solid rgba(56,189,248,.08)}.menu-child{padding:10px 16px 10px 48px;cursor:pointer;transition:all .2s;color:var(--cockpit-text-muted);font-size:13px;position:relative;margin:0 6px;border-radius:var(--radius-sm)}.menu-child:hover{background:#22d3ee14;color:var(--cockpit-text)}.menu-child.active{background:#22d3ee1f;color:var(--cockpit-accent-soft);font-weight:600}.menu-child.active:before{content:"";position:absolute;left:36px;top:50%;transform:translateY(-50%);width:5px;height:5px;background:var(--cockpit-accent);border-radius:50%;box-shadow:0 0 8px var(--cockpit-accent)}.topbar{height:var(--topbar-height);background:linear-gradient(180deg,#0c1c3afa,#08142af5,#061024fa);color:var(--cockpit-heading);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-7);position:fixed;top:0;left:var(--sidebar-width);right:0;z-index:99;border-bottom:1px solid var(--cockpit-border);box-shadow:0 0 40px #22d3ee14,0 4px 24px #00000059}.topbar:after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:linear-gradient(90deg,transparent 0%,rgba(34,211,238,.15) 15%,rgba(34,211,238,.65) 50%,rgba(34,211,238,.15) 85%,transparent 100%);pointer-events:none;opacity:.9}.topbar-left{display:flex;align-items:center;gap:var(--space-6)}.global-farm-indicator{font-size:12px;color:#f0f9ffeb;background:#22d3ee1a;border:1px solid var(--cockpit-border);padding:4px 12px;border-radius:999px;white-space:nowrap;display:inline-flex;align-items:center;gap:8px;-webkit-user-select:none;user-select:none}.global-farm-indicator.is-clickable{cursor:pointer;transition:background .2s,transform .15s,border-color .2s,box-shadow .2s}.global-farm-indicator.is-clickable:hover{background:#22d3ee2e;border-color:var(--cockpit-border-strong);box-shadow:0 0 16px #22d3ee33;transform:translateY(-1px)}.global-farm-indicator:focus-visible{outline:2px solid var(--cockpit-accent);outline-offset:2px}.farm-pin{font-size:14px;line-height:1;filter:drop-shadow(0 0 6px rgba(34,211,238,.5))}.farm-label{opacity:.85;color:var(--cockpit-text-secondary)}.farm-name{color:var(--cockpit-accent-soft);font-weight:700}.farm-arrow{font-size:10px;opacity:.85;transition:transform .2s}.farm-arrow.expanded{transform:rotate(180deg)}.farm-menu-container{position:relative}.farm-dropdown{position:absolute;top:calc(100% + 10px);left:0;min-width:320px;max-height:360px;overflow:auto;background:#061226f7;border:1px solid var(--cockpit-border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg),0 0 32px #22d3ee1f;padding:8px;z-index:1000;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.farm-dd-item{width:100%;text-align:left;border:1px solid rgba(56,189,248,.15);background:#0f234480;color:var(--cockpit-text);padding:10px;border-radius:var(--radius-md);cursor:pointer;display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.farm-dd-item:hover{background:#22d3ee1f;border-color:var(--cockpit-border)}.farm-dd-item.active{background:#22d3ee29;border-color:var(--cockpit-accent);box-shadow:0 0 12px #22d3ee26}.farm-dd-name{font-weight:700;font-size:13px;letter-spacing:.2px}.farm-dd-meta{font-size:12px;color:var(--cockpit-text-muted)}.farm-dd-divider{height:1px;background:var(--cockpit-border);margin:6px 0 10px}.farm-dd-loading,.farm-dd-empty{font-size:12px;color:var(--cockpit-text-secondary);padding:10px 8px}.system-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:17px;letter-spacing:.04em}.logo-icon{font-size:22px;filter:drop-shadow(0 0 8px rgba(34,211,238,.45))}.system-name{white-space:nowrap;color:var(--cockpit-heading)}@supports (-webkit-background-clip: text) or (background-clip: text){.system-name{background:linear-gradient(90deg,#f0f9ff,#67e8f9,#a5f3fc);-webkit-background-clip:text;background-clip:text;color:transparent}}.breadcrumb{font-size:13px;color:var(--cockpit-text-secondary)}.breadcrumb-separator{margin:0 8px;color:var(--cockpit-text-muted)}.breadcrumb-current{color:var(--cockpit-accent-soft);font-weight:600}.topbar-right{display:flex;align-items:center;gap:var(--space-4)}.topbar-button{padding:6px 14px;background:#22d3ee14;border:1px solid var(--cockpit-border);border-radius:var(--radius-sm);color:var(--cockpit-text-secondary);cursor:pointer;font-size:13px;font-weight:600;transition:all .25s}.topbar-button:hover{background:#22d3ee29;color:var(--cockpit-heading);border-color:var(--cockpit-border-strong);box-shadow:0 0 14px #22d3ee1f}.user-menu-container{position:relative}.user-info{display:flex;align-items:center;gap:10px;cursor:pointer;padding:6px 12px;border-radius:var(--radius-sm);transition:background .25s;border:1px solid transparent}.user-info:hover{background:#22d3ee14;border-color:#38bdf833}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#0891b2,#22d3ee);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#042f2e;box-shadow:0 0 12px #22d3ee59}.user-name{font-size:13px;font-weight:600;color:var(--cockpit-text)}.user-arrow{font-size:10px;transition:transform .25s;margin-left:4px;color:var(--cockpit-text-muted)}.user-arrow.expanded{transform:rotate(180deg)}.user-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:#061226fa;border-radius:var(--radius-md);border:1px solid var(--cockpit-border-strong);box-shadow:var(--shadow-lg);min-width:168px;overflow:hidden;z-index:1000;animation:slideDown .25s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{padding:12px 18px;color:var(--cockpit-text);cursor:pointer;transition:background .2s;font-size:13px}.dropdown-item:hover{background:#22d3ee1f}.dropdown-item.logout{color:#fca5a5}.dropdown-item.logout:hover{background:#f871711f}.dropdown-divider{height:1px;background:var(--cockpit-border);margin:4px 0}.farm-switch-toast{position:absolute;left:50%;top:calc(var(--topbar-height) + 6px);transform:translate(-50%);background:#083344f2;border:1px solid var(--cockpit-border-strong);color:var(--cockpit-accent-soft);font-size:13px;font-weight:600;padding:8px 16px;border-radius:var(--radius-md);box-shadow:var(--shadow-md),0 0 20px #22d3ee33;pointer-events:none}.main-layout{display:flex;min-height:100vh;position:relative;background:var(--cockpit-deep)}.main-layout:before{content:"";position:fixed;left:var(--sidebar-width);right:0;top:0;bottom:0;pointer-events:none;z-index:0;background-image:linear-gradient(var(--cockpit-grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--cockpit-grid-line) 1px,transparent 1px);background-size:56px 56px;opacity:.45;-webkit-mask-image:radial-gradient(ellipse 85% 75% at 50% 8%,#000 30%,transparent 72%);mask-image:radial-gradient(ellipse 85% 75% at 50% 8%,#000 30%,transparent 72%)}.main-content-wrapper{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;position:relative;z-index:1}.main-content{margin-top:var(--topbar-height);padding:var(--space-6) var(--space-7);min-height:calc(100vh - var(--topbar-height));color:var(--cockpit-text);position:relative;z-index:1}*{margin:0;padding:0;box-sizing:border-box}:root{--sidebar-width: 240px;--topbar-height: 60px;--cockpit-deep: #030712;--cockpit-bg: #0a1628;--cockpit-bg-elevated: #0f1f3a;--cockpit-panel: rgba(15, 35, 68, .78);--cockpit-panel-solid: #0f2344;--cockpit-panel-hover: rgba(20, 45, 82, .92);--cockpit-grid: rgba(34, 211, 238, .06);--cockpit-grid-line: rgba(56, 189, 248, .12);--cockpit-border: rgba(56, 189, 248, .22);--cockpit-border-strong: rgba(34, 211, 238, .42);--cockpit-glow: rgba(34, 211, 238, .35);--cockpit-accent: #22d3ee;--cockpit-accent-soft: #67e8f9;--cockpit-accent-deep: #0891b2;--cockpit-blue: #38bdf8;--cockpit-text: #e2e8f0;--cockpit-text-secondary: #94a3b8;--cockpit-text-muted: #64748b;--cockpit-heading: #f0f9ff;--cockpit-success: #4ade80;--cockpit-warning: #fbbf24;--cockpit-danger: #f87171;--cockpit-info: #38bdf8;--color-bg: var(--cockpit-bg);--color-surface: var(--cockpit-panel-solid);--color-text-1: var(--cockpit-text);--color-text-2: var(--cockpit-text-secondary);--color-text-3: var(--cockpit-text-muted);--color-border: var(--cockpit-border);--color-primary: var(--cockpit-accent);--color-success: var(--cockpit-success);--color-warning: var(--cockpit-warning);--color-danger: var(--cockpit-danger);--color-info: var(--cockpit-blue);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 30px;--shadow-sm: 0 2px 12px rgba(0, 0, 0, .35);--shadow-md: 0 8px 32px rgba(0, 0, 0, .45);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .55);--shadow-glow: 0 0 24px rgba(34, 211, 238, .15)}html{color-scheme:dark}body{font-family:Segoe UI,PingFang SC,Microsoft YaHei,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--cockpit-deep);color:var(--cockpit-text);min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse 120% 80% at 50% -20%,rgba(34,211,238,.12),transparent 50%),radial-gradient(ellipse 80% 50% at 100% 50%,rgba(56,189,248,.06),transparent 45%),linear-gradient(180deg,var(--cockpit-deep) 0%,var(--cockpit-bg) 100%)}#root{position:relative;z-index:1;min-height:100vh}code{font-family:ui-monospace,Cascadia Code,Source Code Pro,Menlo,Consolas,monospace}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0f234480;border-radius:4px}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--cockpit-accent-deep),var(--cockpit-accent));border-radius:4px;opacity:.85}::-webkit-scrollbar-thumb:hover{background:var(--cockpit-accent-soft)}.main-content h1,.main-content h2{color:var(--cockpit-heading);font-weight:700;letter-spacing:.02em}.main-content h2{font-size:1.25rem}.ui-toast-stack{position:fixed;top:calc(var(--topbar-height) + 14px);right:16px;display:flex;flex-direction:column;gap:10px;z-index:2000;max-width:min(420px,calc(100vw - 32px))}.ui-toast{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:var(--radius-lg);border:1px solid var(--cockpit-border);background:#061226f2;box-shadow:var(--shadow-lg),0 0 20px #22d3ee14;color:var(--cockpit-text);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.ui-toast-message{font-size:13px;line-height:1.5;color:var(--cockpit-text-secondary);word-break:break-word}.ui-toast-close{border:none;background:transparent;cursor:pointer;font-size:18px;line-height:1;color:var(--color-text-3);padding:2px 6px;border-radius:8px}.ui-toast-close:hover{background:#22d3ee1f;color:var(--cockpit-accent-soft)}.ui-toast-info{border-left:4px solid var(--color-info)}.ui-toast-success{border-left:4px solid var(--color-success)}.ui-toast-warn{border-left:4px solid var(--color-warning)}.ui-toast-error{border-left:4px solid var(--color-danger)}.ui-btn{border:1px solid var(--cockpit-border);background:#0f2344a6;color:var(--cockpit-text-secondary);border-radius:10px;cursor:pointer;transition:background .15s,border-color .15s,transform .12s,opacity .15s;font-weight:700}.ui-btn:disabled{cursor:not-allowed;opacity:.55}.ui-btn:hover:not(:disabled){background:#22d3ee1f;border-color:var(--cockpit-border-strong);color:var(--cockpit-text);transform:translateY(-1px)}.ui-btn-md{padding:8px 14px;font-size:13px}.ui-btn-sm{padding:6px 10px;font-size:12px}.ui-btn-primary{background:linear-gradient(135deg,#0e749080,#22d3ee40);border-color:#22d3ee73;color:#ecfeff;box-shadow:0 0 16px #22d3ee26}.ui-btn-outline{background:#08163099}.ui-btn-ghost{background:transparent;border-color:transparent}.ui-btn-danger{background:#7f1d1d59;border-color:#f8717166;color:#fecaca}.main-content input:not([type=checkbox]):not([type=radio]):not([type=file]),.main-content select,.main-content textarea{background:#061226eb!important;border:1px solid var(--cockpit-border)!important;color:var(--cockpit-text)!important;border-radius:var(--radius-md)}.main-content input::placeholder,.main-content textarea::placeholder{color:var(--cockpit-text-muted)}.main-content input:focus,.main-content select:focus,.main-content textarea:focus{outline:none;border-color:var(--cockpit-border-strong)!important;box-shadow:0 0 0 2px #22d3ee26}.main-content .primary-btn{background:linear-gradient(135deg,#0e7490,#0891b2 40%,#22d3ee)!important;color:#f0fdfa!important;border:1px solid rgba(34,211,238,.45)!important;box-shadow:var(--shadow-glow);font-weight:700}.main-content .primary-btn:hover:not(:disabled){filter:brightness(1.08);box-shadow:0 0 28px #22d3ee47}.main-content .outline-btn{background:#0f234480!important;border:1px solid var(--cockpit-border)!important;color:var(--cockpit-text-secondary)!important}.main-content .outline-btn:hover:not(:disabled){border-color:var(--cockpit-border-strong)!important;color:var(--cockpit-text)!important}.main-content .mini-btn{background:#0f23448c!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text-secondary)!important}.main-content .page-btn,.main-content .sys-btn{background:#0f23448c!important;border:1px solid var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content table th{background:#081630f2!important;color:var(--cockpit-text-secondary)!important;border-color:var(--cockpit-border)!important}.main-content table td{border-color:#38bdf81f!important;color:var(--cockpit-text)!important}.main-content table tr:hover td{background:#22d3ee0f!important}.main-content .farm-list-header h2,.main-content .material-header h2,.main-content .op-header h2{color:var(--cockpit-heading)!important}.main-content .farm-list-sub,.main-content .material-sub,.main-content .op-sub,.main-content .monitor-sub,.main-content .system-sub{color:var(--cockpit-text-muted)!important}.main-content .warning-toolbar,.main-content .warning-table-card,.main-content .warning-modal,.main-content .system-card,.main-content .system-filter,.main-content .filter-bar,.main-content .panel-card,.main-content .chart-wrap,.main-content .report-card,.main-content .trend-block,.main-content .filter-card,.main-content .table-card,.main-content .stat-card,.main-content .material-filter-card,.main-content .material-table-card,.main-content .farm-filter-card,.main-content .farm-table-wrap,.main-content .modal-panel,.main-content .sys-modal,.main-content .sys-role-card{background:var(--cockpit-panel)!important;border:1px solid var(--cockpit-border)!important;box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.main-content .warning-module-header h2,.main-content .monitor-header h2,.main-content .system-header h2{color:var(--cockpit-heading)!important}.main-content .warning-module-sub{color:var(--cockpit-text-muted)!important}.main-content .warning-stat-card,.main-content .warning-chart-box{background:#081630a6!important;border:1px solid var(--cockpit-border)!important}.main-content .warning-stat-card .num,.main-content .warning-stat-card .lbl,.main-content .warning-chart-box h4{color:var(--cockpit-text)!important}.main-content .warning-stat-card .lbl{color:var(--cockpit-text-muted)!important}.main-content .warning-data-table th,.main-content .system-table th{background:#061226fa!important}.main-content .warning-modal-overlay,.main-content .sys-modal-mask,.main-content .modal{background:#020617b8!important;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.main-content .warning-toast,.main-content .toast,.main-content .sys-toast{background:var(--cockpit-panel-solid)!important;border:1px solid var(--cockpit-border)!important;color:var(--cockpit-text)!important;box-shadow:var(--shadow-md)}.main-content .toast.error,.main-content .warning-toast.error{border-color:#f8717173!important;background:#3c1419d9!important;color:#fecaca!important}.main-content .filter-item label,.main-content .warning-toolbar .field label,.main-content .system-filter label{color:var(--cockpit-text-secondary)!important}.main-content .panel-title,.main-content .report-card h4,.main-content .report-card .big,.main-content .metric-value{color:var(--cockpit-heading)!important}.main-content .metric-label,.main-content .panel-meta,.main-content .report-card .sub{color:var(--cockpit-text-muted)!important}.main-content .metric-cell{background:#0612268c!important;border-color:var(--cockpit-border)!important}.main-content .pagination,.main-content .sys-pagebar,.main-content .warning-pagination{color:var(--cockpit-text-secondary)!important}.main-content .loading,.main-content .warning-empty{color:var(--cockpit-text-muted)!important}.main-content .farm-list-actions .primary-btn{background:linear-gradient(135deg,#0e7490,#0891b2 45%,#22d3ee)!important;color:#f0fdfa!important;border:1px solid rgba(34,211,238,.4)!important;box-shadow:0 0 18px #22d3ee33}.main-content .farm-detail-page .farm-detail-header h2{color:var(--cockpit-heading)!important}.main-content .farm-detail-page .sub-text{color:var(--cockpit-text-muted)!important}.main-content .farm-detail-page .farm-name-trigger{color:var(--cockpit-accent-soft)!important}.main-content .farm-detail-page .farm-name-trigger:hover,.main-content .farm-detail-page .farm-name-trigger.active{color:#a5f3fc!important}.main-content .farm-detail-page .farm-name-underline{background:linear-gradient(90deg,var(--cockpit-accent),var(--cockpit-accent-deep))!important}.main-content .farm-detail-page .farm-name-arrow{color:var(--cockpit-text-muted)!important}.main-content .farm-detail-page .farm-panel{background:#061226f7!important;border:1px solid var(--cockpit-border-strong)!important;box-shadow:var(--shadow-lg),0 0 32px #22d3ee1a!important;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.main-content .farm-detail-page .farm-panel-search{border-bottom-color:var(--cockpit-border)!important}.main-content .farm-detail-page .search-icon{color:var(--cockpit-text-muted)!important}.main-content .farm-detail-page .farm-panel-search input{background:#040c1ce6!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content .farm-detail-page .search-highlight{background:#fbbf2440!important;color:#fde68a!important}.main-content .farm-detail-page .farm-panel-status-filter{background:#040c1c99!important;border-bottom-color:var(--cockpit-border)!important}.main-content .farm-detail-page .status-filter-btn{background:#081630bf!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text-secondary)!important}.main-content .farm-detail-page .status-filter-btn:hover{border-color:var(--cockpit-accent)!important;color:var(--cockpit-accent-soft)!important}.main-content .farm-detail-page .status-filter-btn.active{color:#042f2e!important;border-color:var(--cockpit-accent)!important}.main-content .farm-detail-page .status-filter-btn.status-normal.active{background:linear-gradient(135deg,#0e7490,#22d3ee)!important}.main-content .farm-detail-page .farm-panel-item:hover{background:#22d3ee14!important;border-left-color:var(--cockpit-accent)!important}.main-content .farm-detail-page .farm-panel-item.active{background:linear-gradient(135deg,#0c4a6e,#155e75)!important;color:var(--cockpit-heading)!important;border-left-color:var(--cockpit-accent)!important}.main-content .farm-detail-page .farm-panel-item.selected{background:#22d3ee1a!important}.main-content .farm-detail-page .farm-item-name{color:var(--cockpit-text)!important}.main-content .farm-detail-page .farm-item-address{color:var(--cockpit-text-muted)!important}.main-content .farm-detail-page .farm-item-checkmark{color:var(--cockpit-accent)!important}.main-content .farm-detail-page .quick-switch-btn,.main-content .farm-detail-page .batch-export-btn,.main-content .farm-detail-page .empty-action-btn{background:linear-gradient(135deg,#0e7490,#22d3ee)!important;color:#f0fdfa!important;border:none!important;box-shadow:0 0 14px #22d3ee40}.main-content .farm-detail-page .view-all-btn{background:#081630cc!important;color:var(--cockpit-accent-soft)!important;border:1px solid var(--cockpit-border-strong)!important}.main-content .farm-detail-page .view-all-btn:hover{background:#22d3ee1f!important}.main-content .farm-detail-page .more-menu{background:var(--cockpit-panel-solid)!important;border:1px solid var(--cockpit-border)!important;box-shadow:var(--shadow-lg)!important}.main-content .farm-detail-page .more-menu-item{color:var(--cockpit-text)!important}.main-content .farm-detail-page .more-menu-item:hover{background:#22d3ee1a!important}.main-content .farm-detail-page .more-menu-item.danger{color:#fecaca!important}.main-content .farm-detail-page .more-menu-item.danger:hover{background:#f871711f!important}.main-content .farm-detail-page .farm-panel-footer{border-top-color:var(--cockpit-border)!important}.main-content .farm-detail-page .farm-panel-empty,.main-content .farm-detail-page .empty-text{color:var(--cockpit-text-muted)!important}.main-content .farm-detail-page .btn-secondary{background:#081630bf!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text-secondary)!important}.main-content .farm-detail-page .btn-secondary:hover{border-color:var(--cockpit-accent)!important;color:var(--cockpit-accent-soft)!important}.main-content .farm-detail-page .back-menu{background:var(--cockpit-panel-solid)!important;border:1px solid var(--cockpit-border)!important;box-shadow:var(--shadow-lg)!important}.main-content .farm-detail-page .back-menu-item{color:var(--cockpit-text)!important}.main-content .farm-detail-page .back-menu-item:hover{background:#22d3ee1a!important}.main-content .farm-detail-page .loading-spinner{border-color:#38bdf833!important;border-top-color:var(--cockpit-accent)!important}.main-content .farm-detail-page .loading-text{color:var(--cockpit-text-muted)!important}.main-content .farm-detail-page .notification-content{background:var(--cockpit-panel-solid)!important;border:1px solid var(--cockpit-border-strong)!important;color:var(--cockpit-text)!important;box-shadow:var(--shadow-lg)!important}.main-content .farm-detail-page .farm-tabs{border-bottom-color:var(--cockpit-border)!important}.main-content .farm-detail-page .farm-tab{color:var(--cockpit-text-muted)!important}.main-content .farm-detail-page .farm-tab.active{background:#081630e6!important;border:1px solid var(--cockpit-border)!important;border-bottom:none!important;color:var(--cockpit-accent-soft)!important;font-weight:600}.main-content .farm-detail-page .farm-tab-panel{background:var(--cockpit-panel)!important;border:1px solid var(--cockpit-border)!important;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.main-content .farm-detail-page .card{background:#0612268c!important;border:1px solid var(--cockpit-border)!important}.main-content .farm-detail-page .card-title{color:var(--cockpit-heading)!important}.main-content .farm-detail-page .form-grid label{color:var(--cockpit-text-secondary)!important}.main-content .farm-detail-page .coord-separator{color:var(--cockpit-text-muted)!important}.main-content .farm-detail-page .actions button{background:#081630bf!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content .farm-detail-page .actions .primary,.main-content .farm-detail-page .submit-btn{background:linear-gradient(135deg,#0e7490,#22d3ee)!important;color:#f0fdfa!important;border:none!important;box-shadow:0 0 16px #22d3ee33}.main-content .farm-detail-page .simple-table th{background:#040c1cf2!important;color:var(--cockpit-text-secondary)!important;border-bottom-color:var(--cockpit-border)!important}.main-content .farm-detail-page .simple-table td{border-bottom-color:#38bdf81a!important;color:var(--cockpit-text)!important}.main-content .farm-detail-page .simple-table button{background:#081630bf!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content .farm-detail-page .mini-chart{background:#06122680!important;border-color:var(--cockpit-border)!important}.main-content .farm-detail-page .chart-title{color:var(--cockpit-heading)!important}.main-content .farm-detail-page .chart-footer,.main-content .farm-detail-page .chart-empty,.main-content .farm-detail-page .bar-label{color:var(--cockpit-text-muted)!important}.main-content .farm-detail-page .ring-inner{background:var(--cockpit-bg-elevated)!important;color:var(--cockpit-accent-soft)!important}.main-content .farm-detail-page .factor-item{background:#0612268c!important;color:var(--cockpit-text-secondary)!important}.main-content .farm-detail-page .advice-list{color:var(--cockpit-text-secondary)!important}.main-content .crop-list-page{background:transparent!important;min-height:auto!important;padding:20px}.main-content .crop-list-page .crop-list-header h2{color:var(--cockpit-heading)!important}.main-content .crop-list-page .primary-btn{background:linear-gradient(135deg,#0e7490,#22d3ee)!important;color:#f0fdfa!important;box-shadow:0 0 16px #22d3ee33}.main-content .crop-list-page .primary-outline-btn{background:#081630bf!important;color:var(--cockpit-accent-soft)!important;border:1px solid var(--cockpit-border-strong)!important}.main-content .crop-list-page .primary-outline-btn:hover{background:#22d3ee1f!important}.main-content .crop-list-page .quick-farm-filter{background:var(--cockpit-panel)!important;border:1px solid var(--cockpit-border)!important;box-shadow:var(--shadow-sm)}.main-content .crop-list-page .quick-filter-label{color:var(--cockpit-text-secondary)!important}.main-content .crop-list-page .quick-filter-btn{background:#081630bf!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text-secondary)!important}.main-content .crop-list-page .quick-filter-btn:hover{border-color:var(--cockpit-accent)!important;color:var(--cockpit-accent-soft)!important}.main-content .crop-list-page .quick-filter-btn.active{background:linear-gradient(135deg,#0e7490,#22d3ee)!important;color:#042f2e!important;border-color:var(--cockpit-accent)!important}.main-content .crop-list-page .crop-filter-panel{background:var(--cockpit-panel)!important;border:1px solid var(--cockpit-border)!important;box-shadow:var(--shadow-sm)}.main-content .crop-list-page .filter-item label{color:var(--cockpit-text-secondary)!important}.main-content .crop-list-page .filter-sep,.main-content .crop-list-page .advanced-link{color:var(--cockpit-text-muted)!important}.main-content .crop-list-page .advanced-link{color:var(--cockpit-accent-soft)!important}.main-content .crop-list-page .filter-actions-row{border-top-color:var(--cockpit-border)!important}.main-content .crop-list-page .crop-table-wrapper{background:var(--cockpit-panel)!important;border:1px solid var(--cockpit-border)!important}.main-content .crop-list-page .batch-bar{background:#22d3ee14!important;border-bottom-color:var(--cockpit-border)!important}.main-content .crop-list-page .batch-bar span{color:var(--cockpit-text-secondary)!important}.main-content .crop-list-page .batch-bar button{background:#081630d9!important;border-color:var(--cockpit-accent)!important;color:var(--cockpit-accent-soft)!important}.main-content .crop-list-page .batch-bar button:hover{background:#22d3ee33!important;color:#f0fdfa!important}.main-content .crop-list-page .crop-table thead{background:#040c1cf2!important}.main-content .crop-list-page .crop-table th{color:var(--cockpit-text-secondary)!important;border-bottom-color:var(--cockpit-border)!important}.main-content .crop-list-page .crop-table td{border-bottom-color:#38bdf81a!important;color:var(--cockpit-text)!important}.main-content .crop-list-page .crop-table th.sortable:hover{background:#22d3ee14!important}.main-content .crop-list-page .sort-indicator{color:var(--cockpit-accent)!important}.main-content .crop-list-page .crop-table tbody tr:hover{background:#22d3ee0f!important}.main-content .crop-list-page .crop-name-cell{color:var(--cockpit-accent-soft)!important}.main-content .crop-list-page .crop-overview-card{background:var(--cockpit-panel-solid)!important;border:1px solid var(--cockpit-border-strong)!important;box-shadow:var(--shadow-lg)!important}.main-content .crop-list-page .overview-title{color:var(--cockpit-heading)!important;border-bottom-color:var(--cockpit-border)!important}.main-content .crop-list-page .overview-label{color:var(--cockpit-text-muted)!important}.main-content .crop-list-page .overview-data{color:var(--cockpit-text)!important}.main-content .crop-list-page .overview-data.highlight{color:var(--cockpit-success)!important}.main-content .crop-list-page .health-score-text{color:var(--cockpit-heading)!important}.main-content .crop-list-page .empty-text{color:var(--cockpit-text-muted)!important}.main-content .crop-list-page .crop-pagination{border-top-color:var(--cockpit-border)!important}.main-content .crop-list-page .pagination-info{color:var(--cockpit-text-muted)!important}.main-content .crop-list-page .page-btn{background:#081630bf!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content .crop-list-page .page-btn.active{background:linear-gradient(135deg,#0e7490,#22d3ee)!important;color:#f0fdfa!important;border-color:var(--cockpit-accent)!important}.main-content .crop-list-page .modal-content{background:var(--cockpit-panel-solid)!important;border:1px solid var(--cockpit-border-strong)!important;box-shadow:var(--shadow-lg)!important}.main-content .crop-list-page .modal-header{border-bottom-color:var(--cockpit-border)!important}.main-content .crop-list-page .modal-header h3{color:var(--cockpit-heading)!important}.main-content .crop-list-page .modal-footer{border-top-color:var(--cockpit-border)!important}.main-content .crop-list-page .form-grid label{color:var(--cockpit-text-secondary)!important}.main-content .crop-list-page .range-separator{color:var(--cockpit-text-muted)!important}.main-content .crop-list-page .skeleton-row{background:linear-gradient(90deg,#0f234480 25%,#22d3ee14,#0f234480 75%)!important}.main-content .crop-list-page .edit-btn{background:#38bdf826!important;color:#7dd3fc!important}.main-content .crop-list-page .delete-btn{background:#f8717126!important;color:#fecaca!important}.main-content .farm-manager-page .farm-manager-header h2{color:var(--cockpit-heading)!important}.main-content .farm-manager-page .tab-btn{background:#081630bf!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text-secondary)!important}.main-content .farm-manager-page .tab-btn:hover{border-color:var(--cockpit-accent)!important;color:var(--cockpit-accent-soft)!important}.main-content .farm-manager-page .tab-btn.active{background:linear-gradient(135deg,#0e7490,#22d3ee)!important;color:#f0fdfa!important;border-color:var(--cockpit-accent)!important}.main-content .farm-manager-page .farm-manager-actions .primary-btn{background:linear-gradient(135deg,#0e7490,#22d3ee)!important;color:#f0fdfa!important;box-shadow:0 0 14px #22d3ee33}.main-content .farm-manager-page .farm-manager-actions .outline-btn{background:#081630bf!important;border-color:var(--cockpit-border-strong)!important;color:var(--cockpit-accent-soft)!important}.main-content .farm-manager-page .farm-filter-panel{background:var(--cockpit-panel)!important;border:1px solid var(--cockpit-border)!important;box-shadow:var(--shadow-sm)}.main-content .farm-manager-page .farm-table-wrapper{background:var(--cockpit-panel)!important;border:1px solid var(--cockpit-border)!important}.main-content .farm-manager-page .farm-table thead{background:#040c1cf2!important}.main-content .farm-manager-page .farm-table th{color:var(--cockpit-text-secondary)!important;border-bottom-color:var(--cockpit-border)!important}.main-content .farm-manager-page .farm-table td{color:var(--cockpit-text)!important;border-bottom-color:#38bdf81a!important}.main-content .farm-manager-page .farm-table tbody tr:hover{background:#22d3ee0f!important}.main-content .farm-manager-page .empty-state{background:var(--cockpit-panel)!important;border:1px solid var(--cockpit-border)!important}.main-content .farm-manager-page .empty-state p{color:var(--cockpit-text-muted)!important}.main-content .farm-manager-page .filter-item label{color:var(--cockpit-text-secondary)!important}.main-content .farm-manager-page .filter-item.buttons button{color:var(--cockpit-accent-soft)!important;border-color:var(--cockpit-accent)!important;background:transparent!important}.main-content .farm-manager-page .filter-item.buttons button:hover{background:#22d3ee1f!important}.main-content .farm-manager-page .table-btn{color:var(--cockpit-accent-soft)!important}.main-content .farm-manager-page .table-btn:hover{background:#22d3ee1a!important}.main-content .farm-manager-page .principal-tag.main{background:#f8717126!important;color:#fecaca!important}.main-content .farm-manager-page .principal-tag.sub{background:#38bdf826!important;color:#7dd3fc!important}.main-content .farm-manager-page .scope-tag{background:#0f234499!important;color:var(--cockpit-text-muted)!important}.main-content .farm-manager-page .scope-tag.single{background:#4ade801f!important;color:#86efac!important}.main-content .farm-manager-page .scope-tag.multiple{background:#fbbf241f!important;color:#fde68a!important}.main-content .farm-manager-page .permission-tag{background:#081630bf!important;color:var(--cockpit-text-secondary)!important}.main-content .farm-manager-page .farm-pagination{background:var(--cockpit-panel)!important;border:1px solid var(--cockpit-border)!important}.main-content .farm-manager-page .page-info{color:var(--cockpit-text-muted)!important}.main-content .farm-manager-page .page-btn{background:#081630bf!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content .farm-manager-page .page-current{background:linear-gradient(135deg,#0e7490,#22d3ee)!important;color:#f0fdfa!important}.main-content .farm-manager-page .modal-content{background:var(--cockpit-panel-solid)!important;border:1px solid var(--cockpit-border-strong)!important}.main-content .farm-manager-page .modal-content h3{color:var(--cockpit-heading)!important}.main-content .farm-manager-page .form-row label,.main-content .farm-manager-page .permission-module{color:var(--cockpit-text-secondary)!important}.main-content .farm-manager-page .checkbox-group{border-color:var(--cockpit-border)!important;background:#040c1c80!important}.main-content .farm-manager-page .modal-footer{border-top-color:var(--cockpit-border)!important}.main-content .farm-manager-page .modal-footer .primary-btn{background:linear-gradient(135deg,#0e7490,#22d3ee)!important}.main-content .farm-manager-page .modal-footer .outline-btn{background:#081630bf!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content .stock-flow-page .stock-flow-header h2{color:var(--cockpit-heading)!important}.main-content .stock-flow-page .stock-flow-hint{color:var(--cockpit-text-muted)!important}.main-content .stock-flow-page .filter-card,.main-content .stock-flow-page .table-card{background:var(--cockpit-panel)!important;border:1px solid var(--cockpit-border)!important}.main-content .stock-flow-page .tag-flow-in{background:#4ade801f!important;color:#86efac!important;border-color:#4ade804d!important}.main-content .stock-flow-page .tag-flow-out{background:#f871711f!important;color:#fecaca!important;border-color:#f871714d!important}.main-content .material-purchase-page .stat-card,.main-content .material-purchase-page .filter-card,.main-content .material-purchase-page .table-card,.main-content .material-warning-page .stat-card,.main-content .material-warning-page .warning-filter-card,.main-content .material-warning-page .table-card{background:var(--cockpit-panel)!important;border:1px solid var(--cockpit-border)!important}.main-content .material-purchase-page .stat-card.warn,.main-content .material-warning-page .stat-card.warn{background:#78501440!important;border-color:#fbbf2459!important}.main-content .material-warning-page .stat-card.danger{background:#3c141966!important;border-color:#f8717159!important}.main-content .material-warning-page .stat-value{color:var(--cockpit-heading)!important}.main-content .material-purchase-page .tag-normal,.main-content .material-warning-page .tag-normal{background:#4ade801f!important;color:#86efac!important;border-color:#4ade804d!important}.main-content .material-purchase-page .tag-warn,.main-content .material-warning-page .tag-warn{background:#fbbf241f!important;color:#fde68a!important;border-color:#fbbf244d!important}.main-content .material-purchase-page .tag-off,.main-content .material-warning-page .tag-danger{background:#0f234499!important;color:var(--cockpit-text-muted)!important;border-color:var(--cockpit-border)!important}.main-content .material-warning-page .tag-danger{background:#f871711f!important;color:#fecaca!important;border-color:#f871714d!important}.main-content .material-warning-page .row-danger{background:#32141959!important}.main-content .farm-list-page{color:var(--cockpit-text)}.main-content .farm-list-page .farm-list-header h2{color:var(--cockpit-heading)!important}.main-content .farm-list-page .farm-filter-panel{background:var(--cockpit-panel)!important;border:1px solid var(--cockpit-border)!important;box-shadow:var(--shadow-sm)!important}.main-content .farm-list-page .filter-item label{color:var(--cockpit-text-secondary)!important}.main-content .farm-list-page .filter-item input,.main-content .farm-list-page .filter-item select{background:#040c1cd9!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content .farm-list-page .filter-sep{color:var(--cockpit-text-muted)!important}.main-content .farm-list-page .advanced-toggle .advanced-link{color:var(--cockpit-accent-soft)!important}.main-content .farm-list-page .farm-table-wrapper{background:var(--cockpit-panel)!important;border:1px solid var(--cockpit-border)!important;box-shadow:var(--shadow-sm)!important}.main-content .farm-list-page .farm-table thead{background:linear-gradient(135deg,#082f49f2,#0f2344fa)!important}.main-content .farm-list-page .farm-table th{color:var(--cockpit-text-secondary)!important;border-bottom-color:var(--cockpit-border)!important}.main-content .farm-list-page .farm-table td{color:var(--cockpit-text)!important;border-bottom-color:var(--cockpit-border)!important}.main-content .farm-list-page .farm-table tbody tr{background:transparent!important}.main-content .farm-list-page .farm-table tbody tr:hover{background:#22d3ee0f!important}.main-content .farm-list-page .farm-table th:hover{background:#22d3ee14!important}.main-content .farm-list-page .farm-name-cell{color:var(--cockpit-accent-soft)!important}.main-content .farm-list-page .batch-bar{background:#082f4980!important;border-bottom-color:var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content .farm-list-page .batch-bar button{background:#040c1cbf!important;border-color:var(--cockpit-border-strong)!important;color:var(--cockpit-accent-soft)!important}.main-content .farm-list-page .table-btn{background:#040c1ca6!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text-secondary)!important}.main-content .farm-list-page .table-btn:hover{background:#22d3ee1a!important;border-color:var(--cockpit-accent)!important;color:var(--cockpit-text)!important}.main-content .farm-list-page .farm-pagination{padding:12px 16px;background:var(--cockpit-panel)!important;border:1px solid var(--cockpit-border)!important;border-radius:var(--radius-lg)}.main-content .farm-list-page .farm-pagination .page-info{color:var(--cockpit-text-muted)!important}.main-content .farm-list-page .farm-pagination button{background:#040c1cbf!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text-secondary)!important}.main-content .farm-list-page .farm-pagination select{background:#040c1cd9!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content .farm-list-page .page-current{background:linear-gradient(135deg,var(--cockpit-accent-deep),var(--cockpit-accent))!important;color:#042f2e!important}.main-content .farm-list-page .farm-overview-popover{background:#061226fa!important;border:1px solid var(--cockpit-border-strong)!important;box-shadow:var(--shadow-lg)!important}.main-content .farm-list-page .overview-title{color:var(--cockpit-heading)!important}.main-content .farm-list-page .overview-env,.main-content .farm-list-page .overview-device,.main-content .farm-list-page .overview-warning{color:var(--cockpit-text-secondary)!important}.main-content .farm-list-page .overview-empty{color:var(--cockpit-text-muted)!important}.main-content .farm-list-page .farm-form-modal{background:var(--cockpit-panel-solid)!important;border:1px solid var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content .farm-list-page .farm-form-modal h3{color:var(--cockpit-heading)!important}.main-content .farm-list-page .farm-form-row label{color:var(--cockpit-text-secondary)!important}.main-content .farm-list-page .farm-form-row input,.main-content .farm-list-page .farm-form-row select{background:#040c1cd9!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content .farm-list-page .coord-tip{color:var(--cockpit-text-muted)!important}.main-content .farm-list-page .farm-form-footer button{background:#040c1cbf!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content .material-list-page{color:var(--cockpit-text)}.main-content .material-list-page .material-sub,.main-content .material-list-page .page-info,.main-content .material-list-page .loading,.main-content .material-list-page .empty-state-panel{color:var(--cockpit-text-muted)!important}.main-content .material-list-page .material-filter-card,.main-content .material-list-page .table-card{background:var(--cockpit-panel)!important;border:1px solid var(--cockpit-border)!important}.main-content .material-list-page .filter-item label{color:var(--cockpit-text-secondary)!important}.main-content .material-list-page .filter-item input,.main-content .material-list-page .filter-item select{background:#040c1cd9!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content .material-list-page .material-table th{color:var(--cockpit-text-secondary)!important;border-bottom-color:var(--cockpit-border)!important}.main-content .material-list-page .material-table td{color:var(--cockpit-text)!important;border-bottom-color:var(--cockpit-border)!important}.main-content .material-list-page .material-table tbody tr{background:transparent!important}.main-content .material-list-page .material-table tbody tr:hover{background:#22d3ee0f!important}.main-content .material-list-page .row-danger{background:#3c161c8c!important}.main-content .material-list-page .row-danger td{color:var(--cockpit-text)!important}.main-content .material-list-page .tag-normal{background:#4ade801f!important;color:#86efac!important;border-color:#4ade804d!important}.main-content .material-list-page .tag-warn{background:#fbbf241f!important;color:#fde68a!important;border-color:#fbbf244d!important}.main-content .material-list-page .tag-danger{background:#f8717126!important;color:#fecaca!important;border-color:#f8717159!important}.main-content .material-list-page .tag-off{background:#0f234499!important;color:var(--cockpit-text-muted)!important;border-color:var(--cockpit-border)!important}.main-content .material-list-page .pagination{padding:12px 0 0}.main-content .material-list-page .page-btn,.main-content .material-list-page .page-controls select{background:#040c1cbf!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text-secondary)!important}.main-content .material-list-page .page-current{color:var(--cockpit-accent-soft)!important}.main-content .material-list-page .mini-btn{background:#040c1ca6!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text-secondary)!important}.main-content .material-list-page .modal-panel{background:var(--cockpit-panel-solid)!important;border:1px solid var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content .material-list-page .form-grid label,.main-content .material-list-page .kv-label,.main-content .material-list-page .stock-meta{color:var(--cockpit-text-secondary)!important}.main-content .material-list-page .form-grid input,.main-content .material-list-page .form-grid select{background:#040c1cd9!important;border-color:var(--cockpit-border)!important;color:var(--cockpit-text)!important}.main-content .material-list-page .kv-row,.main-content .material-list-page .log-item{background:#040c1c80!important;border-color:var(--cockpit-border)!important}.main-content .material-list-page .kv-value,.main-content .material-list-page .log-type,.main-content .material-list-page .log-reason{color:var(--cockpit-text)!important}.main-content .farm-detail-entry-page{padding:var(--space-6);max-width:960px}.main-content .farm-detail-entry-loading{color:var(--cockpit-text-muted);font-size:15px}.main-content .farm-detail-entry-header{margin-bottom:var(--space-6)}.main-content .farm-detail-entry-title{font-size:22px;font-weight:600;color:var(--cockpit-heading);margin-bottom:var(--space-3)}.main-content .farm-detail-entry-desc{font-size:14px;line-height:1.65;color:var(--cockpit-text-secondary);margin-bottom:var(--space-3)}.main-content .farm-detail-entry-link{display:inline-block;font-size:14px;color:var(--cockpit-accent-soft);text-decoration:none;border-bottom:1px solid rgba(34,211,238,.35)}.main-content .farm-detail-entry-link:hover{color:#a5f3fc;border-bottom-color:var(--cockpit-accent)}.main-content .farm-detail-entry-link--inline{margin-top:var(--space-2)}.main-content .farm-detail-entry-error{color:var(--cockpit-danger);margin-bottom:var(--space-4);line-height:1.5}.main-content .farm-detail-entry-card{padding:var(--space-5);background:var(--cockpit-panel);border:1px solid var(--cockpit-border);border-radius:var(--radius-lg)}.main-content .farm-detail-entry-card--narrow{max-width:480px}.main-content .farm-detail-entry-empty{color:var(--cockpit-text-muted);margin-bottom:var(--space-4)}.main-content .farm-detail-entry-grid{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-4)}.main-content .farm-detail-entry-item{width:100%;text-align:left;padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);border:1px solid var(--cockpit-border);background:#040c1c8c;color:var(--cockpit-text);cursor:pointer;transition:border-color .2s,background .2s,box-shadow .2s}.main-content .farm-detail-entry-item:hover{border-color:var(--cockpit-border-strong);background:#22d3ee14;box-shadow:var(--shadow-glow)}.main-content .farm-detail-entry-item-name{display:block;font-size:16px;font-weight:600;color:var(--cockpit-heading);margin-bottom:6px}.main-content .farm-detail-entry-item-meta{display:block;font-size:13px;color:var(--cockpit-text-muted)}
