@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.header{background:linear-gradient(135deg,#1e293b,#0f172a);border-bottom:1px solid rgba(255,255,255,.1);padding:1rem 2rem;box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:100}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1600px;margin:0 auto}.header-left{display:flex;align-items:center;gap:1rem}.logo{display:flex;align-items:center;color:#10b981;filter:drop-shadow(0 2px 4px rgba(16,185,129,.3))}.header-title{font-size:1.5rem;font-weight:600;color:#fff;margin:0;letter-spacing:-.5px}.header-right{display:flex;align-items:center;gap:1rem}.btn-theme{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#ffffffe6;cursor:pointer;transition:all .2s}.btn-theme:hover{background:#ffffff1f;border-color:#ffffff40;transform:translateY(-1px);color:#fbbf24}.btn-refresh{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#ffffffe6;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-refresh:hover:not(:disabled){background:#ffffff1f;border-color:#ffffff40;transform:translateY(-1px)}.btn-refresh:disabled{opacity:.5;cursor:not-allowed}.user-info{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffe6;font-size:.9rem;font-weight:500}.user-name{white-space:nowrap}.btn-logout{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#fca5a5;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-logout:hover{background:#ef444440;border-color:#ef444480;color:#fecaca;transform:translateY(-1px)}@media(max-width:768px){.header{padding:.75rem 1rem}.header-content{flex-wrap:wrap;gap:.75rem}.header-right{width:100%;justify-content:space-between}.btn-refresh span,.btn-logout span{display:none}.user-name{max-width:120px;overflow:hidden;text-overflow:ellipsis}}@media(max-width:480px){.header-title{font-size:1.25rem}.user-info{padding:.5rem .75rem;font-size:.85rem}.btn-refresh,.btn-logout{padding:.5rem .75rem}}:root{--primary: #0f766e;--primary-light: #14b8a6;--primary-dark: #115e59;--secondary: #0369a1;--secondary-light: #0ea5e9;--secondary-dark: #075985;--success: #059669;--warning: #d97706;--error: #dc2626;--info: #2563eb;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--text-primary: #111827;--text-secondary: #4b5563;--text-tertiary: #6b7280;--border-light: #e5e7eb;--border-medium: #d1d5db;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--gradient-primary: linear-gradient(135deg, var(--primary), var(--secondary));--space-xs: .25rem;--space-sm: .5rem;--space: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: .375rem;--radius: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--transition: all .2s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg-primary: #111827;--bg-secondary: #0f172a;--bg-tertiary: #1f2937;--text-primary: #f9fafb;--text-secondary: #d1d5db;--text-tertiary: #9ca3af;--border-light: #374151;--border-medium: #4b5563;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .3);--shadow: 0 1px 3px 0 rgb(0 0 0 / .4), 0 1px 2px -1px rgb(0 0 0 / .4);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .4), 0 2px 4px -2px rgb(0 0 0 / .4);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .4), 0 4px 6px -4px rgb(0 0 0 / .4);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .4), 0 8px 10px -6px rgb(0 0 0 / .4)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;color:var(--text-secondary);background-color:var(--bg-secondary);transition:background-color .3s ease,color .3s ease;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600;line-height:1.25;letter-spacing:-.025em}h1{font-size:2.25rem;margin-bottom:var(--space-lg)}h2{font-size:1.875rem;margin-bottom:var(--space)}h3{font-size:1.5rem;margin-bottom:var(--space)}h4{font-size:1.25rem;margin-bottom:var(--space-sm)}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-secondary)}.app-body{display:flex;flex:1}.main{flex:1;overflow-y:auto;background:var(--bg-secondary)}.navbar{background:var(--bg-primary);border-bottom:1px solid var(--border-light);padding:var(--space-sm) 0;position:sticky;top:0;z-index:999;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:rgba(var(--bg-primary),.8)}[data-theme=dark] .navbar{background:#111827d9}.nav-content{max-width:1400px;margin:0 auto;padding:0 var(--space);display:grid;grid-template-columns:auto auto 1fr auto auto auto;gap:var(--space);align-items:center;min-height:56px}.nav-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius);transition:var(--transition);font-size:.875rem;font-weight:500;min-height:36px;box-sizing:border-box;border:1px solid transparent}.nav-logo{font-weight:700;font-size:1.125rem;color:var(--text-primary);cursor:default;background:transparent;border:none;justify-content:flex-start;padding-left:0;letter-spacing:-.025em}.nav-logo-icon{color:var(--primary);display:flex;align-items:center;margin-right:var(--space-xs)}.theme-toggle-nav{background:transparent;border:1px solid var(--border-light);color:var(--text-secondary);cursor:pointer;justify-content:center}.theme-toggle-nav:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-medium)}.theme-toggle-icon-nav{display:flex;align-items:center}.user-info-simple{background:var(--bg-tertiary);border:1px solid var(--border-light);color:var(--text-primary);justify-content:center;cursor:default}.user-icon{display:flex;align-items:center;color:var(--text-secondary)}.logout-btn-nav{background:transparent;border:1px solid var(--error);color:var(--error);cursor:pointer;justify-content:center;font-weight:600}.logout-btn-nav:hover{background:var(--error);color:#fff}.mobile-menu-toggle{display:none;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:1px solid var(--border-light);border-radius:var(--radius);cursor:pointer;transition:var(--transition);color:var(--text-primary)}.mobile-menu-toggle:hover{background:var(--bg-tertiary)}.burger-icon{display:flex;align-items:center;justify-content:center}.mobile-nav-menu{display:none;flex-direction:column;gap:var(--space-xs);background:var(--bg-primary);border-radius:var(--radius);padding:var(--space);margin-top:var(--space-sm);border:1px solid var(--border-light);box-shadow:var(--shadow-lg);grid-column:1 / -1}.mobile-nav-menu.active{display:flex;animation:slideDown .2s ease-out}.sidebar{width:260px;background:var(--bg-primary);border-right:1px solid var(--border-light);padding:var(--space);min-height:calc(100vh - 57px)}.sidebar-menu{display:flex;flex-direction:column;gap:var(--space-xs)}.menu-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space);background:transparent;border:1px solid transparent;border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;transition:var(--transition);font-size:.875rem;font-weight:500;text-align:left;width:100%}.menu-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.menu-item.active{background:#0f766e1a;color:var(--primary);border-color:#0f766e33}[data-theme=dark] .menu-item.active{background:#14b8a626;color:var(--primary-light);border-color:#14b8a64d}.dashboard-container{padding:var(--space-xl);max-width:1400px;margin:0 auto;animation:fadeIn .4s ease-out}.plantation-info{background:var(--bg-primary);border:1px solid var(--border-light);padding:var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-xl);box-shadow:var(--shadow-sm)}.plantation-info h2{color:var(--text-primary);margin-bottom:var(--space);font-size:1.25rem}.plantation-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space)}.plantation-info-item{background:var(--bg-secondary);padding:var(--space);border-radius:var(--radius);border:1px solid var(--border-light);display:flex;flex-direction:column;gap:var(--space-xs)}.info-label{color:var(--text-tertiary);font-weight:500;text-transform:uppercase;font-size:.7rem;letter-spacing:.05em}.info-value{color:var(--text-primary);font-weight:600;font-size:1rem}.global-status-section{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl);box-shadow:var(--shadow-sm)}.global-status-section h2{color:var(--text-primary);margin-bottom:var(--space-lg);font-size:1.25rem}.global-status-card{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-lg);background:var(--bg-secondary);border-radius:var(--radius);border:1px solid var(--border-light);transition:var(--transition)}.global-status-card.optimo{border-left:4px solid var(--success)}.global-status-card.regular{border-left:4px solid var(--warning)}.global-status-card.critico{border-left:4px solid var(--error)}.global-status-icon{display:flex;align-items:center;justify-content:center}.global-status-text h3{color:var(--text-primary);margin-bottom:var(--space-xs);font-size:1.125rem}.global-status-text p{color:var(--text-secondary);margin:0;font-size:.875rem}.current-data-section{margin-bottom:var(--space-xl)}.current-data-section h2{color:var(--text-primary);margin-bottom:var(--space);font-size:1.5rem}.sensors-grid,.sensors-grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-lg)}.sensor-card{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);transition:var(--transition);display:flex;flex-direction:column;justify-content:space-between;min-height:380px}.sensor-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--border-medium)}.sensor-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-light)}.sensor-info{flex:1}.sensor-info h3{color:var(--text-secondary);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-xs);display:flex;align-items:center;gap:var(--space-sm)}.sensor-title-icon{color:var(--primary);display:flex;align-items:center;margin-right:var(--space-xs)}.sensor-value{font-size:2.5rem;font-weight:700;color:var(--text-primary);line-height:1.1;margin:var(--space-sm) 0;letter-spacing:-.025em}.sensor-icon{color:var(--text-tertiary);opacity:.5;display:flex;align-items:center;justify-content:center}.sensor-stats{background:var(--bg-secondary);border-radius:var(--radius);padding:var(--space);border:1px solid var(--border-light);display:flex;flex-direction:column;gap:var(--space-sm)}.sensor-stat-item{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.sensor-stat-label{color:var(--text-secondary)}.sensor-stat-value{color:var(--text-primary);font-weight:500}.sensor-details{background:var(--bg-secondary);border-radius:var(--radius);padding:var(--space);border:1px solid var(--border-light);margin-top:var(--space)}.detail-row{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;padding:var(--space-xs) 0}.detail-row:not(:last-child){border-bottom:1px solid var(--border-light)}.detail-row span:first-child{color:var(--text-secondary)}.detail-row span:last-child{color:var(--text-primary);font-weight:500}.detail-row .trend{display:flex;align-items:center;gap:var(--space-xs)}.mini-chart-container{margin-top:var(--space);padding-top:var(--space);border-top:1px solid var(--border-light)}.mini-chart-empty{height:60px;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);font-size:.75rem;margin-top:var(--space);padding-top:var(--space);border-top:1px solid var(--border-light)}.empty-state{display:flex;align-items:center;justify-content:center;min-height:400px;padding:3rem 2rem}.empty-state-content{max-width:500px;text-align:center}.empty-state-icon{margin:0 auto 1.5rem;opacity:.8}.empty-state-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.empty-state-description{font-size:1rem;color:var(--text-secondary);line-height:1.6;margin-bottom:2rem}.empty-state-suggestion{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.5rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:12px;text-align:left;margin-bottom:2rem}.suggestion-icon{font-size:1.25rem;flex-shrink:0}.empty-state-suggestion p{font-size:.9rem;color:var(--text-secondary);margin:0;line-height:1.5}.empty-state-action{margin-top:1.5rem}@media(max-width:768px){.empty-state{min-height:300px;padding:2rem 1rem}.empty-state-title{font-size:1.25rem}.empty-state-description{font-size:.95rem}}.icon-status,.icon-trend{display:inline-flex;vertical-align:middle}.icon-status.success{color:var(--success)}.icon-status.warning{color:var(--warning)}.icon-status.error{color:var(--error)}.icon-status.neutral{color:var(--text-tertiary)}.icon-trend.up{color:var(--success)}.icon-trend.down{color:var(--error)}.icon-trend.stable{color:var(--text-tertiary)}.alerts-section{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl);box-shadow:var(--shadow-sm)}.alerts-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space)}.alerts-title{display:flex;align-items:center;gap:var(--space-sm);color:var(--text-primary);margin:0;font-size:1.25rem}.alerts-count{background:var(--error);color:#fff;padding:2px 8px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.alerts-list{display:flex;flex-direction:column;gap:var(--space-sm)}.alert-item{background:var(--bg-secondary);border-radius:var(--radius);padding:var(--space);border:1px solid var(--border-light);display:flex;gap:var(--space)}.alert-item.critical{border-left:4px solid var(--error)}.alert-item.warning{border-left:4px solid var(--warning)}.alert-item.info{border-left:4px solid var(--info)}.alert-content{flex:1}.alert-sensor{font-weight:600;color:var(--text-primary);margin-bottom:2px;display:flex;align-items:center;gap:var(--space-xs)}.alert-message{color:var(--text-secondary);font-size:.875rem}.alert-timestamp{color:var(--text-tertiary);font-size:.75rem;margin-top:var(--space-xs)}.table-container{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);overflow:hidden;margin-bottom:var(--space-xl)}.table-header{background:var(--bg-secondary);padding:var(--space-lg);border-bottom:1px solid var(--border-light)}.table-header h2{color:var(--text-primary);margin:0 0 var(--space-xs) 0;font-size:1.125rem}.table-header p{color:var(--text-secondary);margin:0;font-size:.875rem}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}.table{width:100%;border-collapse:collapse;font-size:.875rem;white-space:nowrap}.table th{background:var(--bg-secondary);color:var(--text-secondary);padding:var(--space-sm) var(--space-lg);text-align:left;font-weight:600;border-bottom:1px solid var(--border-light);text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}.table td{padding:var(--space) var(--space-lg);border-bottom:1px solid var(--border-light);color:var(--text-primary)}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--bg-secondary)}.stats-section{margin-bottom:var(--space-xl)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-lg)}.stat-card{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.stat-card h4{color:var(--text-primary);margin-bottom:var(--space);font-size:.9rem;display:flex;align-items:center;gap:var(--space-sm)}.stat-card-icon{color:var(--primary);display:flex;align-items:center}.stat-list{display:flex;flex-direction:column;gap:var(--space-sm)}.stat-item{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;padding-bottom:var(--space-xs);border-bottom:1px solid var(--border-light)}.stat-item:last-child{border-bottom:none;padding-bottom:0}.dashboard-footer-simple{text-align:center;padding:var(--space-xl) 0;border-top:1px solid var(--border-light);margin-top:var(--space-2xl)}.footer-info p{color:var(--text-tertiary);font-size:.875rem;margin-bottom:var(--space-xs)}.copyright{color:var(--text-tertiary);font-size:.75rem;margin-top:var(--space)}.status-optimo{color:var(--success);font-weight:600}.status-regular{color:var(--warning);font-weight:600}.status-critico{color:var(--error);font-weight:600}.alert-indicator{display:flex;align-items:center}.alert-indicator.red{color:var(--error)}.alert-indicator.yellow{color:var(--warning)}.alert-indicator.green{color:var(--success)}@media(max-width:768px){.nav-content{grid-template-columns:auto 1fr auto}.nav-logo{font-size:1rem}.mobile-menu-toggle{display:flex}.theme-toggle-nav:not(.mobile-nav-menu .theme-toggle-nav),.user-info-simple:not(.mobile-nav-menu .user-info-simple),.logout-btn-nav:not(.mobile-nav-menu .logout-btn-nav){display:none}.app-body{flex-direction:column}.sidebar{width:100%;min-height:auto;border-right:none;border-bottom:1px solid var(--border-light);padding:var(--space-sm);overflow-x:auto}.sidebar-menu{flex-direction:row;width:max-content}.menu-item{width:auto;white-space:nowrap}.dashboard-container{padding:var(--space)}.sensors-grid,.sensors-grid-4{grid-template-columns:1fr}.sensor-card{min-height:auto}.sensor-value{font-size:2rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem}.loading-spinner{color:#3b82f6}.loading-overlay{position:fixed;inset:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem;color:#ef4444}.error-container h3{font-size:1.5rem;margin:0}.error-container p{font-size:1rem;color:#ffffffb3}.btn-retry{margin-top:1rem;padding:.75rem 1.5rem;background:#3b82f6;border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s}.btn-retry:hover{background:#2563eb;transform:translateY(-2px)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);padding:2rem;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(16,185,129,.05) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(59,130,246,.05) 0%,transparent 50%);animation:pulse 8s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.login-card{position:relative;background:#1e293bcc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:3rem;max-width:480px;width:100%;box-shadow:0 20px 60px #0000004d,0 0 0 1px #ffffff0d inset;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2.5rem}.login-logo{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:.75rem}.login-logo-icon{font-size:3rem;filter:drop-shadow(0 4px 8px rgba(16,185,129,.3));animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-logo h1{font-size:2rem;font-weight:700;background:linear-gradient(135deg,#10b981,#059669);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;letter-spacing:-.5px}.login-subtitle{font-size:1rem;color:#fff9;margin:0;font-weight:400}.login-form{margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.85rem;font-weight:600;color:#fffc;margin-bottom:.5rem;letter-spacing:.5px;text-transform:uppercase}.form-group input{width:100%;padding:.875rem 1rem;background:#0f172a99;border:1.5px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:1rem;transition:all .3s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#10b981;background:#0f172acc;box-shadow:0 0 0 3px #10b9811a}.form-group input::placeholder{color:#ffffff4d}.form-group input:disabled{opacity:.5;cursor:not-allowed}.password-input-container{position:relative}.password-input-container input{padding-right:3rem}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1.25rem;padding:.25rem;opacity:.6;transition:opacity .2s}.password-toggle:hover:not(:disabled){opacity:1}.password-toggle:disabled{cursor:not-allowed}.error-message{display:flex;align-items:center;gap:.5rem;padding:.875rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#fca5a5;font-size:.9rem;margin-bottom:1rem;animation:shake .4s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.login-button{width:100%;padding:1rem;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:12px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;letter-spacing:.5px;box-shadow:0 4px 12px #10b9814d}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-button.loading{background:linear-gradient(135deg,#6b7280,#4b5563)}.login-button .spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.demo-users{padding:1.5rem;background:#0f172a66;border:1px solid rgba(255,255,255,.05);border-radius:16px;margin-bottom:1.5rem}.demo-users h3{font-size:.8rem;font-weight:700;color:#ffffff80;margin:0 0 1rem;text-transform:uppercase;letter-spacing:1px;text-align:center}.demo-user-card{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;transition:all .2s}.demo-user-card:hover{background:#ffffff0d;border-color:#10b9814d;transform:translateY(-2px)}.demo-user-info{margin-bottom:.75rem}.demo-user-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.demo-user-icon{font-size:2rem;opacity:.8}.demo-user-email{font-size:.95rem;font-weight:600;color:#fff;display:block;margin-bottom:.25rem}.demo-user-role{font-size:.8rem;color:#ffffff80;display:block}.demo-user-description{font-size:.85rem;color:#fff9;line-height:1.4}.demo-user-button{width:100%;padding:.75rem;background:#10b98126;border:1.5px solid rgba(16,185,129,.3);border-radius:8px;color:#6ee7b7;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;letter-spacing:.5px}.demo-user-button:hover:not(:disabled){background:#10b98140;border-color:#10b98180;color:#a7f3d0}.demo-user-button:disabled{opacity:.5;cursor:not-allowed}.demo-note{margin-top:1rem;text-align:center;font-size:.8rem;color:#fff6;font-style:italic}.login-footer{text-align:center;font-size:.8rem;color:#fff6;line-height:1.6}.login-footer p{margin:.25rem 0}@media(max-width:600px){.login-container{padding:1rem}.login-card{padding:2rem 1.5rem;border-radius:20px}.login-logo h1{font-size:1.75rem}.login-logo-icon{font-size:2.5rem}.form-group input{font-size:1rem}.demo-users{padding:1rem}}@media(max-width:400px){.login-card{padding:1.5rem 1rem}.login-logo h1{font-size:1.5rem}}.app-container{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-secondary)}.app-body{display:flex;flex:1;overflow:hidden}.sidebar{width:260px;background:var(--bg-primary);border-right:1px solid var(--border-light);display:flex;flex-direction:column;transition:width .3s ease;position:relative;flex-shrink:0}.sidebar.collapsed{width:60px}.sidebar-toggle{position:absolute;right:-12px;top:20px;width:24px;height:24px;border-radius:50%;background:var(--bg-primary);border:1px solid var(--border-light);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;color:var(--text-secondary);transition:all .2s}.sidebar-toggle:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.sidebar-section{padding:1rem;border-bottom:1px solid var(--border-light)}.sidebar-label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:.5rem;letter-spacing:.05em}.sidebar-select{width:100%;padding:.5rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text-primary);font-size:.9rem;cursor:pointer}.sidebar-select:focus{outline:none;border-color:var(--primary)}.plantation-info-compact{padding:1rem}.plantation-info-compact .info-row{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary);margin-bottom:.5rem}.plantation-info-compact .info-row:last-child{margin-bottom:0}.plantation-info-compact .info-row svg{color:var(--text-tertiary);flex-shrink:0}.sidebar-nav{padding:1rem;display:flex;flex-direction:column;gap:.5rem}.sidebar-nav.collapsed{padding:1rem .5rem;align-items:center}.nav-button{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:transparent;border:1px solid transparent;border-radius:var(--radius);color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;width:100%;text-align:left}.nav-button:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-button.active{background:#0f766e1a;color:var(--primary);border-color:#0f766e33}.nav-button-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;transition:all .2s}.nav-button-icon:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-button-icon.active{background:#0f766e1a;color:var(--primary)}.main-content{flex:1;padding:1.5rem;overflow-y:auto;transition:margin-left .3s ease}.main-content.expanded{margin-left:0}.monitoring-view{display:flex;flex-direction:column;gap:1.5rem}.sensors-compact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}@media(max-width:1200px){.sensors-compact-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.sensors-compact-grid{grid-template-columns:1fr}}.sensor-card-compact{background:var(--bg-primary);border:2px solid var(--border-light);border-radius:var(--radius-lg);padding:1rem;cursor:pointer;transition:all .2s}.sensor-card-compact:hover{border-color:var(--border-medium);transform:translateY(-2px);box-shadow:var(--shadow-md)}.sensor-card-compact.selected{border-color:var(--primary);background:#0f766e0d}.sensor-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.sensor-card-compact .sensor-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);background:var(--bg-secondary)}.sensor-card-body{margin-bottom:.5rem}.sensor-card-compact .sensor-name{display:block;font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.sensor-value-row{display:flex;align-items:baseline;gap:.25rem}.sensor-card-compact .sensor-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1}.sensor-card-compact .sensor-unit{font-size:.9rem;color:var(--text-secondary)}.sensor-card-footer{display:flex;justify-content:flex-start}.trend-indicator{display:flex;align-items:center;gap:.25rem;font-size:.8rem;color:var(--text-tertiary)}.trend-icon.up{color:var(--success)}.trend-icon.down{color:var(--error)}.trend-icon.stable{color:var(--text-tertiary)}.status-icon.success{color:var(--success)}.status-icon.warning{color:var(--warning)}.status-icon.error{color:var(--error)}.status-icon.neutral{color:var(--text-tertiary)}.main-chart-container{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:1.5rem}.chart-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.chart-title-section{flex:1}.chart-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 .25rem}.chart-subtitle{font-size:.85rem;color:var(--text-tertiary)}.chart-controls{display:flex;gap:1rem;align-items:center}.period-selector{display:flex;background:var(--bg-secondary);border-radius:var(--radius);padding:.25rem}.period-btn{padding:.5rem 1rem;background:transparent;border:none;border-radius:calc(var(--radius) - 2px);color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.period-btn:hover{color:var(--text-primary)}.period-btn.active{background:var(--primary);color:#fff}.chart-type-toggle{display:flex;background:var(--bg-secondary);border-radius:var(--radius);padding:.25rem}.type-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:calc(var(--radius) - 2px);color:var(--text-secondary);cursor:pointer;transition:all .2s}.type-btn:hover{color:var(--text-primary)}.type-btn.active{background:var(--primary);color:#fff}.chart-wrapper{margin-bottom:1rem}.chart-loading,.chart-error,.chart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;color:var(--text-tertiary);gap:1rem}.chart-stats{display:flex;gap:2rem;padding-top:1rem;border-top:1px solid var(--border-light)}.chart-stats .stat-item{display:flex;flex-direction:column;gap:.25rem}.chart-stats .stat-label{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase}.chart-stats .stat-value{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.toast-container{position:fixed;top:80px;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem}.toast{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:300px;max-width:450px;animation:slideIn .3s ease}.toast.hidden{animation:slideOut .3s ease;opacity:0}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.toast-icon{flex-shrink:0}.toast-success .toast-icon{color:var(--success)}.toast-error .toast-icon{color:var(--error)}.toast-warning .toast-icon{color:var(--warning)}.toast-info .toast-icon{color:var(--info)}.toast-message{flex:1;font-size:.9rem;color:var(--text-primary)}.toast-close{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center}.toast-close:hover{color:var(--text-primary)}.error-banner{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#dc26261a;border:1px solid rgba(220,38,38,.3);border-radius:var(--radius);margin-bottom:1rem;color:var(--error)}.error-banner span{flex:1}.error-banner button{padding:.5rem 1rem;background:var(--error);border:none;border-radius:var(--radius);color:#fff;font-size:.85rem;cursor:pointer;transition:opacity .2s}.error-banner button:hover{opacity:.9}.historical-view{padding:0}.historical-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.header-title{display:flex;align-items:center;gap:.75rem}.header-title h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.crop-selector{display:flex;align-items:center;gap:.75rem}.crop-selector label{font-size:.9rem;color:var(--text-secondary)}.crop-selector select{padding:.5rem 1rem;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text-primary);font-size:.9rem}.crop-info-card{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.crop-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.crop-title{display:flex;align-items:center;gap:.75rem}.crop-title h3{margin:0;font-size:1.25rem;color:var(--text-primary)}.crop-variety{display:block;font-size:.85rem;color:var(--text-tertiary)}.crop-badges{display:flex;gap:.5rem;align-items:center}.crop-status-badge{padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.8rem;font-weight:500;color:#fff;text-transform:capitalize}.crop-phase-badge{padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.8rem;font-weight:500;background:#3b82f633;color:#60a5fa;border:1px solid rgba(59,130,246,.3);text-transform:capitalize}.crop-phases-timeline{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-light)}.crop-phases-timeline h4{margin:0 0 .75rem;font-size:.9rem;color:var(--text-secondary);font-weight:600}.phases-list{display:flex;flex-direction:column;gap:.5rem;padding-left:.5rem}.phase-item{display:flex;align-items:flex-start;gap:.75rem;position:relative}.phase-item:not(:last-child):before{content:"";position:absolute;left:4px;top:12px;width:2px;height:calc(100% + .5rem);background:var(--border-light)}.phase-dot{width:10px;height:10px;border-radius:50%;background:var(--primary);flex-shrink:0;margin-top:4px;z-index:1}.phase-content{display:flex;flex-direction:column;gap:.125rem}.phase-name{font-size:.85rem;font-weight:500;color:var(--text-primary);text-transform:capitalize}.phase-date{font-size:.75rem;color:var(--text-tertiary)}.phase-note{font-size:.8rem;color:var(--text-secondary);font-style:italic;margin-top:.125rem}.crop-details{display:flex;gap:2rem;flex-wrap:wrap}.crop-details .detail-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-secondary)}.period-controls{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.controls-left,.controls-right{display:flex;align-items:center;gap:.75rem}.period-label,.chart-type-label{font-size:.9rem;color:var(--text-secondary)}.period-buttons,.chart-type-buttons{display:flex;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius);padding:.25rem}.chart-type-btn{display:flex;align-items:center;gap:.35rem;padding:.4rem .75rem;background:transparent;border:none;border-radius:calc(var(--radius) - 2px);color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s ease}.chart-type-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.chart-type-btn.active{background:var(--primary);color:#fff}.chart-type-btn svg{flex-shrink:0}.sensors-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1rem}.sensor-chart-card{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:1rem}.sensor-chart-card .chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.sensor-chart-card h4{margin:0;font-size:1rem;color:var(--text-primary)}.sensor-stats{font-size:.8rem;color:var(--text-tertiary)}.sensor-summary{display:flex;gap:1.5rem;padding-top:.75rem;border-top:1px solid var(--border-light);margin-top:.75rem}.summary-item{font-size:.85rem;color:var(--text-secondary)}.summary-item strong{color:var(--text-primary);margin-left:.25rem}.no-data,.no-timeline-data{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--text-tertiary);text-align:center}.no-timeline-data .hint{font-size:.85rem;margin-top:.5rem}.app-footer{background:var(--bg-primary);border-top:1px solid var(--border-light);padding:1rem 1.5rem}.footer-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.footer-left{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary);font-size:.85rem}.footer-brand{font-weight:600;color:var(--text-primary)}.footer-divider{color:var(--border-medium)}.footer-right{font-size:.8rem;color:var(--text-tertiary)}.btn-theme{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;transition:all .2s}.btn-theme:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-medium)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:400px;color:var(--text-secondary);gap:1rem}.loading-spinner{color:var(--primary)}.loading-overlay{position:absolute;inset:0;background:rgba(var(--bg-secondary-rgb),.8);display:flex;align-items:center;justify-content:center;z-index:50;border-radius:var(--radius-lg)}.empty-container,.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:var(--text-tertiary)}.empty-container svg,.loading-container svg{margin-bottom:1rem;opacity:.5}.spinner{width:20px;height:20px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin 1s linear infinite}@media(max-width:768px){.sidebar{position:fixed;left:0;top:60px;bottom:0;z-index:100;transform:translate(-100%)}.sidebar:not(.collapsed){transform:translate(0)}.main-content{padding:1rem}.chart-header{flex-direction:column}.chart-controls{width:100%;justify-content:space-between}.footer-content{flex-direction:column;gap:.5rem;text-align:center}.sensors-charts{grid-template-columns:1fr}}.admin-panel{padding:1rem;width:100%}.admin-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.admin-header h2{margin:0;font-size:1.4rem;color:var(--text-primary, #e2e8f0)}.admin-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:var(--text-secondary, #94a3b8)}.admin-tabs{display:flex;gap:.25rem;margin-bottom:1rem;overflow-x:auto;border-bottom:2px solid var(--border-color, #334155);padding-bottom:0}.admin-tab{display:flex;align-items:center;gap:.4rem;padding:.6rem 1rem;background:transparent;border:none;color:var(--text-secondary, #94a3b8);cursor:pointer;font-size:.85rem;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s;white-space:nowrap}.admin-tab:hover{color:var(--text-primary, #e2e8f0);background:var(--bg-hover, rgba(255, 255, 255, .05))}.admin-tab.active{color:var(--accent-color, #3b82f6);border-bottom-color:var(--accent-color, #3b82f6)}.admin-toolbar{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.admin-count{color:var(--text-secondary, #94a3b8);font-size:.85rem;margin-left:auto}.toolbar-filter{max-width:200px}.admin-message{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-radius:.5rem;margin-bottom:1rem;font-size:.9rem}.admin-message.success{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3)}.admin-message.error{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.msg-close{background:none;border:none;color:inherit;cursor:pointer;font-size:1rem;padding:0 .25rem;opacity:.7}.msg-close:hover{opacity:1}.admin-table-wrapper{overflow-x:auto;border-radius:.5rem;border:1px solid var(--border-color, #334155)}.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-table th{background:var(--bg-secondary, #1e293b);color:var(--text-secondary, #94a3b8);padding:.6rem .75rem;text-align:left;font-weight:600;white-space:nowrap;border-bottom:1px solid var(--border-color, #334155)}.admin-table td{padding:.5rem .75rem;border-bottom:1px solid var(--border-color, rgba(51, 65, 85, .5));color:var(--text-primary, #e2e8f0)}.admin-table tr:hover td{background:var(--bg-hover, rgba(255, 255, 255, .03))}.empty-row{text-align:center;color:var(--text-secondary, #94a3b8);padding:2rem!important}.actions-cell{display:flex;gap:.4rem;white-space:nowrap}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:none;border-radius:.375rem;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn-primary{background:var(--accent-color, #3b82f6);color:#fff}.btn-primary:hover{background:#2563eb}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg-secondary, #1e293b);color:var(--text-primary, #e2e8f0);border:1px solid var(--border-color, #334155)}.btn-secondary:hover{background:var(--bg-hover, #334155)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:.25rem;cursor:pointer;transition:all .2s}.btn-edit{background:#3b82f626;color:#3b82f6}.btn-edit:hover{background:#3b82f64d}.btn-delete{background:#ef444426;color:#ef4444}.btn-delete:hover{background:#ef44444d}.btn-finalize{background:#10b98126;color:#10b981}.btn-finalize:hover{background:#10b9814d}.btn-success{background:#10b98126;color:#10b981}.btn-success:hover{background:#10b9814d}.btn-cancel{background:#ef444426;color:#ef4444}.btn-cancel:hover{background:#ef44444d}.btn-create{background:#8b5cf626;color:#8b5cf6}.btn-create:hover{background:#8b5cf64d}.admin-form{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:.5rem;padding:1.5rem;max-width:600px}.admin-form h3{margin:0 0 1rem;color:var(--text-primary, #e2e8f0);font-size:1.1rem}.form-group{margin-bottom:.75rem}.form-label{display:block;font-size:.8rem;color:var(--text-secondary, #94a3b8);margin-bottom:.3rem;font-weight:500}.form-input,.form-select{width:100%;padding:.5rem .75rem;background:var(--bg-primary, #0f172a);border:1px solid var(--border-color, #334155);border-radius:.375rem;color:var(--text-primary, #e2e8f0);font-size:.85rem;transition:border-color .2s}.form-input:focus,.form-select:focus{outline:none;border-color:var(--accent-color, #3b82f6)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.form-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.85rem;color:var(--text-primary, #e2e8f0)}.form-checkbox input[type=checkbox]{accent-color:var(--accent-color, #3b82f6)}.form-error{background:#ef444426;color:#ef4444;padding:.5rem .75rem;border-radius:.375rem;font-size:.85rem;margin-bottom:.75rem;border:1px solid rgba(239,68,68,.3)}.form-actions{display:flex;gap:.75rem;margin-top:1.25rem}.creatable-select-row,.creatable-input-row{display:flex;gap:.5rem;align-items:center}.creatable-select-row .form-select,.creatable-input-row .form-input{flex:1}.badge{display:inline-block;padding:.15rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-success{background:#10b98126;color:#10b981}.badge-info{background:#3b82f626;color:#3b82f6}.badge-danger{background:#ef444426;color:#ef4444}.badge-default{background:#94a3b826;color:#94a3b8}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.user-plantation-manager{display:grid;grid-template-columns:300px 1fr;gap:1rem;min-height:400px}.upm-user-list{border:1px solid var(--border-color, #334155);border-radius:.5rem;overflow:hidden;display:flex;flex-direction:column;background:var(--bg-secondary, #1e293b)}.upm-user-list-header{padding:.75rem;border-bottom:1px solid var(--border-color, #334155);display:flex;flex-direction:column;gap:.4rem}.upm-search-box{position:relative;display:flex;align-items:center}.upm-search-icon{position:absolute;left:.6rem;color:var(--text-secondary, #94a3b8);pointer-events:none}.upm-search-input{padding-left:2rem!important;font-size:.8rem!important}.upm-user-count{font-size:.75rem;color:var(--text-secondary, #94a3b8);text-align:right}.upm-user-list-items{overflow-y:auto;flex:1;max-height:500px}.upm-user-item{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;cursor:pointer;border-bottom:1px solid var(--border-color, rgba(51, 65, 85, .5));transition:background .15s}.upm-user-item:hover{background:var(--bg-hover, rgba(255, 255, 255, .03))}.upm-user-item.selected{background:#3b82f61a;border-left:3px solid var(--accent-color, #3b82f6)}.upm-user-info{display:flex;flex-direction:column;min-width:0;flex:1}.upm-user-name{font-size:.85rem;color:var(--text-primary, #e2e8f0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upm-user-email{font-size:.72rem;color:var(--text-secondary, #94a3b8);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upm-user-list-footer{padding:.5rem .75rem;border-top:1px solid var(--border-color, #334155);display:flex;justify-content:center}.upm-detail-panel{border:1px solid var(--border-color, #334155);border-radius:.5rem;padding:1rem;background:var(--bg-secondary, #1e293b);display:flex;flex-direction:column}.upm-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary, #94a3b8);gap:.75rem;text-align:center;min-height:300px}.upm-placeholder p{font-size:.9rem;max-width:250px}.upm-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color, #334155)}.upm-detail-title{margin:0;font-size:1.1rem;color:var(--text-primary, #e2e8f0)}.upm-detail-email{font-size:.8rem;color:var(--text-secondary, #94a3b8)}.upm-section{margin-bottom:1.25rem}.upm-section-title{display:flex;align-items:center;gap:.4rem;margin:0 0 .6rem;font-size:.9rem;color:var(--text-primary, #e2e8f0);font-weight:600}.upm-empty-section{font-size:.85rem;color:var(--text-secondary, #94a3b8);font-style:italic;padding:.5rem 0}.upm-plantation-list{border:1px solid var(--border-color, rgba(51, 65, 85, .5));border-radius:.375rem;overflow:hidden}.upm-plantation-row{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-bottom:1px solid var(--border-color, rgba(51, 65, 85, .3))}.upm-plantation-row:last-child{border-bottom:none}.upm-plantation-info{display:flex;flex-direction:column;min-width:0}.upm-plantation-name{font-size:.85rem;color:var(--text-primary, #e2e8f0)}.upm-plantation-date{font-size:.72rem;color:var(--text-secondary, #94a3b8)}.upm-add-section{display:flex;gap:.5rem;align-items:center}.upm-add-section .form-select{flex:1}.upm-empty{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem;color:var(--text-secondary, #94a3b8);font-size:.85rem}@media(max-width:768px){.form-row{grid-template-columns:1fr}.admin-tabs{flex-wrap:nowrap}.admin-tab span{display:none}.admin-toolbar{flex-direction:column;align-items:stretch}.admin-count{margin-left:0;text-align:center}.user-plantation-manager{grid-template-columns:1fr}.upm-user-list-items{max-height:200px}.upm-add-section{flex-direction:column}}
