.form-input.error[data-v-1e5cb7ac]{border-color:#f44336;box-shadow:0 0 0 2px #f4433633}.form-input.error[data-v-1e5cb7ac]:focus{border-color:#f44336;box-shadow:0 0 0 2px #f443364d}.input-group[data-v-1e5cb7ac]{display:flex;flex-direction:column;gap:.5rem}@media (min-width: 768px){.input-group[data-v-1e5cb7ac]{flex-direction:row;align-items:flex-end}.input-group .form-input[data-v-1e5cb7ac]{flex:1}.input-group .btn[data-v-1e5cb7ac]{flex-shrink:0;margin-left:.5rem}}.divider[data-v-1e5cb7ac]{text-align:center;margin:1rem 0;color:#999;font-size:.875rem;position:relative}.divider[data-v-1e5cb7ac]:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#e0e0e0;z-index:1}.divider[data-v-1e5cb7ac]:after{content:attr(data-text);background:#fff;padding:0 1rem;position:relative;z-index:2}.btn-full[data-v-1e5cb7ac]{width:100%}.btn-camera[data-v-1e5cb7ac]{display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-icon[data-v-1e5cb7ac]{font-size:1.25rem}@media (min-width: 768px){.btn-icon[data-v-1e5cb7ac]{font-size:1.5rem}}.image-preview[data-v-1e5cb7ac]{position:relative;margin-top:1rem;border-radius:8px;overflow:hidden}.image-preview img[data-v-1e5cb7ac]{width:100%;max-height:300px;object-fit:contain;background:#f5f5f5}@media (min-width: 768px){.image-preview img[data-v-1e5cb7ac]{max-height:400px}}.btn-close[data-v-1e5cb7ac]{position:absolute;top:.5rem;right:.5rem;width:2rem;height:2rem;border-radius:50%;border:none;background:#0009;color:#fff;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .3s}.btn-close[data-v-1e5cb7ac]:hover{background:#000c}.loading[data-v-1e5cb7ac]{text-align:center;padding:2rem 1rem}.loading p[data-v-1e5cb7ac]{font-size:.875rem;color:#666}.spinner[data-v-1e5cb7ac]{width:32px;height:32px;margin:0 auto 1rem;border:3px solid #f3f3f3;border-top:3px solid #4DBA87;border-radius:50%;animation:spin-1e5cb7ac 1s linear infinite}@media (min-width: 768px){.spinner[data-v-1e5cb7ac]{width:40px;height:40px;border-width:4px}}@keyframes spin-1e5cb7ac{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.success-message[data-v-1e5cb7ac],.error-message[data-v-1e5cb7ac]{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);padding:1rem 1.5rem;border-radius:8px;box-shadow:0 4px 12px #0003;z-index:1000;font-size:.875rem;max-width:90vw;text-align:center}@media (min-width: 768px){.success-message[data-v-1e5cb7ac],.error-message[data-v-1e5cb7ac]{padding:1rem 2rem;font-size:1rem;max-width:400px}}.success-message[data-v-1e5cb7ac]{background:#4dba87;color:#fff}.error-message[data-v-1e5cb7ac]{background:#f44336;color:#fff}.form-group[data-v-1e5cb7ac]{margin-bottom:1rem}.form-group[data-v-1e5cb7ac]:last-child{margin-bottom:0}select.form-input[data-v-1e5cb7ac]{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;-webkit-appearance:none;-moz-appearance:none;appearance:none}@media (hover: none) and (pointer: coarse){.btn[data-v-1e5cb7ac],.form-input[data-v-1e5cb7ac]{min-height:48px}.btn-close[data-v-1e5cb7ac]{width:2.5rem;height:2.5rem}}<style scoped> .modal-overlay[data-v-1e5cb7ac]{border-radius:8px;box-shadow:0 4px 12px #0003;z-index:1000}@media (min-width: 768px){.card[data-v-1e5cb7ac]{margin-bottom:2rem}.grid-2[data-v-1e5cb7ac]{gap:1.5rem}.form-group[data-v-1e5cb7ac]{margin-bottom:1.5rem}.btn-full[data-v-1e5cb7ac]{max-width:300px;margin:0 auto;display:flex}}@media (min-width: 1024px){.container[data-v-1e5cb7ac]{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:3rem;align-items:start;justify-content:center;max-width:1200px;margin:0 auto}.container[data-v-1e5cb7ac]:has(>:last-child:nth-child(1)){display:flex;justify-content:center}.container:has(>:last-child:nth-child(1)) .card[data-v-1e5cb7ac]{max-width:600px}.card[data-v-1e5cb7ac]:first-child{position:sticky;top:2rem}}.header[data-v-ddd7a5ac]{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}@media (max-width: 480px){.header[data-v-ddd7a5ac]{flex-direction:column;align-items:flex-start}}h2[data-v-ddd7a5ac]{margin:0;font-size:1.125rem}@media (min-width: 768px){h2[data-v-ddd7a5ac]{font-size:1.25rem}}.status[data-v-ddd7a5ac]{display:flex;align-items:center;gap:.5rem;font-size:.8rem}@media (min-width: 768px){.status[data-v-ddd7a5ac]{font-size:.875rem}}.status-dot[data-v-ddd7a5ac]{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.running[data-v-ddd7a5ac]{background:#4dba87;box-shadow:0 0 0 2px #4dba8733}.status-dot.stopped[data-v-ddd7a5ac]{background:#999}.status-text[data-v-ddd7a5ac]{color:#666}.loading[data-v-ddd7a5ac]{text-align:center;padding:2rem 1rem}.loading p[data-v-ddd7a5ac]{font-size:.875rem;color:#666}.spinner[data-v-ddd7a5ac]{width:32px;height:32px;margin:0 auto 1rem;border:3px solid #f3f3f3;border-top:3px solid #4DBA87;border-radius:50%;animation:spin-ddd7a5ac 1s linear infinite}@media (min-width: 768px){.spinner[data-v-ddd7a5ac]{width:40px;height:40px;border-width:4px}}@keyframes spin-ddd7a5ac{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error[data-v-ddd7a5ac]{text-align:center;padding:2rem 1rem;color:#f44336}.not-running[data-v-ddd7a5ac]{text-align:center;padding:2rem 1rem}.not-running p[data-v-ddd7a5ac]:first-child{font-size:1rem;font-weight:500;margin-bottom:.5rem}.not-running p[data-v-ddd7a5ac]:last-of-type{font-size:.8rem;color:#666;margin:1rem 0;line-height:1.4}@media (min-width: 768px){.not-running p[data-v-ddd7a5ac]:last-of-type{font-size:.875rem}}.actions[data-v-ddd7a5ac]{display:flex;gap:.5rem;flex-direction:column}@media (min-width: 480px){.actions[data-v-ddd7a5ac]{flex-direction:row}}.actions .btn[data-v-ddd7a5ac]{flex:1;min-height:44px}.fava-container[data-v-ddd7a5ac]{margin-top:1rem;height:calc(100vh - 280px);min-height:500px;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.fava-iframe[data-v-ddd7a5ac]{width:100%;height:100%;border:none}@media (hover: none) and (pointer: coarse){.btn[data-v-ddd7a5ac]{min-height:48px}}.login-container[data-v-54702d2c]{display:flex;justify-content:center;align-items:center;min-height:100vh;background:#f5f5f5}.login-form[data-v-54702d2c]{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a;width:100%;max-width:400px}.login-form h2[data-v-54702d2c]{text-align:center;margin-bottom:1.5rem;color:#333}.form-group[data-v-54702d2c]{margin-bottom:1rem}.form-group input[data-v-54702d2c]{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}button[data-v-54702d2c]{width:100%;padding:.75rem;background:#007bff;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer}button[data-v-54702d2c]:disabled{background:#ccc;cursor:not-allowed}.error[data-v-54702d2c]{color:#dc3545;text-align:center;margin-top:1rem}.app-header[data-v-bcd54b17]{background:#4dba87;color:#fff;padding:1rem;text-align:center;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:100;display:flex;justify-content:space-between;align-items:center}.app-header h1[data-v-bcd54b17]{font-size:1.125rem;font-weight:600;margin:0}.logout-btn[data-v-bcd54b17]{background:#fff3;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.875rem}.logout-btn[data-v-bcd54b17]:hover{background:#ffffff4d}@media (min-width: 768px){.app-header[data-v-bcd54b17]{padding:1.5rem}.app-header h1[data-v-bcd54b17]{font-size:1.5rem}}.app-main[data-v-bcd54b17]{flex:1;overflow-y:auto;padding-bottom:70px}@media (min-width: 768px){.app-main[data-v-bcd54b17]{padding-bottom:80px}}.app-nav[data-v-bcd54b17]{position:fixed;bottom:0;left:0;right:0;background:#fff;display:flex;justify-content:space-around;padding:.5rem;box-shadow:0 -2px 8px #0000001a;z-index:100}@media (min-width: 768px){.app-nav[data-v-bcd54b17]{padding:.75rem}}.nav-item[data-v-bcd54b17]{display:flex;flex-direction:column;align-items:center;padding:.5rem 1rem;text-decoration:none;color:#666;transition:color .3s;min-width:60px;border-radius:8px}.nav-item[data-v-bcd54b17]:hover{background:#f5f5f5}.nav-item span[data-v-bcd54b17]:first-child{font-size:1.25rem;margin-bottom:.25rem}.nav-item span[data-v-bcd54b17]:last-child{font-size:.75rem;font-weight:500}@media (min-width: 768px){.nav-item[data-v-bcd54b17]{padding:.75rem 1.5rem}.nav-item span[data-v-bcd54b17]:first-child{font-size:1.5rem}.nav-item span[data-v-bcd54b17]:last-child{font-size:.875rem}}.nav-item.router-link-active[data-v-bcd54b17]{color:#4dba87;background:#4dba871a}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#f5f5f5;color:#333;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.5}#app{min-height:100vh;display:flex;flex-direction:column}.container{width:100%;margin:0 auto;padding:.75rem}@media (min-width: 768px){.container{max-width:900px;padding:2rem}}@media (min-width: 1024px){.container{max-width:1200px;padding:3rem}}@media (min-width: 1440px){.container{max-width:1400px;padding:4rem}}.btn{padding:.75rem 1rem;border:none;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .3s;min-height:44px;display:inline-flex;align-items:center;justify-content:center;text-align:center}@media (min-width: 768px){.btn{padding:.75rem 1.5rem;font-size:1rem}}.btn-primary{background:#4dba87;color:#fff}.btn-primary:hover{background:#3da872}.btn-primary:active{background:#2d8a5f;transform:translateY(1px)}.btn-secondary{background:#f0f0f0;color:#333}.btn-secondary:hover{background:#e0e0e0}.card{background:#fff;border-radius:12px;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000001a;width:100%}@media (min-width: 768px){.card{padding:1.5rem;margin-bottom:1.5rem}}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.9rem}@media (min-width: 768px){.form-label{font-size:1rem}}.form-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:16px;background:#fff;transition:border-color .3s}.form-input:focus{outline:none;border-color:#4dba87;box-shadow:0 0 0 3px #4dba871a}.grid{display:grid;gap:1rem}.grid-2{grid-template-columns:1fr}@media (min-width: 768px){.grid-2{grid-template-columns:1fr 1fr}}.flex{display:flex;gap:.5rem}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.justify-between{justify-content:space-between}.items-center{align-items:center}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}@media (min-width: 768px){.text-lg{font-size:1.25rem}}.hidden-mobile{display:none}@media (min-width: 768px){.hidden-mobile{display:block}}.hidden-desktop{display:block}@media (min-width: 768px){.hidden-desktop{display:none}}@media (hover: none) and (pointer: coarse){.btn:hover{background:initial}.btn-primary:hover{background:#4dba87}.btn-secondary:hover{background:#f0f0f0}}
