code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}*,body{margin:0;padding:0}body{-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#e8f5e8,#c8e6c9);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}.container{border-radius:12px;box-shadow:0 8px 25px #00000026;margin:10px auto;max-width:1400px;width:98%}.auth-container,.container{background:#fff;overflow:hidden}.auth-container{border-radius:20px;box-shadow:0 10px 30px #0003;margin:50px auto;max-width:400px}.auth-card{padding:40px 30px;text-align:center}.input-group{margin-bottom:25px;text-align:left}.input-group label{align-items:center;color:#2e7d32;display:flex;font-size:.95rem;font-weight:600;gap:8px;margin-bottom:8px}.input-group input,.input-group select{background:#fafafa;border:2px solid #e0e0e0;border-radius:10px;font-size:16px;padding:15px;transition:all .3s ease;width:100%}.input-group input:focus,.input-group select:focus{background:#fff;border-color:#4caf50;box-shadow:0 0 10px #4caf501a;outline:none}.btn{background:linear-gradient(135deg,#4caf50,#2e7d32);border:none;border-radius:12px;color:#fff;font-size:16px;font-weight:600;margin-top:10px;padding:15px;transition:all .3s ease;width:100%}.btn:hover{box-shadow:0 5px 15px #4caf504d;transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn:disabled{background:#ccc;transform:none}.dashboard-layout{background:#f5f7fa;min-height:100vh;width:100%}.main-content{margin:0 auto;max-width:1600px;min-height:calc(100vh - 60px);padding:15px;width:100%}.dashboard-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:40px}.dashboard-card{background:#fff;border-left:5px solid #4caf50;border-radius:15px;box-shadow:0 4px 15px #0000001a;padding:25px;transition:transform .3s ease}.dashboard-card:hover{transform:translateY(-5px)}.dashboard-card h3{align-items:center;color:#2e7d32;display:flex;gap:10px;margin-bottom:15px}.dashboard-card p{color:#666;line-height:1.6;margin-bottom:20px}.dashboard-card .card-action{align-items:center;background:#4caf50;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-weight:500;gap:8px;padding:10px 20px;text-decoration:none;transition:all .3s ease}.dashboard-card .card-action:hover{background:#45a049;transform:translateY(-2px)}.quick-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.stat-item{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:20px;text-align:center}.stat-item i{color:#1976d2;font-size:2rem;margin-bottom:10px}.stat-item h4{color:#1976d2;font-size:1.8rem;margin:0 0 5px}.stat-item p{color:#666;font-size:.9rem;margin:0}@media (min-width:1200px){.container{max-width:1400px}.main-content{max-width:1600px}}@media (max-width:768px){.container{width:95%}.auth-container,.container{margin:20px;max-width:none}.auth-card{padding:30px 20px}.main-content{padding:15px}.dashboard-grid{gap:20px;grid-template-columns:1fr}.quick-stats{gap:15px;grid-template-columns:repeat(2,1fr)}.stat-item{padding:15px}.stat-item h4{font-size:1.5rem}}@media (max-width:480px){.quick-stats{grid-template-columns:1fr}.dashboard-card{padding:20px}.auth-container{margin:10px}}:root{--color-bg:#f5f7fa;--color-surface:#fff;--color-surface-alt:#f8f9fa;--color-primary:#4f46e5;--color-primary-accent:#6366f1;--color-primary-gradient-start:#667eea;--color-primary-gradient-end:#764ba2;--color-success:#2e7d32;--color-success-accent:#4caf50;--color-warning:#f59e0b;--color-danger:#dc2626;--color-border:#e2e8f0;--color-text:#1f2937;--color-text-light:#6b7280;--color-muted:#94a3b8;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #00000014,0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000014,0 2px 4px #0000000f;--shadow-lg:0 10px 15px #0000001a,0 4px 6px #0000000d;--radius-sm:4px;--radius-md:8px;--radius-lg:14px;--radius-full:999px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--font-stack:"Inter","system-ui","Segoe UI",Roboto,Arial,sans-serif;--font-size-xs:12px;--font-size-sm:14px;--font-size-md:16px;--font-size-lg:20px;--font-size-xl:28px;--line-height-base:1.5}body{-webkit-font-smoothing:antialiased;background:linear-gradient(180deg,#fafbfd,#f2f5f9);font-family:Inter,"system-ui",Segoe UI,Roboto,Arial,sans-serif;font-family:var(--font-stack)}.container-narrow{margin:0 auto;max-width:900px}.flex{display:flex}.flex-center{align-items:center;display:flex;justify-content:center}.grid{display:grid}.text-muted{color:#6b7280;color:var(--color-text-light)}.fade-in{animation:fadeIn .35s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.card-surface{background:#fff;background:var(--color-surface);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;box-shadow:var(--shadow-sm);padding:20px 24px;padding:var(--space-5) var(--space-6);transition:box-shadow .25s ease,transform .25s ease}.card-surface:hover{box-shadow:0 4px 6px #00000014,0 2px 4px #0000000f;box-shadow:var(--shadow-md)}.btn{align-items:center;border:1px solid #0000;border-radius:8px;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font:inherit;font-weight:500;gap:8px;gap:var(--space-2);padding:8px 16px;padding:var(--space-2) var(--space-4);transition:background .2s,box-shadow .2s,transform .15s}.btn:disabled{cursor:not-allowed;opacity:.55}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);background:linear-gradient(135deg,var(--color-primary-gradient-start),var(--color-primary-gradient-end));box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;box-shadow:var(--shadow-sm);color:#fff}.btn-primary:hover:not(:disabled){filter:brightness(1.08)}.btn-outline{background:#fff;border-color:#e2e8f0;border-color:var(--color-border)}.btn-outline:hover{background:#f8f9fa;background:var(--color-surface-alt)}.badge{border-radius:999px;border-radius:var(--radius-full);display:inline-block;font-size:12px;font-size:var(--font-size-xs);font-weight:600;letter-spacing:.25px;padding:2px 8px}.badge-high{background:#16a34a20;color:#15803d}.badge-medium{background:#f59e0b20;color:#d97706}.badge-low{background:#dc262620;color:#b91c1c}.tab-bar{background:#fff;background:var(--color-surface);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;box-shadow:var(--shadow-sm);display:flex;overflow:hidden}.tab-btn{background:#f8f9fa;background:var(--color-surface-alt);border:0;color:#6b7280;color:var(--color-text-light);cursor:pointer;flex:1 1;font-weight:500;padding:16px 20px;padding:var(--space-4) var(--space-5);transition:background .25s,color .25s}.tab-btn:hover{background:#eef2f7;color:#1f2937;color:var(--color-text)}.tab-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);background:linear-gradient(135deg,var(--color-primary-gradient-start),var(--color-primary-gradient-end));box-shadow:inset 0 0 0 1px #ffffff30;color:#fff}.section-heading{font-size:28px;font-size:var(--font-size-xl);font-weight:600;letter-spacing:-.5px;margin:0 0 8px;margin:0 0 var(--space-2)}.subheading{color:#6b7280;color:var(--color-text-light);margin:0 0 20px;margin:0 0 var(--space-5)}.soft-divider{background:linear-gradient(90deg,#fff,#dfe6ee 50%,#fff);height:1px;margin:24px 0;margin:var(--space-6) 0;width:100%}.pest-root{animation:fadeIn .4s ease;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif;line-height:1.4;margin:0 auto;max-width:1200px;padding:var(--space-8) var(--space-5) var(--space-12)}.preview-image{border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:block;max-width:100%}.bounding-box-canvas{left:0;pointer-events:none;position:absolute;top:0}.detection-header{margin-bottom:var(--space-6);text-align:center}.detection-header .header-title{font-size:var(--font-size-xl);font-weight:600;letter-spacing:-.5px;margin:0 0 var(--space-2)}.detection-header .header-subtitle{color:var(--color-text-light);font-size:var(--font-size-sm);margin:0}.upload-section{background:#f9fbfd;border:2px dashed #d0d7e2;border-radius:var(--radius-lg);padding:var(--space-6);position:relative;text-align:center;transition:border-color .25s,background .25s}.upload-section.has-image{padding:var(--space-4)}.upload-section:hover{background:#f3f6fb;border-color:var(--color-primary-accent)}.upload-button{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font:inherit;padding:var(--space-2) var(--space-4);transition:background .2s,box-shadow .2s}.upload-button:hover{background:var(--color-surface-alt)}.image-preview-container{display:inline-block;max-width:100%;position:relative}.image-preview{border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:block;max-width:100%}.canvas-overlay{left:0;pointer-events:none;position:absolute;top:0}.controls-section{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-5)}.detect-button{align-items:center;background:linear-gradient(135deg,var(--color-primary-gradient-start),var(--color-primary-gradient-end));border:1px solid #0000;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;display:inline-flex;font:inherit;font-weight:500;gap:var(--space-2);padding:var(--space-3) var(--space-5)}.detect-button:hover:not(:disabled){filter:brightness(1.08)}.clear-button{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font:inherit;font-weight:500;padding:var(--space-2) var(--space-4)}.clear-button:hover{background:var(--color-surface-alt)}.toggle-switch{align-items:center;cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--space-2)}.results-section{margin-top:var(--space-6)}.detection-results{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-5)}.results-header{align-items:center;display:flex;font-size:var(--font-size-lg);font-weight:600;gap:var(--space-2);margin:0 0 var(--space-5)}.detection-item{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-4);overflow:hidden;padding:var(--space-4);position:relative}.detection-item:last-child{margin-bottom:0}.detection-item:hover{box-shadow:var(--shadow-sm)}.detection-header-item{align-items:center;display:flex;gap:var(--space-3);justify-content:space-between;margin-bottom:var(--space-2)}.pest-name{color:var(--color-text);font-weight:600;text-transform:capitalize}.confidence-badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;letter-spacing:.25px;padding:4px 8px}.confidence-badge.high{background:#16a34a20;color:#15803d}.confidence-badge.medium{background:#f59e0b20;color:#d97706}.confidence-badge.low{background:#dc262620;color:#b91c1c}.metadata-section{border-top:1px solid var(--color-border);margin-top:var(--space-5);padding-top:var(--space-5)}.metadata-grid{grid-gap:var(--space-3);display:grid;font-size:var(--font-size-sm);gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.metadata-item{color:var(--color-text-light)}.metadata-label{color:var(--color-text);font-weight:600}.error-message{background:#fee2e2;border:1px solid #fecaca;border-radius:var(--radius-md);color:#b91c1c;font-size:var(--font-size-sm);margin:var(--space-5) 0;padding:var(--space-4);text-align:center}.no-detections{color:var(--color-text-light);font-style:italic;padding:var(--space-6);text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #ffffff70;border-radius:50%;border-top-color:#fff;height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:768px){.controls-section{align-items:stretch;flex-direction:column}}
/*# sourceMappingURL=main.88f37e12.css.map*/