:root{--color-primary:#16a34a;--color-primary-light:#22c55e;--color-primary-dark:#15803d;--color-primary-glow:#16a34a14;--color-primary-glow-strong:#16a34a24;--color-accent:#f59e0b;--color-accent-light:#fbbf24;--color-accent-glow:#f59e0b1a;--color-bg:#f5f7fa;--color-bg-elevated:#fff;--color-surface:#fff;--color-surface-hover:#f0f2f5;--color-surface-elevated:#f8f9fb;--color-border:#e2e8f0;--color-border-hover:#cbd5e1;--color-text:#1e293b;--color-text-secondary:#64748b;--color-text-muted:#94a3b8;--color-success:#16a34a;--color-success-bg:#16a34a14;--color-danger:#ef4444;--color-danger-bg:#ef444414;--color-warning:#f59e0b;--color-warning-bg:#f59e0b14;--color-info:#3b82f6;--color-info-bg:#3b82f614;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:50%;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #00000014, 0 8px 10px -6px #0000000a;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-xs:.7rem;--font-sm:.8rem;--font-base:.875rem;--font-md:1rem;--font-lg:1.125rem;--font-xl:1.35rem;--font-2xl:1.75rem;--font-3xl:2.25rem;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--sidebar-width:264px;--sidebar-collapsed:72px;--topbar-height:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);min-height:100vh;line-height:1.6;overflow-x:hidden}#root{min-height:100vh}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-dark)}img{max-width:100%;display:block}input,select,textarea,button{font-family:var(--font-family);font-size:var(--font-base)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-hover)}.app-layout{min-height:100vh;display:flex}.app-main{margin-left:var(--sidebar-width);transition:margin-left var(--transition-base);flex-direction:column;flex:1;min-width:0;min-height:100vh;display:flex}.app-main.sidebar-collapsed{margin-left:var(--sidebar-collapsed)}.app-content{padding:var(--space-lg);margin-top:var(--topbar-height);flex:1;width:100%;min-width:0;animation:.35s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.sidebar{width:var(--sidebar-width);background:var(--color-bg-elevated);border-right:1px solid var(--color-border);z-index:100;height:100vh;transition:width var(--transition-base), transform var(--transition-base);box-shadow:var(--shadow-sm);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-brand{align-items:center;gap:var(--space-md);padding:var(--space-lg);border-bottom:1px solid var(--color-border);min-height:73px;display:flex}.sidebar-brand-icon{background:linear-gradient(135deg, var(--color-primary-light), var(--color-primary-dark));border-radius:var(--radius-md);color:#fff;width:40px;height:40px;font-weight:800;font-size:var(--font-lg);flex-shrink:0;justify-content:center;align-items:center;display:flex;box-shadow:0 2px 8px #16a34a4d}.sidebar-brand-text{white-space:nowrap;flex-direction:column;display:flex;overflow:hidden}.sidebar-brand-text h1{font-size:var(--font-lg);color:var(--color-text);font-weight:700;line-height:1.2}.sidebar-brand-text span{font-size:var(--font-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1px}.sidebar.collapsed .sidebar-brand-text,.sidebar.collapsed .sidebar-nav-label,.sidebar.collapsed .sidebar-section-title,.sidebar.collapsed .sidebar-farm-info{display:none}.sidebar-farm{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border)}.sidebar-farm-info{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-primary-glow);border-radius:var(--radius-md);color:var(--color-primary-dark);font-size:var(--font-sm);cursor:pointer;transition:all var(--transition-fast);border:1px solid #16a34a26;font-weight:600;display:flex}.sidebar-farm-info:hover{background:var(--color-primary-glow-strong)}.sidebar-nav{padding:var(--space-md) var(--space-sm);flex:1;overflow-y:auto}.sidebar-section-title{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1.5px;padding:var(--space-md) var(--space-md) var(--space-xs);font-size:10px;font-weight:700}.sidebar-nav-item{align-items:center;gap:var(--space-md);padding:10px var(--space-md);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-base);white-space:nowrap;margin-bottom:2px;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-nav-item:hover{background:var(--color-surface-hover);color:var(--color-text)}.sidebar-nav-item.active{background:var(--color-primary-glow-strong);color:var(--color-primary-dark);font-weight:600}.sidebar-nav-item.active:before{content:"";background:var(--color-primary);border-radius:0 3px 3px 0;width:3px;position:absolute;top:6px;bottom:6px;left:0}.sidebar-nav-item svg{flex-shrink:0;width:20px;height:20px}.sidebar-nav-label{flex:1;overflow:hidden}.sidebar-nav-badge{font-size:var(--font-xs);background:var(--color-danger);color:#fff;border-radius:10px;padding:1px 7px;font-weight:600}.sidebar-toggle{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border);justify-content:center;align-items:center;display:flex}.sidebar-toggle button{background:var(--color-surface-hover);border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;width:36px;height:36px;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.sidebar-toggle button:hover{background:var(--color-primary-glow);color:var(--color-primary);border-color:var(--color-primary)}.topbar{top:0;right:0;left:var(--sidebar-width);height:var(--topbar-height);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border);padding:0 var(--space-lg);z-index:90;transition:left var(--transition-base);background:#ffffffd9;justify-content:space-between;align-items:center;display:flex;position:fixed}.topbar.sidebar-collapsed{left:var(--sidebar-collapsed)}.topbar-title{align-items:center;gap:var(--space-md);display:flex}.topbar-title h2{font-size:var(--font-lg);color:var(--color-text);font-weight:700;line-height:1.2}.topbar-title span{font-size:var(--font-xs);color:var(--color-text-muted)}.topbar-actions{align-items:center;gap:var(--space-md);display:flex}.topbar-btn{background:var(--color-surface-hover);border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;width:40px;height:40px;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex;position:relative}.topbar-btn:hover{background:var(--color-primary-glow);color:var(--color-primary);border-color:var(--color-primary)}.topbar-badge{background:var(--color-danger);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px;box-shadow:0 2px 4px #ef44444d}.page-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.page-header h2{font-size:var(--font-xl);font-weight:700}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-base);box-shadow:var(--shadow-xs);overflow:hidden}.card:hover{box-shadow:var(--shadow-sm);border-color:var(--color-border-hover)}.card-header{padding:var(--space-lg);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.card-header h3{font-size:var(--font-md);font-weight:600}.card-body{padding:var(--space-lg)}.card-clickable{cursor:pointer}.card-clickable:hover{box-shadow:var(--shadow-lg);border-color:var(--color-primary);transform:translateY(-3px)}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);align-items:flex-start;gap:var(--space-md);transition:all var(--transition-base);box-shadow:var(--shadow-xs);display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-card-icon.green{background:var(--color-success-bg);color:var(--color-success)}.stat-card-icon.red{background:var(--color-danger-bg);color:var(--color-danger)}.stat-card-icon.amber{background:var(--color-warning-bg);color:var(--color-warning)}.stat-card-icon.blue{background:var(--color-info-bg);color:var(--color-info)}.stat-card-icon.primary{background:var(--color-primary-glow);color:var(--color-primary)}.stat-card-info{flex:1;min-width:0}.stat-card-label{font-size:var(--font-xs);color:var(--color-text-secondary);margin-bottom:2px}.stat-card-value{letter-spacing:-.5px;word-break:break-word;font-size:.95rem;font-weight:700;line-height:1.1}.stat-card-change{font-size:var(--font-xs);margin-top:var(--space-xs);align-items:center;gap:4px;display:flex}.stat-card-change.positive{color:var(--color-success)}.stat-card-change.negative{color:var(--color-danger)}.stats-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.grid-2{gap:var(--space-lg);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-lg);grid-template-columns:repeat(3,1fr);display:grid}.grid-cards{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.table-container{border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-xs);overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:var(--font-sm)}.data-table thead{background:var(--color-surface-elevated)}.data-table th{padding:var(--space-md);text-align:left;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border-bottom:2px solid var(--color-border);font-size:11px;font-weight:600}.data-table td{padding:var(--space-md);border-bottom:1px solid var(--color-border);color:var(--color-text);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--color-surface-hover)}.data-table tbody tr:last-child td{border-bottom:none}.table-actions{gap:var(--space-sm);display:flex}.btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:8px var(--space-md);border-radius:var(--radius-md);font-size:var(--font-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;font-weight:600;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.97)}.btn svg{width:18px;height:18px}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 1px 3px #16a34a4d}.btn-primary:hover{background:var(--color-primary-dark);box-shadow:0 4px 12px #16a34a4d}.btn-accent{background:var(--color-accent);color:#fff}.btn-accent:hover{filter:brightness(.9)}.btn-outline{border-color:var(--color-border);color:var(--color-text-secondary);background:#fff}.btn-outline:hover{background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-border-hover)}.btn-danger{border-color:var(--color-danger);color:var(--color-danger);background:#fff}.btn-danger:hover{background:var(--color-danger-bg)}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover{background:var(--color-surface-hover);color:var(--color-text)}.btn-icon{border-radius:var(--radius-sm);width:36px;height:36px;padding:0}.btn-sm{padding:4px var(--space-sm);font-size:var(--font-xs)}.btn-sm svg{width:14px;height:14px}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--font-md)}.form-group{margin-bottom:var(--space-md)}.form-label{font-size:var(--font-sm);color:var(--color-text-secondary);margin-bottom:6px;font-weight:600;display:block}.form-input,.form-select,.form-textarea{width:100%;padding:10px var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:var(--font-base);transition:all var(--transition-fast);background:#fff;outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow)}.form-input::placeholder{color:var(--color-text-muted)}.form-textarea{resize:vertical;min-height:80px}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-row{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.form-error{font-size:var(--font-xs);color:var(--color-danger);margin-top:4px}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;padding:var(--space-md);background:#0f172a66;justify-content:center;align-items:center;animation:.2s modalOverlayIn;display:flex;position:fixed;inset:0}@keyframes modalOverlayIn{0%{opacity:0}to{opacity:1}}.toggle-switch{width:44px;height:24px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:var(--color-border);border-radius:24px;transition:all .4s;position:absolute;inset:0}.toggle-slider:before{content:"";width:18px;height:18px;box-shadow:var(--shadow-sm);background-color:#fff;border-radius:50%;transition:all .4s;position:absolute;bottom:3px;left:3px}input:checked+.toggle-slider{background-color:var(--color-primary)}input:focus+.toggle-slider{box-shadow:0 0 1px var(--color-primary)}input:checked+.toggle-slider:before{transform:translate(20px)}.modal{border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:90vh;box-shadow:var(--shadow-xl);background:#fff;flex-direction:column;animation:.25s modalSlideIn;display:flex;overflow:hidden}.modal-lg{max-width:740px}.modal-xl{max-width:960px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{padding:var(--space-lg);border-bottom:1px solid var(--color-border);background:var(--color-surface-elevated);justify-content:space-between;align-items:center;display:flex}.modal-header h3{font-size:var(--font-lg);color:var(--color-text);font-weight:700}.btn-close{background:var(--color-surface-hover);border-radius:var(--radius-sm);width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;display:flex}.btn-close:hover{background:var(--color-danger-bg);color:var(--color-danger)}.modal-body{padding:var(--space-lg);overflow-y:auto}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border);background:var(--color-surface-elevated);display:flex}.badge{font-size:var(--font-xs);white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-weight:600;display:inline-flex}.badge-success{background:var(--color-success-bg);color:#15803d}.badge-danger{background:var(--color-danger-bg);color:#dc2626}.badge-warning{background:var(--color-warning-bg);color:#d97706}.badge-info{background:var(--color-info-bg);color:#2563eb}.badge-primary{background:var(--color-primary-glow);color:var(--color-primary-dark)}.badge-neutral{background:var(--color-surface-hover);color:var(--color-text-secondary)}.tabs{border-bottom:2px solid var(--color-border);margin-bottom:var(--space-lg);-webkit-overflow-scrolling:touch;scrollbar-width:thin;gap:4px;padding-bottom:4px;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{padding:var(--space-md) var(--space-lg);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;font-size:var(--font-sm);align-items:center;gap:var(--space-sm);background:0 0;border:none;border-bottom:2px solid #0000;flex-shrink:0;margin-bottom:-2px;font-weight:600;display:flex}.tab:hover{color:var(--color-text);background:var(--color-surface-hover);border-radius:var(--radius-sm) var(--radius-sm) 0 0}.tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab svg{width:16px;height:16px}.tab-badge{background:var(--color-surface-hover);color:var(--color-text-secondary);border-radius:10px;padding:1px 7px;font-size:10px;font-weight:700}.empty-state{padding:var(--space-3xl) var(--space-lg);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{border-radius:var(--radius-xl);background:var(--color-surface-hover);width:72px;height:72px;color:var(--color-text-muted);margin-bottom:var(--space-lg);justify-content:center;align-items:center;display:flex}.empty-state h3{font-size:var(--font-lg);color:var(--color-text);margin-bottom:var(--space-sm)}.empty-state p{color:var(--color-text-secondary);font-size:var(--font-sm);margin-bottom:var(--space-lg);max-width:400px}.notification-panel{top:var(--topbar-height);width:380px;max-height:calc(100vh - var(--topbar-height));border-left:1px solid var(--color-border);box-shadow:var(--shadow-xl);z-index:150;background:#fff;animation:.25s slideInRight;position:fixed;right:0;overflow-y:auto}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.notification-panel-header{padding:var(--space-lg);border-bottom:1px solid var(--color-border);background:#fff;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.notification-item{gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);transition:background var(--transition-fast);cursor:pointer;display:flex}.notification-item:hover{background:var(--color-surface-hover)}.notification-item.unread{background:var(--color-primary-glow)}.notification-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}.notification-dot.warning{background:var(--color-warning)}.notification-dot.danger{background:var(--color-danger)}.notification-dot.info{background:var(--color-info)}.notification-dot.success{background:var(--color-success)}.notification-content h4{font-size:var(--font-sm);margin-bottom:2px;font-weight:600}.notification-content p{font-size:var(--font-xs);color:var(--color-text-secondary)}.notification-content time{font-size:var(--font-xs);color:var(--color-text-muted);margin-top:4px;display:block}.timeline{padding-left:var(--space-xl);position:relative}.timeline:before{content:"";background:var(--color-border);width:2px;position:absolute;top:0;bottom:0;left:11px}.timeline-item{padding-bottom:var(--space-lg);position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-dot{width:12px;height:12px;box-shadow:0 0 0 2px var(--color-border);border:2px solid #fff;border-radius:50%;position:absolute;top:2px;left:-22px}.timeline-dot.done{background:var(--color-success);box-shadow:0 0 0 2px var(--color-success)}.timeline-dot.pending{background:var(--color-warning);box-shadow:0 0 0 2px var(--color-warning)}.timeline-dot.future{background:var(--color-text-muted)}.timeline-dot.overdue{background:var(--color-danger);box-shadow:0 0 0 2px var(--color-danger), 0 0 8px #ef44444d}.timeline-date{font-size:var(--font-xs);color:var(--color-text-muted);margin-bottom:2px}.timeline-label{font-size:var(--font-sm);word-break:break-word;font-weight:500}.timeline-label.done{color:var(--color-text-muted);text-decoration:line-through}.timeline-notif-tag{font-size:var(--font-xs);word-break:break-word;max-width:100%;box-shadow:var(--shadow-xs);border-radius:8px;margin-top:6px;padding:6px 10px;font-weight:600;display:inline-block}.chart-container{width:100%;height:300px}.ferme-selector{min-height:100vh;padding:4vh var(--space-md) var(--space-xl);background:linear-gradient(135deg,#f0fdf4 0%,#f5f7fa 50%,#eff6ff 100%);flex-direction:column;justify-content:flex-start;align-items:center;display:flex}.ferme-selector-header{text-align:center;margin-bottom:var(--space-md)}.ferme-selector-header .logo{background:linear-gradient(135deg, var(--color-primary-light), var(--color-primary-dark));border-radius:var(--radius-xl);color:#fff;width:64px;height:64px;font-weight:800;font-size:var(--font-xl);margin:0 auto var(--space-sm);justify-content:center;align-items:center;display:flex;box-shadow:0 8px 24px #16a34a40}.ferme-selector-header h1{font-size:var(--font-3xl);margin-bottom:var(--space-sm);background:linear-gradient(135deg, var(--color-primary) 0%, #0ea5e9 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800}.ferme-selector-header p{color:var(--color-text-secondary);font-size:var(--font-md)}.ferme-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;width:100%;max-width:1200px;margin:0 auto;display:grid}.ferme-card{border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-xl);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm);background:#fff;position:relative;overflow:hidden}.ferme-card:before{content:"";background:linear-gradient(90deg, var(--color-primary-light), var(--color-primary-dark));height:4px;transition:transform var(--transition-base);transform-origin:0;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.ferme-card:hover{box-shadow:var(--shadow-xl);border-color:var(--color-primary);transform:translateY(-4px)}.ferme-card:hover:before{transform:scaleX(1)}.ferme-card-icon{border-radius:var(--radius-lg);background:var(--color-primary-glow);width:52px;height:52px;color:var(--color-primary);margin-bottom:var(--space-md);justify-content:center;align-items:center;display:flex}.ferme-card h3{font-size:var(--font-lg);margin-bottom:var(--space-xs);color:var(--color-text);font-weight:700}.ferme-card p{font-size:var(--font-sm);color:var(--color-text-secondary);margin-bottom:var(--space-md)}.ferme-card-stats{gap:var(--space-md);flex-wrap:wrap;display:flex}.ferme-card-stat{font-size:var(--font-xs);color:var(--color-text-muted);align-items:center;gap:4px;display:flex}.ferme-card-stat strong{color:var(--color-text-secondary)}.ferme-add-card{border-style:dashed;border-color:var(--color-border-hover);color:var(--color-text-muted);min-height:200px;box-shadow:none;background:0 0;flex-direction:column;justify-content:center;align-items:center;display:flex}.ferme-add-card:hover{color:var(--color-primary);border-color:var(--color-primary);background:var(--color-primary-glow);box-shadow:none}.ferme-add-card svg{margin-bottom:var(--space-sm)}.dashboard-grid{gap:var(--space-lg);grid-template-columns:2fr 1fr;display:grid}.bande-progress{align-items:center;gap:var(--space-sm);display:flex}.bande-progress-bar{background:var(--color-border);border-radius:3px;flex:1;height:6px;overflow:hidden}.bande-progress-fill{background:linear-gradient(90deg, var(--color-primary-light), var(--color-primary-dark));border-radius:3px;height:100%;transition:width .5s}.bande-progress-text{font-size:var(--font-xs);color:var(--color-text-muted);white-space:nowrap}.mortality-rate{padding:var(--space-md) var(--space-lg);background:var(--color-danger-bg);border-radius:var(--radius-md);align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);border:1px solid #ef444426;display:flex}.mortality-rate.low{background:var(--color-success-bg);border-color:#16a34a26}.mortality-rate-value{font-size:var(--font-2xl);font-weight:800}.mortality-rate.low .mortality-rate-value{color:var(--color-success)}.mortality-rate:not(.low) .mortality-rate-value{color:var(--color-danger)}.toast-container{bottom:var(--space-lg);right:var(--space-lg);z-index:300;gap:var(--space-sm);flex-direction:column-reverse;display:flex;position:fixed}.toast{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);align-items:center;gap:var(--space-md);box-shadow:var(--shadow-lg);background:#fff;min-width:300px;max-width:420px;animation:.3s toastIn;display:flex}.toast.exit{animation:.3s forwards toastOut}@keyframes toastIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(16px)}}.toast-icon{flex-shrink:0}.toast-message{font-size:var(--font-sm);flex:1}.toast-close{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:4px}.stock-alert{align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-sm);font-size:var(--font-sm);border:1px solid;display:flex}.stock-alert.critical{background:var(--color-danger-bg);color:#dc2626;border-color:#ef444426}.stock-alert.warning{background:var(--color-warning-bg);color:#d97706;border-color:#f59e0b26}.perm-grid{flex-wrap:wrap;gap:6px;display:flex}.perm-chip{font-size:var(--font-xs);background:var(--color-surface-hover);border:1px solid var(--color-border);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;color:var(--color-text-secondary);border-radius:20px;align-items:center;gap:4px;padding:5px 12px;font-weight:500;display:inline-flex}.perm-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.perm-chip.active{background:var(--color-primary-glow-strong);border-color:var(--color-primary);color:var(--color-primary-dark);font-weight:600}@media (width<=1024px){.grid-2,.dashboard-grid{grid-template-columns:1fr}.grid-3{grid-template-columns:repeat(2,1fr)}.ferme-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.table-container{box-shadow:none;border:none;overflow:visible}.data-table thead{display:none}.data-table,.data-table tbody,.data-table tr,.data-table td{width:100%;display:block}.data-table tr{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-sm);padding:var(--space-md);box-shadow:var(--shadow-xs)}.data-table td{border-bottom:1px solid var(--color-border);font-size:var(--font-sm);text-align:right;justify-content:space-between;align-items:center;padding:8px 0;display:flex}.data-table td:last-child{padding-top:var(--space-sm);border-bottom:none;justify-content:flex-end}.data-table td:before{content:attr(data-label);color:var(--color-text-secondary);font-weight:600;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.5px;margin-right:var(--space-sm);text-align:left;flex-shrink:0}.table-actions{justify-content:flex-end;gap:8px}.table-actions .btn-icon{width:36px;height:36px}}@media (width<=768px){:root{--sidebar-width:0px}.sidebar{width:280px;box-shadow:var(--shadow-xl);z-index:100;transition:transform .3s ease-in-out;transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.mobile-overlay{z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a4d;position:fixed;inset:0}.app-main{margin-left:0!important}.topbar{left:0!important}.topbar-menu-btn{display:flex!important}.app-content{padding:var(--space-md)}.stats-grid{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:1fr}.notification-panel{width:100%}.modal{margin:var(--space-sm);max-height:calc(100vh - var(--space-md));border-radius:var(--radius-lg)}.modal-lg,.modal-xl{max-width:100%}.modal-header,.modal-body,.modal-footer{padding:var(--space-md)}.tabs{gap:0}.tab{padding:var(--space-sm) var(--space-md);font-size:var(--font-xs)}.tab svg{width:14px;height:14px}.ferme-selector{padding:var(--space-lg)}.ferme-selector-header h1{font-size:var(--font-2xl)}.page-header{flex-direction:column;align-items:flex-start}.page-header .btn{width:100%}.toast-container{left:var(--space-md);right:var(--space-md);bottom:var(--space-md)}.toast{width:100%;min-width:auto}.stat-card{padding:var(--space-md)}.stat-card-icon{width:40px;height:40px}.stat-card-value{font-size:var(--font-lg)}.chart-container{height:220px}.bande-kpis-grid{grid-template-columns:repeat(2,1fr)!important}.flex-between{gap:var(--space-sm);flex-wrap:wrap}}@media (width<=480px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.grid-cards,.form-row{grid-template-columns:1fr}.ferme-selector-header .logo{width:56px;height:56px;font-size:var(--font-lg)}.ferme-selector-header h1{font-size:var(--font-xl)}.bande-kpis-grid{grid-template-columns:1fr!important}.stat-card{gap:8px;padding:10px}.stat-card-icon{border-radius:8px;width:34px;min-width:34px;height:34px}.stat-card-icon svg{width:16px;height:16px}.stat-card-label{font-size:10px}.stat-card-value{font-size:.8rem!important}.stat-card-change{font-size:10px}.tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:0;padding-bottom:2px;overflow-x:auto}.tab{white-space:nowrap;flex-shrink:0;padding:6px 10px;font-size:10px}.tab svg{width:12px;height:12px;display:inline-block}.tab-badge{padding:1px 4px;font-size:8px}.perm-grid{gap:4px}.perm-chip{padding:4px 8px;font-size:10px}.timeline-item{padding-bottom:var(--space-md)}.timeline-date{font-size:10px}.timeline-label{font-size:var(--font-xs)}.timeline-notif-tag{padding:3px 8px;font-size:9px}.btn{padding:6px 12px;font-size:.75rem}.btn svg{width:14px;height:14px}.data-table th,.data-table td{padding:8px 10px;font-size:.75rem}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.page-header{gap:8px}.page-header h2{font-size:1rem}.page-header .page-subtitle,.page-header p{font-size:.75rem}.chatbot-fab{width:52px!important;height:52px!important}}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.text-center{text-align:center}.text-right{text-align:right}.font-bold{font-weight:700}.font-semibold{font-weight:600}.mt-md{margin-top:var(--space-md)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.flex{display:flex}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.w-full{width:100%}.topbar-menu-btn{margin-right:var(--space-md);display:none}@media (width<=768px){.topbar-menu-btn{display:flex}.ferme-global-report .stats-grid{grid-template-columns:1fr!important}}.building-stats-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.building-stat-card{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);text-align:center;transition:all var(--transition-fast);background:#fff}.building-stat-card:hover{box-shadow:var(--shadow-sm)}.building-stat-card .building-name{font-size:var(--font-sm);color:var(--color-text);margin-bottom:var(--space-sm);justify-content:center;align-items:center;gap:6px;font-weight:600;display:flex}.building-stat-card .building-rate{font-size:var(--font-xl);font-weight:800}.building-stat-card .building-detail{font-size:var(--font-xs);color:var(--color-text-muted);margin-top:4px}.login-grid{grid-template-columns:1fr 1fr;display:grid}@media (width<=768px){.login-grid{grid-template-columns:1fr}.login-brand-panel{display:none!important}.mobile-login-logo{display:flex!important}}@media print{.sidebar,.topbar,.toast-container,.notification-panel{display:none!important}.app-main{margin-left:0!important}.app-content{margin-top:0;padding:0}}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-slide-up{animation:.3s ease-out forwards slide-up}@keyframes bounce-subtle{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.animate-bounce-subtle{animation:2s ease-in-out infinite bounce-subtle}
