2 lines
10 KiB
CSS
2 lines
10 KiB
CSS
*{margin:0;padding:0;box-sizing:border-box}#app{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:#f5f7fa;min-height:100vh}.login-container[data-v-bb5c78dc]{background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 15px 35px #0003;padding:40px;width:100%;max-width:400px;text-align:center;animation:fadeIn-bb5c78dc .5s ease-out;margin:100px auto}@keyframes fadeIn-bb5c78dc{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.logo[data-v-bb5c78dc]{width:80px;height:80px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:50%;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:30px;font-weight:700}h1[data-v-bb5c78dc]{color:#333;margin-bottom:10px;font-size:28px}.subtitle[data-v-bb5c78dc]{color:#666;margin-bottom:30px;font-size:14px}.form-group[data-v-bb5c78dc]{margin-bottom:20px;text-align:left}label[data-v-bb5c78dc]{display:block;margin-bottom:8px;color:#555;font-weight:500}input[data-v-bb5c78dc]{width:100%;padding:15px;border:2px solid #e1e1e1;border-radius:10px;font-size:16px;transition:all .3s ease;outline:none}input[data-v-bb5c78dc]:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}button[data-v-bb5c78dc]{width:100%;padding:15px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:10px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}button[data-v-bb5c78dc]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}button[data-v-bb5c78dc]:disabled{opacity:.7;cursor:not-allowed}.error-message[data-v-bb5c78dc]{color:#dc3545;margin-top:15px;padding:10px;background-color:#f8d7da;border-radius:5px}.success-message[data-v-bb5c78dc]{color:#28a745;margin-top:15px;padding:10px;background-color:#d4edda;border-radius:5px}.header[data-v-7c1d0503]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:20px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;align-items:center}.header h1[data-v-7c1d0503]{font-size:24px;display:flex;align-items:center;gap:10px}.user-info[data-v-7c1d0503]{display:flex;align-items:center;gap:15px}.logout-btn[data-v-7c1d0503]{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 15px;border-radius:5px;cursor:pointer;transition:all .3s ease}.logout-btn[data-v-7c1d0503]:hover{background:rgba(255,255,255,.3)}.nav[data-v-7c1d0503]{background:white;padding:15px 20px;box-shadow:0 2px 5px #0000000d}.nav ul[data-v-7c1d0503]{display:flex;list-style:none;gap:20px}.nav a[data-v-7c1d0503]{text-decoration:none;color:#666;padding:8px 15px;border-radius:5px;transition:all .3s ease}.nav a[data-v-7c1d0503]:hover,.nav a.active[data-v-7c1d0503]{background:#667eea;color:#fff}.container[data-v-7c1d0503]{max-width:1200px;margin:30px auto;padding:0 20px}.dashboard-grid[data-v-7c1d0503]{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:30px}.card[data-v-7c1d0503]{background:white;border-radius:15px;box-shadow:0 5px 15px #00000014;padding:25px;transition:transform .3s ease,box-shadow .3s ease}.card[data-v-7c1d0503]:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0000001f}.card h3[data-v-7c1d0503]{color:#333;margin-bottom:15px;display:flex;align-items:center;gap:10px}.card p[data-v-7c1d0503]{color:#666;line-height:1.6}.device-control[data-v-7c1d0503]{background:white;border-radius:15px;box-shadow:0 5px 15px #00000014;padding:25px;margin-bottom:30px}.control-grid[data-v-7c1d0503]{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-top:20px}.control-item[data-v-7c1d0503]{background:#f8f9fa;border-radius:10px;padding:20px;text-align:center}.control-item h4[data-v-7c1d0503]{margin-bottom:15px;color:#333}.control-buttons[data-v-7c1d0503]{display:flex;gap:10px;justify-content:center}.control-btn[data-v-7c1d0503]{padding:8px 15px;border:none;border-radius:5px;cursor:pointer;font-size:14px;transition:all .3s ease}.on-btn[data-v-7c1d0503]{background:#28a745;color:#fff}.off-btn[data-v-7c1d0503]{background:#dc3545;color:#fff}.control-btn[data-v-7c1d0503]:hover{opacity:.9;transform:translateY(-2px)}@media (max-width: 768px){.dashboard-grid[data-v-7c1d0503]{grid-template-columns:1fr}.header[data-v-7c1d0503]{flex-direction:column;gap:15px}}.device-management[data-v-5f1c4878]{height:100vh;display:flex;flex-direction:column;background-color:#f5f7fa}.header[data-v-5f1c4878]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a}.header h1[data-v-5f1c4878]{margin:0;font-size:1.5rem;display:flex;align-items:center;gap:10px}.user-info[data-v-5f1c4878]{display:flex;align-items:center;gap:1rem}.logout-btn[data-v-5f1c4878]{background:rgba(255,255,255,.2);color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:all .3s ease}.logout-btn[data-v-5f1c4878]:hover{background:rgba(255,255,255,.3)}.main-content[data-v-5f1c4878]{flex:1;padding:1.5rem;overflow-y:auto}.toolbar[data-v-5f1c4878]{margin-bottom:1.5rem;display:flex;justify-content:flex-end}.btn[data-v-5f1c4878]{padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease;display:inline-flex;align-items:center;gap:8px}.btn-primary[data-v-5f1c4878]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;box-shadow:0 4px 15px #0003}.btn-primary[data-v-5f1c4878]:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.btn-secondary[data-v-5f1c4878]{background:#f5f5f5;color:#333;border:1px solid #ddd}.btn-secondary[data-v-5f1c4878]:hover{background:#e0e0e0}.device-tree[data-v-5f1c4878]{background:white;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:1.5rem;overflow:hidden}.tree-node[data-v-5f1c4878]{margin-bottom:.75rem;border-radius:8px;transition:all .3s ease;box-shadow:0 1px 3px #0000001a}.tree-node[data-v-5f1c4878]:hover{box-shadow:0 2px 8px #00000026}.tree-node.relay-node[data-v-5f1c4878]{background:#fff3e0;border-left:4px solid #ff9800}.tree-node.controller-node[data-v-5f1c4878]{background:#e3f2fd;border-left:4px solid #2196f3;margin-left:1.5rem}.tree-node.device-node[data-v-5f1c4878]{background:#e8f5e9;border-left:4px solid #4caf50;margin-left:3rem}.node-header[data-v-5f1c4878]{display:flex;justify-content:space-between;align-items:center;padding:1rem;cursor:pointer}.node-header[data-v-5f1c4878]:hover{background-color:#00000005}.node-info[data-v-5f1c4878]{display:flex;align-items:center;gap:.75rem}.toggle-icon[data-v-5f1c4878]{width:20px;text-align:center;font-size:.8rem;color:#666}.node-title[data-v-5f1c4878]{font-weight:600;color:#333;font-size:1.1rem}.node-address[data-v-5f1c4878]{font-size:.9rem;color:#666;background:rgba(0,0,0,.05);padding:.2rem .5rem;border-radius:4px}.node-type[data-v-5f1c4878]{font-size:.8rem;padding:.3rem .6rem;border-radius:12px;font-weight:500;text-transform:uppercase}.node-status[data-v-5f1c4878]{font-size:.8rem;padding:.3rem .6rem;border-radius:12px;font-weight:500}.status-active[data-v-5f1c4878]{background:#4caf50;color:#fff}.status-inactive[data-v-5f1c4878]{background:#9e9e9e;color:#fff}.relay-type[data-v-5f1c4878]{background:#ff9800;color:#fff}.controller-type[data-v-5f1c4878]{background:#2196f3;color:#fff}.device-type[data-v-5f1c4878]{background:#4caf50;color:#fff}.node-actions[data-v-5f1c4878]{display:flex;gap:.5rem}.action-btn[data-v-5f1c4878]{padding:.4rem .8rem;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s ease}.edit-btn[data-v-5f1c4878]{background:#1976d2;color:#fff}.edit-btn[data-v-5f1c4878]:hover{background:#1565c0;transform:translateY(-1px)}.delete-btn[data-v-5f1c4878]{background:#d32f2f;color:#fff}.delete-btn[data-v-5f1c4878]:hover{background:#c62828;transform:translateY(-1px)}.children-container[data-v-5f1c4878]{padding:.5rem 0 .5rem 1rem;border-left:2px dashed rgba(0,0,0,.1);margin-left:1rem}.modal[data-v-5f1c4878]{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn-5f1c4878 .3s ease}@keyframes fadeIn-5f1c4878{0%{opacity:0}to{opacity:1}}.modal-content[data-v-5f1c4878]{background:white;border-radius:10px;width:90%;max-width:500px;box-shadow:0 10px 30px #0000004d;animation:slideIn-5f1c4878 .3s ease}@keyframes slideIn-5f1c4878{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.modal-header[data-v-5f1c4878]{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #eee}.modal-header h3[data-v-5f1c4878]{margin:0;color:#333;font-size:1.3rem}.close-btn[data-v-5f1c4878]{background:none;border:none;font-size:1.8rem;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;color:#999;transition:color .2s ease}.close-btn[data-v-5f1c4878]:hover{color:#333}.modal-body[data-v-5f1c4878]{padding:1.5rem}.form-group[data-v-5f1c4878]{margin-bottom:1.5rem}.form-group label[data-v-5f1c4878]{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input[data-v-5f1c4878],.form-group select[data-v-5f1c4878]{width:100%;padding:.8rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease}.form-group input[data-v-5f1c4878]:focus,.form-group select[data-v-5f1c4878]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-footer[data-v-5f1c4878]{padding:1.5rem;border-top:1px solid #eee;display:flex;justify-content:flex-end;gap:.75rem}.no-devices[data-v-5f1c4878]{text-align:center;color:#7f8c8d;padding:3rem;font-style:italic;font-size:1.1rem}@media (max-width: 768px){.main-content[data-v-5f1c4878],.header[data-v-5f1c4878]{padding:1rem}.node-header[data-v-5f1c4878]{flex-direction:column;align-items:flex-start;gap:.75rem}.node-actions[data-v-5f1c4878]{align-self:flex-end}.tree-node.controller-node[data-v-5f1c4878],.tree-node.device-node[data-v-5f1c4878]{margin-left:1rem}}
|