*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1f0f;--bg2:#162616;--bg3:#1e3320;--bg4:#243d26;--accent:#4ade80;--accent2:#22c55e;--text:#f0fdf4;--muted:#86efac;--border:#4ade8026;--danger:#f87171;--warning:#fbbf24;--info:#60a5fa;--radius:10px;--sidebar:230px}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Segoe UI,system-ui,sans-serif;font-size:14px}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}input,select,textarea{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:7px;outline:none;width:100%;padding:8px 12px;font-size:14px}input:focus,select:focus,textarea:focus{border-color:var(--accent)}select option{background:var(--bg3)}button{cursor:pointer;border:none;border-radius:7px;padding:9px 18px;font-size:14px;font-weight:600;transition:opacity .15s}button:hover{opacity:.85}button:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent2);color:#0f1f0f}.btn-danger{background:var(--danger);color:#fff}.btn-ghost{background:var(--bg3);color:var(--text);border:1px solid var(--border)}.btn-sm{padding:5px 12px;font-size:12px}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.badge{border-radius:20px;padding:2px 10px;font-size:11px;font-weight:700;display:inline-block}.badge-green{color:var(--accent);background:#4ade8026}.badge-yellow{color:var(--warning);background:#fbbf2426}.badge-red{color:var(--danger);background:#f8717126}.badge-blue{color:var(--info);background:#60a5fa26}.badge-gray{color:#94a3b8;background:#94a3b81a}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid var(--border);padding:10px 14px}th{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg3)}.modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:520px;max-height:90vh;padding:28px;overflow-y:auto}.modal h3{margin-bottom:20px;font-size:18px}.modal-footer{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.form-group{margin-bottom:14px}.form-group label{color:var(--muted);margin-bottom:5px;font-size:12px;font-weight:600;display:block}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header h2{font-size:20px}.empty-state{text-align:center;color:var(--muted);padding:60px 20px}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px}.stat-card .stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:11px}.stat-card .stat-value{font-size:26px;font-weight:700}.stat-card .stat-sub{color:var(--muted);margin-top:4px;font-size:12px}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar);background:var(--bg2);border-right:1px solid var(--border);z-index:100;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--border);color:var(--accent);align-items:center;gap:10px;padding:20px 18px;font-size:15px;font-weight:700;line-height:1.3;display:flex}.logo-icon{flex-shrink:0;font-size:22px}.sidebar-logo small{color:var(--muted);font-size:12px;font-weight:400}.sidebar-nav{flex:1;padding:10px 0;overflow-y:auto}.sidebar-bottom{border-top:1px solid var(--border);padding:10px 0}.nav-item{color:var(--muted);text-align:left;background:0 0;border-radius:0;align-items:center;gap:10px;width:100%;padding:10px 18px;font-size:13px;font-weight:500;transition:all .15s;display:flex;position:relative}.nav-item:hover{color:var(--text);background:var(--bg3)}.nav-item.active{color:var(--accent);background:#4ade8014}.nav-item svg{flex-shrink:0;font-size:15px}.notif-badge{background:var(--danger);color:#fff;border-radius:10px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:700}.logout-btn{cursor:pointer}.sidebar-profile{background:#4ade800f;border:1px solid #4ade801f;border-radius:10px;align-items:center;gap:10px;margin:4px 8px;padding:12px 14px;display:flex}.sidebar-avatar{color:#fff;background:linear-gradient(135deg,#4ade80,#16a34a);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:800;display:flex}.sidebar-profile-info{flex:1;min-width:0}.sidebar-profile-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:700;overflow:hidden}.sidebar-profile-role{color:var(--accent);text-transform:uppercase;letter-spacing:.6px;margin-top:1px;font-size:10px}.sidebar-logout{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:4px;font-size:14px;transition:color .15s,background .15s}.sidebar-logout:hover{color:var(--danger);background:#ef44441a}.main-content{margin-left:var(--sidebar);flex:1;padding:28px 32px;position:relative;overflow-y:auto}.watermark{top:50%;left:calc(50% + var(--sidebar) / 2);color:#4ade800b;pointer-events:none;-webkit-user-select:none;user-select:none;white-space:nowrap;letter-spacing:12px;z-index:0;font-size:96px;font-weight:900;position:fixed;transform:translate(-50%,-50%)rotate(-35deg)}.auth-page{justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.auth-slide{opacity:0;z-index:0;background-position:50%;background-size:cover;transition:opacity 1.5s ease-in-out;position:absolute;inset:0}.auth-slide.active{opacity:1}.auth-overlay{z-index:1;background:linear-gradient(135deg,#0a190ad1 0%,#0f1f0fbf 100%);position:absolute;inset:0}.auth-dots{z-index:3;gap:8px;display:flex;position:absolute;bottom:24px;left:50%;transform:translate(-50%)}.auth-dot{background:#ffffff59;border-radius:50%;width:7px;height:7px;transition:background .3s}.auth-dot.active{background:var(--accent)}.auth-caption{color:#ffffff80;white-space:nowrap;z-index:3;letter-spacing:.05em;font-size:11px;position:absolute;bottom:52px;left:50%;transform:translate(-50%)}.auth-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);z-index:2;background:#162616eb;width:100%;max-width:420px;padding:40px;position:relative}.auth-logo{color:var(--accent);align-items:center;gap:10px;margin-bottom:24px;font-size:18px;font-weight:700;display:flex}.auth-card h2{color:var(--text);margin-bottom:24px;font-size:22px}.auth-err{color:var(--danger);background:#f871711a;border:1px solid #f871714d;border-radius:7px;margin-bottom:14px;padding:10px 14px;font-size:13px}.auth-link{text-align:center;color:var(--muted);margin-top:20px;font-size:13px}.auth-dev{text-align:center;border-top:1px solid var(--border);color:var(--muted);margin-top:24px;padding-top:16px;font-size:11px}.auth-dev a{color:var(--muted)}.auth-dev a:hover{color:var(--accent)}.dash-root{flex-direction:column;gap:20px;display:flex}.dash-hero{background:linear-gradient(135deg,#14532d 0%,#166534 60%,#15803d 100%);border-radius:14px;justify-content:space-between;align-items:center;gap:24px;padding:28px 32px;display:flex;box-shadow:0 4px 24px #00000059}.dash-hero-left{align-items:center;gap:20px;display:flex}.dash-hero-icon{color:#86efac;background:#ffffff1f;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:26px;display:flex}.dash-hero-farm{color:#fff;letter-spacing:.3px;font-size:22px;font-weight:800}.dash-hero-location{color:#86efac;align-items:center;gap:6px;margin-top:4px;font-size:13px;display:flex}.dash-hero-date{color:#ffffff80;text-transform:capitalize;margin-top:6px;font-size:12px}.dash-weather{background:#00000026;border-radius:10px;flex-shrink:0;align-items:center;gap:12px;padding:12px 16px;display:flex}.dash-weather-icon{color:#fde68a;font-size:28px}.dash-weather-temp{color:#fff;font-size:18px;font-weight:700}.dash-weather-temp span{color:#ffffffb3;margin-left:6px;font-size:13px;font-weight:400}.dash-weather-details{color:#fff9;gap:10px;margin-top:4px;font-size:11px;display:flex}.dash-weather-details span{align-items:center;gap:4px;display:flex}.dash-hero-user{background:#0003;border-radius:12px;flex-shrink:0;align-items:center;gap:14px;padding:14px 20px;display:flex}.dash-hero-username{color:#fff;font-size:15px;font-weight:700}.dash-hero-role{color:#86efac;text-transform:uppercase;letter-spacing:.8px;margin-top:3px;font-size:11px;font-weight:600}.dash-hero-email{color:#ffffff73;margin-top:2px;font-size:11px}.dash-avatar{color:#fff;background:linear-gradient(135deg,#4ade80,#16a34a);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:800;display:flex}.dash-kpis{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.dash-kpi{background:var(--bg2);border:1px solid var(--border);border-radius:12px;align-items:center;gap:16px;padding:20px 22px;transition:transform .15s,box-shadow .15s;display:flex}.dash-kpi:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.dash-kpi-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;display:flex}.dash-kpi--green .dash-kpi-icon{color:var(--accent);background:#4ade801f}.dash-kpi--red .dash-kpi-icon{color:var(--danger);background:#ef44441f}.dash-kpi--blue .dash-kpi-icon{color:#60a5fa;background:#3b82f61f}.dash-kpi-label{color:var(--muted);margin-bottom:4px;font-size:12px;font-weight:500}.dash-kpi-value{color:var(--text);font-size:18px;font-weight:800}.dash-kpi--green .dash-kpi-value{color:var(--accent)}.dash-kpi--red .dash-kpi-value{color:var(--danger)}.dash-kpi--blue .dash-kpi-value{color:#60a5fa}.dash-kpi-sub{color:var(--muted);margin-top:2px;font-size:11px}.dash-grid2{grid-template-columns:1fr 1fr;gap:20px;display:grid}.dash-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.dash-row:last-child{border-bottom:none}.dash-row-title{color:var(--text);font-size:14px;font-weight:600}.dash-row-sub{color:var(--muted);margin-top:2px;font-size:12px}.dash-empty{color:var(--muted);padding:8px 0;font-size:13px}.card-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.card-title{align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.card-title-icon{font-size:14px}.card-title-icon.green{color:var(--accent)}.card-title-icon.yellow{color:var(--warning)}.card-title-icon.blue{color:#60a5fa}.card-link{color:var(--muted);font-size:12px;transition:color .15s}.card-link:hover{color:var(--accent)}.dash-notif-row{border-bottom:1px solid var(--border);align-items:flex-start;gap:14px;padding:10px 0;display:flex}.dash-notif-row:last-child{border-bottom:none}.dash-notif-dot{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:15px;display:flex}.dash-notif-dot.green{background:#4ade801a}.dash-notif-dot.yellow{background:#eab3081a}.dash-notif-dot.blue{background:#3b82f61a}.rpt-period{flex-wrap:wrap;align-items:center;gap:24px;margin-bottom:20px;padding:16px 20px;display:flex}.rpt-period-label{color:var(--muted);white-space:nowrap;font-size:13px;font-weight:700}.rpt-period-inputs{gap:16px;display:flex}.rpt-shortcuts{flex-wrap:wrap;gap:8px;margin-left:auto;display:flex}.rpt-shortcut{border:1px solid var(--border);background:var(--bg3);color:var(--muted);cursor:pointer;border-radius:6px;padding:5px 12px;font-size:12px;transition:all .15s}.rpt-shortcut:hover{border-color:var(--accent);color:var(--accent)}.rpt-label-group{text-transform:uppercase;letter-spacing:1px;color:var(--muted);align-items:center;gap:8px;margin:24px 0 12px;font-size:12px;font-weight:700;display:flex}.rpt-card{flex-direction:column;gap:16px;margin-bottom:16px;display:flex}.rpt-card-top{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.rpt-section-header{align-items:center;gap:14px;display:flex}.rpt-section-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;display:flex}.rpt-section-title{color:var(--text);font-size:14px;font-weight:700}.rpt-section-sub{color:var(--muted);margin-top:2px;font-size:12px}.rpt-actions{align-items:center;gap:10px;display:flex}.btn-excel{color:#fff;cursor:pointer;background:#16a34a;border:none;border-radius:8px;align-items:center;gap:7px;padding:8px 16px;font-size:13px;font-weight:600;transition:background .15s;display:flex}.btn-excel:hover{background:#15803d}.btn-pdf{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:8px;align-items:center;gap:7px;padding:8px 16px;font-size:13px;font-weight:600;transition:background .15s;display:flex}.btn-pdf:hover{background:#b91c1c}.rpt-kpis{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.rpt-kpi{border:1px solid var(--border);background:var(--bg2);border-radius:10px;padding:14px 16px}.rpt-kpi--green{border-color:#4ade8033}.rpt-kpi--red{border-color:#ef444433}.rpt-kpi--blue{border-color:#60a5fa33}.rpt-kpi-l{color:var(--muted);margin-bottom:4px;font-size:11px}.rpt-kpi-v{font-size:16px;font-weight:800}.rpt-kpi--green .rpt-kpi-v{color:var(--accent)}.rpt-kpi--red .rpt-kpi-v{color:var(--danger)}.rpt-kpi--blue .rpt-kpi-v{color:#60a5fa}.rpt-table{border-collapse:collapse;width:100%;font-size:13px}.rpt-table th{text-align:left;background:var(--bg3);color:var(--muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);padding:8px 10px;font-size:11px;font-weight:700}.rpt-table td{border-bottom:1px solid var(--border);color:var(--text);padding:9px 10px}.rpt-table tbody tr:hover{background:var(--bg3)}.rpt-table tfoot td{background:var(--bg2);border-top:2px solid var(--border);padding:9px 10px}.rpt-num{text-align:right;font-variant-numeric:tabular-nums}.rpt-center{text-align:center}.rpt-green{color:var(--accent);font-weight:700}.rpt-yellow{color:var(--warning);font-weight:700}.rpt-muted{color:var(--muted);font-weight:400}.rpt-sub-title{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding-top:4px;font-size:12px;font-weight:700}.rpt-toggle{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;margin-top:8px;padding:5px 12px;font-size:12px;transition:all .15s}.rpt-toggle:hover{color:var(--accent);border-color:var(--accent)}.rpt-empty{color:var(--muted);text-align:center;padding:12px 0;font-size:13px}.cal-legend{flex-wrap:wrap;gap:12px;margin-bottom:16px;display:flex}.cal-legend-item{color:var(--muted);align-items:center;gap:6px;font-size:12px;display:flex}.cal-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.cal-card{padding:0;overflow:hidden}.cal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.cal-month{font-size:16px;font-weight:700}.cal-nav{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.cal-nav:hover{border-color:var(--accent);color:var(--accent)}.cal-grid{grid-template-columns:repeat(7,1fr);display:grid}.cal-week-header{border-bottom:1px solid var(--border)}.cal-dow{text-align:center;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:8px 0;font-size:11px;font-weight:700}.cal-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);vertical-align:top;min-height:100px;padding:6px;transition:background .1s}.cal-cell:nth-child(7n){border-right:none}.cal-cell--empty{background:var(--bg2)}.cal-cell:hover:not(.cal-cell--empty){background:var(--bg3)}.cal-cell--today{background:#4ade800f}.cal-cell--today .cal-day-num{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;display:flex}.cal-day-num{color:var(--text);justify-content:center;align-items:center;width:22px;height:22px;margin-bottom:4px;font-size:12px;font-weight:600;display:flex}.cal-events{flex-direction:column;gap:2px;display:flex}.cal-event{background:var(--bg3);color:var(--text);white-space:nowrap;text-overflow:ellipsis;cursor:default;border-radius:3px;padding:2px 5px;font-size:10px;overflow:hidden}.cal-more{color:var(--muted);padding:1px 4px;font-size:10px}
