.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:16px;animation:fadeIn .2s ease forwards}.modal{background-color:var(--surface-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:calc(100vh - 32px);display:flex;flex-direction:column;animation:slideUp .3s ease forwards;outline:none}.modal-small{width:100%;max-width:360px}.modal-medium{width:100%;max-width:480px}.modal-large{width:100%;max-width:640px}.modal-full{width:100%;max-width:calc(100vw - 32px);height:calc(100vh - 32px)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color);flex-shrink:0}.modal-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin:0}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;border-radius:var(--radius-full);cursor:pointer;color:var(--text-secondary);font-size:18px;transition:background-color var(--transition-fast),color var(--transition-fast)}.modal-close:hover{background-color:var(--background-color);color:var(--text-primary)}.modal-body{padding:20px;overflow-y:auto;flex:1}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid var(--border-color);flex-shrink:0}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-family);font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;white-space:nowrap}.btn-primary{background-color:var(--primary-color);color:var(--white)}.btn-primary:hover:not(:disabled){background-color:var(--primary-dark)}.btn-secondary{background-color:transparent;color:var(--primary-color);border:2px solid var(--primary-color)}.btn-secondary:hover:not(:disabled){background-color:var(--primary-color);color:var(--white)}.btn-outline{background-color:transparent;color:var(--text-primary);border:1px solid var(--border-color)}.btn-outline:hover:not(:disabled){background-color:var(--background-color);border-color:var(--text-secondary)}.btn-danger{background-color:var(--error-color);color:var(--white)}.btn-danger:hover:not(:disabled){background-color:#b71c1c}.btn-text{background-color:transparent;color:var(--primary-color);padding:8px 12px}.btn-text:hover:not(:disabled){background-color:#4caf501a}.btn-small{padding:6px 12px;font-size:var(--font-size-sm)}.btn-medium{padding:10px 20px;font-size:var(--font-size-md)}.btn-large{padding:14px 28px;font-size:var(--font-size-lg)}.btn-full-width{width:100%}.btn-disabled,.btn:disabled{opacity:.6;cursor:not-allowed}.btn-loading{position:relative;color:transparent}.btn-spinner{width:20px;height:20px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}.btn-loading .btn-spinner{color:var(--white)}.btn-secondary.btn-loading .btn-spinner,.btn-outline.btn-loading .btn-spinner,.btn-text.btn-loading .btn-spinner{color:var(--primary-color)}.btn-icon{display:flex;align-items:center;justify-content:center;font-size:1.1em}.terms-content{display:flex;flex-direction:column;gap:20px}.terms-scroll{max-height:400px;overflow-y:auto;padding-right:8px;scrollbar-width:thin;scrollbar-color:var(--primary-color) var(--background-color)}.terms-scroll::-webkit-scrollbar{width:6px}.terms-scroll::-webkit-scrollbar-track{background:var(--background-color);border-radius:3px}.terms-scroll::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:3px}.terms-scroll h3{font-size:var(--font-size-lg);font-weight:700;color:var(--primary-color);margin:0 0 12px}.terms-scroll h4{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);margin:20px 0 8px}.terms-scroll h4:first-of-type{margin-top:16px}.terms-scroll p{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6;margin:0 0 8px}.terms-checkbox{padding:16px;background:var(--background-color);border-radius:var(--radius-md)}.checkbox-label{display:flex;align-items:flex-start;gap:12px;cursor:pointer}.checkbox-label input[type=checkbox]{display:none}.checkbox-custom{width:22px;height:22px;border:2px solid var(--border-color);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-fast);margin-top:1px}.checkbox-label input[type=checkbox]:checked+.checkbox-custom{background:var(--primary-color);border-color:var(--primary-color)}.checkbox-label input[type=checkbox]:checked+.checkbox-custom:after{content:"✓";color:var(--white);font-size:14px;font-weight:700}.checkbox-text{font-size:var(--font-size-sm);color:var(--text-primary);line-height:1.5}.checkbox-label:hover .checkbox-custom{border-color:var(--primary-color)}@media (max-width: 480px){.terms-scroll{max-height:300px}}.spinner{display:inline-flex;align-items:center;justify-content:center}.spinner-circle{border-radius:50%;border-style:solid;border-color:currentColor;border-top-color:transparent;animation:spin .8s linear infinite}.spinner-small .spinner-circle{width:16px;height:16px;border-width:2px}.spinner-medium .spinner-circle{width:32px;height:32px;border-width:3px}.spinner-large .spinner-circle{width:48px;height:48px;border-width:4px}.spinner-primary{color:var(--primary-color)}.spinner-white{color:var(--white)}.spinner-secondary{color:var(--text-secondary)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;padding:32px;gap:16px}.loading-message{font-size:var(--font-size-md);color:var(--text-secondary);margin:0}.input-wrapper{display:flex;flex-direction:column;gap:6px;width:100%}.input-label{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary)}.input-required{color:var(--error-color);margin-left:4px}.input-container{position:relative;display:flex;align-items:center}.input-field{width:100%;padding:12px 16px;font-size:var(--font-size-md);color:var(--text-primary);background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input-field::placeholder{color:var(--text-secondary)}.input-field:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4caf5026}.input-field:disabled{background-color:var(--background-color);cursor:not-allowed;opacity:.7}.input-icon{position:absolute;left:12px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);pointer-events:none;z-index:1}.input-field.input-with-icon{padding-left:44px}.input-password-toggle{position:absolute;right:12px;background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:18px}.input-password-toggle:hover{color:var(--text-primary)}.input-field.input-with-toggle{padding-right:44px}.input-helper{font-size:var(--font-size-xs);color:var(--text-secondary)}.input-helper-error{color:var(--error-color)}.input-error .input-field{border-color:var(--error-color)}.input-error .input-field:focus{box-shadow:0 0 0 3px #d32f2f26}.input-disabled{opacity:.7}.input-disabled .input-label{color:var(--text-secondary)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);padding:16px}.login-container{width:100%;max-width:400px;background:var(--surface-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:32px;animation:slideUp .4s ease forwards}.login-header{text-align:center;margin-bottom:32px}.login-logo{width:100px;height:100px;border-radius:50%;object-fit:cover;margin-bottom:16px}.login-title{font-size:var(--font-size-xxl);font-weight:700;color:var(--primary-color);margin:0 0 8px}.login-subtitle{font-size:var(--font-size-md);color:var(--text-secondary);margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.login-footer{margin-top:24px;text-align:center;padding-top:24px;border-top:1px solid var(--border-color)}@media (max-width: 480px){.login-container{padding:24px}.login-icon{font-size:48px}.login-title{font-size:var(--font-size-xl)}}.header{position:sticky;top:0;z-index:50;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:var(--white);box-shadow:var(--shadow-md)}.header-content{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;max-width:1200px;margin:0 auto}.header-left{display:flex;align-items:center;gap:12px;min-width:0}.header-back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#ffffff1a;border:none;border-radius:var(--radius-full);color:var(--white);cursor:pointer;transition:background-color var(--transition-fast);flex-shrink:0}.header-back:hover{background:#fff3}.header-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}.header-logo-img{width:40px;height:40px;border-radius:50%;object-fit:cover}.header-logo-icon{font-size:28px}.header-title{font-size:var(--font-size-lg);font-weight:600;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-nav{display:flex;align-items:center;gap:16px;flex-shrink:0}.header-avatar{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--white);color:var(--primary-dark);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;text-decoration:none;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.header-avatar:hover{transform:scale(1.05);box-shadow:0 0 0 3px #ffffff4d}.header-login{padding:8px 16px;background:#ffffff26;color:var(--white);border-radius:var(--radius-md);text-decoration:none;font-size:var(--font-size-sm);font-weight:500;transition:background-color var(--transition-fast)}.header-login:hover{background:#ffffff40;color:var(--white)}@media (max-width: 480px){.header-content{padding:10px 12px}.header-title{font-size:var(--font-size-md)}.header-avatar,.header-back{width:36px;height:36px}}.home-page{min-height:100vh;background:#f5f7f2}.home-main{max-width:720px;margin:0 auto;padding:10px 12px 80px}.search-row{display:flex;gap:8px}.search-box{flex:1;display:flex;align-items:center;gap:8px;padding:0 10px;background:#fff;border:1px solid #d5ded1;border-radius:10px}.search-box svg{color:#6e7c6f;flex-shrink:0}.search-box input{flex:1;min-width:0;border:none;outline:none;background:transparent;padding:10px 0;font-size:.95rem}.clear-btn{width:24px;height:24px;border:none;border-radius:50%;background:#dfe6dc;color:#3f4e40;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center}.legend-text{margin:8px 0 6px;font-size:.78rem;color:#7a887b;line-height:1.4}.crop-list{display:grid;gap:6px}.crop-row{display:grid;grid-template-columns:1fr auto 16px;align-items:center;gap:10px;background:#fff;border-radius:12px;padding:12px 14px;cursor:pointer;transition:box-shadow .15s;border:1px solid #e4ebe1}.crop-row:active{box-shadow:0 0 0 2px #1f6d3e40}.crop-left{display:flex;align-items:center;gap:10px;min-width:0}.crop-icon{font-size:1.2rem;flex-shrink:0}.crop-info{min-width:0}.crop-info h3{margin:0;font-size:.95rem;color:#1c2d1f;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.crop-total-label{display:block;font-size:.7rem;color:#8a928b;margin-top:2px}.crop-right{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:1px}.month-num{font-weight:700;font-size:1rem;color:#1f6d3e;line-height:1.2}.crop-unit{font-size:.62rem;color:#8a928b;font-weight:500}.row-arrow{color:#b0bab1;flex-shrink:0}.fab-register{position:fixed;bottom:20px;right:20px;padding:12px 20px;border:none;border-radius:28px;background:#1f6d3e;color:#fff;font-weight:700;font-size:.9rem;box-shadow:0 4px 14px #1f6d3e59;cursor:pointer;z-index:40}.loading-state,.empty-state{text-align:center;padding:28px 14px;color:#536153}.empty-state p{margin:0}@media (min-width: 640px){.crop-row{padding:14px 18px}}.line-chart-wrapper{background:#fff;border-radius:14px;padding:16px;border:1px solid #dfe7da}.chart-title{font-size:1rem;font-weight:600;color:#203023;margin:0 0 12px}.chart-stats{display:flex;gap:8px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #e8ece8}.stat-item{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;padding:8px;background:#f5f7f2;border-radius:8px}.stat-value{font-size:.95rem;font-weight:700;color:#1f6d3e}.stat-label{font-size:.62rem;color:#6a786b;margin-top:2px;text-transform:uppercase;letter-spacing:.4px}.chart-color-legend{display:flex;gap:14px;margin-bottom:10px;justify-content:center}.legend-item{display:flex;align-items:center;gap:4px;font-size:.72rem;color:#5a675a;font-weight:600}.dot{width:8px;height:8px;border-radius:50%}.dot-green{background:#27ae60}.dot-yellow{background:#f0b932}.dot-red{background:#e74c3c}.scroll-hint{font-size:.7rem;color:#8a928b;text-align:center;margin:0 0 6px}.chart-container{height:280px;position:relative;touch-action:none}.reset-zoom-btn{display:block;margin:8px auto 0;padding:6px 16px;border:1px solid #d5ded1;border-radius:8px;background:#f5f7f2;color:#3f4e40;font-size:.78rem;font-weight:600;cursor:pointer}.reset-zoom-btn:active{background:#e8ece8}@media (min-width: 768px){.chart-container{height:340px}}@media (max-width: 480px){.line-chart-wrapper{padding:12px}.chart-stats{gap:6px}.stat-item{padding:6px}.stat-value{font-size:.85rem}.chart-container{height:240px}}.plant-detail-page{min-height:100vh;background:#f5f7f2}.detail-content{max-width:720px;margin:0 auto;padding:10px 12px 24px;display:grid;gap:10px}.entries-section{margin-top:4px}.entries-title{margin:0 0 8px;font-size:1rem;color:#223225}.entries-list{display:grid;gap:8px}.loc-group{background:#fff;border:1px solid #dfe7da;border-radius:12px;overflow:hidden}.loc-group-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#f5f7f2;border-bottom:1px solid #e4ebe1}.loc-group-name{font-size:.92rem;font-weight:600;color:#263627}.loc-group-total{font-size:.8rem;color:#1f6d3e;font-weight:700}.loc-entries{padding:6px 10px 10px}.entry-row{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border-radius:8px}.entry-row:nth-child(odd){background:#f9fbf8}.entry-date{font-size:.85rem;color:#4f5c50}.entry-qty{font-size:.85rem;color:#243424;font-weight:700}.loading-container,.empty-state,.empty-locations{background:#fff;border:1px solid #dfe7da;border-radius:12px;padding:28px 14px;text-align:center;color:#566456}.empty-state h3{margin:0 0 6px;color:#273627}.empty-state p,.empty-locations p{margin:0}.chart-page{min-height:100vh;background:#f5f7f2}.chart-content{max-width:720px;margin:0 auto;padding:10px 12px 24px}.chart-header{margin-bottom:8px}.chart-info{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fff;border:1px solid #dfe7da;border-radius:12px}.chart-icon{width:36px;height:36px;border-radius:8px;background:#e7f2e8;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.chart-plant-name{margin:0 0 2px;color:#203023;font-size:1.05rem}.chart-total{margin:0;color:#5a665a;font-size:.82rem}.chart-summary-signals{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;margin-bottom:8px}.summary-signal-card{background:#fff;border:1px solid #dfe7da;border-radius:10px;padding:8px}.summary-signal-card span{display:block;font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;color:#6b786c;font-weight:700}.summary-signal-card strong{display:block;margin-top:3px;color:#243524;font-size:.9rem}.chart-note{margin-top:8px;background:#eef6ed;border:1px solid #dbe8d8;border-radius:10px;padding:10px}.chart-note p{margin:0;color:#4f5f4f;font-size:.85rem;line-height:1.5}.loading-container,.empty-state{background:#fff;border:1px solid #dfe7da;border-radius:12px;margin:12px;padding:28px 14px;text-align:center;color:#556355}.empty-icon{font-size:1.6rem}.empty-state h3{margin:6px 0;color:#233224}.empty-state p{margin:0 0 10px}.create-edit-page{min-height:100vh;display:flex;flex-direction:column;background-color:var(--background-color)}.form-content{flex:1;max-width:500px;width:100%;margin:0 auto;padding:24px 16px}.germination-form{background:var(--surface-color);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:20px}.form-actions{display:flex;gap:12px;margin-top:8px}.form-actions button{flex:1}.form-tips{margin-top:24px;padding:16px;background:#4caf5014;border-radius:var(--radius-md);border-left:4px solid var(--primary-color)}.form-tips h4{font-size:var(--font-size-sm);font-weight:600;color:var(--primary-dark);margin:0 0 8px}.form-tips ul{margin:0;padding-left:20px;list-style:disc}.form-tips li{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:4px}.form-tips li:last-child{margin-bottom:0}@media (max-width: 480px){.form-content{padding:16px}.germination-form{padding:20px}.form-actions{flex-direction:column-reverse}}.nombre-field{position:relative}.nombre-suggestions{position:absolute;top:100%;left:0;right:0;margin:0;padding:4px 0;list-style:none;background:#fff;border:1px solid #dfe7da;border-radius:8px;box-shadow:0 4px 12px #0000001f;max-height:200px;overflow-y:auto;z-index:20}.nombre-suggestions li{padding:10px 14px;font-size:.9rem;color:#223225;cursor:pointer}.nombre-suggestions li:hover,.nombre-suggestions li.selected{background:#e8f5e9;color:#1b5e20}.profile-page{min-height:100vh;display:flex;flex-direction:column;background-color:var(--background-color)}.profile-header{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 50%,var(--primary-dark) 100%);padding:32px 16px;display:flex;flex-direction:column;align-items:center;text-align:center}.profile-avatar{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:var(--white);color:var(--primary-dark);font-size:28px;font-weight:700;border-radius:var(--radius-full);box-shadow:0 4px 12px #0003;margin-bottom:12px}.profile-name{font-size:var(--font-size-xl);font-weight:700;color:var(--white);margin:0 0 8px}.profile-badge{display:inline-block;padding:4px 12px;background:#fff3;color:var(--white);font-size:var(--font-size-sm);border-radius:var(--radius-lg)}.profile-content{flex:1;max-width:600px;width:100%;margin:0 auto;padding:16px}.profile-section{margin-bottom:24px}.section-title{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);margin:0 0 12px}.info-card{background:var(--surface-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.info-item{display:flex;align-items:center;gap:16px;padding:16px;border-bottom:1px solid var(--border-color)}.info-item:last-child{border-bottom:none}.info-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#4caf501a;border-radius:var(--radius-md);color:var(--primary-color);flex-shrink:0}.info-content{flex:1;min-width:0}.info-label{display:block;font-size:var(--font-size-xs);color:var(--text-secondary);margin-bottom:2px}.info-value{display:block;font-size:var(--font-size-md);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.action-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px 16px;background:var(--surface-color);border:2px solid transparent;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--transition-fast)}.action-card:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-md)}.action-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#4caf501a;border-radius:var(--radius-md);color:var(--primary-color)}.action-label{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);text-align:center}.action-danger{border-color:#d32f2f4d}.action-danger:hover{border-color:var(--error-color)}.action-danger .action-icon{background:#d32f2f1a;color:var(--error-color)}.action-admin{border-color:#9c27b04d}.action-admin:hover{border-color:#9c27b0}.action-admin .action-icon{background:#9c27b01a;color:#9c27b0}.modal-form{display:flex;flex-direction:column;gap:16px}@media (max-width: 480px){.profile-header{padding:24px 16px}.profile-avatar{width:64px;height:64px;font-size:24px}.profile-name{font-size:var(--font-size-lg)}.actions-grid{gap:8px}.action-card{padding:16px 12px}.action-icon{width:40px;height:40px}}.card{background-color:var(--surface-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow var(--transition-fast),transform var(--transition-fast)}.card-clickable{cursor:pointer}.card-clickable:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.card-hover:hover,.card-clickable:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-header{padding:16px 16px 0}.card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin:0 0 4px}.card-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0}.card-content{padding:16px}.card-header+.card-content{padding-top:12px}.my-plants-page{min-height:100vh;display:flex;flex-direction:column;background-color:var(--background-color)}.my-plants-content{flex:1;max-width:800px;width:100%;margin:0 auto;padding:16px}.actions-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:16px}.section-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.refresh-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;min-width:110px;background-color:#2e7d32;border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.refresh-button:hover:not(:disabled){background:var(--primary-dark);transform:scale(1.02)}.refresh-button:disabled{opacity:.6;cursor:not-allowed}.refresh-button .spinning{animation:spin .8s linear infinite}.refresh-button svg{flex-shrink:0}.plants-list{display:flex;flex-direction:column;gap:12px}.plant-item .card-content{padding:0}.plant-item-content{display:flex;align-items:center;gap:12px;padding:16px}.plant-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#4caf501a;border-radius:var(--radius-md);font-size:22px;flex-shrink:0}.plant-info{flex:1;min-width:0}.plant-name{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.plant-details{display:flex;flex-wrap:wrap;gap:8px;font-size:var(--font-size-sm);color:var(--text-secondary)}.plant-quantity:after{content:"•";margin-left:8px}.plant-actions{display:flex;gap:8px;flex-shrink:0}.action-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--background-color);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.edit-btn{color:var(--primary-color)}.edit-btn:hover{background:#4caf5026}.delete-btn{color:var(--error-color)}.delete-btn:hover{background:#d32f2f26}.delete-confirm-content{text-align:center}.delete-confirm-content>p:first-child{color:var(--text-primary);margin:0 0 16px}.delete-plant-info{display:flex;flex-direction:column;gap:4px;padding:12px;background:var(--background-color);border-radius:var(--radius-md);margin-bottom:16px}.delete-plant-info strong{color:var(--text-primary);font-size:var(--font-size-md)}.delete-plant-info span{color:var(--text-secondary);font-size:var(--font-size-sm)}.delete-warning{color:var(--error-color);font-size:var(--font-size-sm);margin:0}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 16px;gap:16px;color:var(--text-secondary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 16px;text-align:center;gap:16px}.empty-icon{font-size:64px}.empty-state h3{font-size:var(--font-size-lg);color:var(--text-primary);margin:0}.empty-state p{font-size:var(--font-size-md);color:var(--text-secondary);margin:0}@media (max-width: 480px){.plant-item-content{flex-wrap:wrap}.plant-actions{width:100%;justify-content:flex-end;padding-top:8px;margin-top:8px;border-top:1px solid var(--border-color)}}.admin-page{min-height:100vh;display:flex;flex-direction:column;background-color:#f8faf8}.admin-content{flex:1;max-width:1000px;width:100%;margin:0 auto;padding:24px}.admin-tabs{display:flex;gap:8px;margin-bottom:24px;background:#fff;padding:8px;border-radius:12px;box-shadow:0 2px 8px #0000000f}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;border:none;background:transparent;border-radius:8px;font-size:.95rem;font-weight:500;color:#757575;cursor:pointer;transition:all .2s}.tab-btn:hover{background:#f5f5f5;color:#424242}.tab-btn.active{background:linear-gradient(135deg,#2e7d32,#43a047);color:#fff;box-shadow:0 4px 12px #2e7d324d}.tab-content{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px #00000014}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #f0f0f0}.section-header h2{font-size:1.25rem;font-weight:600;color:#212121;margin:0}.user-count{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#2e7d32;padding:6px 14px;border-radius:20px;font-size:.85rem;font-weight:600}.users-table{overflow:hidden}.table-header{display:grid;grid-template-columns:1.5fr 2fr 1fr 1fr 1.5fr;gap:16px;padding:12px 16px;background:#f5f5f5;border-radius:8px;font-size:.8rem;font-weight:600;color:#616161;text-transform:uppercase;letter-spacing:.5px}.table-row{display:grid;grid-template-columns:1.5fr 2fr 1fr 1fr 1.5fr;gap:16px;padding:16px;border-bottom:1px solid #f0f0f0;align-items:center}.table-row:last-child{border-bottom:none}.table-row:hover{background:#f8faf8}.user-name{font-weight:600;color:#212121}.role-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:capitalize}.role-ingeniero{background:linear-gradient(135deg,#e3f2fd,#bbdefb);color:#1565c0}.role-agricultor{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#2e7d32}.role-admin{background:linear-gradient(135deg,#fce4ec,#f8bbd9);color:#c2185b}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px 20px;color:#616161}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px 20px;text-align:center;color:#757575}.create-form{display:flex;flex-direction:column;gap:24px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.9rem;font-weight:500;color:#424242}.form-select{padding:12px 16px;font-size:1rem;border:1px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;transition:border-color .2s}.form-select:focus{outline:none;border-color:#2e7d32}.form-spacer{display:none}.form-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;border-top:1px solid #f0f0f0}@media (max-width: 768px){.admin-tabs{flex-direction:column}.table-header{display:none}.table-row{grid-template-columns:1fr;gap:8px;padding:16px;border:1px solid #f0f0f0;border-radius:8px;margin-bottom:8px}.table-row span:before{font-weight:600;color:#757575;font-size:.8rem}.table-row span:nth-child(1):before{content:"Nombre: "}.table-row span:nth-child(2):before{content:"Correo: "}.table-row span:nth-child(3):before{content:"Tel: "}.table-row span:nth-child(4):before{content:"Rol: "}.table-row span:nth-child(5):before{content:"Ubicación: "}.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions button{width:100%}}:root{--primary-color: #4CAF50;--primary-dark: #388E3C;--primary-light: #81C784;--accent-color: #8D6E63;--error-color: #D32F2F;--warning-color: #FFA000;--success-color: #4CAF50;--info-color: #1976D2;--background-color: #F5F5F5;--surface-color: #FFFFFF;--text-primary: #000000;--text-secondary: rgba(0, 0, 0, .54);--text-disabled: rgba(0, 0, 0, .38);--white: #FFFFFF;--black: #000000;--border-color: rgba(0, 0, 0, .12);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .12), 0 1px 2px rgba(0, 0, 0, .24);--shadow-md: 0 3px 6px rgba(0, 0, 0, .15), 0 2px 4px rgba(0, 0, 0, .12);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .15), 0 3px 6px rgba(0, 0, 0, .1);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 50%;--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease;--font-family: "Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-md: 16px;--font-size-lg: 18px;--font-size-xl: 24px;--font-size-xxl: 32px;--z-dropdown: 100;--z-modal: 200;--z-toast: 300}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-md);line-height:1.5;color:var(--text-primary);background-color:var(--background-color);min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--primary-color);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-dark)}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}button,input,select,textarea{font-family:inherit;font-size:inherit}button{cursor:pointer;border:none;background:none}:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--background-color)}::-webkit-scrollbar-thumb{background:var(--text-secondary);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--text-primary)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.text-center{text-align:center}.text-error{color:var(--error-color)}.text-success{color:var(--success-color)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn var(--transition-normal) forwards}.slide-up{animation:slideUp var(--transition-normal) forwards}.slide-down{animation:slideDown var(--transition-normal) forwards}
