@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--primary-color:#4a9e3f;--primary-dark:#2d6a27;--primary-light:#72c263;--primary-50:#f2faf0;--primary-100:#d6f0d0;--bg-main:#f5faf4;--bg-card:#fff;--bg-sidebar:#fff;--text-dark:#0f1f0c;--text-body:#2e3d28;--text-muted:#637560;--text-light:#fff;--accent-gold:#f5c832;--accent-gold-light:#fef9d7;--accent-orange:#e8a020;--accent-orange-light:#fef3c7;--accent-red:#d94040;--accent-red-light:#fde8e8;--accent-green:#72c263;--border-color:#ddebd8;--border-focus:#4a9e3f;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #00000012, 0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #00000014, 0 2px 4px -1px #0000000a;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -2px #0000000a;--border-radius:10px;--border-radius-lg:16px;--border-radius-xl:24px;--border-radius-full:9999px;--sidebar-width:240px;--mobile-nav-height:74px;--mobile-top-bar-height:56px;color:var(--text-body);background-color:var(--bg-main);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,sans-serif;font-weight:400;line-height:1.6}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;overflow-x:hidden}body{background-color:var(--bg-main);min-height:100vh;overflow-x:hidden}#root{flex-direction:column;min-height:100vh;display:flex}h1,h2,h3,h4,h5,h6{color:var(--text-dark);font-weight:600;line-height:1.3}a{color:var(--primary-color);font-weight:500;text-decoration:none;transition:color .15s}a:hover{color:var(--primary-dark);text-decoration:underline}input,select,textarea{background-color:var(--bg-card);color:var(--text-dark);border:1.5px solid var(--border-color);border-radius:var(--border-radius);outline:none;width:100%;padding:.625rem .875rem;font-family:inherit;font-size:.9375rem;transition:border-color .2s,box-shadow .2s}input:focus,select:focus,textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #16a34a1f}label{color:var(--text-body);margin-bottom:.375rem;font-size:.875rem;font-weight:500;display:block}button{border-radius:var(--border-radius);background-color:var(--primary-color);color:var(--text-light);cursor:pointer;border:1px solid #0000;padding:.625rem 1.25rem;font-family:inherit;font-size:.9375rem;font-weight:500;transition:all .2s}button:hover{background-color:var(--primary-dark)}button:active{transform:scale(.98)}button:focus-visible{outline-offset:2px;outline:3px solid #16a34a66}button:disabled{opacity:.6;cursor:not-allowed}.page-wrapper{flex-direction:column;gap:1.25rem;padding-bottom:2rem;display:flex}.metrics-row{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}.actions-grid{grid-template-columns:repeat(4,1fr);gap:.625rem;display:grid}.card{background:var(--bg-card);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);margin-bottom:1rem;padding:1.25rem}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.text-h1{color:var(--text-dark);font-size:1.5rem;font-weight:700}.text-h2{color:var(--text-dark);margin-bottom:1rem;font-size:1.25rem;font-weight:600}.text-muted{color:var(--text-muted);font-size:.875rem}.hoverable:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.animate-slide-up{animation:.35s ease-out forwards slideUp}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-fade-in{animation:.3s ease-out forwards fadeIn}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (width>=768px){.app-shell{min-height:100vh;display:block}.sidebar{display:flex!important}.main-content{margin-left:var(--sidebar-width);min-width:0;max-width:calc(900px + var(--sidebar-width));box-sizing:border-box;width:100%;padding:2rem}.bottom-nav,.mobile-top-bar{display:none!important}.metrics-row{grid-template-columns:repeat(4,1fr)!important;gap:1rem!important;display:grid!important;overflow-x:visible!important}.actions-grid{grid-template-columns:repeat(4,1fr)!important;gap:.75rem!important}.reports-feature-grid{grid-template-columns:repeat(2,1fr)}.chat-fab,.chat-panel{bottom:28px!important;right:28px!important}}@media (width>=1200px){.main-content{padding:2rem 3rem}}@media (width<=767px){.sidebar{display:none!important}.bottom-nav,.mobile-top-bar{display:flex!important}.main-content{padding:1rem;padding-top:calc(var(--mobile-top-bar-height) + 1rem);padding-bottom:calc(var(--mobile-nav-height) + env(safe-area-inset-bottom) + 12px);margin-left:0;overflow-x:hidden}.chat-fab,.chat-panel{bottom:76px!important;right:14px!important}}.pwa-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:9998;background:#00000059;animation:.25s ease-out fadeIn;position:fixed;inset:0}.pwa-banner{z-index:9999;background:#fff;border-radius:20px 20px 0 0;width:min(480px,100vw);padding:1.5rem 1.5rem 2rem;animation:.4s cubic-bezier(.34,1.56,.64,1) forwards pwaSlideUp;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -8px 32px #0000002e}@keyframes pwaSlideUp{0%{transform:translate(-50%)translateY(100%)}to{transform:translate(-50%)translateY(0)}}.pwa-banner-inner{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.pwa-icon-wrap{background:var(--primary-50);border:1.5px solid var(--border-color);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:60px;height:60px;display:flex;overflow:hidden}.pwa-icon{object-fit:contain;width:52px;height:52px}.pwa-copy{flex:1;min-width:0}.pwa-title{color:var(--text-dark);margin-bottom:.2rem;font-size:1.05rem;font-weight:700}.pwa-subtitle{color:var(--text-muted);font-size:.8rem;line-height:1.45}.pwa-pills{flex-wrap:wrap;gap:.5rem;margin-bottom:1.2rem;display:flex}.pwa-pill{background:var(--primary-50);color:var(--primary-dark);border:1px solid var(--primary-100);border-radius:var(--border-radius-full);white-space:nowrap;padding:.2rem .65rem;font-size:.72rem;font-weight:500}.pwa-actions{gap:.75rem;display:flex}.pwa-btn-install{background:var(--primary-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;flex:1;padding:.75rem 1rem;font-size:.9rem;font-weight:600;transition:background .2s,transform .15s}.pwa-btn-install:hover{background:var(--primary-dark)}.pwa-btn-install:active{transform:scale(.97)}.pwa-btn-install:disabled{opacity:.7;cursor:not-allowed}.pwa-btn-later{color:var(--text-muted);border:1.5px solid var(--border-color);border-radius:var(--border-radius);cursor:pointer;background:0 0;flex:none;padding:.75rem 1rem;font-size:.85rem;font-weight:500;transition:border-color .2s,color .2s}.pwa-btn-later:hover{border-color:var(--text-muted);color:var(--text-body)}.pwa-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.25rem .5rem;font-size:1rem;line-height:1;transition:color .15s,background .15s;position:absolute;top:.9rem;right:1rem}.pwa-close:hover{color:var(--text-dark);background:var(--primary-50)}.pwa-ios-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;background:#0000008c;justify-content:center;align-items:center;padding:1rem;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.pwa-ios-modal{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:340px;padding:2rem 1.5rem 1.5rem;animation:.3s ease-out slideUp;position:relative;box-shadow:0 20px 60px #00000040}.pwa-ios-close{background:var(--primary-50);color:var(--text-muted);cursor:pointer;border:none;border-radius:6px;padding:.3rem .6rem;font-size:.85rem;position:absolute;top:.75rem;right:.75rem}.pwa-ios-icon{margin-bottom:.75rem;font-size:3rem}.pwa-ios-title{color:var(--text-dark);margin-bottom:.4rem;font-size:1.1rem;font-weight:700}.pwa-ios-subtitle{color:var(--text-muted);margin-bottom:1rem;font-size:.85rem}.pwa-ios-steps{text-align:left;color:var(--text-body);margin-bottom:.5rem;padding-left:1.4rem;font-size:.875rem;line-height:1.7}.pwa-ios-share{background:var(--primary-50);border-radius:4px;padding:0 4px;font-size:1rem;display:inline-block}@media (width>=768px){.pwa-backdrop{display:none}.pwa-banner{border-radius:16px;width:380px;animation:.4s cubic-bezier(.34,1.56,.64,1) forwards pwaToastIn;bottom:1.5rem;left:auto;right:1.5rem;transform:none;box-shadow:0 8px 32px #00000024,0 2px 8px #00000014}@keyframes pwaToastIn{0%{opacity:0;transform:translateY(120%)}to{opacity:1;transform:translateY(0)}}}:root{--bg-main:#f7faf9;--text-dark:#0f172a;--text-muted:#6b7280;--primary-color:#2d6a27;--border-color:#e6e9ef;--accent-red:#ef4444;--accent-red-light:#fff1f2}.login-container{background-color:var(--bg-main);align-items:stretch;min-height:100vh;display:flex}.login-panel{color:#fff;background:linear-gradient(160deg,#4a9e3f 0%,#2d6a27 50%,#1e4d1b 100%);flex-direction:column;flex:0 0 45%;justify-content:center;align-items:center;padding:3rem;display:none;position:relative;overflow:hidden}@media (width>=768px){.login-panel{display:flex}.login-form-panel{flex:1}}.login-panel-inner{z-index:1;text-align:center;max-width:340px;position:relative}.login-panel-logo img{object-fit:contain;filter:brightness(0)invert();width:88px;height:88px;margin:0 auto 1rem;display:block}.login-panel-title{color:#fff;margin:0 0 .5rem;font-size:2.25rem;font-weight:800}.login-panel-sub{opacity:.9;font-size:1rem;line-height:1.6}.login-panel-features{flex-direction:column;gap:.6rem;margin-top:1.75rem;display:flex}.feature-item{text-align:left;background:#ffffff1a;border-radius:12px;padding:.6rem .85rem;font-size:.9rem}.login-form-panel{flex-direction:column;flex:1;justify-content:center;align-items:center;padding:clamp(1.5rem,5vw,3rem);display:flex}.login-card{background:var(--bg-main);border-radius:12px;width:100%;max-width:420px;padding:1.75rem;box-shadow:0 10px 30px #0206170f}.login-logo{text-align:center;margin-bottom:1.25rem}.login-logo img{object-fit:contain;width:56px;height:56px;margin:0 auto .6rem;display:block}.login-title{color:var(--text-dark);margin:0;font-size:1.6rem;font-weight:800}.login-subtitle{color:var(--text-muted);margin-top:.35rem}.error-box{background-color:var(--accent-red-light);color:var(--accent-red);border-left:3px solid var(--accent-red);border-radius:10px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.95rem}.login-form{flex-direction:column;gap:1rem;display:flex}.form-group{flex-direction:column;gap:.375rem;display:flex}.form-group label{color:var(--text-dark);font-size:.92rem;font-weight:600}.form-group input{border:1px solid var(--border-color);background:#fff;border-radius:10px;outline:none;width:100%;padding:.75rem .9rem;font-size:1rem;transition:box-shadow .15s,border-color .15s}.form-group input::placeholder{color:#94a3b8}.form-group input:focus{border-color:var(--primary-color);box-shadow:0 0 0 6px #2d6a270f}.password-wrapper{position:relative}.password-toggle{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:.25rem;position:absolute;top:50%;right:.5rem;transform:translateY(-50%)}.register-cta{text-align:center;color:var(--text-muted);margin-top:1.25rem;font-size:.92rem}.register-link{color:var(--primary-color);cursor:pointer;font-weight:600}@media (width<=767px){.login-card{box-shadow:none;padding:1.25rem}}
