@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700&family=JetBrains+Mono:wght@400;500&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(135deg,#f8fafc,#e2e8f0)}.dark .login-container{background:linear-gradient(135deg,#0f172a,#1e293b)}.login-card{width:100%;max-width:28rem;background:#fff;border-radius:.75rem;box-shadow:0 10px 25px #0000001a;border:1px solid #e2e8f0;overflow:hidden}.dark .login-card{background:#1e293b;border-color:#334155;box-shadow:0 10px 25px #0000004d}.login-header{padding:2rem 1.5rem 1.5rem;margin-bottom:1rem}.logo-container{display:flex;justify-content:center;margin-bottom:1rem}.logo-icon{width:4rem;height:4rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2563eb,#3b82f6);border-radius:1rem;color:#fff;box-shadow:0 4px 12px #2563eb4d}.logo-icon svg{width:2rem;height:2rem}.login-title{font-size:1.875rem;font-weight:700;text-align:center;color:#0f172a;margin:0 0 .5rem}.dark .login-title{color:#fff}.login-subtitle{display:flex;align-items:center;justify-content:center;text-align:center;color:#64748b;font-size:.875rem;gap:.75rem}.dark .login-subtitle{color:#94a3b8}.subtitle-line{flex:1;height:1px;background:#cbd5e1;max-width:3rem}.dark .subtitle-line{background:#475569}.login-form{padding:0 1.5rem 1.5rem}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:#334155;margin-bottom:.5rem}.dark .form-label{color:#cbd5e1}.form-input{width:100%;padding:.625rem .875rem;font-size:.9375rem;color:#0f172a;background:#fff;border:1px solid #cbd5e1;border-radius:.5rem;transition:all .2s ease;outline:none}.dark .form-input{color:#fff;background:#0f172a;border-color:#475569}.form-input::placeholder{color:#94a3b8}.dark .form-input::placeholder{color:#64748b}.form-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.dark .form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.input-error{border-color:#ef4444}.dark .input-error{border-color:#f87171}.input-error:focus{box-shadow:0 0 0 3px #ef44441a}.error-message{font-size:.75rem;color:#ef4444;margin-top:.375rem}.dark .error-message{color:#f87171}.password-input-wrapper{position:relative}.password-input-wrapper .form-input{padding-right:2.75rem}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:transparent;border:none;padding:.25rem;cursor:pointer;color:#64748b;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.dark .password-toggle{color:#94a3b8}.password-toggle:hover{color:#2563eb}.dark .password-toggle:hover{color:#3b82f6}.password-toggle svg{width:1.125rem;height:1.125rem}.forgot-password-wrapper{display:flex;justify-content:flex-end;margin-bottom:1.5rem}.forgot-password-link{font-size:.75rem;color:#2563eb;text-decoration:none;transition:color .2s ease}.dark .forgot-password-link{color:#3b82f6}.forgot-password-link:hover{color:#1d4ed8;text-decoration:underline}.dark .forgot-password-link:hover{color:#60a5fa}.submit-button{width:100%;padding:.75rem 1rem;font-size:.9375rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#2563eb,#3b82f6);border:none;border-radius:.5rem;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #2563eb33}.submit-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:640px){.login-card{max-width:100%}.login-header{padding:1.5rem 1rem 1rem}.login-form{padding:0 1rem 1rem}.login-title{font-size:1.5rem}.login-subtitle{font-size:.8125rem}}.projects-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.projects-eyebrow{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#2563eb;font-family:JetBrains Mono,monospace;margin-bottom:4px}.projects-title{font-size:1.6rem;font-weight:700;color:#0f172a;letter-spacing:-.03em;line-height:1.2;margin:0 0 4px;font-family:DM Sans,sans-serif}.projects-subtitle{font-size:.82rem;color:#64748b;margin:0}.projects-stats{display:flex;align-items:center;gap:6px;margin-top:12px;flex-wrap:wrap}.stat-chip{display:inline-flex;align-items:center;gap:5px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:3px 9px;font-size:.7rem;font-family:JetBrains Mono,monospace;color:#64748b;font-weight:500}.stat-chip-active{background:#eff6ff;border-color:#bfdbfe;color:#2563eb}.stat-chip-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;background:#94a3b8}.stat-chip-dot.blue{background:#3b82f6}.stat-chip-dot.gray{background:#94a3b8}.projects-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:20px;flex-wrap:wrap;position:relative}.search-box{position:relative;display:flex;align-items:center;flex:1;min-width:200px;max-width:360px}.search-icon-svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none;flex-shrink:0;z-index:1;display:block}.search-input{width:100%;height:36px;padding:0 32px;border:1px solid #e2e8f0;border-radius:8px;font-size:.82rem;font-family:DM Sans,sans-serif;color:#1e293b;background:#fff;outline:none;transition:border-color .15s,box-shadow .15s;box-shadow:0 1px 3px #0000000a;box-sizing:border-box}.search-input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #3b82f61f}.search-input::placeholder{color:#94a3b8}.search-clear-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:18px;height:18px;border-radius:50%;background:#e2e8f0;border:none;cursor:pointer;color:#64748b;display:flex;align-items:center;justify-content:center;padding:0;margin:0;transition:background .12s,color .12s;flex-shrink:0;z-index:1}.search-clear-btn:hover{background:#cbd5e1;color:#334155}.toolbar-btn-wrap{position:relative}.toolbar-btn{display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 12px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;font-size:.78rem;font-weight:500;font-family:DM Sans,sans-serif;color:#475569;cursor:pointer;transition:all .15s;box-shadow:0 1px 3px #0000000a;white-space:nowrap;margin:0}.toolbar-btn:hover{border-color:#cbd5e1;color:#0f172a;background:#fafafa}.toolbar-btn.active{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.toolbar-badge{display:inline-flex;align-items:center;justify-content:center;background:#2563eb;color:#fff;border-radius:999px;padding:1px 6px;font-size:.6rem;font-weight:700;min-width:16px;line-height:1.4}.toolbar-dropdown{position:absolute;top:calc(100% + 6px);left:0;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 8px 28px #0000001f,0 2px 8px #0000000f;width:216px;z-index:300;overflow:hidden;animation:dropdownIn .16s cubic-bezier(.34,1.56,.64,1)}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.toolbar-dropdown-head{display:flex;align-items:center;justify-content:space-between;padding:11px 14px 8px;border-bottom:1px solid #f1f5f9}.toolbar-dropdown-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#94a3b8;font-family:JetBrains Mono,monospace}.toolbar-dropdown-reset{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:600;color:#ef4444;background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:4px;font-family:DM Sans,sans-serif;transition:background .1s;margin:0}.toolbar-dropdown-reset:hover{background:#fef2f2}.toolbar-dropdown-body{padding:6px 6px 8px;display:flex;flex-direction:column;gap:1px}.toolbar-dropdown-empty{padding:12px 14px;font-size:.75rem;color:#94a3b8;font-family:JetBrains Mono,monospace}.toolbar-dropdown-item{display:flex;align-items:center;gap:9px;padding:8px;border-radius:7px;border:none;background:transparent;font-family:DM Sans,sans-serif;color:#475569;cursor:pointer;text-align:left;width:100%;transition:background .1s,color .1s;margin:0}.toolbar-dropdown-item:hover{background:#f8fafc;color:#0f172a}.toolbar-dropdown-item.checked{background:#eff6ff;color:#1d4ed8}.item-checkbox{width:16px;height:16px;border-radius:4px;border:1.5px solid #e2e8f0;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .12s}.item-checkbox.checked{background:#2563eb;border-color:#2563eb;color:#fff}.item-label{font-size:.82rem;font-weight:500;display:block}.item-label-wrap{display:flex;flex-direction:column}.item-desc{font-size:.67rem;color:#94a3b8;font-family:JetBrains Mono,monospace;margin-top:1px;display:block}.view-toggle{display:flex;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;background:#fff;box-shadow:0 1px 3px #0000000a}.view-toggle-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:#94a3b8;cursor:pointer;transition:all .15s;margin:0;padding:0}.view-toggle-btn.active{background:#2563eb;color:#fff}.view-toggle-btn:hover:not(.active){background:#f1f5f9;color:#475569}.enhanced-project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(288px,1fr));gap:16px}.enhanced-project-list{display:flex;flex-direction:column;gap:8px}.project-list-item{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:13px 16px;display:flex;align-items:center;gap:14px;box-shadow:0 1px 3px #0000000a;transition:all .15s;cursor:pointer}.project-list-item:hover{border-color:#bfdbfe;box-shadow:0 4px 14px #3b82f61a;transform:translate(2px)}.project-list-icon{width:36px!important;height:36px!important;border-radius:9px!important;flex-shrink:0}.project-list-main{flex:1;min-width:0}.project-list-name{font-size:.88rem;font-weight:600;color:#0f172a;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px;font-family:DM Sans,sans-serif}.project-list-desc{font-size:.74rem;color:#94a3b8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:380px}.project-list-cats{display:flex;align-items:center;gap:4px;flex-shrink:0}.project-list-meta{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0;min-width:90px}.project-list-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.project-list-item .project-card-menu{opacity:0}.project-list-item:hover .project-card-menu{opacity:1}.enhanced-project-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 1px 4px #0000000d;transition:all .2s cubic-bezier(.34,1.56,.64,1);cursor:pointer}.enhanced-project-card:hover{box-shadow:0 8px 24px #3b82f61f,0 2px 8px #00000012;transform:translateY(-3px);border-color:#bfdbfe}.project-card-header{display:flex;align-items:flex-start;gap:12px;padding:18px 18px 14px}.project-icon{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:linear-gradient(135deg,#1d4ed8,#3b82f6);box-shadow:0 4px 10px #3b82f64d}.project-icon.icon-emerald{background:linear-gradient(135deg,#065f46,#10b981);box-shadow:0 4px 10px #10b9814d}.project-icon.icon-violet{background:linear-gradient(135deg,#5b21b6,#8b5cf6);box-shadow:0 4px 10px #8b5cf64d}.project-icon.icon-amber{background:linear-gradient(135deg,#b45309,#f59e0b);box-shadow:0 4px 10px #f59e0b4d}.project-card-title{flex:1;min-width:0}.project-card-title h3{margin:0 0 3px;font-size:.95rem;font-weight:600;color:#0f172a;letter-spacing:-.02em;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.35;font-family:DM Sans,sans-serif}.project-card-id{font-family:JetBrains Mono,monospace;font-size:.65rem;color:#94a3b8}.project-card-menu{width:28px;height:28px;border-radius:7px;border:1px solid #e2e8f0;background:transparent;display:flex;align-items:center;justify-content:center;color:#94a3b8;cursor:pointer;opacity:0;transition:all .15s;flex-shrink:0;margin:0;padding:0}.enhanced-project-card:hover .project-card-menu{opacity:1}.project-card-menu:hover{background:#f1f5f9;color:#475569}.project-card-body{padding:0 18px 14px;flex:1;display:flex;flex-direction:column}.project-description{color:#64748b;font-size:.8rem;line-height:1.55;margin:0 0 12px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:38px}.project-categories{display:flex;flex-wrap:wrap;gap:5px;margin-top:auto}.category-badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:6px;font-size:.7rem;font-weight:500;background:#eff6ff;color:#1d4ed8;border:1px solid #dbeafe;font-family:DM Sans,sans-serif}.category-badge.green{background:#ecfdf5;color:#047857;border-color:#a7f3d0}.category-more{background:#f1f5f9;color:#64748b;border-color:#e2e8f0}.project-card-divider{height:1px;background:#f1f5f9;margin:0 18px}.project-card-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 18px}.project-card-devices{display:flex;align-items:center;gap:5px;font-size:.7rem;color:#94a3b8;font-family:JetBrains Mono,monospace}.view-detail-btn{display:inline-flex;align-items:center;gap:5px;font-size:.75rem;font-weight:600;color:#2563eb;text-decoration:none;background:#eff6ff;padding:5px 10px;border-radius:6px;border:1px solid #dbeafe;transition:all .15s;white-space:nowrap;font-family:DM Sans,sans-serif}.view-detail-btn:hover{background:#dbeafe;border-color:#bfdbfe;transform:translate(2px)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:72px 24px;text-align:center}.empty-icon{width:72px;height:72px;border-radius:50%;background:#f1f5f9;border:1.5px dashed #cbd5e1;display:flex;align-items:center;justify-content:center;color:#94a3b8;margin-bottom:20px}.empty-state h3{font-size:1rem;font-weight:600;color:#334155;margin:0 0 6px;font-family:DM Sans,sans-serif}.empty-state p{font-size:.8rem;color:#94a3b8;margin:0 0 20px;max-width:280px;line-height:1.5}.enhanced-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#080c14a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:pmOverlayIn .2s ease}@keyframes pmOverlayIn{0%{opacity:0}to{opacity:1}}.enhanced-modal{background:#fff;border-radius:16px;box-shadow:0 0 0 1px #0000000f,0 24px 64px #0000002e;width:100%;max-width:480px;max-height:90vh;display:flex;flex-direction:column;animation:pmModalIn .25s cubic-bezier(.34,1.56,.64,1);font-family:DM Sans,sans-serif}@keyframes pmModalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid #f0f0f0;background:#fafafa}.modal-header-left{display:flex;align-items:center;gap:12px}.modal-header-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#1d4ed8,#3b82f6);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 10px #3b82f64d;flex-shrink:0}.modal-header h2{font-size:.95rem;font-weight:600;color:#0f172a;margin:0;letter-spacing:-.015em}.modal-header-sub{font-size:.68rem;color:#94a3b8;font-family:JetBrains Mono,monospace;margin-top:2px}.close-btn{width:32px;height:32px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#94a3b8;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0;padding:0;margin:0}.close-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626}.modal-body{padding:22px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;font-family:JetBrains Mono,monospace}.required{color:#ef4444}.form-input{width:100%;padding:9px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:.83rem;font-family:DM Sans,sans-serif;color:#1e293b;background:#fff;outline:none;transition:all .15s;box-shadow:0 1px 2px #0000000a;box-sizing:border-box}.form-input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #3b82f61f}.form-input::placeholder{color:#cbd5e1}.form-textarea{resize:vertical;min-height:80px;line-height:1.5}.checkbox-container{border:1px solid #e2e8f0;border-radius:8px;background:#fafafa;overflow:hidden}.checkbox-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .12s;border-bottom:1px solid #f1f5f9}.checkbox-item:last-child{border-bottom:none}.checkbox-item:hover{background:#fff}.checkbox-input{width:15px;height:15px;border-radius:4px;cursor:pointer;accent-color:#2563eb;flex-shrink:0}.checkbox-label{font-size:.82rem;color:#475569;cursor:pointer}.selected-chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}.selected-chip{display:inline-flex;align-items:center;gap:4px;background:#eff6ff;border:1px solid #dbeafe;color:#1d4ed8;padding:3px 8px;border-radius:6px;font-size:.7rem;font-weight:500}.modal-footer{display:flex;gap:8px;padding:16px 22px;border-top:1px solid #f0f0f0;background:#fafafa}.loading-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;gap:16px}.loading-ring{width:38px;height:38px;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:lspin .75s linear infinite}@keyframes lspin{to{transform:rotate(360deg)}}.loading-text{font-size:.78rem;color:#94a3b8;font-family:JetBrains Mono,monospace}@media(max-width:768px){.projects-header{flex-direction:column}.projects-toolbar{flex-wrap:wrap}.search-box{max-width:100%;flex:1 1 100%}.enhanced-project-grid{grid-template-columns:1fr}.project-list-cats,.project-list-meta{display:none}}.custom-button{font-family:DM Sans,sans-serif;font-weight:500;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;cursor:pointer;border:1px solid transparent;outline:none;position:relative;overflow:hidden;letter-spacing:-.01em;transition:background-color .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease,transform .12s ease,opacity .15s ease}.custom-button:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffff1f;opacity:0;transition:opacity .15s ease;border-radius:inherit;pointer-events:none}.custom-button:active:not(:disabled):after{opacity:1}.custom-button:active:not(:disabled){transform:translateY(1px)}.custom-button:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.custom-button:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none!important}.button-sm{padding:6px 11px;font-size:.75rem;gap:5px;height:30px}.button-md{padding:8px 14px;font-size:.82rem;gap:6px;height:36px}.button-lg{padding:10px 18px;font-size:.875rem;gap:8px;height:42px}.button-fill-primary{background:linear-gradient(135deg,#1d4ed8,#3b82f6);color:#fff;border-color:transparent;box-shadow:0 2px 8px #3b82f647}.button-fill-primary:not(:disabled):hover{background:linear-gradient(135deg,#1e40af,#2563eb);box-shadow:0 4px 14px #3b82f661;transform:translateY(-1px)}.button-fill-secondary{background:linear-gradient(135deg,#5b21b6,#7c3aed);color:#fff;border-color:transparent;box-shadow:0 2px 8px #7c3aed47}.button-fill-secondary:not(:disabled):hover{background:linear-gradient(135deg,#4c1d95,#6d28d9);box-shadow:0 4px 14px #7c3aed61;transform:translateY(-1px)}.button-fill-success{background:linear-gradient(135deg,#065f46,#10b981);color:#fff;border-color:transparent;box-shadow:0 2px 8px #10b98147}.button-fill-success:not(:disabled):hover{background:linear-gradient(135deg,#064e3b,#059669);box-shadow:0 4px 14px #10b98161;transform:translateY(-1px)}.button-fill-warning{background:linear-gradient(135deg,#b45309,#f59e0b);color:#fff;border-color:transparent;box-shadow:0 2px 8px #f59e0b47}.button-fill-warning:not(:disabled):hover{background:linear-gradient(135deg,#92400e,#d97706);box-shadow:0 4px 14px #f59e0b61;transform:translateY(-1px)}.button-fill-danger{background:linear-gradient(135deg,#991b1b,#ef4444);color:#fff;border-color:transparent;box-shadow:0 2px 8px #ef444447}.button-fill-danger:not(:disabled):hover{background:linear-gradient(135deg,#7f1d1d,#dc2626);box-shadow:0 4px 14px #ef444461;transform:translateY(-1px)}.button-fill-info{background:linear-gradient(135deg,#0369a1,#38bdf8);color:#fff;border-color:transparent;box-shadow:0 2px 8px #38bdf847}.button-fill-info:not(:disabled):hover{background:linear-gradient(135deg,#075985,#0ea5e9);box-shadow:0 4px 14px #38bdf861;transform:translateY(-1px)}.button-fill-basic{background:#fff;color:#374151;border-color:#e2e8f0;box-shadow:0 1px 3px #00000012}.button-fill-basic:not(:disabled):hover{background:#f8fafc;border-color:#cbd5e1;color:#0f172a;box-shadow:0 2px 6px #0000001a;transform:translateY(-1px)}.button-outline-primary{background:transparent;color:#1d4ed8;border-color:#bfdbfe}.button-outline-primary:not(:disabled):hover{background:#eff6ff;border-color:#93c5fd;transform:translateY(-1px)}.button-outline-secondary{background:transparent;color:#7c3aed;border-color:#ddd6fe}.button-outline-secondary:not(:disabled):hover{background:#f5f3ff;border-color:#c4b5fd;transform:translateY(-1px)}.button-outline-success{background:transparent;color:#059669;border-color:#a7f3d0}.button-outline-success:not(:disabled):hover{background:#ecfdf5;border-color:#6ee7b7;transform:translateY(-1px)}.button-outline-warning{background:transparent;color:#d97706;border-color:#fde68a}.button-outline-warning:not(:disabled):hover{background:#fffbeb;border-color:#fcd34d;transform:translateY(-1px)}.button-outline-danger{background:transparent;color:#dc2626;border-color:#fecaca}.button-outline-danger:not(:disabled):hover{background:#fef2f2;border-color:#fca5a5;transform:translateY(-1px)}.button-outline-info{background:transparent;color:#0284c7;border-color:#bae6fd}.button-outline-info:not(:disabled):hover{background:#f0f9ff;border-color:#7dd3fc;transform:translateY(-1px)}.button-outline-basic{background:transparent;color:#475569;border-color:#e2e8f0}.button-outline-basic:not(:disabled):hover{background:#f8fafc;border-color:#94a3b8;color:#0f172a;transform:translateY(-1px)}.button-tonal-primary{background:#dbeafe;color:#1d4ed8;border-color:transparent}.button-tonal-primary:not(:disabled):hover{background:#bfdbfe;transform:translateY(-1px)}.button-tonal-secondary{background:#ede9fe;color:#6d28d9;border-color:transparent}.button-tonal-secondary:not(:disabled):hover{background:#ddd6fe;transform:translateY(-1px)}.button-tonal-success{background:#d1fae5;color:#047857;border-color:transparent}.button-tonal-success:not(:disabled):hover{background:#a7f3d0;transform:translateY(-1px)}.button-tonal-warning{background:#fef3c7;color:#b45309;border-color:transparent}.button-tonal-warning:not(:disabled):hover{background:#fde68a;transform:translateY(-1px)}.button-tonal-danger{background:#fee2e2;color:#dc2626;border-color:transparent}.button-tonal-danger:not(:disabled):hover{background:#fecaca;transform:translateY(-1px)}.button-tonal-info{background:#e0f2fe;color:#0369a1;border-color:transparent}.button-tonal-info:not(:disabled):hover{background:#bae6fd;transform:translateY(-1px)}.button-tonal-basic{background:#f1f5f9;color:#334155;border-color:transparent}.button-tonal-basic:not(:disabled):hover{background:#e2e8f0;color:#0f172a;transform:translateY(-1px)}.button-clear-primary{background:transparent;color:#2563eb;border-color:transparent}.button-clear-primary:not(:disabled):hover{background:#eff6ff;color:#1d4ed8}.button-clear-secondary{background:transparent;color:#7c3aed;border-color:transparent}.button-clear-secondary:not(:disabled):hover{background:#f5f3ff;color:#6d28d9}.button-clear-success{background:transparent;color:#10b981;border-color:transparent}.button-clear-success:not(:disabled):hover{background:#ecfdf5;color:#059669}.button-clear-warning{background:transparent;color:#f59e0b;border-color:transparent}.button-clear-warning:not(:disabled):hover{background:#fffbeb;color:#d97706}.button-clear-danger{background:transparent;color:#ef4444;border-color:transparent}.button-clear-danger:not(:disabled):hover{background:#fef2f2;color:#dc2626}.button-clear-info{background:transparent;color:#38bdf8;border-color:transparent}.button-clear-info:not(:disabled):hover{background:#f0f9ff;color:#0284c7}.button-clear-basic{background:transparent;color:#64748b;border-color:transparent}.button-clear-basic:not(:disabled):hover{background:#f1f5f9;color:#0f172a}.pd-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.pd-eyebrow{display:flex;align-items:center;gap:6px;margin-bottom:6px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#94a3b8;font-family:JetBrains Mono,monospace}.pd-eyebrow a{color:#3b82f6;text-decoration:none;transition:color .15s}.pd-eyebrow a:hover{color:#1d4ed8}.pd-title{font-size:1.5rem;font-weight:700;color:#0f172a;letter-spacing:-.03em;margin:0 0 4px}.pd-subtitle{font-size:.82rem;color:#64748b;margin:0;line-height:1.5;max-width:520px}.pd-header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-top:4px}.devices-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.device-stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px;box-shadow:0 1px 3px #0000000a;transition:box-shadow .15s,transform .15s}.device-stat-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.device-stat-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.device-stat-icon.primary{background:linear-gradient(135deg,#1d4ed8,#3b82f6);box-shadow:0 4px 10px #3b82f64d}.device-stat-icon.success{background:linear-gradient(135deg,#065f46,#10b981);box-shadow:0 4px 10px #10b9814d}.device-stat-icon.warning{background:linear-gradient(135deg,#b45309,#f59e0b);box-shadow:0 4px 10px #f59e0b4d}.device-stat-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;margin-bottom:2px}.device-stat-value{font-size:1.5rem;font-weight:700;color:#0f172a;letter-spacing:-.03em;font-family:JetBrains Mono,monospace;line-height:1.2;margin:0}.pd-tabs{display:flex;gap:2px;margin-bottom:24px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:4px;box-shadow:0 1px 3px #0000000a;width:fit-content}.pd-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:7px;border:none;font-size:.82rem;font-weight:500;font-family:DM Sans,sans-serif;cursor:pointer;transition:all .15s;color:#64748b;background:transparent;white-space:nowrap}.pd-tab:hover:not(.active){color:#1e293b;background:#f1f5f9}.pd-tab.active{background:#0f172a;color:#fff;box-shadow:0 2px 6px #00000026}.tab-count{border-radius:999px;padding:1px 7px;font-size:.65rem;font-weight:700;background:#fff3}.pd-tab:not(.active) .tab-count{background:#f1f5f9;color:#64748b}.pd-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 1px 4px #0000000d;overflow:hidden;margin-bottom:16px}.pd-card-head{display:flex;align-items:center;gap:10px;padding:14px 20px;border-bottom:1px solid #f1f5f9;background:#fafafa}.pd-card-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pd-card-icon.blue{background:linear-gradient(135deg,#1d4ed8,#3b82f6);box-shadow:0 3px 8px #3b82f64d}.pd-card-icon.green{background:linear-gradient(135deg,#065f46,#10b981);box-shadow:0 3px 8px #10b9814d}.pd-card-icon.amber{background:linear-gradient(135deg,#b45309,#f59e0b);box-shadow:0 3px 8px #f59e0b4d}.pd-card-icon.slate{background:linear-gradient(135deg,#334155,#64748b);box-shadow:0 3px 8px #47556940}.pd-card-icon.red{background:linear-gradient(135deg,#991b1b,#ef4444);box-shadow:0 3px 8px #ef44444d}.pd-card-icon.violet{background:linear-gradient(135deg,#5b21b6,#8b5cf6);box-shadow:0 3px 8px #8b5cf64d}.pd-card-title{font-size:.9rem;font-weight:600;color:#1e293b;letter-spacing:-.01em}.pd-card-sub{font-size:.7rem;color:#94a3b8;font-family:JetBrains Mono,monospace;margin-top:1px}.pd-card-body{padding:20px}.overview-section{display:flex;flex-direction:column;gap:16px}.overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.overview-desc{font-size:.83rem;color:#64748b;line-height:1.6;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid #f1f5f9}.cat-items{display:flex;flex-direction:column;gap:7px}.cat-item{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;background:#f8fafc;border:1px solid #f1f5f9;border-radius:8px;transition:border-color .15s}.cat-item:hover{border-color:#e2e8f0}.cat-item-left{display:flex;align-items:center;gap:8px}.cat-item-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.cat-item-name{font-size:.82rem;font-weight:500;color:#334155}.yolo-class-badge{font-size:.65rem;font-weight:600;font-family:JetBrains Mono,monospace;background:#eff6ff;color:#1d4ed8;border:1px solid #dbeafe;padding:2px 7px;border-radius:4px}.device-items{display:flex;flex-direction:column;gap:8px}.device-item{display:flex;align-items:center;justify-content:space-between;padding:11px 12px;background:#f8fafc;border:1px solid #f1f5f9;border-radius:8px;gap:10px;transition:border-color .15s}.device-item:hover{border-color:#e2e8f0}.device-item-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.device-item-icon{width:34px;height:34px;border-radius:8px;background:linear-gradient(135deg,#334155,#64748b);display:flex;align-items:center;justify-content:center;flex-shrink:0}.device-item-name{font-size:.82rem;font-weight:600;color:#1e293b}.device-url{font-size:.7rem;color:#94a3b8;font-family:JetBrains Mono,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px;margin-top:1px}.status-indicator{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;margin-bottom:16px;font-size:.82rem;font-weight:500;font-family:DM Sans,sans-serif}.status-indicator.running{background:#f0fdf4;color:#15803d;border:1px solid #dcfce7}.status-indicator.paused{background:#fffbeb;color:#b45309;border:1px solid #fef3c7}.status-indicator.stopped{background:#f1f5f9;color:#64748b;border:1px solid #e2e8f0}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.running{background:#22c55e;box-shadow:0 0 0 3px #22c55e33;animation:pd-pulse 1.5s ease-in-out infinite}.status-dot.paused{background:#f59e0b}.status-dot.stopped{background:#94a3b8}@keyframes pd-pulse{0%,to{opacity:1}50%{opacity:.5}}.control-buttons{display:flex;gap:8px;flex-wrap:wrap}.log-container{background:#0f172a;border-radius:10px;overflow:hidden;border:1px solid #1e293b}.log-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#1e293b;border-bottom:1px solid #334155}.log-header-left{display:flex;align-items:center;gap:8px;font-size:.75rem;font-weight:600;color:#94a3b8;font-family:JetBrains Mono,monospace}.log-live-dot{display:flex;align-items:center;gap:6px;font-size:.65rem;color:#64748b;font-family:JetBrains Mono,monospace}.log-live-dot-circle{width:6px;height:6px;border-radius:50%;background:#22c55e;animation:pd-pulse 1.5s infinite}.log-scroll{padding:12px 14px;max-height:260px;overflow-y:auto;display:flex;flex-direction:column;gap:3px}.log-scroll::-webkit-scrollbar{width:4px}.log-scroll::-webkit-scrollbar-track{background:transparent}.log-scroll::-webkit-scrollbar-thumb{background:#334155;border-radius:2px}.log-line{display:flex;align-items:baseline;gap:7px;font-size:.73rem;font-family:JetBrains Mono,monospace;line-height:1.6}.log-timestamp{color:#475569;flex-shrink:0}.log-badge{font-size:.58rem;font-weight:700;padding:1px 5px;border-radius:3px;letter-spacing:.04em;flex-shrink:0}.log-badge.system{background:#1d4ed8;color:#fff}.log-badge.success{background:#15803d;color:#fff}.log-badge.error{background:#b91c1c;color:#fff}.log-badge.warning{background:#b45309;color:#fff}.log-badge.info{background:#334155;color:#94a3b8}.log-text{flex:1}.log-system{color:#93c5fd}.log-success{color:#4ade80}.log-error{color:#f87171}.log-warning{color:#fbbf24}.log-info{color:#64748b}.log-empty{color:#475569;font-size:.73rem;font-family:JetBrains Mono,monospace;padding:24px 0;text-align:center}.detections-section{display:flex;flex-direction:column;gap:20px}.pd-table-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden;box-shadow:0 1px 4px #0000000d}.pd-table-head{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid #f1f5f9;background:#fafafa}.pd-table-title{display:flex;align-items:center;gap:8px;font-size:.88rem;font-weight:600;color:#1e293b}.pd-table-sub{font-size:.7rem;color:#94a3b8;font-family:JetBrains Mono,monospace;margin-top:2px}.pd-table-wrap{overflow-x:auto}.pd-table{width:100%;border-collapse:collapse}.pd-table thead th{padding:10px 16px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8;background:#fafafa;border-bottom:1px solid #f1f5f9;text-align:left;white-space:nowrap}.pd-table tbody tr{border-bottom:1px solid #f8fafc;transition:background .1s}.pd-table tbody tr:last-child{border-bottom:none}.pd-table tbody tr:hover{background:#fafafa}.pd-table tbody td{padding:12px 16px;font-size:.82rem;color:#475569;vertical-align:middle}.td-mono{font-family:JetBrains Mono,monospace;font-size:.73rem;color:#64748b}.vehicle-counts{display:flex;flex-wrap:wrap;gap:5px}.vehicle-count-item{display:flex;align-items:center;gap:3px;background:#f1f5f9;border-radius:5px;padding:2px 7px;font-family:JetBrains Mono,monospace}.vehicle-count-label{font-size:.68rem;color:#94a3b8}.vehicle-count-value{font-size:.72rem;font-weight:700;color:#1e293b}.density-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:6px;font-size:.72rem;font-weight:600;white-space:nowrap}.density-high{background:#fef2f2;color:#dc2626;border:1px solid #fee2e2}.density-medium{background:#fffbeb;color:#b45309;border:1px solid #fef3c7}.density-low{background:#f0fdf4;color:#15803d;border:1px solid #dcfce7}.density-none{background:#f1f5f9;color:#64748b;border:1px solid #e2e8f0}.event-kind-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:6px;font-size:.72rem;font-weight:600}.event-kind-danger{background:#fef2f2;color:#dc2626;border:1px solid #fee2e2}.event-kind-warning{background:#fffbeb;color:#b45309;border:1px solid #fef3c7}.event-kind-info{background:#eff6ff;color:#1d4ed8;border:1px solid #dbeafe}.confidence-high{font-family:JetBrains Mono,monospace;font-size:.75rem;font-weight:600;color:#dc2626}.confidence-medium{font-family:JetBrains Mono,monospace;font-size:.75rem;font-weight:600;color:#b45309}.confidence-low{font-family:JetBrains Mono,monospace;font-size:.75rem;font-weight:600;color:#15803d}.view-detail-btn-table{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:6px;font-size:.75rem;font-weight:600;font-family:DM Sans,sans-serif;background:#eff6ff;color:#2563eb;border:1px solid #dbeafe;cursor:pointer;transition:all .15s}.view-detail-btn-table:hover{background:#dbeafe;border-color:#bfdbfe}.load-more-indicator{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;font-size:.78rem;color:#94a3b8;font-family:JetBrains Mono,monospace}.load-more-ring{width:16px;height:16px;border:2px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:pd-spin .7s linear infinite}@keyframes pd-spin{to{transform:rotate(360deg)}}.no-more-text{text-align:center;padding:14px;font-size:.73rem;color:#cbd5e1;font-family:JetBrains Mono,monospace}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#080c14a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:999;padding:16px;animation:pd-fade .2s ease}@keyframes pd-fade{0%{opacity:0}to{opacity:1}}.modal-card{background:#fff;border-radius:14px;box-shadow:0 0 0 1px #0000000f,0 24px 64px #0000002e;width:100%;max-width:400px;padding:28px;animation:pd-card-in .2s cubic-bezier(.34,1.56,.64,1);font-family:DM Sans,sans-serif}@keyframes pd-card-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-card h3{font-size:1rem;font-weight:700;color:#0f172a;letter-spacing:-.02em;margin-bottom:10px}.modal-card p{font-size:.83rem;color:#64748b;line-height:1.55;margin-bottom:20px}.modal-card strong{color:#0f172a;font-weight:600}.modal-actions{display:flex;justify-content:flex-end;gap:8px}@media(max-width:900px){.overview-grid,.devices-stats{grid-template-columns:1fr}}@media(max-width:640px){.pd-header,.control-buttons{flex-direction:column}}.roi-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#080c14bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:16px;animation:roiOverlayIn .2s ease}@keyframes roiOverlayIn{0%{opacity:0}to{opacity:1}}.roi-modal{background:#fff;border-radius:16px;box-shadow:0 0 0 1px #0000000f,0 24px 64px #0000002e,0 8px 24px #0000001a;width:100%;max-width:1080px;max-height:92vh;display:flex;flex-direction:column;overflow:hidden;font-family:DM Sans,sans-serif;animation:roiModalIn .25s cubic-bezier(.34,1.56,.64,1)}@keyframes roiModalIn{0%{opacity:0;transform:scale(.95) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.roi-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid #f0f0f0;background:#fafafa}.roi-header-left{display:flex;align-items:center;gap:12px}.roi-header-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#1d4ed8,#3b82f6);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 4px 12px #3b82f659}.roi-title{font-size:1rem;font-weight:600;color:#0f172a;margin:0;line-height:1.3;letter-spacing:-.01em}.roi-subtitle{font-size:.78rem;color:#64748b;margin:1px 0 0;font-family:JetBrains Mono,monospace}.roi-close-btn{width:34px;height:34px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;flex-shrink:0}.roi-close-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626}.roi-phase-bar{display:flex;align-items:center;gap:6px;padding:10px 24px;background:#f8fafc;border-bottom:1px solid #f0f0f0}.roi-phase-step{display:flex;align-items:center;gap:6px;font-size:.78rem;color:#94a3b8;font-weight:500;transition:color .2s}.roi-phase-step.active{color:#1d4ed8}.roi-phase-step.done{color:#16a34a}.roi-phase-dot{width:22px;height:22px;border-radius:50%;background:#e2e8f0;color:#94a3b8;font-size:.7rem;font-weight:600;display:flex;align-items:center;justify-content:center;transition:all .2s}.roi-phase-step.active .roi-phase-dot{background:#1d4ed8;color:#fff;box-shadow:0 0 0 3px #1d4ed826}.roi-phase-step.done .roi-phase-dot{background:#16a34a;color:#fff}.roi-phase-arrow{color:#cbd5e1;flex-shrink:0}.roi-body{display:flex;flex:1;overflow:hidden;min-height:0}.roi-sidebar{width:220px;flex-shrink:0;border-right:1px solid #f0f0f0;display:flex;flex-direction:column;gap:0;overflow-y:auto;background:#fafafa}.roi-sidebar-section{padding:16px;border-bottom:1px solid #f0f0f0}.roi-list-section{flex:1;display:flex;flex-direction:column}.roi-label{display:flex;align-items:center;gap:6px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8;margin-bottom:8px}.roi-count-badge{background:#dbeafe;color:#1d4ed8;font-size:.65rem;font-weight:700;border-radius:999px;padding:1px 6px;text-transform:none;letter-spacing:0}.roi-select{width:100%;padding:8px 28px 8px 10px;border:1px solid #e2e8f0;border-radius:8px;font-size:.82rem;color:#1e293b;background:#fff;outline:none;font-family:DM Sans,sans-serif;transition:border-color .15s,box-shadow .15s;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.roi-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61f}.roi-list{display:flex;flex-direction:column;gap:4px;flex:1;margin-bottom:10px;min-height:60px}.roi-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:20px 0;color:#cbd5e1;font-size:.78rem;text-align:center}.roi-list-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:.82rem;font-weight:500;color:#475569;transition:all .15s;border:1px solid transparent;background:transparent}.roi-list-item:hover{background:#f1f5f9;color:#0f172a}.roi-list-item--active{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.roi-list-item-indicator{width:6px;height:6px;border-radius:50%;background:#cbd5e1;flex-shrink:0;transition:background .15s}.roi-list-item--active .roi-list-item-indicator{background:#3b82f6}.roi-list-item-badge{margin-left:auto;font-size:.65rem;font-weight:700;background:#dbeafe;color:#1d4ed8;padding:2px 6px;border-radius:999px}.roi-add-btn{display:flex;align-items:center;gap:6px;width:100%;padding:8px 10px;border-radius:8px;border:1px dashed #cbd5e1;background:transparent;color:#64748b;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s;font-family:DM Sans,sans-serif;justify-content:center}.roi-add-btn:hover{border-color:#3b82f6;color:#1d4ed8;background:#eff6ff}.roi-hint-box{padding:14px 16px;background:#f0f9ff;border-top:1px solid #bae6fd}.roi-hint-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#0284c7;margin-bottom:4px}.roi-hint-text{font-size:.78rem;color:#0369a1;line-height:1.5}.roi-canvas-area{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#0f172a;position:relative}.roi-canvas-wrapper{flex:1;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.roi-canvas-wrapper canvas{max-width:100%;max-height:100%;width:auto;height:auto;display:block}.roi-canvas-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#080c14b3;color:#f1f5f9;font-size:.85rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.roi-canvas-overlay--error{color:#fca5a5}.roi-canvas-overlay--error p{margin:0;font-size:.85rem}.roi-retry-btn{padding:7px 16px;background:#ef4444;color:#fff;border:none;border-radius:7px;font-size:.8rem;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif;transition:background .15s}.roi-retry-btn:hover{background:#dc2626}.roi-spinner{width:28px;height:28px;border:3px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:roiSpin .8s linear infinite}.roi-spinner--sm{width:14px;height:14px;border-width:2px;border-color:#ffffff4d;border-top-color:#fff}@keyframes roiSpin{to{transform:rotate(360deg)}}.roi-footer{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-top:1px solid #f0f0f0;background:#fafafa;gap:10px;flex-wrap:wrap}.roi-footer-left,.roi-footer-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.roi-footer-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;font-size:.82rem;font-weight:500;font-family:DM Sans,sans-serif;cursor:pointer;transition:all .15s ease;border:1px solid transparent;white-space:nowrap}.roi-footer-btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.roi-footer-btn--ghost{background:transparent;color:#64748b;border-color:transparent}.roi-footer-btn--ghost:hover{background:#f1f5f9;color:#0f172a}.roi-footer-btn--secondary{background:#fff;color:#475569;border-color:#e2e8f0}.roi-footer-btn--secondary:hover{background:#f8fafc;border-color:#cbd5e1;color:#0f172a}.roi-footer-btn--outline{background:#fff;color:#1d4ed8;border-color:#bfdbfe}.roi-footer-btn--outline:hover{background:#eff6ff;border-color:#93c5fd}.roi-footer-btn--primary{background:linear-gradient(135deg,#1d4ed8,#3b82f6);color:#fff;border:none;box-shadow:0 4px 12px #3b82f64d}.roi-footer-btn--primary:hover:not(:disabled){background:linear-gradient(135deg,#1e40af,#2563eb);box-shadow:0 6px 16px #3b82f666;transform:translateY(-1px)}.roi-footer-btn--primary:active:not(:disabled){transform:translateY(0)}@media(max-width:700px){.roi-modal{max-height:100vh;border-radius:12px 12px 0 0;align-self:flex-end}.roi-body{flex-direction:column}.roi-sidebar{width:100%;border-right:none;border-bottom:1px solid #f0f0f0;max-height:220px}.roi-phase-bar{font-size:.72rem}}.categories-header{margin-bottom:2rem}.categories-title-section h1{font-size:2rem;font-weight:700;color:#111827;margin:0 0 .25rem}.categories-subtitle{color:#6b7280;font-size:.875rem;margin:0}.categories-form-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #00000014;border:1px solid #e5e7eb;margin-bottom:1.5rem}.categories-form-card h2{font-size:1.25rem;font-weight:600;color:#111827;margin:0 0 1rem;display:flex;align-items:center;gap:8px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{font-weight:500;color:#374151;font-size:.9rem}.form-field input{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.9rem;outline:none;transition:all .2s}.form-field input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-field input::placeholder{color:#9ca3af}.form-actions{display:flex;gap:.75rem;justify-content:flex-end}.btn-add{background-color:#2563eb;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:8px;font-size:.9rem;transition:all .2s}.btn-add:hover{background-color:#1d4ed8}.btn-add:disabled{opacity:.5;cursor:not-allowed}.btn-reset{background-color:#f3f4f6;color:#374151;border:none;padding:10px 20px;border-radius:8px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:8px;font-size:.9rem;transition:all .2s}.btn-reset:hover{background-color:#e5e7eb}.categories-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 1px 3px #00000014;border:1px solid #e5e7eb;display:flex;align-items:center;gap:1rem}.stat-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.primary{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.stat-icon.success{background:linear-gradient(135deg,#10b981,#059669)}.stat-content{flex:1}.stat-label{font-size:.875rem;color:#6b7280;margin:0 0 4px}.stat-value{font-size:1.75rem;font-weight:700;color:#111827;margin:0}.categories-table-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;border:1px solid #e5e7eb;overflow:hidden}.table-header{padding:1.25rem 1.5rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.table-header h2{font-size:1.25rem;font-weight:600;color:#111827;margin:0;display:flex;align-items:center;gap:8px}.action-buttons{display:flex;gap:8px;align-items:center}.btn-icon{padding:8px;background:transparent;border:none;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s;color:#6b7280}.btn-icon:hover{background:#f3f4f6;color:#374151}.btn-delete{color:#ef4444;padding:6px 12px;background:#fef2f2;border:none;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;font-size:.875rem;font-weight:500;transition:all .2s}.btn-delete:hover{background:#fee2e2;color:#dc2626}.yolo-badge{background:#eff6ff;color:#1e40af;padding:4px 10px;border-radius:6px;font-size:.8rem;font-weight:500;font-family:monospace}.empty-yolo{color:#9ca3af;font-style:italic}@media(max-width:768px){.form-grid,.categories-stats{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%;justify-content:center}.table-header{flex-direction:column;align-items:flex-start;gap:1rem}}.devices-header{margin-bottom:2rem}.devices-title-section h1{font-size:2rem;font-weight:700;color:#111827;margin:0 0 .25rem}.devices-subtitle{color:#6b7280;font-size:.875rem;margin:0}.devices-header-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.devices-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.device-stat-card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 1px 3px #00000014;border:1px solid #e5e7eb;display:flex;align-items:center;gap:1rem}.device-stat-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.device-stat-icon.primary{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.device-stat-icon.success{background:linear-gradient(135deg,#10b981,#059669)}.device-stat-icon.warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.device-stat-content{flex:1}.device-stat-label{font-size:.875rem;color:#6b7280;margin:0 0 4px}.device-stat-value{font-size:1.75rem;font-weight:700;color:#111827;margin:0}.device-modal-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-field-full{grid-column:1 / -1}.device-status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-size:.8rem;font-weight:500}.device-status-badge.online{background:#d1fae5;color:#065f46}.device-status-badge.offline{background:#fee2e2;color:#991b1b}.device-status-badge.unassigned{background:#fef3c7;color:#92400e}.status-dot-indicator{width:6px;height:6px;border-radius:50%;background:currentColor}.location-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:#eff6ff;color:#1e40af;border-radius:6px;font-size:.75rem;font-weight:500}.location-none{color:#9ca3af;font-style:italic;font-size:.875rem}.inline-project-select{padding:6px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;outline:none;transition:all .2s;background:#fff;cursor:pointer}.inline-project-select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.inline-project-select option{padding:8px}.table-wrapper{width:100%;overflow-x:auto}.table-wrapper table{min-width:1200px}.ip-column{max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-column{max-width:200px}.inline-project-select{max-width:180px}@media(max-width:768px){.devices-stats,.form-row{grid-template-columns:1fr}.devices-header-actions{flex-direction:column;align-items:stretch}}.models-header{margin-bottom:2rem}.models-title-section h1{font-size:2rem;font-weight:700;color:#111827;margin:0 0 .25rem}.models-subtitle{color:#6b7280;font-size:.875rem;margin:0}.models-header-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.models-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.model-stat-card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 1px 3px #00000014;border:1px solid #e5e7eb;display:flex;align-items:center;gap:1rem}.model-stat-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.model-stat-icon.primary{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.model-stat-icon.success{background:linear-gradient(135deg,#10b981,#059669)}.model-stat-icon.info{background:linear-gradient(135deg,#3b82f6,#2563eb)}.model-stat-content{flex:1}.model-stat-label{font-size:.875rem;color:#6b7280;margin:0 0 4px}.model-stat-value{font-size:1.75rem;font-weight:700;color:#111827;margin:0}.model-status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-size:.8rem;font-weight:600}.model-status-badge.active{background:#d1fae5;color:#065f46}.model-status-badge.inactive{background:#f3f4f6;color:#6b7280}.status-dot-badge{width:6px;height:6px;border-radius:50%;background:currentColor}.framework-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#eff6ff;color:#1e40af;border-radius:6px;font-size:.75rem;font-weight:600;font-family:monospace}.classes-list{display:flex;flex-wrap:wrap;gap:4px}.class-badge{padding:2px 8px;background:#f3f4f6;color:#374151;border-radius:4px;font-size:.75rem;font-weight:500}.file-size{font-family:monospace;font-size:.875rem;color:#6b7280}.upload-progress{margin-top:1rem;padding:1rem;background:#eff6ff;border-radius:8px;border:1px solid #dbeafe}.progress-bar-container{width:100%;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-top:8px}.progress-bar{height:100%;background:linear-gradient(90deg,#2563eb,#3b82f6);transition:width .3s ease}.upload-text{font-size:.875rem;color:#1e40af;font-weight:500;display:flex;align-items:center;gap:8px}.file-input-wrapper{position:relative;display:inline-block;width:100%}.file-input{width:100%;padding:10px 12px;border:2px dashed #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s;background:#f9fafb}.file-input:hover{border-color:#2563eb;background:#eff6ff}.file-input-label{display:flex;align-items:center;gap:8px;color:#6b7280;font-size:.875rem}.file-selected{color:#2563eb;font-weight:500}.model-info-section{background:#f9fafb;border-radius:10px;padding:1rem;margin-bottom:1rem}.model-info-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #e5e7eb}.model-info-item:last-child{border-bottom:none}.model-info-label{font-weight:500;color:#6b7280;font-size:.875rem}.model-info-value{font-weight:600;color:#111827;font-size:.875rem}.training-coming-soon{text-align:center;padding:4rem 2rem}.training-icon-circle{width:80px;height:80px;background:#eff6ff;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}.training-quick-stats{display:flex;gap:2rem;justify-content:center;margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb}.training-stat-item{text-align:center}.training-stat-label{fontSize:.875rem;color:#6b7280;margin-bottom:4px}.training-stat-value{fontSize:1.25rem;font-weight:700;color:#111827}@media(max-width:768px){.models-stats{grid-template-columns:1fr}.models-header-actions{flex-direction:column;align-items:stretch}.classes-list{max-width:200px}.training-quick-stats{flex-direction:column;gap:1rem}}.navbar-container{background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:40;box-shadow:0 1px 3px #0000001a}.navbar-content{max-width:100%;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.navbar-brand{display:flex;align-items:center;gap:12px}.navbar-logo{width:32px;height:32px;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.navbar-title{font-size:1.25rem;font-weight:700;color:#111827;margin:0;white-space:nowrap}.navbar-actions{display:flex;align-items:center;gap:12px}.navbar-user-info{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.navbar-user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#2563eb);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem;flex-shrink:0}.navbar-user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 25px #0000001f;z-index:50;display:flex;flex-direction:column}.navbar-user-dropdown button{padding:10px 14px;background:none;border:none;text-align:left;cursor:pointer;font-size:.875rem}.navbar-user-dropdown button:hover{background:#f9fafb}.navbar-user-dropdown .danger{color:#dc2626}.navbar-user-name{font-size:.875rem;font-weight:500;color:#374151;display:none}.navbar-user-wrapper{position:relative;cursor:pointer}.navbar-time{font-size:.875rem;color:#6b7280;font-weight:500;padding:6px 12px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb;display:flex;align-items:center;gap:6px}.navbar-icon-button{width:40px;height:40px;border-radius:8px;background:transparent;border:1px solid #e5e7eb;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#6b7280}.navbar-icon-button:hover{background:#f9fafb;border-color:#d1d5db;color:#374151}.navbar-notification-badge{position:relative}.navbar-notification-badge:after{content:"";position:absolute;top:8px;right:8px;width:8px;height:8px;background:#ef4444;border-radius:50%;border:2px solid white}.logout-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:9999;display:flex;align-items:center;justify-content:center}.logout-modal{background:#1f2937;color:#f9fafb;padding:24px;border-radius:12px;width:360px;max-width:calc(100% - 32px);box-shadow:0 20px 40px #0006}.logout-modal h3{margin:0 0 8px;font-size:1.125rem;font-weight:600}.logout-modal p{font-size:.875rem;color:#d1d5db;margin-bottom:20px}.logout-modal .actions{display:flex;justify-content:flex-end;gap:10px}.logout-modal .actions button{padding:8px 14px;border-radius:8px;border:none;cursor:pointer;font-weight:500}.logout-modal .actions .danger{background:#dc2626;color:#fff}.dark .navbar-container{background:#1f2937;border-bottom-color:#374151}.dark .navbar-title{color:#f9fafb}.dark .navbar-user-info{background:#374151;border-color:#4b5563}.dark .navbar-user-name{color:#e5e7eb}.dark .navbar-time{background:#374151;border-color:#4b5563;color:#9ca3af}.dark .navbar-icon-button{border-color:#4b5563;color:#9ca3af}.dark .navbar-icon-button:hover{background:#374151;border-color:#6b7280;color:#e5e7eb}@media(min-width:640px){.navbar-user-name{display:block}}@media(max-width:640px){.navbar-content{padding:1rem}.navbar-title{font-size:1.125rem}.navbar-time{display:none}}.sidebar-container{width:280px;background-color:#1f2937;color:#fff;display:flex;flex-direction:column;height:100vh;position:sticky;top:0;overflow-y:auto;border-right:1px solid #374151}.sidebar-header{padding:1.5rem;border-bottom:1px solid #374151}.sidebar-brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff}.sidebar-logo{width:40px;height:40px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-brand-text{display:flex;flex-direction:column;gap:2px}.sidebar-title{font-size:1.25rem;font-weight:700;margin:0;line-height:1.2}.sidebar-subtitle{font-size:.75rem;color:#9ca3af;font-weight:400;margin:0}.sidebar-nav{flex:1;padding:1rem}.sidebar-nav-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.sidebar-nav-item{position:relative}.sidebar-nav-link{display:flex;align-items:center;gap:12px;padding:12px 16px;color:#d1d5db;text-decoration:none;border-radius:8px;transition:all .2s;font-weight:500;font-size:.9375rem;position:relative}.sidebar-nav-link:hover{background-color:#374151;color:#fff}.sidebar-nav-link.active{background-color:#3b82f6;color:#fff;box-shadow:0 2px 8px #3b82f64d}.sidebar-nav-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:60%;background:#fff;border-radius:0 4px 4px 0}.sidebar-nav-icon{flex-shrink:0;color:inherit}.sidebar-nav-text{flex:1}.sidebar-footer{padding:1rem;border-top:1px solid #374151}.sidebar-footer-link{display:flex;align-items:center;gap:12px;padding:12px 16px;color:#9ca3af;text-decoration:none;border-radius:8px;transition:all .2s;font-weight:500;font-size:.875rem}.sidebar-footer-link:hover{background-color:#374151;color:#fff}.sidebar-version{padding:1rem;text-align:center;font-size:.75rem;color:#6b7280}.sidebar-container::-webkit-scrollbar{width:6px}.sidebar-container::-webkit-scrollbar-track{background:#1f2937}.sidebar-container::-webkit-scrollbar-thumb{background:#4b5563;border-radius:3px}.sidebar-container::-webkit-scrollbar-thumb:hover{background:#6b7280}@media(max-width:768px){.sidebar-container{position:fixed;left:-280px;top:0;z-index:50;transition:left .3s}.sidebar-container.open{left:0}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:40;display:none}.sidebar-overlay.open{display:block}}.sidebar-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:#ef4444;color:#fff;border-radius:10px;font-size:.75rem;font-weight:600;margin-left:auto}.sidebar-nav-link.active .sidebar-badge{background:#ffffff4d}@layer theme,base,components,utilities;@layer theme{@theme default{ --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; --font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif; --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; --color-red-50: oklch(97.1% .013 17.38); --color-red-100: oklch(93.6% .032 17.717); --color-red-200: oklch(88.5% .062 18.334); --color-red-300: oklch(80.8% .114 19.571); --color-red-400: oklch(70.4% .191 22.216); --color-red-500: oklch(63.7% .237 25.331); --color-red-600: oklch(57.7% .245 27.325); --color-red-700: oklch(50.5% .213 27.518); --color-red-800: oklch(44.4% .177 26.899); --color-red-900: oklch(39.6% .141 25.723); --color-red-950: oklch(25.8% .092 26.042); --color-orange-50: oklch(98% .016 73.684); --color-orange-100: oklch(95.4% .038 75.164); --color-orange-200: oklch(90.1% .076 70.697); --color-orange-300: oklch(83.7% .128 66.29); --color-orange-400: oklch(75% .183 55.934); --color-orange-500: oklch(70.5% .213 47.604); --color-orange-600: oklch(64.6% .222 41.116); --color-orange-700: oklch(55.3% .195 38.402); --color-orange-800: oklch(47% .157 37.304); --color-orange-900: oklch(40.8% .123 38.172); --color-orange-950: oklch(26.6% .079 36.259); --color-amber-50: oklch(98.7% .022 95.277); --color-amber-100: oklch(96.2% .059 95.617); --color-amber-200: oklch(92.4% .12 95.746); --color-amber-300: oklch(87.9% .169 91.605); --color-amber-400: oklch(82.8% .189 84.429); --color-amber-500: oklch(76.9% .188 70.08); --color-amber-600: oklch(66.6% .179 58.318); --color-amber-700: oklch(55.5% .163 48.998); --color-amber-800: oklch(47.3% .137 46.201); --color-amber-900: oklch(41.4% .112 45.904); --color-amber-950: oklch(27.9% .077 45.635); --color-yellow-50: oklch(98.7% .026 102.212); --color-yellow-100: oklch(97.3% .071 103.193); --color-yellow-200: oklch(94.5% .129 101.54); --color-yellow-300: oklch(90.5% .182 98.111); --color-yellow-400: oklch(85.2% .199 91.936); --color-yellow-500: oklch(79.5% .184 86.047); --color-yellow-600: oklch(68.1% .162 75.834); --color-yellow-700: oklch(55.4% .135 66.442); --color-yellow-800: oklch(47.6% .114 61.907); --color-yellow-900: oklch(42.1% .095 57.708); --color-yellow-950: oklch(28.6% .066 53.813); --color-lime-50: oklch(98.6% .031 120.757); --color-lime-100: oklch(96.7% .067 122.328); --color-lime-200: oklch(93.8% .127 124.321); --color-lime-300: oklch(89.7% .196 126.665); --color-lime-400: oklch(84.1% .238 128.85); --color-lime-500: oklch(76.8% .233 130.85); --color-lime-600: oklch(64.8% .2 131.684); --color-lime-700: oklch(53.2% .157 131.589); --color-lime-800: oklch(45.3% .124 130.933); --color-lime-900: oklch(40.5% .101 131.063); --color-lime-950: oklch(27.4% .072 132.109); --color-green-50: oklch(98.2% .018 155.826); --color-green-100: oklch(96.2% .044 156.743); --color-green-200: oklch(92.5% .084 155.995); --color-green-300: oklch(87.1% .15 154.449); --color-green-400: oklch(79.2% .209 151.711); --color-green-500: oklch(72.3% .219 149.579); --color-green-600: oklch(62.7% .194 149.214); --color-green-700: oklch(52.7% .154 150.069); --color-green-800: oklch(44.8% .119 151.328); --color-green-900: oklch(39.3% .095 152.535); --color-green-950: oklch(26.6% .065 152.934); --color-emerald-50: oklch(97.9% .021 166.113); --color-emerald-100: oklch(95% .052 163.051); --color-emerald-200: oklch(90.5% .093 164.15); --color-emerald-300: oklch(84.5% .143 164.978); --color-emerald-400: oklch(76.5% .177 163.223); --color-emerald-500: oklch(69.6% .17 162.48); --color-emerald-600: oklch(59.6% .145 163.225); --color-emerald-700: oklch(50.8% .118 165.612); --color-emerald-800: oklch(43.2% .095 166.913); --color-emerald-900: oklch(37.8% .077 168.94); --color-emerald-950: oklch(26.2% .051 172.552); --color-teal-50: oklch(98.4% .014 180.72); --color-teal-100: oklch(95.3% .051 180.801); --color-teal-200: oklch(91% .096 180.426); --color-teal-300: oklch(85.5% .138 181.071); --color-teal-400: oklch(77.7% .152 181.912); --color-teal-500: oklch(70.4% .14 182.503); --color-teal-600: oklch(60% .118 184.704); --color-teal-700: oklch(51.1% .096 186.391); --color-teal-800: oklch(43.7% .078 188.216); --color-teal-900: oklch(38.6% .063 188.416); --color-teal-950: oklch(27.7% .046 192.524); --color-cyan-50: oklch(98.4% .019 200.873); --color-cyan-100: oklch(95.6% .045 203.388); --color-cyan-200: oklch(91.7% .08 205.041); --color-cyan-300: oklch(86.5% .127 207.078); --color-cyan-400: oklch(78.9% .154 211.53); --color-cyan-500: oklch(71.5% .143 215.221); --color-cyan-600: oklch(60.9% .126 221.723); --color-cyan-700: oklch(52% .105 223.128); --color-cyan-800: oklch(45% .085 224.283); --color-cyan-900: oklch(39.8% .07 227.392); --color-cyan-950: oklch(30.2% .056 229.695); --color-sky-50: oklch(97.7% .013 236.62); --color-sky-100: oklch(95.1% .026 236.824); --color-sky-200: oklch(90.1% .058 230.902); --color-sky-300: oklch(82.8% .111 230.318); --color-sky-400: oklch(74.6% .16 232.661); --color-sky-500: oklch(68.5% .169 237.323); --color-sky-600: oklch(58.8% .158 241.966); --color-sky-700: oklch(50% .134 242.749); --color-sky-800: oklch(44.3% .11 240.79); --color-sky-900: oklch(39.1% .09 240.876); --color-sky-950: oklch(29.3% .066 243.157); --color-blue-50: oklch(97% .014 254.604); --color-blue-100: oklch(93.2% .032 255.585); --color-blue-200: oklch(88.2% .059 254.128); --color-blue-300: oklch(80.9% .105 251.813); --color-blue-400: oklch(70.7% .165 254.624); --color-blue-500: oklch(62.3% .214 259.815); --color-blue-600: oklch(54.6% .245 262.881); --color-blue-700: oklch(48.8% .243 264.376); --color-blue-800: oklch(42.4% .199 265.638); --color-blue-900: oklch(37.9% .146 265.522); --color-blue-950: oklch(28.2% .091 267.935); --color-indigo-50: oklch(96.2% .018 272.314); --color-indigo-100: oklch(93% .034 272.788); --color-indigo-200: oklch(87% .065 274.039); --color-indigo-300: oklch(78.5% .115 274.713); --color-indigo-400: oklch(67.3% .182 276.935); --color-indigo-500: oklch(58.5% .233 277.117); --color-indigo-600: oklch(51.1% .262 276.966); --color-indigo-700: oklch(45.7% .24 277.023); --color-indigo-800: oklch(39.8% .195 277.366); --color-indigo-900: oklch(35.9% .144 278.697); --color-indigo-950: oklch(25.7% .09 281.288); --color-violet-50: oklch(96.9% .016 293.756); --color-violet-100: oklch(94.3% .029 294.588); --color-violet-200: oklch(89.4% .057 293.283); --color-violet-300: oklch(81.1% .111 293.571); --color-violet-400: oklch(70.2% .183 293.541); --color-violet-500: oklch(60.6% .25 292.717); --color-violet-600: oklch(54.1% .281 293.009); --color-violet-700: oklch(49.1% .27 292.581); --color-violet-800: oklch(43.2% .232 292.759); --color-violet-900: oklch(38% .189 293.745); --color-violet-950: oklch(28.3% .141 291.089); --color-purple-50: oklch(97.7% .014 308.299); --color-purple-100: oklch(94.6% .033 307.174); --color-purple-200: oklch(90.2% .063 306.703); --color-purple-300: oklch(82.7% .119 306.383); --color-purple-400: oklch(71.4% .203 305.504); --color-purple-500: oklch(62.7% .265 303.9); --color-purple-600: oklch(55.8% .288 302.321); --color-purple-700: oklch(49.6% .265 301.924); --color-purple-800: oklch(43.8% .218 303.724); --color-purple-900: oklch(38.1% .176 304.987); --color-purple-950: oklch(29.1% .149 302.717); --color-fuchsia-50: oklch(97.7% .017 320.058); --color-fuchsia-100: oklch(95.2% .037 318.852); --color-fuchsia-200: oklch(90.3% .076 319.62); --color-fuchsia-300: oklch(83.3% .145 321.434); --color-fuchsia-400: oklch(74% .238 322.16); --color-fuchsia-500: oklch(66.7% .295 322.15); --color-fuchsia-600: oklch(59.1% .293 322.896); --color-fuchsia-700: oklch(51.8% .253 323.949); --color-fuchsia-800: oklch(45.2% .211 324.591); --color-fuchsia-900: oklch(40.1% .17 325.612); --color-fuchsia-950: oklch(29.3% .136 325.661); --color-pink-50: oklch(97.1% .014 343.198); --color-pink-100: oklch(94.8% .028 342.258); --color-pink-200: oklch(89.9% .061 343.231); --color-pink-300: oklch(82.3% .12 346.018); --color-pink-400: oklch(71.8% .202 349.761); --color-pink-500: oklch(65.6% .241 354.308); --color-pink-600: oklch(59.2% .249 .584); --color-pink-700: oklch(52.5% .223 3.958); --color-pink-800: oklch(45.9% .187 3.815); --color-pink-900: oklch(40.8% .153 2.432); --color-pink-950: oklch(28.4% .109 3.907); --color-rose-50: oklch(96.9% .015 12.422); --color-rose-100: oklch(94.1% .03 12.58); --color-rose-200: oklch(89.2% .058 10.001); --color-rose-300: oklch(81% .117 11.638); --color-rose-400: oklch(71.2% .194 13.428); --color-rose-500: oklch(64.5% .246 16.439); --color-rose-600: oklch(58.6% .253 17.585); --color-rose-700: oklch(51.4% .222 16.935); --color-rose-800: oklch(45.5% .188 13.697); --color-rose-900: oklch(41% .159 10.272); --color-rose-950: oklch(27.1% .105 12.094); --color-slate-50: oklch(98.4% .003 247.858); --color-slate-100: oklch(96.8% .007 247.896); --color-slate-200: oklch(92.9% .013 255.508); --color-slate-300: oklch(86.9% .022 252.894); --color-slate-400: oklch(70.4% .04 256.788); --color-slate-500: oklch(55.4% .046 257.417); --color-slate-600: oklch(44.6% .043 257.281); --color-slate-700: oklch(37.2% .044 257.287); --color-slate-800: oklch(27.9% .041 260.031); --color-slate-900: oklch(20.8% .042 265.755); --color-slate-950: oklch(12.9% .042 264.695); --color-gray-50: oklch(98.5% .002 247.839); --color-gray-100: oklch(96.7% .003 264.542); --color-gray-200: oklch(92.8% .006 264.531); --color-gray-300: oklch(87.2% .01 258.338); --color-gray-400: oklch(70.7% .022 261.325); --color-gray-500: oklch(55.1% .027 264.364); --color-gray-600: oklch(44.6% .03 256.802); --color-gray-700: oklch(37.3% .034 259.733); --color-gray-800: oklch(27.8% .033 256.848); --color-gray-900: oklch(21% .034 264.665); --color-gray-950: oklch(13% .028 261.692); --color-zinc-50: oklch(98.5% 0 0); --color-zinc-100: oklch(96.7% .001 286.375); --color-zinc-200: oklch(92% .004 286.32); --color-zinc-300: oklch(87.1% .006 286.286); --color-zinc-400: oklch(70.5% .015 286.067); --color-zinc-500: oklch(55.2% .016 285.938); --color-zinc-600: oklch(44.2% .017 285.786); --color-zinc-700: oklch(37% .013 285.805); --color-zinc-800: oklch(27.4% .006 286.033); --color-zinc-900: oklch(21% .006 285.885); --color-zinc-950: oklch(14.1% .005 285.823); --color-neutral-50: oklch(98.5% 0 0); --color-neutral-100: oklch(97% 0 0); --color-neutral-200: oklch(92.2% 0 0); --color-neutral-300: oklch(87% 0 0); --color-neutral-400: oklch(70.8% 0 0); --color-neutral-500: oklch(55.6% 0 0); --color-neutral-600: oklch(43.9% 0 0); --color-neutral-700: oklch(37.1% 0 0); --color-neutral-800: oklch(26.9% 0 0); --color-neutral-900: oklch(20.5% 0 0); --color-neutral-950: oklch(14.5% 0 0); --color-stone-50: oklch(98.5% .001 106.423); --color-stone-100: oklch(97% .001 106.424); --color-stone-200: oklch(92.3% .003 48.717); --color-stone-300: oklch(86.9% .005 56.366); --color-stone-400: oklch(70.9% .01 56.259); --color-stone-500: oklch(55.3% .013 58.071); --color-stone-600: oklch(44.4% .011 73.639); --color-stone-700: oklch(37.4% .01 67.558); --color-stone-800: oklch(26.8% .007 34.298); --color-stone-900: oklch(21.6% .006 56.043); --color-stone-950: oklch(14.7% .004 49.25); --color-black: #000; --color-white: #fff; --spacing: .25rem; --breakpoint-sm: 40rem; --breakpoint-md: 48rem; --breakpoint-lg: 64rem; --breakpoint-xl: 80rem; --breakpoint-2xl: 96rem; --container-3xs: 16rem; --container-2xs: 18rem; --container-xs: 20rem; --container-sm: 24rem; --container-md: 28rem; --container-lg: 32rem; --container-xl: 36rem; --container-2xl: 42rem; --container-3xl: 48rem; --container-4xl: 56rem; --container-5xl: 64rem; --container-6xl: 72rem; --container-7xl: 80rem; --text-xs: .75rem; --text-xs--line-height: calc(1 / .75); --text-sm: .875rem; --text-sm--line-height: calc(1.25 / .875); --text-base: 1rem; --text-base--line-height: 1.5 ; --text-lg: 1.125rem; --text-lg--line-height: calc(1.75 / 1.125); --text-xl: 1.25rem; --text-xl--line-height: calc(1.75 / 1.25); --text-2xl: 1.5rem; --text-2xl--line-height: calc(2 / 1.5); --text-3xl: 1.875rem; --text-3xl--line-height: 1.2 ; --text-4xl: 2.25rem; --text-4xl--line-height: calc(2.5 / 2.25); --text-5xl: 3rem; --text-5xl--line-height: 1; --text-6xl: 3.75rem; --text-6xl--line-height: 1; --text-7xl: 4.5rem; --text-7xl--line-height: 1; --text-8xl: 6rem; --text-8xl--line-height: 1; --text-9xl: 8rem; --text-9xl--line-height: 1; --font-weight-thin: 100; --font-weight-extralight: 200; --font-weight-light: 300; --font-weight-normal: 400; --font-weight-medium: 500; --font-weight-semibold: 600; --font-weight-bold: 700; --font-weight-extrabold: 800; --font-weight-black: 900; --tracking-tighter: -.05em; --tracking-tight: -.025em; --tracking-normal: 0em; --tracking-wide: .025em; --tracking-wider: .05em; --tracking-widest: .1em; --leading-tight: 1.25; --leading-snug: 1.375; --leading-normal: 1.5; --leading-relaxed: 1.625; --leading-loose: 2; --radius-xs: .125rem; --radius-sm: .25rem; --radius-md: .375rem; --radius-lg: .5rem; --radius-xl: .75rem; --radius-2xl: 1rem; --radius-3xl: 1.5rem; --radius-4xl: 2rem; --shadow-2xs: 0 1px rgb(0 0 0 / .05); --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .05); --shadow-sm: 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); --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25); --inset-shadow-2xs: inset 0 1px rgb(0 0 0 / .05); --inset-shadow-xs: inset 0 1px 1px rgb(0 0 0 / .05); --inset-shadow-sm: inset 0 2px 4px rgb(0 0 0 / .05); --drop-shadow-xs: 0 1px 1px rgb(0 0 0 / .05); --drop-shadow-sm: 0 1px 2px rgb(0 0 0 / .15); --drop-shadow-md: 0 3px 3px rgb(0 0 0 / .12); --drop-shadow-lg: 0 4px 4px rgb(0 0 0 / .15); --drop-shadow-xl: 0 9px 7px rgb(0 0 0 / .1); --drop-shadow-2xl: 0 25px 25px rgb(0 0 0 / .15); --text-shadow-2xs: 0px 1px 0px rgb(0 0 0 / .15); --text-shadow-xs: 0px 1px 1px rgb(0 0 0 / .2); --text-shadow-sm: 0px 1px 0px rgb(0 0 0 / .075), 0px 1px 1px rgb(0 0 0 / .075), 0px 2px 2px rgb(0 0 0 / .075); --text-shadow-md: 0px 1px 1px rgb(0 0 0 / .1), 0px 1px 2px rgb(0 0 0 / .1), 0px 2px 4px rgb(0 0 0 / .1); --text-shadow-lg: 0px 1px 2px rgb(0 0 0 / .1), 0px 3px 2px rgb(0 0 0 / .1), 0px 4px 8px rgb(0 0 0 / .1); --ease-in: cubic-bezier(.4, 0, 1, 1); --ease-out: cubic-bezier(0, 0, .2, 1); --ease-in-out: cubic-bezier(.4, 0, .2, 1); --animate-spin: spin 1s linear infinite; --animate-ping: ping 1s cubic-bezier(0, 0, .2, 1) infinite; --animate-pulse: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite; --animate-bounce: bounce 1s infinite; @keyframes spin { to { transform: rotate(360deg); } } @keyframes ping { 75%, 100% { transform: scale(2); opacity: 0; } } @keyframes pulse { 50% { opacity: .5; } } @keyframes bounce { 0%, 100% { transform: translateY(-25%); animation-timing-function: cubic-bezier(.8, 0, 1, 1); } 50% { transform: none; animation-timing-function: cubic-bezier(0, 0, .2, 1); } } --blur-xs: 4px; --blur-sm: 8px; --blur-md: 12px; --blur-lg: 16px; --blur-xl: 24px; --blur-2xl: 40px; --blur-3xl: 64px; --perspective-dramatic: 100px; --perspective-near: 300px; --perspective-normal: 500px; --perspective-midrange: 800px; --perspective-distant: 1200px; --aspect-video: 16 / 9; --default-transition-duration: .15s; --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1); --default-font-family: --theme(--font-sans, initial); --default-font-feature-settings: --theme( --font-sans--font-feature-settings, initial ); --default-font-variation-settings: --theme( --font-sans--font-variation-settings, initial ); --default-mono-font-family: --theme(--font-mono, initial); --default-mono-font-feature-settings: --theme( --font-mono--font-feature-settings, initial ); --default-mono-font-variation-settings: --theme( --font-mono--font-variation-settings, initial ); }@theme default inline reference{ --blur: 8px; --shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / .05); --drop-shadow: 0 1px 2px rgb(0 0 0 / .1), 0 1px 1px rgb(0 0 0 / .06); --radius: .25rem; --max-width-prose: 65ch; }}@layer base{*,:after,:before,::backdrop,::file-selector-button{box-sizing:border-box;margin:0;padding:0;border:0 solid}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:--theme(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:--theme(--default-font-feature-settings,normal);font-variation-settings:--theme(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:--theme(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:--theme(--default-mono-font-feature-settings,normal);font-variation-settings:--theme(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea,::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;border-radius:0;background-color:transparent;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]),::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{@tailwind utilities;}@property --tw-animation-delay{syntax:"*";inherits:false;initial-value:0s}@property --tw-animation-direction{syntax:"*";inherits:false;initial-value:normal}@property --tw-animation-duration{syntax:"*";inherits:false}@property --tw-animation-fill-mode{syntax:"*";inherits:false;initial-value:none}@property --tw-animation-iteration-count{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-translate-y{syntax:"*";inherits:false;initial-value:0}@theme inline{--animation-delay-0: 0s; --animation-delay-75: 75ms; --animation-delay-100: .1s; --animation-delay-150: .15s; --animation-delay-200: .2s; --animation-delay-300: .3s; --animation-delay-500: .5s; --animation-delay-700: .7s; --animation-delay-1000: 1s; --animation-repeat-0: 0; --animation-repeat-1: 1; --animation-repeat-infinite: infinite; --animation-direction-normal: normal; --animation-direction-reverse: reverse; --animation-direction-alternate: alternate; --animation-direction-alternate-reverse: alternate-reverse; --animation-fill-mode-none: none; --animation-fill-mode-forwards: forwards; --animation-fill-mode-backwards: backwards; --animation-fill-mode-both: both; --percentage-0: 0; --percentage-5: .05; --percentage-10: .1; --percentage-15: .15; --percentage-20: .2; --percentage-25: .25; --percentage-30: .3; --percentage-35: .35; --percentage-40: .4; --percentage-45: .45; --percentage-50: .5; --percentage-55: .55; --percentage-60: .6; --percentage-65: .65; --percentage-70: .7; --percentage-75: .75; --percentage-80: .8; --percentage-85: .85; --percentage-90: .9; --percentage-95: .95; --percentage-100: 1; --percentage-translate-full: 1; --animate-in: enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none); --animate-out: exit var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none); @keyframes enter { from { opacity: var(--tw-enter-opacity,1); transform: translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0)scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1))rotate(var(--tw-enter-rotate,0)); filter: blur(var(--tw-enter-blur,0)); }}@keyframes exit { to { opacity: var(--tw-exit-opacity,1); transform: translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0)scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1))rotate(var(--tw-exit-rotate,0)); filter: blur(var(--tw-exit-blur,0)); }}--animate-accordion-down: accordion-down var(--tw-animation-duration,var(--tw-duration,.2s))var(--tw-ease,ease-out)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none); --animate-accordion-up: accordion-up var(--tw-animation-duration,var(--tw-duration,.2s))var(--tw-ease,ease-out)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none); --animate-collapsible-down: collapsible-down var(--tw-animation-duration,var(--tw-duration,.2s))var(--tw-ease,ease-out)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none); --animate-collapsible-up: collapsible-up var(--tw-animation-duration,var(--tw-duration,.2s))var(--tw-ease,ease-out)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none); @keyframes accordion-down { from { height: 0; }to { height: var(--radix-accordion-content-height,var(--bits-accordion-content-height,var(--reka-accordion-content-height,var(--kb-accordion-content-height,var(--ngp-accordion-content-height,auto))))); }}@keyframes accordion-up { from { height: var(--radix-accordion-content-height,var(--bits-accordion-content-height,var(--reka-accordion-content-height,var(--kb-accordion-content-height,var(--ngp-accordion-content-height,auto))))); }to { height: 0; }}@keyframes collapsible-down { from { height: 0; }to { height: var(--radix-collapsible-content-height,var(--bits-collapsible-content-height,var(--reka-collapsible-content-height,var(--kb-collapsible-content-height,auto)))); }}@keyframes collapsible-up { from { height: var(--radix-collapsible-content-height,var(--bits-collapsible-content-height,var(--reka-collapsible-content-height,var(--kb-collapsible-content-height,auto)))); }to { height: 0; }}--animate-caret-blink: caret-blink 1.25s ease-out infinite; @keyframes caret-blink { 0%,70%,100% { opacity: 1; }20%,50% { opacity: 0; }}}@utility animation-duration-*{--tw-animation-duration: calc(--value(number)*1ms) ; --tw-animation-duration: --value(--animation-duration-*,[duration],"initial",[*]); animation-duration: calc(--value(number)*1ms) ; animation-duration: --value(--animation-duration-*,[duration],"initial",[*]);}@utility delay-*{animation-delay: calc(--value(number)*1ms) ; animation-delay: --value(--animation-delay-*,[duration],"initial",[*]); --tw-animation-delay: calc(--value(number)*1ms) ; --tw-animation-delay: --value(--animation-delay-*,[duration],"initial",[*]);}@utility repeat-*{animation-iteration-count: --value(--animation-repeat-*,number,"initial",[*]); --tw-animation-iteration-count: --value(--animation-repeat-*,number,"initial",[*]);}@utility direction-*{animation-direction: --value(--animation-direction-*,"initial",[*]); --tw-animation-direction: --value(--animation-direction-*,"initial",[*]);}@utility fill-mode-*{animation-fill-mode: --value(--animation-fill-mode-*,"initial",[*]); --tw-animation-fill-mode: --value(--animation-fill-mode-*,"initial",[*]);}@utility running{animation-play-state: running;}@utility paused{animation-play-state: paused;}@utility play-state-*{animation-play-state: --value("initial",[*]);}@utility blur-in{--tw-enter-blur: 20px;}@utility blur-in-*{--tw-enter-blur: calc(--value(number)*1px) ; --tw-enter-blur: --value(--blur-*,[*]);}@utility blur-out{--tw-exit-blur: 20px;}@utility blur-out-*{--tw-exit-blur: calc(--value(number)*1px) ; --tw-exit-blur: --value(--blur-*,[*]);}@utility fade-in{--tw-enter-opacity: 0;}@utility fade-in-*{--tw-enter-opacity: calc(--value(number)*.01) ; --tw-enter-opacity: --value(--percentage-*,[*]);}@utility fade-out{--tw-exit-opacity: 0;}@utility fade-out-*{--tw-exit-opacity: calc(--value(number)*.01) ; --tw-exit-opacity: --value(--percentage-*,[*]);}@utility zoom-in{--tw-enter-scale: 0;}@utility zoom-in-*{--tw-enter-scale: calc(--value(number)*1%) ; --tw-enter-scale: --value(ratio) ; --tw-enter-scale: --value(--percentage-*,[*]);}@utility -zoom-in-*{--tw-enter-scale: calc(--value(number)*-1%) ; --tw-enter-scale: calc(--value(ratio)*-1) ; --tw-enter-scale: --value(--percentage-*,[*]);}@utility zoom-out{--tw-exit-scale: 0;}@utility zoom-out-*{--tw-exit-scale: calc(--value(number)*1%) ; --tw-exit-scale: --value(ratio) ; --tw-exit-scale: --value(--percentage-*,[*]);}@utility -zoom-out-*{--tw-exit-scale: calc(--value(number)*-1%) ; --tw-exit-scale: calc(--value(ratio)*-1) ; --tw-exit-scale: --value(--percentage-*,[*]);}@utility spin-in{--tw-enter-rotate: 30deg;}@utility spin-in-*{--tw-enter-rotate: calc(--value(number)*1deg) ; --tw-enter-rotate: calc(--value(ratio)*360deg) ; --tw-enter-rotate: --value(--rotate-*,[*]);}@utility -spin-in{--tw-enter-rotate: -30deg;}@utility -spin-in-*{--tw-enter-rotate: calc(--value(number)*-1deg) ; --tw-enter-rotate: calc(--value(ratio)*-360deg) ; --tw-enter-rotate: --value(--rotate-*,[*]);}@utility spin-out{--tw-exit-rotate: 30deg;}@utility spin-out-*{--tw-exit-rotate: calc(--value(number)*1deg) ; --tw-exit-rotate: calc(--value(ratio)*360deg) ; --tw-exit-rotate: --value(--rotate-*,[*]);}@utility -spin-out{--tw-exit-rotate: -30deg;}@utility -spin-out-*{--tw-exit-rotate: calc(--value(number)*-1deg) ; --tw-exit-rotate: calc(--value(ratio)*-360deg) ; --tw-exit-rotate: --value(--rotate-*,[*]);}@utility slide-in-from-top{--tw-enter-translate-y: -100%;}@utility slide-in-from-top-*{--tw-enter-translate-y: calc(--value(integer)*var(--spacing)*-1); --tw-enter-translate-y: calc(--value(--percentage-*,--percentage-translate-*)*-100%) ; --tw-enter-translate-y: calc(--value(ratio)*-100%) ; --tw-enter-translate-y: calc(--value(--translate-*,[percentage],[length])*-1) ;}@utility slide-in-from-bottom{--tw-enter-translate-y: 100%;}@utility slide-in-from-bottom-*{--tw-enter-translate-y: calc(--value(integer)*var(--spacing)); --tw-enter-translate-y: calc(--value(--percentage-*,--percentage-translate-*)*100%) ; --tw-enter-translate-y: calc(--value(ratio)*100%) ; --tw-enter-translate-y: --value(--translate-*,[percentage],[length]);}@utility slide-in-from-left{--tw-enter-translate-x: -100%;}@utility slide-in-from-left-*{--tw-enter-translate-x: calc(--value(integer)*var(--spacing)*-1); --tw-enter-translate-x: calc(--value(--percentage-*,--percentage-translate-*)*-100%) ; --tw-enter-translate-x: calc(--value(ratio)*-100%) ; --tw-enter-translate-x: calc(--value(--translate-*,[percentage],[length])*-1) ;}@utility slide-in-from-right{--tw-enter-translate-x: 100%;}@utility slide-in-from-right-*{--tw-enter-translate-x: calc(--value(integer)*var(--spacing)); --tw-enter-translate-x: calc(--value(--percentage-*,--percentage-translate-*)*100%) ; --tw-enter-translate-x: calc(--value(ratio)*100%) ; --tw-enter-translate-x: --value(--translate-*,[percentage],[length]);}@utility slide-in-from-start{&:dir(ltr){ --tw-enter-translate-x: -100%; }&:dir(rtl){ --tw-enter-translate-x: 100%; }}@utility slide-in-from-start-*{&:where(:dir(ltr),[dir="ltr"],[dir="ltr"]*){ --tw-enter-translate-x: calc(--value(integer)*var(--spacing)*-1); --tw-enter-translate-x: calc(--value(--percentage-*,--percentage-translate-*)*-100%) ; --tw-enter-translate-x: calc(--value(ratio)*-100%) ; --tw-enter-translate-x: calc(--value(--translate-*,[percentage],[length])*-1) ; }&:where(:dir(rtl),[dir="rtl"],[dir="rtl"]*){ --tw-enter-translate-x: calc(--value(integer)*var(--spacing)); --tw-enter-translate-x: calc(--value(--percentage-*,--percentage-translate-*)*100%) ; --tw-enter-translate-x: calc(--value(ratio)*100%) ; --tw-enter-translate-x: --value(--translate-*,[percentage],[length]); }}@utility slide-in-from-end{&:dir(ltr){ --tw-enter-translate-x: 100%; }&:dir(rtl){ --tw-enter-translate-x: -100%; }}@utility slide-in-from-end-*{&:where(:dir(ltr),[dir="ltr"],[dir="ltr"]*){ --tw-enter-translate-x: calc(--value(integer)*var(--spacing)); --tw-enter-translate-x: calc(--value(--percentage-*,--percentage-translate-*)*100%) ; --tw-enter-translate-x: calc(--value(ratio)*100%) ; --tw-enter-translate-x: --value(--translate-*,[percentage],[length]); }&:where(:dir(rtl),[dir="rtl"],[dir="rtl"]*){ --tw-enter-translate-x: calc(--value(integer)*var(--spacing)*-1); --tw-enter-translate-x: calc(--value(--percentage-*,--percentage-translate-*)*-100%) ; --tw-enter-translate-x: calc(--value(ratio)*-100%) ; --tw-enter-translate-x: calc(--value(--translate-*,[percentage],[length])*-1) ; }}@utility slide-out-to-top{--tw-exit-translate-y: -100%;}@utility slide-out-to-top-*{--tw-exit-translate-y: calc(--value(integer)*var(--spacing)*-1); --tw-exit-translate-y: calc(--value(--percentage-*,--percentage-translate-*)*-100%) ; --tw-exit-translate-y: calc(--value(ratio)*-100%) ; --tw-exit-translate-y: calc(--value(--translate-*,[percentage],[length])*-1) ;}@utility slide-out-to-bottom{--tw-exit-translate-y: 100%;}@utility slide-out-to-bottom-*{--tw-exit-translate-y: calc(--value(integer)*var(--spacing)); --tw-exit-translate-y: calc(--value(--percentage-*,--percentage-translate-*)*100%) ; --tw-exit-translate-y: calc(--value(ratio)*100%) ; --tw-exit-translate-y: --value(--translate-*,[percentage],[length]);}@utility slide-out-to-left{--tw-exit-translate-x: -100%;}@utility slide-out-to-left-*{--tw-exit-translate-x: calc(--value(integer)*var(--spacing)*-1); --tw-exit-translate-x: calc(--value(--percentage-*,--percentage-translate-*)*-100%) ; --tw-exit-translate-x: calc(--value(ratio)*-100%) ; --tw-exit-translate-x: calc(--value(--translate-*,[percentage],[length])*-1) ;}@utility slide-out-to-right{--tw-exit-translate-x: 100%;}@utility slide-out-to-right-*{--tw-exit-translate-x: calc(--value(integer)*var(--spacing)); --tw-exit-translate-x: calc(--value(--percentage-*,--percentage-translate-*)*100%) ; --tw-exit-translate-x: calc(--value(ratio)*100%) ; --tw-exit-translate-x: --value(--translate-*,[percentage],[length]);}@utility slide-out-to-start{&:dir(ltr){ --tw-exit-translate-x: -100%; }&:dir(rtl){ --tw-exit-translate-x: 100%; }}@utility slide-out-to-start-*{&:where(:dir(ltr),[dir="ltr"],[dir="ltr"]*){ --tw-exit-translate-x: calc(--value(integer)*var(--spacing)*-1); --tw-exit-translate-x: calc(--value(--percentage-*,--percentage-translate-*)*-100%) ; --tw-exit-translate-x: calc(--value(ratio)*-100%) ; --tw-exit-translate-x: calc(--value(--translate-*,[percentage],[length])*-1) ; }&:where(:dir(rtl),[dir="rtl"],[dir="rtl"]*){ --tw-exit-translate-x: calc(--value(integer)*var(--spacing)); --tw-exit-translate-x: calc(--value(--percentage-*,--percentage-translate-*)*100%) ; --tw-exit-translate-x: calc(--value(ratio)*100%) ; --tw-exit-translate-x: --value(--translate-*,[percentage],[length]); }}@utility slide-out-to-end{&:dir(ltr){ --tw-exit-translate-x: 100%; }&:dir(rtl){ --tw-exit-translate-x: -100%; }}@utility slide-out-to-end-*{&:where(:dir(ltr),[dir="ltr"],[dir="ltr"]*){ --tw-exit-translate-x: calc(--value(integer)*var(--spacing)); --tw-exit-translate-x: calc(--value(--percentage-*,--percentage-translate-*)*100%) ; --tw-exit-translate-x: calc(--value(ratio)*100%) ; --tw-exit-translate-x: --value(--translate-*,[percentage],[length]); }&:where(:dir(rtl),[dir="rtl"],[dir="rtl"]*){ --tw-exit-translate-x: calc(--value(integer)*var(--spacing)*-1); --tw-exit-translate-x: calc(--value(--percentage-*,--percentage-translate-*)*-100%) ; --tw-exit-translate-x: calc(--value(ratio)*-100%) ; --tw-exit-translate-x: calc(--value(--translate-*,[percentage],[length])*-1) ; }}@tailwind utilities;@custom-variant dark (&:is(.dark *));@theme{ --color-primary: var(--color-blue-600); --color-secondary: var(--color-purple-600); --color-success: var(--color-green-500); --color-warning: var(--color-yellow-500); --color-danger: var(--color-red-500); --color-info: var(--color-blue-500); --color-primary-hover: var(--color-blue-700); --color-secondary-hover: var(--color-purple-700); --color-success-hover: var(--color-green-600); --color-warning-hover: var(--color-yellow-600); --color-danger-hover: var(--color-red-600); --color-info-hover: var(--color-blue-600); --color-primary-trans: var(--color-blue-100); --color-secondary-trans: var(--color-purple-100); --color-success-trans: var(--color-green-100); --color-warning-trans: var(--color-yellow-100); --color-danger-trans: var(--color-red-100); --color-info-trans: var(--color-blue-100); --color-primary-trans-hover: var(--color-blue-200); --color-secondary-trans-hover: var(--color-purple-200); --color-success-trans-hover: var(--color-green-200); --color-warning-trans-hover: var(--color-yellow-200); --color-danger-trans-hover: var(--color-red-200); --color-info-trans-hover: var(--color-blue-200); }.dark{--color-primary: var(--color-sky-600);--color-primary-hover: var(--color-sky-700);--color-primary-trans: var(--color-sky-100);--color-primary-trans-hover: var(--color-sky-200);--background: oklch(.145 0 0);--foreground: oklch(.985 0 0);--card: oklch(.205 0 0);--card-foreground: oklch(.985 0 0);--popover: oklch(.205 0 0);--popover-foreground: oklch(.985 0 0);--primary: oklch(.922 0 0);--primary-foreground: oklch(.205 0 0);--secondary: oklch(.269 0 0);--secondary-foreground: oklch(.985 0 0);--muted: oklch(.269 0 0);--muted-foreground: oklch(.708 0 0);--accent: oklch(.269 0 0);--accent-foreground: oklch(.985 0 0);--destructive: oklch(.704 .191 22.216);--border: oklch(1 0 0 / 10%);--input: oklch(1 0 0 / 15%);--ring: oklch(.556 0 0);--chart-1: oklch(.488 .243 264.376);--chart-2: oklch(.696 .17 162.48);--chart-3: oklch(.769 .188 70.08);--chart-4: oklch(.627 .265 303.9);--chart-5: oklch(.645 .246 16.439);--sidebar: oklch(.205 0 0);--sidebar-foreground: oklch(.985 0 0);--sidebar-primary: oklch(.488 .243 264.376);--sidebar-primary-foreground: oklch(.985 0 0);--sidebar-accent: oklch(.269 0 0);--sidebar-accent-foreground: oklch(.985 0 0);--sidebar-border: oklch(1 0 0 / 10%);--sidebar-ring: oklch(.556 0 0)}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--radius: .625rem;--background: oklch(1 0 0);--foreground: oklch(.145 0 0);--card: oklch(1 0 0);--card-foreground: oklch(.145 0 0);--popover: oklch(1 0 0);--popover-foreground: oklch(.145 0 0);--primary: oklch(.205 0 0);--primary-foreground: oklch(.985 0 0);--secondary: oklch(.97 0 0);--secondary-foreground: oklch(.205 0 0);--muted: oklch(.97 0 0);--muted-foreground: oklch(.556 0 0);--accent: oklch(.97 0 0);--accent-foreground: oklch(.205 0 0);--destructive: oklch(.577 .245 27.325);--border: oklch(.922 0 0);--input: oklch(.922 0 0);--ring: oklch(.708 0 0);--chart-1: oklch(.646 .222 41.116);--chart-2: oklch(.6 .118 184.704);--chart-3: oklch(.398 .07 227.392);--chart-4: oklch(.828 .189 84.429);--chart-5: oklch(.769 .188 70.08);--sidebar: oklch(.985 0 0);--sidebar-foreground: oklch(.145 0 0);--sidebar-primary: oklch(.205 0 0);--sidebar-primary-foreground: oklch(.985 0 0);--sidebar-accent: oklch(.97 0 0);--sidebar-accent-foreground: oklch(.205 0 0);--sidebar-border: oklch(.922 0 0);--sidebar-ring: oklch(.708 0 0)}a{font-weight:500;color:var(--color-primary);text-decoration:inherit}a:hover{color:var(--color-primary-hover)}body{margin:0;max-width:100vw;min-height:100vh;font-family:Inter,sans-serif;background:#f4f6f8;color:#1e1e1e}button{transition:all .25s}html.dark{scrollbar-color:var(--color-zinc-600) var(--color-zinc-800)}html.dark a{color:var(--color-cyan-500)}html::-webkit-scrollbar-track .dark{background:var(--color-zinc-800)}html::-webkit-scrollbar-thumb .dark{background-color:var(--color-zinc-600)}table{width:100%;border-collapse:collapse;border-radius:10px;overflow:hidden;background-color:#fff;box-shadow:0 2px 6px #0000000d;margin-top:1rem}th,td{text-align:left;padding:12px 16px;font-size:.95rem}th{background-color:#f9fafb;color:#374151;font-weight:600;border-bottom:2px solid #e5e7eb}td{border-bottom:1px solid #f1f5f9;color:#1f2937}tbody tr:nth-child(2n){background-color:#f9fafb}tbody tr:hover{background-color:#eef2ff;transition:background-color .2s ease}.scrollbar-hide::-webkit-scrollbar{display:none}.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}.app-container{display:flex;min-height:100vh}.sidebar{width:240px;background-color:#1f2937;color:#fff;padding:1.5rem}.sidebar h2{margin-top:0;margin-bottom:2rem}.sidebar ul{list-style:none;padding:0}.sidebar li{margin-bottom:1rem}.sidebar a{color:#cbd5e1;text-decoration:none}.sidebar .active a{color:#60a5fa;font-weight:700}.main-content{flex:1;display:flex;flex-direction:column}.navbar{background:#fff;padding:1rem 2rem;border-bottom:1px solid #e5e7eb}.page-wrapper{padding:2rem}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.project-card{background:#fff;padding:1rem;border-radius:8px;box-shadow:0 1px 4px #00000014}.btn{display:inline-block;padding:8px 14px;border-radius:6px;background-color:#2563eb;color:#fff;border:none;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.btn:hover{background-color:#1d4ed8;transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-danger{background-color:#ef4444}.btn-danger:hover{background-color:#dc2626}.btn-success{background-color:#10b981;display:inline-block;padding:8px 14px;border-radius:6px;color:#fff;border:none;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.btn-success:hover{background-color:#059669}.detection-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.detection-card{background:#fff;border-radius:8px;padding:.5rem;text-align:center;box-shadow:0 1px 4px #0000001a}.detection-card img{width:100%;border-radius:6px}.tag{font-size:.8rem;background:#e5e7eb;padding:2px 6px;border-radius:4px}.train-btn{background:#f59e0b;margin-top:1rem}input[type=text],select{padding:8px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;outline:none}input[type=text]:focus,select:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}.form-inline{display:flex;gap:.6rem;margin-bottom:1rem;flex-wrap:wrap}.form-inline input{flex:1;min-width:180px}.page-container{background:#f9fafb;padding:1.5rem;border-radius:10px;box-shadow:0 2px 8px #0000000d}.page-container h1{font-size:1.5rem;color:#111827}.table{width:100%;border-collapse:collapse;margin-top:16px}.table-wrapper{overflow-x:auto}.table th,.table td{border:1px solid #ccc;padding:8px}.tabs{display:flex;gap:12px;margin-bottom:16px}.tabs button{background:#f0f0f0;border:none;padding:8px 16px;border-radius:8px;cursor:pointer}.tabs button.active{background:#2c7be5;color:#fff}.detection-table{width:100%;border-collapse:collapse;margin-top:16px}.detection-table th,.detection-table td{border:1px solid #ddd;padding:10px}.detection-table th{background:#fafafa}.page-title{font-size:1.6rem;font-weight:700;margin-bottom:12px}.info-card{background-color:#f9fafb;border-radius:10px;padding:1rem 1.2rem;box-shadow:inset 0 0 3px #0000000d}.info-card h3{font-size:1.1rem;margin-bottom:.8rem}.info-card ul{margin:0;padding-left:1rem;color:#444}.info-card li{margin-bottom:.4rem}.yolo-class{color:#777}@media(max-width:768px){.overview-grid{grid-template-columns:1fr}}.add-btn{background-color:#2563eb;color:#fff;border:none;padding:8px 14px;border-radius:6px;margin-bottom:12px;cursor:pointer}.add-btn:hover{background-color:#1d4ed8}button{margin-right:6px;border:none;background:transparent;cursor:pointer}button:hover{opacity:.8}.modal-overlay{position:fixed;right:0;bottom:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000;top:0;left:0;width:100%;height:100%}.modal{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 12px #00000026;width:400px;max-width:90%}.modal label{display:block;margin-top:10px;font-weight:500}.modal input,.modal select{width:100%;padding:6px 8px;border-radius:6px;border:1px solid #ccc;margin-top:4px}.modal-actions{margin-top:1rem;text-align:right;display:flex;justify-content:flex-end}.modal-actions button{background-color:#2563eb;color:#fff;padding:8px 12px;border-radius:6px;margin-left:8px}.modal-actions button[type=button]{background-color:#ef4444}.control-buttons{display:flex;gap:12px;margin-top:20px}.btn-play,.btn-pause,.btn-stop{padding:10px 20px;border-radius:8px;border:none;font-size:15px;cursor:pointer;font-weight:700}.btn-play{background:#22c55e;color:#fff}.btn-pause{background:#eab308;color:#000}.btn-stop{background:#ef4444;color:#fff}.btn-play:disabled,.btn-pause:disabled,.btn-stop:disabled{opacity:.5;cursor:not-allowed}.btn{padding:6px 12px;margin-right:6px;cursor:pointer}.btn.primary{background:#007bff;color:#fff}.btn.danger{background:#d9534f;color:#fff}.btn.small{padding:4px 8px;font-size:12px}@keyframes fadeIn{0%{background-color:#0000}to{background-color:#00000080}}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.75) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}@theme inline{ --radius-sm: calc(var(--radius) - 4px); --radius-md: calc(var(--radius) - 2px); --radius-lg: var(--radius); --radius-xl: calc(var(--radius) + 4px); --color-background: var(--background); --color-foreground: var(--foreground); --color-card: var(--card); --color-card-foreground: var(--card-foreground); --color-popover: var(--popover); --color-popover-foreground: var(--popover-foreground); --color-primary: var(--primary); --color-primary-foreground: var(--primary-foreground); --color-secondary: var(--secondary); --color-secondary-foreground: var(--secondary-foreground); --color-muted: var(--muted); --color-muted-foreground: var(--muted-foreground); --color-accent: var(--accent); --color-accent-foreground: var(--accent-foreground); --color-destructive: var(--destructive); --color-border: var(--border); --color-input: var(--input); --color-ring: var(--ring); --color-chart-1: var(--chart-1); --color-chart-2: var(--chart-2); --color-chart-3: var(--chart-3); --color-chart-4: var(--chart-4); --color-chart-5: var(--chart-5); --color-sidebar: var(--sidebar); --color-sidebar-foreground: var(--sidebar-foreground); --color-sidebar-primary: var(--sidebar-primary); --color-sidebar-primary-foreground: var(--sidebar-primary-foreground); --color-sidebar-accent: var(--sidebar-accent); --color-sidebar-accent-foreground: var(--sidebar-accent-foreground); --color-sidebar-border: var(--sidebar-border); --color-sidebar-ring: var(--sidebar-ring); }@layer base{*{@apply border-border outline-ring/50;}body{@apply bg-background text-foreground;}}
