.home-container{display:flex;align-items:center;justify-content:center;height:calc(100% - 60px);padding:2rem;background:#0d1117}.home-card{background:#161b22;border:1px solid #30363d;padding:2.5rem 3rem;border-radius:16px;text-align:center;color:#e6edf3;box-shadow:0 4px 24px #0000004d;animation:fadeIn .4s ease}.home-title{font-size:2rem;margin-bottom:.5rem;color:#fff;font-weight:600}.home-subtitle{color:#8b949e;margin-top:0;font-size:1.1rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.auth-container{height:100vh;width:100%;background:#0d1117;display:flex;justify-content:center;align-items:center;padding:20px}.auth-card{background:#161b22;padding:32px 40px;border-radius:14px;width:360px;box-shadow:0 8px 24px #0006;animation:fadeIn .4s ease}.auth-card h2{margin:0 0 20px;text-align:center;color:#fff;font-weight:500}label{display:block;color:#ccc;margin-bottom:6px;margin-top:15px}input{width:100%;padding:12px;border-radius:8px;border:1px solid #30363d;background:#0d1117;color:#fff;font-size:15px;outline:none;transition:border-color .2s}input:focus{border-color:#58a6ff}.auth-btn{margin-top:20px;width:100%;padding:12px;background:#238636;border:none;border-radius:8px;color:#fff;font-weight:500;cursor:pointer;transition:background .25s}.auth-btn:hover{background:#2ea043}.auth-error{background:#8b0000;padding:10px;border-radius:6px;margin-bottom:15px;color:#fff;font-size:14px;text-align:center}.auth-success{background:#155724;padding:10px;border-radius:6px;margin-bottom:15px;color:#b6ffbf;font-size:14px;text-align:center}.auth-switch{margin-top:20px;text-align:center;color:#aaa}.auth-switch a{color:#58a6ff;text-decoration:none}.auth-switch a:hover{text-decoration:underline}@keyframes fadeIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.helper-text{font-size:.85rem;margin-top:6px;min-height:1.2rem;color:#6b7280}.auth-field.valid input{border-color:#16a34a;box-shadow:0 0 0 3px #10b98114}.auth-field.invalid input{border-color:#dc2626;box-shadow:0 0 0 3px #dc26260f}.auth-field.valid .helper-text{color:#065f46}.auth-field.invalid .helper-text{color:#991b1b}.auth-btn[disabled],.auth-btn[aria-disabled=true]{opacity:.6;cursor:not-allowed}.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.container{max-width:900px;margin:40px auto;padding:0 20px}.title{font-size:28px;font-weight:700;margin-bottom:20px;color:#f3f4f6}.user-list-container{border:1px solid #374151;border-radius:12px;padding:16px;background-color:#1f2937;display:flex;flex-direction:column;gap:12px}.user-row{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;padding:12px 16px;border-radius:8px;background-color:#111827;color:#f3f4f6;transition:box-shadow .2s ease,transform .1s ease}.user-row:hover{box-shadow:0 4px 12px #ffffff1a;transform:translateY(-2px)}.user-email{flex:1 1 200px;font-weight:500;margin-bottom:8px}.user-actions{display:flex;gap:8px;flex:0 0 auto}.user-actions select{padding:6px 10px;border-radius:6px;border:1px solid #374151;background-color:#111827;color:#f3f4f6;outline:none}.user-actions select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d}.user-actions button{padding:6px 12px;border-radius:6px;border:none;background-color:#dc2626;color:#f3f4f6;cursor:pointer;transition:background-color .2s ease}.user-actions button:hover{background-color:#b91c1c}.loading{text-align:center;font-size:18px;margin-top:40px}.device-types-page{min-height:calc(100vh - 64px);padding:2rem;background:#1f2937;color:#f3f4f6;width:100%;max-width:1200px;margin:0 auto}.dt-card{background:#111827eb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.dt-form{gap:1rem}.dt-table-card .dt-table-wrapper{margin-top:1rem}.dt-header{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1.5rem}.dt-header h1{font-size:1.8rem;font-weight:600;color:#f3f4f6}.dt-header p{font-size:.95rem;color:#d1d5db}.dt-layout{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1.7fr);gap:1.5rem;max-width:1200px;margin:0 auto}@media(max-width:960px){.dt-layout{grid-template-columns:minmax(0,1fr)}}.dt-card{background-color:#111827;color:#f3f4f6;border-radius:.75rem;padding:1.25rem 1.5rem;border:1px solid #374151;box-shadow:0 20px 25px -20px #0009}.dt-table-card{align-self:stretch;display:flex;flex-direction:column}.dt-form-card{align-self:flex-start}.dt-form-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:1rem}.dt-form-header h2{font-size:1.1rem;font-weight:500;color:#f3f4f6}.dt-form-header-actions{display:flex;align-items:center;gap:.5rem}.dt-form{display:flex;flex-direction:column;gap:.75rem}.dt-form-group{display:flex;flex-direction:column;gap:.25rem}.dt-form-group label{font-size:.85rem;font-weight:500;color:#f3f4f6}.dt-form-group input,.dt-form-group select{background-color:#1f2937;border-radius:.5rem;border:1px solid #4b5563;padding:.5rem .6rem;font-size:.9rem;color:#f3f4f6;outline:none;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease}.dt-form-group input::placeholder{color:#9ca3af}.dt-form-group input:focus,.dt-form-group select:focus{border-color:#60a5fa;box-shadow:0 0 0 1px #60a5fa73}.dt-inline{flex-direction:row;align-items:center;gap:.5rem}.dt-inline label{display:flex;align-items:center;gap:.4rem}.dt-help-text,.dt-small{font-size:.8rem;color:#d1d5db}.dt-btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid transparent;padding:.4rem .85rem;font-size:.85rem;font-weight:500;cursor:pointer;background-color:#111827;color:#f3f4f6;transition:background-color .15s ease,border-color .15s ease,transform .05s ease}.dt-btn:hover{background-color:#0f172a;transform:translateY(-.5px)}.dt-btn:disabled{opacity:.6;cursor:default;transform:none}.dt-btn-primary{background-color:#3b82f6;border-color:#3b82f6;color:#f3f4f6}.dt-btn-primary:hover{background-color:#2563eb;border-color:#2563eb}.dt-btn-outline{background-color:transparent;border-color:#4b5563;color:#f3f4f6}.dt-btn-outline:hover{background-color:#1f2937}.dt-btn-ghost{background-color:transparent;border-color:transparent;color:#d1d5db}.dt-btn-ghost:hover{background-color:#111827}.dt-btn-xs{padding:.2rem .5rem;font-size:.75rem}.dt-btn-danger{background-color:#b91c1c;border-color:#b91c1c;color:#f3f4f6}.dt-btn-danger:hover{background-color:#991b1b;border-color:#991b1b}.dt-alert{border-radius:.5rem;padding:.4rem .6rem;font-size:.8rem}.dt-alert-error{background-color:#dc262614;border:1px solid rgba(220,38,38,.6);color:#fecaca}.dt-alert-success{background-color:#16a34a14;border:1px solid rgba(22,163,74,.6);color:#bbf7d0}.dt-chip{display:inline-flex;align-items:center;padding:.1rem .45rem;border-radius:999px;font-size:.7rem;background-color:#1f2937;color:#d1d5db}.dt-table-wrapper{position:relative;margin-top:.5rem;border-radius:.75rem;border:1px solid #374151;overflow:hidden;background-color:#111827}.dt-table{width:100%;border-collapse:collapse;font-size:.85rem}.dt-table thead{background-color:#111827}.dt-table th,.dt-table td{padding:.55rem .75rem;text-align:left}.dt-table th{font-weight:500;color:#d1d5db;border-bottom:1px solid #374151;font-size:.8rem}.dt-table tbody tr:nth-child(2n){background-color:#111827}.dt-table tbody tr:nth-child(odd){background-color:#1f2937}.dt-table tbody tr:hover{background-color:#0f172a}.dt-actions{display:flex;flex-wrap:wrap;gap:.25rem}.dt-loading{padding:1rem;font-size:.9rem;color:#d1d5db}.dt-empty{padding:.75rem .2rem;font-size:.85rem;color:#9ca3af}.dt-divider{height:1px;width:100%;margin:1rem 0;background:linear-gradient(to right,transparent,#4b5563,transparent);border:none}.dt-table-header{display:flex;align-items:center;justify-content:space-between}.dt-properties-panel,.dt-props-list{display:flex;flex-direction:column;gap:.75rem}.dt-prop-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;background-color:#0f172a;padding:.7rem .8rem;border-radius:.75rem;border:1px solid #1f2937}.dt-prop-key{display:flex;align-items:center;gap:.35rem;font-size:.95rem}.devices-page{min-height:calc(100vh - 64px);padding:2rem;background:#1f2937;color:#f3f4f6;width:100%;max-width:1200px;margin:0 auto}.dt-header{max-width:1200px;margin:0 auto 1.5rem}.dt-table-card{background:#111827e6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.dt-prop-row input{width:100%}*{margin:0;padding:0;box-sizing:border-box;font-family:Inter,sans-serif}html,body{height:100%;background-color:#1f2937;color:#f3f4f6;line-height:1.6}.header{display:flex;justify-content:space-between;align-items:center;padding:.3rem 1rem;background-color:#111827;box-shadow:0 2px 4px #00000080;position:sticky;top:0;z-index:1000}.header h1{color:#f3f4f6}.header nav span{margin-right:1rem;font-weight:500;color:#d1d5db}.header nav a{margin-right:1rem;text-decoration:none;color:#3b82f6}.header nav a:hover{color:#60a5fa}.header nav button{background-color:#3b82f6;color:#f3f4f6;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer}.header nav button:hover{background-color:#2563eb}.layout{min-height:calc(100vh - 64px);overflow:hidden;display:flex;align-items:stretch}.sidebar{width:220px;background-color:#111827;padding:1rem;border-right:1px solid #374151;min-height:calc(100vh - 64px);display:flex;flex-direction:column;position:sticky;top:64px}.sidebar ul{list-style:none;padding:0}.sidebar li{margin-bottom:1rem}.sidebar a{text-decoration:none;color:#3b82f6}.sidebar a:hover{color:#60a5fa}.main-content{flex:1;overflow-y:auto;background-color:#1f2937;display:flex;justify-content:center}button,input,select,textarea{font-family:Inter,sans-serif}input,select,textarea{padding:.5rem .75rem;border-radius:.375rem;border:1px solid #374151;background-color:#1f2937;color:#f3f4f6}input:focus,select:focus,textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d}a{text-decoration:none}a:hover{text-decoration:underline}@media(max-width:768px){.layout{flex-direction:column}.sidebar{width:100%;height:auto;border-right:none;border-bottom:1px solid #374151}.main-content{padding:1rem}}
