:root{font-family:Segoe UI,system-ui,sans-serif;line-height:1.5;font-weight:400;color:#1f2937;background:#eef2eb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-height:100vh}a{color:#2d6a4f;text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font:inherit}.page-center{min-height:100vh;display:grid;place-items:center}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:linear-gradient(180deg,#1b4332,#2d6a4f);color:#fff;padding:1.5rem 1rem;display:flex;flex-direction:column;gap:2rem}.brand{display:flex;align-items:center;gap:.75rem}.brand.centered{justify-content:center;margin-bottom:.5rem}.brand-icon{font-size:1.75rem}.brand strong{display:block;font-size:1.1rem}.brand small{opacity:.85}.nav{display:flex;flex-direction:column;gap:.35rem}.nav-link{color:#ffffffe6;padding:.65rem .85rem;border-radius:.6rem;text-decoration:none}.nav-link:hover,.nav-link.active{background:#ffffff24;text-decoration:none}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:.5rem}.sidebar-footer p{margin:0;font-size:.95rem}.main{display:flex;flex-direction:column}.topbar{padding:1.5rem 2rem 1rem;display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.topbar h1{margin:0 0 .25rem;font-size:1.6rem}.topbar p{margin:0;color:#6b7280}.farm-select{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;color:#4b5563}.farm-select select{min-width:220px;padding:.55rem .75rem;border:1px solid #d1d5db;border-radius:.55rem;background:#fff}.content{padding:0 2rem 2rem}.page-grid{display:grid;grid-template-columns:minmax(280px,380px) 1fr;gap:1.25rem;align-items:start}.fields-page{grid-template-columns:minmax(320px,520px) 1fr}.card{background:#fff;border:1px solid #e5e7eb;border-radius:1rem;padding:1.25rem;box-shadow:0 8px 24px #1b43320f}.card h2{margin:0 0 1rem;font-size:1.15rem}.empty-state{max-width:560px}.form-grid{display:grid;gap:.85rem}.field-label{display:block;font-size:.9rem;color:#374151;margin-bottom:.35rem}.checkbox-group{display:flex;flex-direction:column;gap:.45rem;padding:.65rem .75rem;border:1px solid #d1d5db;border-radius:.55rem;background:#fff}.checkbox-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#374151}.tag-list{display:flex;flex-wrap:wrap;gap:.35rem}.mode-toggle{display:flex;gap:.5rem;margin-bottom:1rem}.batch-help{margin:0 0 .75rem}.batch-tags{display:flex;flex-direction:column;gap:.65rem;margin-bottom:.75rem}.batch-tag-row{display:grid;grid-template-columns:1fr auto;gap:.5rem;align-items:end}.batch-tag-row label{margin:0}.batch-input-toggle{margin-bottom:.85rem}.batch-range{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;margin-bottom:.5rem}.batch-range label{margin:0}.tag{display:inline-block;padding:.15rem .5rem;border-radius:999px;background:#ecfdf3;color:#166534;font-size:.78rem}.form-grid label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;color:#374151}.form-grid .full-width{grid-column:1 / -1}.form-grid input,.form-grid select,.form-grid textarea{padding:.6rem .75rem;border:1px solid #d1d5db;border-radius:.55rem;background:#fff}.form-actions{display:flex;gap:.5rem;margin-top:.25rem}.btn{border:1px solid #d1d5db;background:#fff;color:#1f2937;border-radius:.55rem;padding:.55rem .9rem;cursor:pointer}.btn:hover{background:#f9fafb}.btn-primary{background:#2d6a4f;border-color:#2d6a4f;color:#fff}.btn-primary:hover{background:#1b4332}.btn-ghost{background:transparent}.btn-sm{padding:.35rem .65rem;font-size:.85rem}.btn-danger{color:#b91c1c;border-color:#fecaca}.btn-danger:hover{background:#fef2f2}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:.75rem .5rem;border-bottom:1px solid #eef2f7;vertical-align:top}th{font-size:.85rem;color:#6b7280}.actions{display:flex;gap:.35rem;flex-wrap:wrap}.muted{color:#6b7280}.alert{padding:.75rem .9rem;border-radius:.55rem;margin-bottom:1rem}.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.badge{display:inline-block;padding:.2rem .55rem;border-radius:999px;font-size:.8rem;font-weight:600}.badge-pending{background:#fef3c7;color:#92400e}.badge-in_progress{background:#dbeafe;color:#1d4ed8}.badge-completed{background:#dcfce7;color:#166534}.badge-cancelled{background:#f3f4f6;color:#4b5563}.badge-delivery-on-time{background:#dcfce7;color:#166534}.badge-delivery-overdue{background:#fee2e2;color:#991b1b}.badge-delivery-late{background:#ffedd5;color:#9a3412}.auth-page{min-height:100vh;display:grid;place-items:center;padding:1rem;background:radial-gradient(circle at top left,rgba(45,106,79,.18),transparent 40%),#eef2eb}.auth-card{width:min(100%,420px);background:#fff;border:1px solid #e5e7eb;border-radius:1rem;padding:1.5rem;display:grid;gap:.85rem;box-shadow:0 12px 32px #1b433214}.auth-card label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem}.auth-card input{padding:.6rem .75rem;border:1px solid #d1d5db;border-radius:.55rem}.auth-footer{margin:0;text-align:center;color:#6b7280}@media(max-width:960px){.app-shell{grid-template-columns:1fr}.sidebar{gap:1rem}.nav{flex-direction:row;flex-wrap:wrap}.page-grid,.fields-page{grid-template-columns:1fr}.topbar{flex-direction:column}}.map-preview{border:1px solid #e5e7eb;border-radius:.75rem;overflow:hidden;background:#f9fafb}.map-preview img{display:block;width:100%;max-height:280px;object-fit:contain}.map-drawer{display:flex;flex-direction:column;gap:.65rem}.map-drawer-toolbar{display:flex;justify-content:space-between;gap:.75rem;align-items:center;flex-wrap:wrap}.map-drawer-actions{display:flex;gap:.35rem;flex-wrap:wrap}.map-drawer-canvas{position:relative;border:1px solid #d1d5db;border-radius:.75rem;overflow:hidden;background:#111827;min-height:240px}.map-drawer-image{position:absolute;display:block;object-fit:contain;pointer-events:none}.map-drawer-overlay{position:absolute;cursor:crosshair}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:grid;place-items:center;padding:1rem;background:#1118278c}.modal-card{width:min(100%,420px);background:#fff;border-radius:.85rem;padding:1.25rem;box-shadow:0 20px 45px #0f172a2e}.modal-card.modal-wide{width:min(100%,760px)}.modal-card h3{margin:0 0 .5rem}.modal-card .form-actions{margin-top:.25rem}.dashboard,.dashboard-summary{display:flex;flex-direction:column;gap:1.25rem}.dashboard-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.85rem}.dashboard-stat{display:flex;flex-direction:column;gap:.35rem;padding:1rem 1.1rem}.dashboard-stat-label{font-size:.85rem;color:#6b7280}.dashboard-stat-value{font-size:1.75rem;line-height:1.1;color:#1b4332}.dashboard-delivery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.85rem;margin-bottom:1rem}.dashboard-delivery-stat{display:flex;flex-direction:column;gap:.25rem;padding:.95rem 1rem;border:1px solid #e5e7eb;border-radius:.85rem;background:#fafafa}.dashboard-delivery-on-time{background:#f0fdf4;border-color:#bbf7d0}.dashboard-delivery-overdue{background:#fef2f2;border-color:#fecaca}.dashboard-delivery-completed{background:#eff6ff;border-color:#bfdbfe}.dashboard-delivery-late{background:#fff7ed;border-color:#fed7aa}.dashboard-delivery-table-wrap{margin-top:.5rem}.dashboard-overdue-list{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid #eef2f7}.dashboard-overdue-list h3{margin:0 0 .75rem;font-size:1rem}.dashboard-overdue-item-header{display:flex;gap:.35rem;flex-wrap:wrap}.dashboard-overdue-action{align-self:flex-start;margin-top:.15rem}.dashboard-section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.dashboard-section-header h2{margin:0 0 .25rem}.dashboard-section-header p{margin:0}.dashboard-table td,.dashboard-table th{white-space:nowrap}.dashboard-row-active{background:#f0fdf4}.dashboard-farm-link{border:none;background:none;padding:0;color:#2d6a4f;font-weight:600;cursor:pointer;text-align:left}.dashboard-farm-link:hover{text-decoration:underline}.dashboard-farm-note{display:block;color:#9ca3af;font-size:.75rem;margin-top:.15rem}.dashboard-map-section{display:flex;flex-direction:column;gap:1rem}.dashboard-map-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.dashboard-map-header h2{margin:0 0 .25rem}.dashboard-map-header p{margin:0}.dashboard-map-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(280px,380px);gap:1.25rem;align-items:start}.dashboard-map-card{min-width:0}.dashboard-field-panel h2,.dashboard-field-panel h3{margin:0 0 .75rem}.dashboard-field-panel h4{margin:1rem 0 .5rem;font-size:.95rem}.dashboard-field-list{list-style:none;margin:.75rem 0 0;padding:0;display:flex;flex-direction:column;gap:.45rem}.dashboard-field-list-item{width:100%;display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.65rem .75rem;border:1px solid #e5e7eb;border-radius:.65rem;background:#f9fafb;cursor:pointer;text-align:left}.dashboard-field-list-item:hover{border-color:#86efac;background:#f0fdf4}.dashboard-field-meta{display:grid;gap:.65rem;margin:0}.dashboard-field-meta div{display:grid;gap:.15rem}.dashboard-field-meta dt{font-size:.8rem;color:#6b7280}.dashboard-field-meta dd{margin:0}.dashboard-task-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}.dashboard-task-list li{display:flex;flex-direction:column;gap:.25rem;padding:.65rem .75rem;border:1px solid #eef2f7;border-radius:.65rem;background:#fafafa;font-size:.92rem}.map-viewer{display:flex;flex-direction:column;gap:.75rem}.map-viewer-canvas{cursor:default}.map-viewer-overlay{cursor:pointer}.map-viewer-polygon{transition:fill-opacity .15s ease}.map-viewer-legend{display:flex;flex-wrap:wrap;gap:.45rem}.map-viewer-legend-item{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .65rem;border:1px solid #e5e7eb;border-radius:999px;background:#fff;cursor:pointer;font-size:.85rem}.map-viewer-legend-item.selected{border-color:#2d6a4f;background:#f0fdf4}.map-viewer-legend-swatch{width:.75rem;height:.75rem;border-radius:999px;flex-shrink:0}@media(max-width:960px){.dashboard-map-grid{grid-template-columns:1fr}}
