*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--color-bg-body);color:var(--color-text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:260px;padding:var(--spacing-xl);background-color:var(--color-bg-body);min-width:0}h1,h2,h3,h4,h5,h6{color:var(--color-text-primary);line-height:1.2}p{color:var(--color-text-secondary)}.sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;background-color:var(--color-bg-sidebar);border-right:1px solid var(--color-border);display:flex;flex-direction:column;z-index:50}.sidebar-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.sidebar-logo{display:flex;align-items:center;gap:var(--spacing-sm)}.sidebar-logo-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.25rem;object-fit:contain}.sidebar-logo-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:-.025em}.sidebar-nav{flex:1;padding:var(--spacing-md);overflow-y:auto}.nav-section-title{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em;padding:var(--spacing-sm) var(--spacing-md);margin-top:var(--spacing-md);margin-bottom:var(--spacing-xs);font-weight:var(--font-weight-semibold)}.nav-item{display:flex;align-items:center;gap:var(--spacing-md);padding:10px var(--spacing-md);border-radius:var(--radius-sm);color:var(--color-text-secondary);text-decoration:none;transition:all .2s;cursor:pointer;margin-bottom:2px;font-weight:var(--font-weight-medium)}.nav-item:hover{background-color:#ffffff0d;color:var(--color-text-primary)}.nav-item.active{background-color:var(--color-accent-glow);color:var(--color-accent-primary)}.page-header{margin-bottom:var(--spacing-xl)}.page-title{font-size:2rem;font-weight:var(--font-weight-bold);letter-spacing:-.025em;margin-bottom:var(--spacing-xs)}.page-subtitle{font-size:var(--font-size-md);color:var(--color-text-secondary)}.card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);width:100%}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.card-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:4px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--spacing-lg)}.stat-card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;flex-direction:column}.stat-card-icon{width:48px;height:48px;border-radius:var(--radius-md);background:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:var(--spacing-md)}.stat-card-value{font-size:2rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1.1;margin-bottom:var(--spacing-xs)}.stat-card-label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.form-group{margin-bottom:var(--spacing-md);display:flex;flex-direction:column}.form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:6px}.form-input,.form-select,.form-textarea{width:100%;padding:10px 12px;background-color:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow)}.input-group{display:flex}.input-addon{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-right:none;padding:8px 12px;border-radius:var(--radius-sm) 0 0 var(--radius-sm);color:var(--color-text-secondary);font-size:var(--font-size-sm);display:flex;align-items:center}.input-group .form-input{border-top-left-radius:0;border-bottom-left-radius:0}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-bg-tertiary);transition:.4s;border-radius:24px;border:1px solid var(--color-border)}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:2px;bottom:2px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.toggle-slider{background-color:var(--color-accent-primary)}input:checked+.toggle-slider:before{transform:translate(20px)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;border-radius:var(--radius-sm);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);cursor:pointer;border:1px solid transparent;text-decoration:none;transition:all .2s;white-space:nowrap}.btn-sm{padding:4px 12px;font-size:var(--font-size-xs)}.btn-lg{padding:12px 24px;font-size:var(--font-size-md)}.btn-primary{background:var(--color-accent-primary);color:#000;border:none;font-weight:var(--font-weight-semibold)}.btn-primary:hover:not(:disabled){background:var(--color-accent-hover)}.btn-primary:disabled{background:var(--color-bg-tertiary);color:var(--color-text-muted);cursor:not-allowed}.btn-secondary{background:var(--color-bg-card);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){border-color:var(--color-text-secondary);background:var(--color-bg-tertiary)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{background:#ffffff0d;color:var(--color-text-primary)}.badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:1}.badge-success{background:#22c55e33;color:var(--color-success)}.badge-warning{background:#f59e0b33;color:var(--color-warning)}.badge-error{background:#ef444433;color:var(--color-error)}.badge-info{background:#3b82f633;color:var(--color-info)}.badge-neutral{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md);border:1px solid transparent}.alert-warning{background:#f59e0b1a;border-color:#f59e0b33;color:#fbbf24}.alert-title{font-weight:var(--font-weight-bold);margin-bottom:4px}.alert-message{font-size:var(--font-size-sm);opacity:.9}.table-container{overflow-x:auto}.table{width:100%;border-collapse:separate;border-spacing:0;text-align:left}.table th{background-color:var(--color-bg-tertiary);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.table td{padding:var(--spacing-md);border-bottom:1px solid var(--color-border);color:var(--color-text-primary);font-size:var(--font-size-sm)}.table tr:last-child td{border-bottom:none}.table tr:hover td{background-color:#ffffff05}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.modal-close{background:none;border:none;color:var(--color-text-secondary);font-size:1.5rem;line-height:1;cursor:pointer;padding:4px}.modal-body{padding:var(--spacing-lg);overflow-y:auto}.modal-footer{padding:var(--spacing-lg);border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:var(--spacing-md)}.tabs{display:flex;border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-lg);gap:var(--spacing-md);overflow-x:auto}.tab{padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;border-bottom:2px solid transparent;color:var(--color-text-secondary);font-weight:var(--font-weight-medium);transition:all .2s;display:flex;align-items:center;white-space:nowrap}.tab:hover{color:var(--color-text-primary);border-bottom-color:var(--color-border)}.tab.active{color:var(--color-accent-primary);border-bottom-color:var(--color-accent-primary)}.gantt-container{overflow-x:auto;background:var(--color-bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--color-border);position:relative}.gantt-header{display:grid;grid-template-columns:repeat(12,1fr);border-bottom:1px solid var(--color-border);background:var(--color-bg-card);position:sticky;top:0;z-index:10}.gantt-month{padding:var(--spacing-sm);text-align:center;font-size:var(--font-size-xs);font-weight:700;border-right:1px solid var(--color-border);color:var(--color-text-secondary)}.gantt-body{position:relative;min-height:400px;background:repeating-linear-gradient(to right,transparent 0%,transparent calc(100% / 12 - 1px),var(--color-border) calc(100% / 12 - 1px),var(--color-border) calc(100% / 12))}.gantt-row{position:relative;height:48px;border-bottom:1px solid rgba(255,255,255,.05);display:flex;align-items:center;padding:0 var(--spacing-sm)}.gantt-row:hover{background:#ffffff05}.gantt-label{position:absolute;left:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary);z-index:5;background:#00000080;padding:2px 4px;border-radius:4px;pointer-events:none}.gantt-bar-group{position:absolute;height:24px;display:flex;border-radius:4px;overflow:hidden;cursor:pointer;box-shadow:0 2px 4px #0003;transition:transform .2s}.gantt-bar-group:hover{transform:translateY(-2px);z-index:20}.gantt-bar-segment{height:100%}.gantt-bar-segment.nursery{background:var(--color-info)}.gantt-bar-segment.grow{background:var(--color-success)}.gantt-bar-segment.harvest{background:var(--color-error)}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.mt-md{margin-top:var(--spacing-md)}.text-center{text-align:center}.text-right{text-align:right}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.progress-bar{background:var(--color-bg-tertiary);border-radius:var(--radius-full);height:8px;width:100%;overflow:hidden}.progress-fill{background:var(--color-accent-primary);height:100%;border-radius:var(--radius-full);transition:width .5s ease-out}.loading-container{display:flex;justify-content:center;align-items:center;min-height:300px}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-bg-tertiary);border-top-color:var(--color-accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.rack-grid{display:grid;gap:var(--spacing-md);overflow-x:auto;padding-bottom:20px}.rack-column{background:var(--color-bg-sidebar);border-radius:var(--radius-md);padding:var(--spacing-xs);display:flex;flex-direction:column-reverse;gap:2px}.rack-column-header{text-align:center;font-weight:700;padding:var(--spacing-sm) 0;border-top:1px solid var(--color-border);margin-top:4px;color:var(--color-text-secondary);font-size:var(--font-size-xs)}.rack-level{height:50px;border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:var(--font-size-xs);border:1px solid transparent;transition:all .2s;position:relative}.rack-level.available{background:#37415133;color:var(--color-text-secondary)}.rack-level.growing{background:#22c55e33;border-color:var(--color-growing);color:var(--color-text-primary)}.rack-level.scheduled{background:#3b82f633;border-color:var(--color-scheduled);color:var(--color-text-primary)}.rack-level:hover{transform:scale(1.02);z-index:10}.timeline-view{display:flex;flex-direction:column}.timeline-viz{display:flex;align-items:center;margin:var(--spacing-xl) 0;position:relative;padding:0 var(--spacing-lg)}.timeline-node{width:16px;height:16px;border-radius:50%;background:var(--color-bg-tertiary);border:2px solid var(--color-border);position:relative;z-index:2}.timeline-node.start{background:var(--color-accent-primary);border-color:var(--color-accent-primary)}.timeline-node.end{background:var(--color-error);border-color:var(--color-error)}.timeline-node.middle{background:var(--color-text-secondary);border-color:var(--color-text-secondary)}.timeline-segment{height:4px;background:var(--color-bg-tertiary);position:relative;margin:0 4px}.timeline-segment.nursery{background:#3b82f680}.timeline-segment.grow{background:#22c55e80}.segment-label{position:absolute;top:-24px;left:50%;transform:translate(-50%);font-size:var(--font-size-xs);white-space:nowrap;color:var(--color-text-secondary)}.node-info{position:absolute;bottom:-24px;left:50%;transform:translate(-50%);font-size:var(--font-size-xs);white-space:nowrap;font-weight:700}.gauge{position:relative;width:120px;height:120px}.gauge-circle{fill:none;stroke-width:10;stroke-linecap:round;transform:rotate(-90deg);transform-origin:50% 50%}.gauge-bg{stroke:var(--color-bg-tertiary)}.gauge-fill{stroke:var(--color-accent-primary);transition:stroke-dashoffset 1s ease-out}.gauge-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.gauge-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.gauge-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-day-header{text-align:center;padding:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:700}.calendar-day{min-height:80px;background:var(--color-bg-tertiary);border-radius:var(--radius-sm);padding:4px;border:1px solid transparent;transition:all .2s}.calendar-day.today{background:var(--color-accent-glow);border-color:var(--color-accent-primary)}.calendar-day:hover{background:#ffffff0d}.calendar-event{font-size:9px;padding:2px 4px;border-radius:3px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;margin-bottom:2px}.calendar-event.harvest{background:var(--color-error)}.calendar-event.transplant{background:var(--color-success)}.calendar-event.nursery{background:var(--color-info)}.schedule-calendar{background:var(--color-bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.schedule-calendar-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--color-bg-card);border-bottom:1px solid var(--color-border)}.schedule-calendar-title{font-weight:var(--font-weight-semibold);font-size:var(--font-size-md)}.schedule-calendar-nav{display:flex;gap:var(--spacing-sm)}.schedule-calendar-nav button{background:var(--color-bg-tertiary);border:1px solid var(--color-border);color:var(--color-text-secondary);padding:4px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.schedule-calendar-nav button:hover{background:var(--color-bg-card);color:var(--color-text-primary)}.schedule-calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:var(--color-bg-card);border-bottom:1px solid var(--color-border)}.schedule-calendar-weekday{text-align:center;padding:var(--spacing-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);text-transform:uppercase}.schedule-calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:4px}.schedule-day{aspect-ratio:1;min-height:60px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;position:relative;border:2px solid transparent}.schedule-day-number{font-size:var(--font-size-md);font-weight:var(--font-weight-medium)}.schedule-day-capacity{font-size:9px;color:var(--color-text-muted);margin-top:2px}.schedule-day.valid{background:#22c55e1a;color:var(--color-text-primary)}.schedule-day.valid:hover{background:#22c55e33;border-color:var(--color-accent-primary)}.schedule-day.selected{background:var(--color-accent-primary);color:#000;border-color:var(--color-accent-primary)}.schedule-day.selected .schedule-day-capacity{color:#000000b3}.schedule-day.earliest{position:relative}.schedule-day.earliest:before{content:"★";position:absolute;top:2px;right:4px;font-size:10px;color:var(--color-warning)}.schedule-day.blocked{background:var(--color-bg-input);color:var(--color-text-muted);cursor:not-allowed;opacity:.5}.schedule-day.holiday{background:#ef444426;color:var(--color-error);cursor:not-allowed}.schedule-day.holiday .schedule-day-number{text-decoration:line-through}.schedule-day.capacity-full{background:#f59e0b26;color:var(--color-warning);cursor:not-allowed}.schedule-day.today{box-shadow:inset 0 0 0 2px var(--color-info)}.schedule-day-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-xs);white-space:nowrap;z-index:100;box-shadow:var(--shadow-lg);pointer-events:none}.schedule-day-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--color-bg-card)}.schedule-alert-banner{background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md)}.schedule-alert-banner.warning{background:#f59e0b26;border-color:#f59e0b4d}.schedule-alert-banner.info{background:#3b82f626;border-color:#3b82f64d}.schedule-alert-icon{font-size:1.5rem}.schedule-alert-content{flex:1}.schedule-alert-title{font-weight:var(--font-weight-semibold);margin-bottom:2px}.schedule-alert-message{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.schedule-alert-actions{display:flex;gap:var(--spacing-sm)}.harvest-window-viz{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-md);margin-top:var(--spacing-md)}.harvest-window-bar{flex:1;height:8px;background:var(--color-bg-input);border-radius:4px;position:relative;overflow:visible}.harvest-window-range{position:absolute;height:100%;background:#22c55e66;border-radius:4px}.harvest-window-target{position:absolute;width:4px;height:16px;top:-4px;background:var(--color-accent-primary);border-radius:2px}.harvest-window-label{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.cycle-status-projected{border:2px dashed var(--color-border);opacity:.7}.cycle-status-confirmed{border:2px solid var(--color-accent-primary)}.cycle-status-in_nursery{border-left:4px solid var(--color-success)}.cycle-status-in_grow{border-left:4px solid var(--color-info)}.cycle-status-completed{background:var(--color-bg-tertiary);opacity:.6}.cycle-status-failed{border:2px solid var(--color-error);background:#ef44441a}.cycle-status-cancelled{text-decoration:line-through;opacity:.5}.status-badge-projected{background:var(--color-bg-tertiary);color:var(--color-text-secondary);border:1px dashed var(--color-border)}.status-badge-confirmed{background:#22c55e33;color:var(--color-success)}.status-badge-in_nursery{background:#22c55e4d;color:var(--color-success)}.status-badge-in_grow{background:#3b82f64d;color:var(--color-info)}.status-badge-completed{background:var(--color-bg-tertiary);color:var(--color-text-muted)}.status-badge-failed{background:#ef44444d;color:var(--color-error)}.status-badge-cancelled{background:var(--color-bg-tertiary);color:var(--color-text-muted);text-decoration:line-through}.capacity-bar{height:6px;background:var(--color-bg-input);border-radius:3px;overflow:hidden}.capacity-bar-fill{height:100%;background:var(--color-success);transition:width .3s}.capacity-bar-fill.warning{background:var(--color-warning)}.capacity-bar-fill.full{background:var(--color-error)}.sop-tag{display:inline-block;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:var(--font-weight-medium)}.tag-daily{background:#3b82f633;color:#3b82f6}.tag-safety{background:#ef444433;color:#ef4444}.tag-harvest{background:#22c55e33;color:#22c55e}.tag-monthly{background:#a855f733;color:#a855f7}.tag-required{background:#f59e0b33;color:#f59e0b}.badge.status-open{background:#f9731633;color:#f97316}.badge.status-in-progress{background:#3b82f633;color:#3b82f6}.badge.status-completed{background:#22c55e33;color:#22c55e}.badge.status-past-due{background:#ef444433;color:#ef4444}.badge.status-paused{background:#9ca3af33;color:#9ca3af}.sop-wizard-steps{display:flex;justify-content:space-between;align-items:center;position:relative;padding:0 var(--spacing-lg)}.sop-wizard-steps:before{content:"";position:absolute;top:15px;left:calc(var(--spacing-lg) + 15px);right:calc(var(--spacing-lg) + 15px);height:2px;background:var(--color-border)}.sop-wizard-step{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);position:relative;z-index:1;cursor:pointer}.sop-wizard-step-circle{width:30px;height:30px;border-radius:50%;background:var(--color-bg-tertiary);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-muted)}.sop-wizard-step.active .sop-wizard-step-circle{background:var(--color-accent-primary);border-color:var(--color-accent-primary);color:#000}.sop-wizard-step.completed .sop-wizard-step-circle{background:var(--color-success);border-color:var(--color-success);color:#fff}.sop-wizard-step-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.sop-wizard-step.active .sop-wizard-step-label{color:var(--color-accent-primary);font-weight:var(--font-weight-medium)}.sop-template-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-tertiary);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.sop-template-option:hover{border-color:var(--color-border-hover)}.sop-template-option.selected{border-color:var(--color-accent-primary);background:#22c55e0d}.sop-template-radio{color:var(--color-accent-primary);font-size:var(--font-size-lg)}.sop-checklist-item{padding:var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md)}.sop-photo-upload{border:2px dashed var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);text-align:center;cursor:pointer;transition:all .2s ease;background:var(--color-bg-input)}.sop-photo-upload:hover{border-color:var(--color-accent-primary);background:#22c55e05}.sop-photo-thumb{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-xs)}.sop-task-bottom-bar{position:fixed;bottom:0;left:260px;right:0;background:var(--color-bg-card);border-top:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-lg);display:flex;align-items:center;z-index:100}@media(max-width:1023px){.sop-task-bottom-bar{left:0}}.sop-dashboard-card{background:var(--color-bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-md);border:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--spacing-sm);min-width:180px;transition:all .2s ease}.sop-dashboard-card:hover{border-color:var(--color-border-hover)}.sop-dashboard-card.past-due{background:#ef444414;border-color:#ef44444d}.sop-dashboard-card.in-progress{border-color:#3b82f666}.wizard-steps{display:flex;justify-content:space-between;position:relative}.wizard-steps:before{content:"";position:absolute;top:20px;left:10%;right:10%;height:2px;background:var(--color-border);z-index:0}.wizard-step{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);position:relative;z-index:1}.wizard-step-number{width:40px;height:40px;border-radius:50%;background:var(--color-bg-tertiary);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-semibold);transition:all .3s ease}.wizard-step.active .wizard-step-number{background:var(--color-accent-primary);border-color:var(--color-accent-primary);color:#000}.wizard-step.completed .wizard-step-number{background:var(--color-success);border-color:var(--color-success);color:#fff}.wizard-step-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.wizard-step.active .wizard-step-label{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.wizard-content{padding:var(--spacing-lg) 0}.wizard-actions{display:flex;justify-content:space-between;margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.schedule-type-option{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;min-width:150px}.schedule-type-option:hover{border-color:var(--color-border-hover)}.schedule-type-option.active{border-color:var(--color-accent-primary);background:var(--color-accent-glow)}.schedule-type-option .option-icon{font-size:2rem}.stat-card{background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:var(--spacing-lg);text-align:center;border:1px solid var(--color-border)}.stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.sensor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--spacing-lg)}.sensor-rack-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:transform .2s,box-shadow .2s}.sensor-rack-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.sensor-rack-header{padding:var(--spacing-md);border-bottom:1px solid var(--color-border);background:var(--color-bg-tertiary);display:flex;justify-content:center;align-items:center;gap:var(--spacing-sm)}.sensor-values-grid{display:grid;grid-template-columns:repeat(2,1fr)}.sensor-item{padding:var(--spacing-md);border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);cursor:pointer;position:relative;transition:background-color .2s;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.sensor-item:hover{background-color:#ffffff0d}.sensor-item:nth-child(2n){border-right:none}.sensor-item:nth-last-child(-n+2){border-bottom:none}.sensor-status-ok{color:var(--color-success)}.sensor-status-warning{color:var(--color-warning)}.sensor-status-critical{color:var(--color-error);animation:pulse-red 2s infinite}@keyframes pulse-red{0%{background-color:#ef444400}50%{background-color:#ef44441a}to{background-color:#ef444400}}.sensor-value-large{font-size:1.5rem;font-weight:var(--font-weight-bold);line-height:1.2}.sensor-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.sensor-unit{font-size:.8rem;font-weight:400;color:var(--color-text-muted);margin-left:2px}.chart-container{height:300px;width:100%;margin:var(--spacing-lg) 0;background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:var(--spacing-md);position:relative}.text-success{color:var(--color-success)!important}.text-warning{color:var(--color-warning)!important}.text-error{color:var(--color-error)!important}.text-primary{color:var(--color-text-primary)!important}.text-secondary{color:var(--color-text-secondary)!important}.text-muted{color:var(--color-text-muted)!important}.control-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--spacing-lg)}.control-card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.control-header{display:flex;justify-content:center;align-items:center;padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border);font-weight:600;gap:var(--spacing-sm)}.control-level{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);display:flex;justify-content:space-between;align-items:center}.level-info{display:flex;flex-direction:column;gap:2px}.level-title{font-size:.75rem;text-transform:uppercase;color:var(--color-text-muted);letter-spacing:.05em}.level-status-row{display:flex;align-items:center;gap:var(--spacing-md)}.status-icon-group{display:flex;align-items:center;gap:6px;font-size:.85rem}.icon-glow-yellow{color:#fbbf24;filter:drop-shadow(0 0 5px rgba(251,191,36,.5))}.icon-spin{animation:spin 2s linear infinite;color:var(--color-success);display:inline-flex;align-items:center;justify-content:center;transform-origin:center}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.icon-off{color:var(--color-text-muted);opacity:.3;display:inline-flex}.fertigation-panel{background:#0f1612;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);margin-top:var(--spacing-xs)}.fert-title{font-size:.7rem;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--spacing-sm);border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:4px}.gauges-row{display:flex;justify-content:space-around;margin-bottom:var(--spacing-md)}.mini-gauge{display:flex;flex-direction:column;align-items:center;text-align:center}.gauge-circle{width:60px;height:60px;border-radius:50%;border:3px solid var(--color-bg-tertiary);border-top-color:var(--color-accent-primary);display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:4px}.gauge-value{font-weight:700;font-size:1.1rem;line-height:1}.gauge-label{font-size:.65rem;color:var(--color-text-secondary)}.dosing-row{display:flex;justify-content:space-between;gap:4px}.dosing-pump{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:4px;padding:6px;flex:1;display:flex;flex-direction:column;align-items:center;font-size:.7rem;color:var(--color-text-muted);transition:all .3s}.dosing-pump.active{border-color:var(--color-accent-primary);background:#22c55e1a;color:var(--color-accent-primary);box-shadow:0 0 10px #22c55e33}.pump-icon{font-size:1.2rem;margin-bottom:2px}
