.splash-wrap{height:100vh;width:100%;background:url(/images/image3.jpg) center/cover no-repeat;display:flex;align-items:center;justify-content:center;animation:fadeIn .8s ease-in}.splash-overlay{text-align:center;color:#fff;background:#00000073;padding:24px 40px;border-radius:16px;animation:scaleUp 1s ease}.splash-title{font-size:2.8rem;font-weight:700;margin:0;letter-spacing:1px}.splash-subtitle{font-size:1.2rem;margin-top:12px;opacity:.9}@keyframes scaleUp{0%{transform:scale(.9);opacity:.7}to{transform:scale(1);opacity:1}}.login-container{display:flex;height:100vh;width:100%;background:linear-gradient(135deg,#f0fdf4,#ecfdf5,#e0f2fe);font-family:Inter,sans-serif}.login-image{flex:1;background:url(/images/image5.jpg) center/cover no-repeat;display:none}@media (min-width: 768px){.login-image{display:block}}.login-form-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:32px;position:relative}.login-card{background:#fffffff2;padding:40px 32px;border-radius:18px;box-shadow:0 10px 40px #0000001a;width:100%;max-width:400px;display:flex;flex-direction:column;gap:16px;animation:slideUp .7s ease forwards;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.login-card h2{margin:0;font-size:2rem;font-weight:700;color:#14532d;text-align:center}.login-subtext{text-align:center;font-size:.95rem;color:#6b7280;margin-bottom:20px}.login-field{position:relative;margin-top:8px}.login-field input{width:100%;padding:14px 40px 14px 12px;border:1px solid #d1d5db;border-radius:10px;font-size:1rem;background:#fff;transition:.2s}.login-field input:focus{outline:none;border-color:#22c55e;box-shadow:0 0 0 3px #22c55e40}.login-field label{position:absolute;top:50%;left:12px;transform:translateY(-50%);color:#9ca3af;font-size:.9rem;pointer-events:none;transition:.2s ease all}.login-field input:focus+label,.login-field input:not(:placeholder-shown)+label{top:-8px;left:10px;font-size:.75rem;background:#fff;padding:0 4px;color:#22c55e}.toggle-pass{position:absolute;right:12px;top:50%;transform:translateY(-50%);cursor:pointer;color:#6b7280;transition:color .2s}.toggle-pass:hover{color:#111827}.input-error{border-color:#ef4444!important;box-shadow:0 0 0 2px #ef444426}.error-text{font-size:.8rem;color:#ef4444;margin-top:4px;margin-bottom:-4px;animation:fadeIn .3s ease}.btn{margin-top:20px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;padding:14px;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,background .3s ease}.btn:hover{transform:translateY(-2px);background:linear-gradient(135deg,#16a34a,#15803d)}.btn:disabled{opacity:.7;cursor:not-allowed}.divider{text-align:center;font-size:.85rem;color:#9ca3af;margin:12px 0;position:relative}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:#e5e7eb}.divider:before{left:0}.divider:after{right:0}.divider span{background:#fff;padding:0 8px}.social-buttons{display:flex;gap:10px}.social-btn{flex:1;padding:10px;border-radius:8px;font-size:.9rem;font-weight:500;display:flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:background .3s ease;border:1px solid #d1d5db}.social-btn.google:hover,.social-btn.github:hover{background:#f3f4f6}.login-footer-text{margin-top:16px;text-align:center;font-size:.85rem;color:#9ca3af}.login-topbar{position:absolute;top:16px;right:20px}.home-btn{background:#2563eb;color:#fff;border:none;padding:8px 14px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s ease}.home-btn:hover{background:#1d4ed8}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}:root{--pf-loader-size: 72px;--pf-loader-accent: #22c55e;--pf-backdrop-blur: 6px;--pf-card-bg: rgba(255,255,255,.96);--pf-card-radius: 12px;--pf-shadow: 0 12px 30px rgba(2,6,23,.12);--pf-text: #0f172a}.pf-loader-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#02061705,#02061705);-webkit-backdrop-filter:blur(var(--pf-backdrop-blur));backdrop-filter:blur(var(--pf-backdrop-blur));z-index:9999}.pf-loader-card{display:flex;flex-direction:column;align-items:center;gap:14px;padding:20px 24px;background:var(--pf-card-bg);border-radius:var(--pf-card-radius);box-shadow:var(--pf-shadow);min-width:220px;max-width:460px;text-align:center}.pf-loader-visual{width:var(--pf-loader-size);height:var(--pf-loader-size);display:flex;align-items:center;justify-content:center;position:relative}.pf-beat{position:relative;width:100%;height:100%;display:inline-block}.pf-beat-core{--s: calc(var(--pf-loader-size) * .28);width:var(--s);height:var(--s);border-radius:50%;background:linear-gradient(135deg,var(--pf-loader-accent),color-mix(in srgb,var(--pf-loader-accent) 70%,#000 10%));box-shadow:0 6px 20px #10b9811f,0 2px 6px #00000014;animation:pf-beat-core 1.1s cubic-bezier(.2,.9,.3,1) infinite;transform-origin:center}.pf-beat-ring{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(.15);border-radius:50%;width:60%;height:60%;border:2px solid color-mix(in srgb,var(--pf-loader-accent) 18%,#fff 82%);opacity:.85;animation-fill-mode:both}.pf-ring-1{animation:pf-ring-exp 1.6s ease-out infinite;animation-delay:0ms}.pf-ring-2{animation:pf-ring-exp 1.6s ease-out infinite;animation-delay:.5s}.pf-dots{display:flex;gap:10px;align-items:center;justify-content:center}.pf-dots .dot{width:calc(var(--pf-loader-size) * .18);height:calc(var(--pf-loader-size) * .18);border-radius:50%;background:var(--pf-loader-accent);animation:pf-dot-bounce .9s ease-in-out infinite}.pf-dots .dot:nth-child(2){animation-delay:.12s;opacity:.9}.pf-dots .dot:nth-child(3){animation-delay:.24s;opacity:.85}.pf-bars{display:flex;gap:8px;align-items:end;justify-content:center;height:100%}.pf-bars .bar{width:calc(var(--pf-loader-size) * .12);height:36%;background:linear-gradient(180deg,var(--pf-loader-accent),color-mix(in srgb,var(--pf-loader-accent) 70%,#000 10%));border-radius:4px;animation:pf-bar-rise .9s ease-in-out infinite}.pf-bars .bar:nth-child(2){animation-delay:.12s}.pf-bars .bar:nth-child(3){animation-delay:.24s}.pf-bars .bar:nth-child(4){animation-delay:.36s}.pf-loader-text{color:var(--pf-text);font-weight:600;font-size:.95rem}.pf-progress{width:100%;height:8px;background:#0206170f;border-radius:999px;overflow:hidden}.pf-progress-bar{height:100%;background:linear-gradient(90deg,color-mix(in srgb,var(--pf-loader-accent) 80%,white 20%),var(--pf-loader-accent));width:0%;transition:width .26s linear}@keyframes pf-beat-core{0%{transform:scale(1);filter:drop-shadow(0 6px 20px rgba(34,197,94,.06))}30%{transform:scale(1.14)}60%{transform:scale(.92);opacity:.98}to{transform:scale(1)}}@keyframes pf-ring-exp{0%{transform:translate(-50%,-50%) scale(.15);opacity:.9}70%{transform:translate(-50%,-50%) scale(1.35);opacity:.06}to{transform:translate(-50%,-50%) scale(1.6);opacity:0}}@keyframes pf-dot-bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-12px)}}@keyframes pf-bar-rise{0%{transform:scaleY(.45)}50%{transform:scaleY(1)}to{transform:scaleY(.45)}}@media (max-width: 560px){.pf-loader-card{margin:12px;padding:18px}:root{--pf-loader-size: 56px}}.pf-loader-overlay{opacity:0;animation:fade-in .25s ease forwards}@keyframes fade-in{to{opacity:1}}.toast-container{position:fixed;top:20px;right:20px;display:flex;flex-direction:column;gap:10px;z-index:9999}.toast{min-width:250px;background:#fff;border-radius:6px;padding:12px 16px;box-shadow:0 4px 8px #00000026;display:flex;justify-content:space-between;align-items:center;font-size:14px;animation:fadeIn .3s ease-out}.toast-success{border-left:5px solid #4caf50}.toast-error{border-left:5px solid #f44336}.toast-info{border-left:5px solid #2196f3}.toast-close{background:none;border:none;font-size:16px;cursor:pointer;color:#666}.toast-content{display:flex;flex-direction:column}.toast-msg{margin-top:4px;font-size:12px;color:#555}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;color:#1f2937;overflow-x:hidden}.landing{display:flex;flex-direction:column;min-height:100vh}.navbar{position:fixed;top:0;width:100%;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.2);z-index:1000;transition:all .3s ease}.nav-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem}.logo{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:700;color:#059669}.logo-icon{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(5,150,105,.3))}.logo-text{background:linear-gradient(135deg,#059669,#34d399);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-links{display:flex;gap:2.5rem;list-style:none}.nav-links a{text-decoration:none;color:#374151;font-weight:500;font-size:.95rem;transition:all .3s ease;position:relative}.nav-links a:after{content:"";position:absolute;bottom:-4px;left:50%;width:0;height:2px;background:linear-gradient(135deg,#059669,#34d399);transition:all .3s ease;transform:translate(-50%)}.nav-links a:hover{color:#059669}.nav-links a:hover:after{width:100%}.nav-cta{background:linear-gradient(135deg,#059669,#34d399);color:#fff;padding:.75rem 1.5rem;border:none;border-radius:50px;text-decoration:none;font-weight:600;font-size:.95rem;transition:all .3s ease;box-shadow:0 4px 15px #0596694d;cursor:pointer}.nav-cta:hover{transform:translateY(-2px);box-shadow:0 8px 25px #05966966}.landing-hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:linear-gradient(135deg,#0f172a,#1e293b 30%,#334155 70%,#475569)}.hero-background{position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(52,211,153,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(5,150,105,.1) 0%,transparent 50%),radial-gradient(circle at 40% 80%,rgba(16,185,129,.05) 0%,transparent 50%)}.hero-content{max-width:1200px;margin:0 auto;padding:2rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative;z-index:2}.hero-text{color:#fff}.hero-title{font-size:3.5rem;font-weight:800;line-height:1.1;margin-bottom:1.5rem;opacity:0;transform:translateY(30px);transition:all .8s ease}.hero-title.animate-in{opacity:1;transform:translateY(0)}.highlight{background:linear-gradient(135deg,#34d399,#10b981);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative}.highlight:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(135deg,#34d399,#10b981);opacity:.3}.hero-subtitle{font-size:1.25rem;color:#cbd5e1;margin-bottom:2.5rem;line-height:1.6;opacity:0;transform:translateY(30px);transition:all .8s ease}.hero-subtitle.animate-in{opacity:1;transform:translateY(0)}.hero-buttons{display:flex;gap:1rem;opacity:0;transform:translateY(30px);transition:all .8s ease}.hero-buttons.animate-in{opacity:1;transform:translateY(0)}.delay-1{transition-delay:.2s}.delay-2{transition-delay:.4s}.delay-3{transition-delay:.6s}.btn-primary{background:linear-gradient(135deg,#059669,#34d399);color:#fff;padding:1rem 2rem;border:none;border-radius:50px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0596694d;display:inline-flex;align-items:center;gap:.5rem}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 25px #05966966}.btn-primary.large{padding:1.25rem 2.5rem;font-size:1.2rem}.btn-secondary{background:transparent;color:#fff;padding:1rem 2rem;border:2px solid rgba(255,255,255,.3);border-radius:50px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem}.btn-secondary:hover{background:#ffffff1a;border-color:#ffffff80;transform:translateY(-2px)}.btn-icon{width:16px;height:16px;transition:transform .3s ease}.btn-primary:hover .btn-icon{transform:translate(3px)}.hero-visual{opacity:0;transform:translateY(30px);transition:all .8s ease}.hero-visual.animate-in{opacity:1;transform:translateY(0)}.dashboard-mockup{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:1.5rem;box-shadow:0 25px 50px #0000004d;border:1px solid rgba(255,255,255,.2);animation:float 6s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.dashboard-header{display:flex;align-items:center;gap:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb;margin-bottom:1.5rem}.dashboard-dots{display:flex;gap:.5rem}.dashboard-dots span{width:10px;height:10px;border-radius:50%;background:#059669}.dashboard-dots span:nth-child(2){background:#fbbf24}.dashboard-dots span:nth-child(3){background:#ef4444}.dashboard-title{font-weight:600;color:#1f2937;font-size:.9rem}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.stat-item{background:#f8fafc;padding:1rem;border-radius:12px;text-align:center}.stat-value{font-size:1.5rem;font-weight:700;color:#059669;margin-bottom:.25rem}.stat-label{font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.progress-bars{display:flex;flex-direction:column;gap:1rem}.progress-item{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:#6b7280}.progress-bar{width:60%;height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(135deg,#059669,#34d399);border-radius:3px;animation:fillProgress 2s ease-out}@keyframes fillProgress{0%{width:0%}}.hero-particles{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden;z-index:1}.particle{position:absolute;width:4px;height:4px;background:#34d39999;border-radius:50%;animation:particleFloat linear infinite}@keyframes particleFloat{0%{opacity:0;transform:translateY(100vh) scale(0)}10%{opacity:1}90%{opacity:1}to{opacity:0;transform:translateY(-100px) scale(1)}}.landing-main{padding:6rem 2rem;background:#f8fafc;position:relative}.landing-main:before{content:"";position:absolute;top:0;left:0;right:0;height:100px;background:linear-gradient(135deg,#0f172a,#1e293b,#334155);clip-path:polygon(0 0,100% 0,100% 50px,0 100px)}.section-header{text-align:center;margin-bottom:4rem;max-width:800px;margin-left:auto;margin-right:auto}.section-title{font-size:2.5rem;font-weight:700;color:#1f2937;margin-bottom:1rem;position:relative}.section-subtitle{font-size:1.2rem;color:#6b7280;line-height:1.6}.features{display:flex;flex-direction:column;gap:2rem;max-width:1200px;margin:0 auto}.feature-card{background:#fff;border-radius:20px;padding:2.5rem;box-shadow:0 10px 30px #0000001a;transition:all .3s ease;border:1px solid rgba(0,0,0,.05);display:flex;align-items:flex-start;gap:2rem;position:relative;overflow:hidden}.feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,#059669,#34d399);transform:scaleX(0);transition:transform .3s ease}.feature-card:hover{transform:translateY(-5px);box-shadow:0 20px 40px #00000026}.feature-card:hover:before{transform:scaleX(1)}.feature-icon{flex-shrink:0;width:80px;height:80px;background:linear-gradient(135deg,#059669,#34d399);border-radius:20px;display:flex;align-items:center;justify-content:center;color:#fff}.feature-icon svg{width:32px;height:32px}.feature-content h3{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.feature-content p{color:#6b7280;line-height:1.6;margin-bottom:1.5rem}.feature-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.feature-list li{display:flex;align-items:center;gap:.5rem;color:#059669;font-size:.9rem;font-weight:500}.feature-list li:before{content:"✓";width:16px;height:16px;background:#059669;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}.stats-section{background:linear-gradient(135deg,#047857,#10b981);padding:6rem 2rem;color:#fff;position:relative;overflow:hidden}.stats-container{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:3rem;text-align:center}.stat-item{background:#ffffff14;padding:2rem 1.5rem;border-radius:16px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 6px 20px #00000026;transition:transform .25s ease,box-shadow .25s ease;opacity:0;transform:translateY(20px);animation:statFadeIn 1s ease forwards}.stat-item:hover{transform:translateY(-6px);box-shadow:0 12px 30px #00000040}.stat-item:nth-child(1){animation-delay:.1s}.stat-item:nth-child(2){animation-delay:.2s}.stat-item:nth-child(3){animation-delay:.3s}.stat-item:nth-child(4){animation-delay:.4s}.stat-number{font-size:3rem;font-weight:800;line-height:1.2;margin-bottom:.5rem;color:#fff}.stat-label{font-size:1.125rem;font-weight:500;color:#ffffffd9}.stat-number{position:relative}.stat-number:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:40%;height:3px;background:#34d399;border-radius:2px;opacity:.7}@keyframes statFadeIn{to{opacity:1;transform:translateY(0)}}.landing .cta-section{padding:80px 24px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;text-align:center}.landing .cta-content{max-width:800px;margin:0 auto}.landing .cta-content h2{font-size:32px;margin-bottom:16px;font-weight:700}.landing .cta-content p{font-size:18px;margin-bottom:32px;opacity:.95}.landing .btn-primary{display:inline-flex;align-items:center;gap:8px;background:#fff;color:#059669;font-weight:600;border:none;border-radius:8px;padding:12px 24px;font-size:16px;cursor:pointer;transition:background .3s ease,transform .2s ease}.landing .btn-primary.large{font-size:18px;padding:14px 28px}.landing .btn-primary:hover{background:#f3f4f6;transform:translateY(-2px)}.landing .btn-icon{width:20px;height:20px}.landing .landing-footer{background:#111827;color:#e5e7eb;padding:60px 24px 24px}.landing .footer-content{max-width:1200px;margin:0 auto}.landing .footer-main{display:flex;flex-wrap:wrap;justify-content:space-between;margin-bottom:40px;gap:40px}.landing .footer-brand{flex:1 1 240px}.landing .footer-brand .logo{display:flex;align-items:center;gap:8px;font-size:20px;font-weight:700;margin-bottom:12px}.landing .footer-brand p{font-size:14px;color:#9ca3af}.landing .footer-links{display:flex;gap:40px;flex:2 1 480px;flex-wrap:wrap}.landing .footer-column h4{font-size:16px;margin-bottom:12px;color:#f9fafb}.landing .footer-column ul{list-style:none;padding:0;margin:0}.landing .footer-column ul li{margin-bottom:8px}.landing .footer-column ul li a{text-decoration:none;color:#d1d5db;font-size:14px;transition:color .2s ease}.landing .footer-column ul li a:hover{color:#10b981}.landing .footer-bottom{border-top:1px solid #374151;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:14px}.landing .footer-legal a{color:#9ca3af;margin-left:16px;text-decoration:none}.landing .footer-legal a:hover{color:#f3f4f6}:root{--sidebar-w: 240px;--sidebar-collapsed-w: 64px;--bg: #0b1220;--panel: #0f1724;--muted: #9ca3af;--muted-2: #d1d5db;--accent: #3b82f6;--highlight: #fbbf24;--radius: 10px}.sidebar{width:var(--sidebar-w);min-height:100vh;background:linear-gradient(180deg,var(--panel),#07101a);color:#fff;display:flex;flex-direction:column;transition:width .2s ease,background .2s ease;position:relative;box-shadow:0 2px 12px #02061799;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed-w)}.brand{display:flex;align-items:center;gap:12px;padding:14px;border-bottom:1px solid rgba(255,255,255,.03)}.logo{width:44px;height:44px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px;background:#ffffff05}.brand-text h1{margin:0;font-size:15px;letter-spacing:.2px}.brand-sub{font-size:11px;color:var(--muted)}.nav{flex:1;overflow-y:auto;padding:12px}.category{margin-bottom:8px}.category-title{width:100%;display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;background:transparent;border:none;color:var(--muted-2);font-weight:600;transition:background .12s ease,color .12s ease}.category-title:focus{outline:2px solid rgba(59,130,246,.16);outline-offset:2px}.category-title:hover{background:#ffffff05;color:#fff}.category.open .category-title{background:#ffffff08;color:#fff}.category .chev{margin-left:auto;transform-origin:center;transition:transform .16s ease;opacity:.9}.category.open .chev{transform:rotate(90deg)}.subcategory{margin-top:6px;display:flex;flex-direction:column;gap:4px;padding-left:6px}.nav-link{display:flex;align-items:center;gap:10px;text-decoration:none;padding:8px 10px;border-radius:8px;color:var(--muted);font-weight:500;transition:background .12s ease,color .12s ease,transform .12s;border-left:3px solid transparent}.nav-link:hover{background:#ffffff05;color:#fff;transform:translateY(-.5px)}.nav-link .link-icon{display:inline-flex;width:20px;justify-content:center;align-items:center}.nav-link.active{color:var(--accent);font-weight:700;background:#3b82f60d;border-left-color:var(--accent)}.sidebar-footer{padding:12px;border-top:1px solid rgba(255,255,255,.03);display:flex;gap:8px;align-items:center}.logout-icon{display:inline-flex;width:20px;justify-content:center;align-items:center}.link-badge{margin-left:auto;min-width:18px;height:18px;background:var(--accent);color:#fff;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;border-radius:999px;padding:0 5px}.sidebar-bottom{margin-top:auto;display:flex;flex-direction:column;gap:10px;padding:12px;border-top:1px solid rgba(255,255,255,.05)}.sidebar-bottom .collapse-btn{margin-top:6px;border-top:1px solid rgba(255,255,255,.08);padding-top:10px}.collapse-btn{background:#ffffff08;border:none;color:#fff;cursor:pointer;padding:8px 10px;border-radius:8px;font-weight:700;width:100%;transition:background .2s}.collapse-btn:hover{background:#ffffff14}.logout-btn{display:flex;align-items:center;gap:10px;padding:8px 10px;width:100%;border-radius:8px;border:none;background:transparent;color:var(--muted);cursor:pointer;font-weight:600}.logout-btn:hover{background:#ffffff0a;color:#fff}.sidebar.collapsed .brand-text,.sidebar.collapsed .brand-sub,.sidebar.collapsed .link-label,.sidebar.collapsed .cat-text,.sidebar.collapsed .footer-meta,.sidebar.collapsed .logout-text{display:none}.sidebar.collapsed .category-title{justify-content:center;padding:10px 6px}.sidebar.collapsed .subcategory{padding-left:0}.sidebar.collapsed .nav-link{justify-content:center;position:relative}.sidebar.collapsed .nav-link:hover:after{content:attr(data-label);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background:#0b1220;color:#fff;padding:6px 10px;border-radius:6px;white-space:nowrap;box-shadow:0 6px 18px #02061799;z-index:1000;font-size:13px}@media (max-width: 900px){.sidebar{position:fixed;z-index:60;left:0;top:0;height:100vh;transform:translate(0)}}.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 4px #0000000f;position:sticky;top:0;z-index:100}.topbar-left h2{margin:0;font-size:18px;font-weight:600;color:#111827}.topbar-right{display:flex;align-items:center;gap:12px;position:relative}.settings{cursor:pointer;font-size:20px;padding:6px 8px;border-radius:6px;transition:background .2s;position:relative}.settings:hover{background-color:#0000000d}.dropdown{position:absolute;top:36px;right:0;background-color:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 6px 16px #0000001f;width:170px;padding:6px 0;display:flex;flex-direction:column;z-index:200}.dropdown button{background:none;border:none;padding:10px 16px;width:100%;text-align:left;font-size:14px;color:#374151;cursor:pointer;transition:background .2s,color .2s}.dropdown button:hover{background-color:#f3f4f6;color:#111827}.app-footer{text-align:center;padding:12px 24px;background-color:#f3f4f6;border-top:1px solid #e5e7eb;font-size:14px;color:#6b7280;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.version{font-weight:500;color:#374151}.app-shell{display:flex;height:100vh;overflow:hidden;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.sidebar{width:240px;background:#111827;color:#fff;display:flex;flex-direction:column;transition:width .3s;height:100vh;overflow-y:auto;overflow-x:hidden}.sidebar.collapsed{width:60px}.main-container,.main-collapsed-container{flex:1;display:flex;flex-direction:column;height:100vh;overflow:hidden;transition:margin-left .3s}.main-content{flex:1;padding:24px;overflow-y:auto;overflow-x:hidden;background:#f9fafb}.app-footer{text-align:center;padding:12px 24px;background-color:#f3f4f6;border-top:1px solid #e5e7eb;font-size:14px;color:#6b7280;flex-shrink:0}.dashboard-container{padding:32px;min-height:100vh;background:#f9fafb;font-family:Inter,sans-serif}.dashboard-title{font-size:32px;font-weight:700;margin-bottom:24px;color:#111827}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px}.dashboard-card{display:flex;align-items:center;padding:20px;background:#fff;border-radius:12px;border-left:5px solid transparent;box-shadow:0 2px 8px #0000000f;transition:transform .2s ease,box-shadow .2s ease}.dashboard-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.card-icon{font-size:32px;margin-right:16px}.card-content h3{margin:0;font-size:16px;font-weight:600;color:#374151}.stat-value{margin-top:4px;font-size:24px;font-weight:700;color:#111827}.datagrid-wrapper{width:100%;display:flex;flex-direction:column;gap:12px;font-family:Inter,sans-serif}.datagrid-container{width:100%;border-radius:10px;overflow:hidden;box-shadow:0 2px 12px #0000000d;border:1px solid #ddd;display:flex;flex-direction:column}.datagrid-scroll{overflow-x:auto}.datagrid-table{width:100%;border-collapse:collapse;min-width:600px;font-size:14px}.datagrid-table th,.datagrid-table td{padding:10px 14px;border-bottom:1px solid #e0e0e0;text-align:left}.datagrid-table th{background:#f8f9fa;font-weight:600;position:sticky;top:0;z-index:2;border-bottom:2px solid #ccc}.datagrid-table tr.even-row{background-color:#fafafa}.datagrid-table tr:hover{background:#e3f2fd}.th-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer}.datagrid-actions{display:flex;gap:8px;justify-content:flex-start}.action-btn{border:none;cursor:pointer;padding:6px;border-radius:6px;color:#fff;font-weight:500;transition:all .2s}.action-btn.edit{background-color:#1976d2}.action-btn.edit:hover{background-color:#1565c0}.action-btn.delete{background-color:#d32f2f}.action-btn.delete:hover{background-color:#b71c1c}.datagrid-pagination{display:flex;justify-content:flex-end;align-items:center;gap:12px;font-size:14px;padding:8px 12px;background:#f8f9fa;border-top:1px solid #ddd;position:sticky;bottom:0;z-index:1}.datagrid-pagination button{border:none;background:#e0e0e0;border-radius:6px;padding:4px 8px;cursor:pointer;transition:all .2s}.datagrid-pagination button:disabled{opacity:.5;cursor:not-allowed}.datagrid-pagination button:hover:not(:disabled){background:#cfcfcf}.datagrid-pagesize{display:flex;align-items:center;gap:6px}.datagrid-pagesize select{padding:4px 6px;border-radius:6px;border:1px solid #ccc;font-size:14px}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0b122099;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;width:800px;max-width:95%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 20px #0003;overflow:hidden}.modal-header{padding:12px 16px;background:#f5f5f5;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;font-size:16px;font-weight:600}.close-btn{background:none;border:none;font-size:20px;cursor:pointer}.modal-body{overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:1.5rem}.form-section{background:#fff;padding:1.25rem 1.5rem;border-radius:10px;border:1px solid #f3f4f6;box-shadow:0 1px 3px #0000000d}.form-section h3{margin-bottom:1rem;font-size:1rem;font-weight:600;border-bottom:1px solid #e5e7eb;padding-bottom:.5rem}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem 1.5rem}.form-field label{font-size:.85rem;font-weight:500;margin-bottom:.35rem;color:#374151}.form-field input,.form-field select{padding:.55rem .75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem}.form-field input:focus,.form-field select:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 2px #2563eb26}.modal-footer{padding:12px 16px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:.75rem;background:#fff;position:sticky;bottom:0}.btn{padding:.55rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s ease}.btn.primary{background:#2563eb;color:#fff;border:none}.btn.primary:hover{background:#1e40af}.btn.secondary{background:#f3f4f6;border:1px solid #d1d5db;color:#111827}.btn.secondary:hover{background:#e5e7eb}@media (max-width: 768px){.modal-content{width:95%}.form-row{grid-template-columns:1fr}}.page-container.full-screen{padding:0;margin:0}.form-card{display:flex;flex-direction:column;gap:14px;padding:20px;border-radius:10px;background:#fff;box-shadow:0 2px 6px #00000014}.form-field{display:flex;flex-direction:column}.form-field label{font-weight:600;margin-bottom:4px}.form-field input{padding:8px 12px;border-radius:6px;border:1px solid #ccc;outline:none;font-size:14px;transition:all .2s}.form-field input:focus{border-color:#2e7d32;box-shadow:0 0 4px #2e7d3233}.input-error{border-color:#d32f2f!important}.error-text{color:#d32f2f;font-size:12px;margin-top:2px}.form-actions{display:flex;gap:10px;justify-content:flex-end}.btn{cursor:pointer;border:none;border-radius:6px;padding:8px 14px;font-weight:600;transition:all .2s;font-size:14px}.btn.primary{background:#2e7d32;color:#fff}.btn.primary:hover{background:#27632a}.btn.secondary{background:#f0f0f0;color:#333}.btn.secondary:hover{background:#e0e0e0}.btn.danger{background:#c43131;color:#f1eded}.btn.danger:hover{background:#4d9247;color:#141414}.datagrid-toolbar{display:flex;justify-content:space-between;align-items:center;padding:0;margin:0 0 12px;gap:12px}.datagrid-toolbar input[type=text]{flex:1;padding:8px 12px;border-radius:6px;border:1px solid #ccc;font-size:14px}.datagrid-toolbar input[type=text]:focus{border-color:#2e7d32;box-shadow:0 0 4px #2e7d3233}.datagrid-toolbar .btn{white-space:nowrap;margin:0%}.password-field .input-wrapper{display:flex;align-items:center;position:relative}.password-field input{flex:1;padding-right:40px}.password-field .toggle-btn{position:absolute;right:10px;background:none;border:none;cursor:pointer;font-size:16px;color:#555}.password-field .toggle-btn:hover{color:#000}.farmer-info{margin-top:12px}.farmer-info .farmer-profile-subtitle{font-size:20px;font-weight:600;margin-bottom:12px;color:#111827}.farmer-info .farmer-profile-table{width:100%;border-collapse:collapse;margin-bottom:16px;font-size:14px}.farmer-info .farmer-profile-table th,.farmer-info .farmer-profile-table td{border:1px solid #e5e7eb;padding:10px 12px;text-align:left}.farmer-info .farmer-profile-table th{background:#f3f4f6;font-weight:600;color:#374151;width:150px}.farmer-info input,.farmer-info select{width:100%;padding:6px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s}.farmer-info input:focus,.farmer-info select:focus{border-color:#16a34a;outline:none}.farmer-info .farmer-profile-btn{background:#16a34a;color:#fff;border:none;border-radius:6px;padding:8px 14px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s}.farmer-info .farmer-profile-btn:hover:not(:disabled){background:#15803d}.farmer-info .farmer-profile-btn:disabled{background:#9ca3af;cursor:not-allowed}.farmer-info .actions{display:flex;align-items:center;gap:10px;margin-top:10px}.farmer-info .alert{padding:10px 14px;border-radius:6px;font-size:14px;margin-bottom:10px}.farmer-info .alert.success{background:#dcfce7;border:1px solid #16a34a;color:#166534}.farmer-info .alert.error{background:#fee2e2;border:1px solid #dc2626;color:#991b1b}.farmer-profile-container{display:flex;flex-direction:column;height:100%;width:100%;overflow:hidden;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#1f2937;background:#f9fafb;padding:16px;box-sizing:border-box}.farmer-profile-header{display:flex;flex-direction:column;gap:12px;flex:0 0 auto}.farmer-profile-title{font-size:24px;font-weight:700;margin:0;color:#111827}.farmer-profile-selector{display:flex;gap:12px;align-items:center}.farmer-profile-dropdown{padding:8px 12px;border-radius:6px;border:1px solid #d1d5db;flex:1;font-size:14px;background:#fff}.farmer-profile-btn{background:#16a34a;color:#fff;border:none;border-radius:6px;padding:10px 18px;cursor:pointer;font-size:14px;font-weight:500;transition:background .18s}.farmer-profile-btn:hover{background:#15803d}.farmer-profile-tabs{display:flex;gap:6px;border-bottom:2px solid #e5e7eb;padding-bottom:6px}.farmer-profile-tab{padding:8px 12px;cursor:pointer;border:none;background:none;font-size:14px;color:#6b7280}.farmer-profile-tab.active{border-bottom:3px solid #16a34a;color:#111827;font-weight:600}.farmer-profile-content{flex:1 1 0%;min-height:0;margin-top:12px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px;box-shadow:0 4px 8px #0000000a;overflow:auto}.farmer-profile-subtitle{font-size:18px;font-weight:600;margin:8px 0 12px;color:#111827}.farmer-profile-table-wrapper{width:100%;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;border-radius:6px}.farmer-profile-table{border-collapse:collapse;margin-bottom:16px;font-size:13px;width:max-content;min-width:100%;max-width:none}.farmer-profile-table thead th{position:sticky;top:0;background:#f3f4f6;z-index:2}.farmer-profile-table th,.farmer-profile-table td{border:1px solid #e5e7eb;padding:8px 10px;text-align:left;white-space:nowrap}.farmer-profile-table tbody tr:nth-child(2n){background:#f9fafb}.farmer-profile-table td{max-width:320px;overflow:hidden;text-overflow:ellipsis}@media (max-width: 900px){.farmer-profile-dropdown{font-size:13px}.farmer-profile-btn{padding:8px 12px}.farmer-profile-table td,.farmer-profile-table th{padding:6px 8px}}.farmer-profile-table-wrapper{overflow-x:auto;margin-top:1rem}.farmer-profile-table{width:100%;border-collapse:collapse;font-size:14px}.farmer-profile-table th,.farmer-profile-table td{border:1px solid #ddd;padding:8px 10px;text-align:left}.farmer-profile-table th{background-color:#f7f7f7;font-weight:600}.farmer-profile-table input{width:100%;padding:6px 8px;border:1px solid #ccc;border-radius:4px;font-size:13px}.farmer-profile-table input:focus{outline:none;border-color:#2a9d8f;box-shadow:0 0 0 1px #2a9d8f}.farmer-profile-table button{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:13px;transition:background-color .2s ease}.farmer-profile-table button:disabled{background-color:#aaa;cursor:not-allowed}.farmer-profile-subtitle{margin:1rem 0;font-size:18px;font-weight:600;color:#333}*{box-sizing:border-box}.iot-history-map{width:100%;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #e2e8f0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.map-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;min-height:80px}.map-header h2{margin:0;font-size:1.5rem;font-weight:600}.view-controls{display:flex;gap:.75rem}.control-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:6px;color:#fff;cursor:pointer;transition:all .2s ease;font-size:.875rem;font-weight:500}.control-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.control-btn.active{background:#ffffffe6;color:#4f46e5}.map-container{display:flex;min-height:600px;background:#f8fafc}.map-view{flex:1;position:relative;background:linear-gradient(135deg,#e3f2fd,#f1f8e9);min-height:500px}.side-panel{width:400px;background:#fff;border-left:1px solid #e2e8f0;overflow-y:auto;flex-shrink:0}.map-container.charts-view{display:grid;grid-template-columns:350px 1fr;grid-gap:0;min-height:700px}.charts-view .map-view{grid-column:1;min-height:100%;border-right:1px solid #e2e8f0}.charts-view .side-panel{grid-column:2;width:100%;border-left:none;background:#f8fafc}.charts-view .farm-map{width:100%;height:100%}.farm-map{width:100%;height:100%;display:block}.farm-unit{cursor:pointer;transition:all .3s ease}.farm-unit-polygon{fill:#22c55e26;stroke:#22c55e;stroke-width:2;transition:all .3s ease}.farm-unit:hover .farm-unit-polygon{fill:#22c55e40;stroke-width:3}.farm-unit.selected .farm-unit-polygon{fill:#22c55e59;stroke:#16a34a;stroke-width:3}.farm-unit-label{font-size:14px;font-weight:600;fill:#1f2937;text-anchor:middle;pointer-events:none}.farm-unit-code{font-size:12px;fill:#6b7280;text-anchor:middle;pointer-events:none}.device-marker{cursor:pointer;transition:all .3s ease}.device-circle{fill:#3b82f6;stroke:#1d4ed8;stroke-width:2;transition:all .3s ease}.device-marker.has-data .device-circle{fill:#22c55e;stroke:#16a34a}.device-marker.no-data .device-circle{fill:#ef4444;stroke:#dc2626}.device-marker.selected .device-circle{stroke-width:3;filter:drop-shadow(0 0 6px rgba(59,130,246,.5))}.device-pulse{fill:none;stroke:#22c55e;stroke-width:2;opacity:0}.device-marker.has-data .device-pulse{opacity:.7}.device-label{font-size:12px;font-weight:600;fill:#1f2937;text-anchor:middle;pointer-events:none}.device-status{font-size:10px;fill:#6b7280;text-anchor:middle;pointer-events:none}.device-count{font-size:10px;font-weight:700;fill:#fff;text-anchor:middle;pointer-events:none}.device-menu-item{cursor:pointer;transition:fill .2s ease}.device-menu-item:hover{fill:#e5e7eb!important}@keyframes pulse{0%{opacity:.7;transform:scale(1)}50%{opacity:.3;transform:scale(1.5)}to{opacity:0;transform:scale(2)}}.map-legend{position:absolute;bottom:1rem;left:1rem;background:#fffffff2;padding:1rem;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.8)}.legend-item{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.875rem}.legend-item:last-child{margin-bottom:0}.legend-color{width:16px;height:16px;border-radius:50%;flex-shrink:0}.device-online{background:#22c55e}.device-offline{background:#ef4444}.device-multiple{background:#8b5cf6}.overview-panel{padding:2rem;height:100%;overflow-y:auto}.overview-panel h3{margin:0 0 1.5rem;color:#1f2937;font-size:1.25rem;font-weight:700}.stats{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.stat-card{display:flex;flex-direction:column;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;text-align:center}.stat-number{font-size:2rem;font-weight:700;margin-bottom:.5rem;line-height:1}.stat-label{font-size:.875rem;opacity:.9;font-weight:500}.device-status-overview{margin-bottom:2rem}.device-status-overview h4{color:#1f2937;margin-bottom:1rem;font-size:1.125rem;font-weight:600}.status-overview{display:flex;flex-direction:column;gap:.75rem}.status-item{display:flex;align-items:center;gap:.75rem;padding:.5rem 0}.status-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.status-dot.online{background:#22c55e}.status-dot.offline{background:#ef4444}.status-dot.no-data{background:#6b7280}.instructions h4{color:#1f2937;margin-bottom:1rem;font-size:1.125rem;font-weight:600}.instructions ul{color:#6b7280;line-height:1.6;padding-left:1.5rem;margin:0}.instructions li{margin-bottom:.5rem}.device-details{padding:2rem;height:100%;overflow-y:auto}.device-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.device-header h3{margin:0;color:#1f2937;font-size:1.25rem;font-weight:700}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:500}.status-badge.online{background:#22c55e1a;color:#16a34a}.status-badge.offline{background:#ef44441a;color:#dc2626}.crop-info{background:#eff6ff;border-left:4px solid #3b82f6;padding:1rem;border-radius:6px;margin-bottom:1.5rem}.crop-info h4{margin:0 0 .5rem;color:#1d4ed8;font-size:1rem;font-weight:600}.crop-info p{margin:0;color:#1e40af;font-size:.875rem}.latest-readings h4{color:#1f2937;margin-bottom:1rem;font-size:1.125rem;font-weight:600}.readings-time{display:flex;align-items:center;gap:.5rem;color:#6b7280;font-size:.875rem;margin-bottom:1.5rem}.readings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:2rem}.reading-card{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb;transition:all .2s ease}.reading-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px -1px #0000001a}.reading-card svg{color:#6b7280;flex-shrink:0}.reading-info{display:flex;flex-direction:column}.reading-label{font-size:.75rem;color:#6b7280;margin-bottom:.25rem;font-weight:500}.reading-value{font-size:1rem;font-weight:700}.reading-value.status-normal{color:#16a34a}.reading-value.status-low{color:#ea580c}.reading-value.status-high{color:#dc2626}.nutrient-levels{margin-bottom:2rem}.nutrient-levels h4{color:#1f2937;margin-bottom:1rem;font-size:1.125rem;font-weight:600}.nutrient-bars{display:flex;flex-direction:column;gap:1rem}.nutrient-bar{display:flex;align-items:center;gap:1rem}.nutrient-bar span{min-width:40px;font-size:.875rem;font-weight:600;color:#1f2937}.bar{flex:1;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:4px;transition:width .3s ease}.view-history-btn,.view-chart-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s ease;margin-bottom:.75rem}.view-history-btn{background:#4f46e5;color:#fff}.view-history-btn:hover{background:#4338ca;transform:translateY(-1px)}.view-chart-btn{background:#10b981;color:#fff}.view-chart-btn:hover{background:#059669;transform:translateY(-1px)}.history-view{padding:2rem;height:100%;overflow-y:auto}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.history-header h3{margin:0;color:#1f2937;font-size:1.25rem;font-weight:700}.back-btn{padding:.5rem 1rem;background:#6b7280;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease}.back-btn:hover{background:#4b5563;transform:translateY(-1px)}.history-list{display:flex;flex-direction:column;gap:1rem}.history-record{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;transition:all .2s ease}.history-record:hover{box-shadow:0 4px 12px -1px #0000001a;border-color:#d1d5db}.record-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.record-time{font-weight:600;color:#1f2937;font-size:.875rem}.record-status{padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600}.record-status.online{background:#22c55e1a;color:#16a34a}.record-status.offline{background:#ef44441a;color:#dc2626}.record-data{padding:1rem;display:grid;grid-template-columns:1fr;gap:1rem}.data-group{display:flex;flex-direction:column;gap:.5rem}.data-group strong{color:#1f2937;font-size:.875rem;font-weight:600;margin-bottom:.25rem}.data-group span{color:#6b7280;font-size:.875rem;padding-left:.75rem}.charts-panel{padding:2rem;height:100%;overflow-y:auto;background:#fff}.charts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.charts-header h3{margin:0;color:#1f2937;font-size:1.5rem;font-weight:700}.charts-container{height:calc(100% - 120px);overflow-y:auto}.chart-section{margin-bottom:2rem;background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.chart-section h4{margin:0 0 1.5rem;color:#1f2937;font-size:1.25rem;font-weight:600;text-align:center}.chart-wrapper{height:350px;width:100%}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.chart-item{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.chart-item h5{margin:0 0 1rem;color:#1f2937;font-size:1.125rem;font-weight:600;text-align:center}.chart-item .chart-wrapper{height:250px}.custom-tooltip{background:#fffffffa;border:1px solid #e5e7eb;border-radius:8px;padding:.75rem;box-shadow:0 4px 6px -1px #0000001a;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tooltip-label{font-weight:600;margin-bottom:.5rem;color:#1f2937;border-bottom:1px solid #e5e7eb;padding-bottom:.25rem;font-size:.875rem}.recharts-cartesian-axis-tick-value{font-size:11px;fill:#6b7280}.recharts-legend-item-text{font-size:12px;color:#374151!important}.recharts-tooltip-item{font-size:12px}.side-panel::-webkit-scrollbar,.history-view::-webkit-scrollbar,.charts-container::-webkit-scrollbar,.overview-panel::-webkit-scrollbar,.device-details::-webkit-scrollbar,.charts-panel::-webkit-scrollbar{width:6px}.side-panel::-webkit-scrollbar-track,.history-view::-webkit-scrollbar-track,.charts-container::-webkit-scrollbar-track,.overview-panel::-webkit-scrollbar-track,.device-details::-webkit-scrollbar-track,.charts-panel::-webkit-scrollbar-track{background:#f1f5f9}.side-panel::-webkit-scrollbar-thumb,.history-view::-webkit-scrollbar-thumb,.charts-container::-webkit-scrollbar-thumb,.overview-panel::-webkit-scrollbar-thumb,.device-details::-webkit-scrollbar-thumb,.charts-panel::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.side-panel::-webkit-scrollbar-thumb:hover,.history-view::-webkit-scrollbar-thumb:hover,.charts-container::-webkit-scrollbar-thumb:hover,.overview-panel::-webkit-scrollbar-thumb:hover,.device-details::-webkit-scrollbar-thumb:hover,.charts-panel::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width: 1200px){.charts-grid{grid-template-columns:1fr}.map-container.charts-view{grid-template-columns:300px 1fr}}@media (max-width: 1024px){.map-container,.map-container.charts-view{display:flex;flex-direction:column;min-height:auto}.map-view{height:400px;order:1}.side-panel{width:100%;max-height:500px;order:2}.readings-grid{grid-template-columns:1fr}}@media (max-width: 768px){.map-header{flex-direction:column;gap:1rem;align-items:flex-start;padding:1rem}.map-header h2{font-size:1.25rem}.view-controls{width:100%;justify-content:center}.overview-panel,.device-details,.history-view,.charts-panel{padding:1rem}.stats{gap:.75rem}.stat-card{padding:1rem}.stat-number{font-size:1.5rem}.chart-wrapper{height:250px}.chart-item .chart-wrapper{height:200px}}@media (max-width: 640px){.device-details .readings-grid{grid-template-columns:1fr}.map-legend{position:relative;margin:1rem;bottom:auto;left:auto}}.farmunit-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;justify-content:center;align-items:center;z-index:999;animation:fadeIn .3s ease-in-out}.farmunit-modal{background:#fff;border-radius:16px;width:85%;max-width:1100px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 8px 30px #00000040;animation:slideUp .3s ease-in-out}.farmunit-modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid #eee;background:#f9fafb}.farmunit-modal-header h2{font-size:20px;font-weight:600;color:#111827}.close-btn{background:#f3f4f6;border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:16px;transition:background .2s}.close-btn:hover{background:#e5e7eb}.farmunit-tabs{display:flex;border-bottom:1px solid #e5e7eb;background:#fafafa}.farmunit-tab{flex:1;padding:12px 0;text-align:center;cursor:pointer;background:none;border:none;font-size:14px;color:#6b7280;transition:all .2s}.farmunit-tab:hover{background:#f3f4f6}.farmunit-tab.active{border-bottom:3px solid #16a34a;color:#16a34a;font-weight:600}.farmunit-content{flex:1;padding:20px;overflow-y:auto;background:#fff}.section-title{font-size:16px;font-weight:600;margin-bottom:12px;color:#374151}.table-wrapper{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 2px 6px #0000000d}.modern-table{width:100%;border-collapse:collapse;font-size:14px}.modern-table thead{background:#f9fafb}.modern-table th,.modern-table td{padding:12px;text-align:left;border-bottom:1px solid #f3f4f6}.modern-table th{font-weight:600;color:#374151}.modern-table tr:hover{background:#f9fafb}select,input{border:1px solid #d1d5db;border-radius:6px;padding:6px 8px;font-size:14px;width:100%}.update-btn{background:#16a34a;color:#fff;padding:6px 12px;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:.2s ease}.update-btn:hover{background:#15803d}.update-btn:disabled{background:#9ca3af;cursor:not-allowed}.view-btn{background:#ceca00;color:#fff;padding:6px 12px;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:.2s ease}.view-btn:hover{background:#7e8015}.view-btn:disabled{background:#9ca3af;cursor:not-allowed}.alert{margin:12px 16px;padding:10px 14px;border-radius:6px;font-size:14px;font-weight:500}.alert.success{background:#dcfce7;color:#166534;border:1px solid #22c55e}.alert.error{background:#fee2e2;color:#991b1b;border:1px solid #ef4444}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.iot-compare-container{padding:16px}.iot-compare-title{font-size:20px;font-weight:600;margin-bottom:16px}.iot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.iot-card{border:1px solid #e5e7eb;border-radius:10px;background:#fff;box-shadow:0 2px 6px #0000000d;display:flex;flex-direction:column}.iot-card-header{padding:12px 16px;background:#f3f4f6;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.iot-date{font-size:12px;color:#6b7280}.iot-card-body{padding:12px 16px;display:flex;flex-direction:column;gap:4px}.iot-val{display:flex;justify-content:space-between;font-size:13px;padding:4px 6px;border-radius:4px}.iot-val.ok{background:#ecfdf5;color:#065f46}.iot-val.low{background:#fffbeb;color:#92400e}.iot-val.high{background:#fef2f2;color:#991b1b}.iot-val .label{font-weight:500}.iot-val .value{margin:0 6px}.iot-val .range{font-size:11px;color:#6b7280}.iot-val .icon{margin-left:6px}.advanced-calendar-container{padding:1.5rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.calendar-wrapper{max-width:100%;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;overflow:hidden}.calendar-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:1.5rem;color:#fff}.calendar-title{font-size:1.875rem;font-weight:700;margin:0 0 .5rem;text-shadow:0 2px 4px rgba(0,0,0,.1)}.calendar-subtitle{color:#ffffffe6;font-size:1rem;margin:0}.calendar-actions-bar{padding:1rem 1.5rem;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.action-buttons{display:flex;gap:.75rem}.action-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:none;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.add-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.add-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 8px #10b9814d}.save-btn{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.save-btn:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.save-btn:disabled{opacity:.6;cursor:not-allowed}.status-indicators{display:flex;gap:.5rem;align-items:center}.status-badge{padding:.375rem .75rem;background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:.75rem;font-weight:500;color:#374151}.copied-badge{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.table-container{overflow-x:auto;overflow-y:auto;max-height:70vh}.calendar-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.8rem;background:#fff;min-width:1400px}.calendar-table th{background:#f8fafc;padding:.75rem;text-align:center;font-weight:600;color:#374151;text-transform:uppercase;font-size:.75rem;letter-spacing:.025em;border-bottom:2px solid #e5e7eb;position:sticky;top:0;z-index:10;box-shadow:0 1px 3px #0000001a}.col-actions{width:120px;min-width:120px}.col-day{width:60px;min-width:60px}.col-range{width:140px;min-width:140px}.col-single{width:80px;min-width:80px}.col-nutrients{width:320px;min-width:320px}.calendar-row{transition:all .2s ease;cursor:move}.calendar-row:nth-child(2n){background:#fafbfc}.calendar-row:hover{background:#f0f9ff;transform:scale(1.001);box-shadow:0 2px 8px #00000014}.calendar-row.dragging{opacity:.5;transform:rotate(2deg)}.calendar-row.drag-over{background:#dbeafe;border:2px dashed #3b82f6}.calendar-row td{padding:.75rem;border-bottom:1px solid #f1f5f9;text-align:center;vertical-align:middle}.actions-cell{padding:.5rem!important}.actions-grid{display:flex;flex-direction:column;gap:.25rem;align-items:center}.action-group{display:flex;gap:.25rem;align-items:center}.drag-handle{color:#9ca3af;cursor:grab}.drag-handle:active{cursor:grabbing}.action-icon{padding:.25rem;border:none;background:transparent;border-radius:4px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.action-icon:hover{transform:scale(1.1)}.action-icon:disabled{opacity:.3;cursor:not-allowed}.move-up:hover,.move-down:hover{color:#3b82f6;background:#dbeafe}.copy-btn:hover{color:#10b981;background:#ecfdf5}.paste-btn:hover:not(:disabled){color:#8b5cf6;background:#f3e8ff}.reset-btn:hover{color:#f59e0b;background:#fef3c7}.delete-btn:hover{color:#ef4444;background:#fef2f2}.day-cell{font-weight:600;color:#1f2937;font-size:.9rem}.input-pair{display:flex;align-items:center;gap:.25rem;justify-content:center}.range-input{width:55px;padding:.375rem;border:1px solid #d1d5db;border-radius:6px;text-align:center;font-size:.75rem;transition:all .2s ease;background:#fff}.range-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;background:#f8fafc}.range-input:hover{border-color:#9ca3af}.range-separator{color:#6b7280;font-weight:500}.single-input{width:60px;padding:.375rem;border:1px solid #d1d5db;border-radius:6px;text-align:center;font-size:.75rem;transition:all .2s ease;background:#fff}.single-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;background:#f8fafc}.nutrients-cell{padding:.5rem!important}.nutrients-grid{display:grid;grid-template-columns:1fr 1fr;gap:.375rem;font-size:.75rem}.nutrient-row{display:flex;align-items:center;gap:.25rem}.nutrient-label{color:#6b7280;font-weight:500;min-width:12px}.nutrient-row .input-pair{gap:.125rem}.nutrient-row .range-input{width:40px;padding:.25rem;font-size:.7rem}.calendar-footer{padding:.75rem 1.5rem;background:#f8fafc;border-top:1px solid #e5e7eb;text-align:center}.calendar-footer p{margin:0;color:#6b7280;font-size:.875rem}@media (max-width: 768px){.advanced-calendar-container,.calendar-header{padding:1rem}.calendar-title{font-size:1.5rem}.calendar-actions-bar{flex-direction:column;align-items:stretch}.status-indicators{justify-content:center}.table-container{max-height:60vh}}.calendar-master-container{padding:20px;font-family:Inter,Arial,sans-serif;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000000d}.calendar-title{font-size:1.5rem;font-weight:600;margin-bottom:15px;color:#111827}.breed-select{max-width:400px;margin-bottom:25px}.calendar-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.btn{padding:8px 16px;border-radius:6px;border:none;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s ease}.btn.primary{background:#4caf50;color:#fff}.btn.primary:hover{background:#43a047}.calendar-table-wrapper{overflow-x:auto}.calendar-table{width:100%;border-collapse:collapse;border:1px solid #e5e7eb}.calendar-table th,.calendar-table td{padding:10px 12px;border:1px solid #e5e7eb;text-align:center;font-size:.9rem}.calendar-table th{background-color:#f9fafb;font-weight:600}.calendar-table tr:nth-child(2n){background-color:#fafafa}.breedmaster-container{padding:20px;background:#fafafa;border-radius:12px}.breedmaster-toolbar{display:flex;justify-content:flex-end;gap:12px;margin-bottom:16px}.breedmaster-btn{padding:8px 14px;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:background .2s ease}.breedmaster-btn.add{background:#007bff;color:#fff}.breedmaster-btn.add:hover{background:#0069d9}.breedmaster-btn.save{background:#28a745;color:#fff}.breedmaster-btn.save:hover{background:#218838}.breedmaster-btn.delete{background:#dc3545;color:#fff;padding:6px 12px;font-size:13px}.breedmaster-btn.delete:hover{background:#c82333}.breedmaster-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden}.breedmaster-table th,.breedmaster-table td{border:1px solid #e0e0e0;padding:10px 12px;text-align:left;font-size:14px}.breedmaster-table th{background:#f4f6f8;font-weight:600}.breedmaster-table tr:nth-child(2n){background:#fafafa}.breedmaster-empty{text-align:center;padding:20px;font-style:italic;color:#666}.breedmaster-input{width:100%;padding:6px 8px;border:1px solid #ccc;border-radius:4px;font-size:13px}.breedmaster-input:focus{border-color:#007bff;outline:none}:root{--bg:#f6f8fa;--card:#ffffff;--muted:#6b7280;--accent:#0ea5a4}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;background:var(--bg);color:#0f172a}.btn{background:var(--accent);border:none;color:#fff;padding:10px 14px;border-radius:8px;cursor:pointer}.small{padding:6px 10px;border-radius:6px;background:#e6eef0;border:1px solid #d0e6e6;cursor:pointer}
