*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#f8f9fa;--color-surface:#fff;--color-border:#e2e8f0;--color-text:#1a202c;--color-text-secondary:#718096;--color-primary:#3b82f6;--color-primary-hover:#2563eb;--color-danger:#ef4444;--color-danger-hover:#dc2626;--color-success:#22c55e;--radius:8px;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-lg:0 10px 15px #0000001a, 0 4px 6px #0000000d}body{background:var(--color-bg);color:var(--color-text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{background:var(--color-surface);box-shadow:var(--shadow-lg);border-radius:12px;width:100%;max-width:420px;padding:2.5rem}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.login-header p{color:var(--color-text-secondary);font-size:.875rem}.login-form{flex-direction:column;gap:1.25rem;display:flex}.field{flex-direction:column;gap:.375rem;display:flex}.field-label{color:var(--color-text);font-size:.875rem;font-weight:500}.field-input{border:1px solid var(--color-border);border-radius:var(--radius);outline:none;width:100%;padding:.625rem .75rem;font-size:.875rem;transition:border-color .15s}.field-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f626}.field-input::placeholder{color:#a0aec0}.error-message{color:var(--color-danger);border-radius:var(--radius);background:#fef2f2;border:1px solid #fecaca;padding:.5rem .75rem;font-size:.8125rem}.btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--color-danger-hover)}.btn-ghost{color:var(--color-text-secondary);border:1px solid var(--color-border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--color-bg)}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.dashboard{max-width:960px;margin:0 auto;padding:1.5rem}.dashboard-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.header-left{align-items:center;gap:.75rem;display:flex}.header-left h1{font-size:1.25rem;font-weight:700}.product-badge{color:var(--color-primary);background:#eff6ff;border-radius:999px;padding:.25rem .625rem;font-size:.75rem;font-weight:500}.header-right{align-items:center;gap:.75rem;display:flex}.user-info{color:var(--color-text-secondary);font-size:.8125rem}.dashboard-stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1rem 1.25rem}.stat-label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.025em;margin-bottom:.25rem;font-size:.75rem}.stat-value{font-size:1.125rem;font-weight:600}.status-active{color:var(--color-success)}.status-inactive{color:var(--color-text-secondary)}.status-expired,.status-disabled{color:var(--color-danger)}.tab-bar{border-bottom:2px solid var(--color-border);gap:0;margin-bottom:1rem;display:flex}.tab{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;transition:all .15s}.tab:hover{color:var(--color-text)}.tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.table{border-collapse:collapse;width:100%;font-size:.875rem}.table th{text-align:left;text-transform:uppercase;letter-spacing:.025em;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);background:#f7fafc;padding:.75rem 1rem;font-size:.75rem;font-weight:600}.table td{border-bottom:1px solid var(--color-border);vertical-align:middle;padding:.75rem 1rem}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:#f7fafc}.table code{color:#475569;background:#f1f5f9;border-radius:4px;padding:.125rem .375rem;font-size:.75rem}.device-name{font-weight:500}.empty-state{text-align:center;color:var(--color-text-secondary);padding:3rem 1rem;font-size:.875rem}.badge{border-radius:999px;padding:.125rem .5rem;font-size:.75rem;font-weight:500}.badge-red{color:var(--color-danger);background:#fef2f2}.dialog-backdrop{z-index:100;background:#0006;position:fixed;inset:0}.dialog-popup{background:var(--color-surface);width:90%;max-width:400px;box-shadow:var(--shadow-lg);z-index:101;border-radius:12px;padding:1.5rem;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.dialog-title{margin-bottom:.5rem;font-size:1.125rem;font-weight:600}.dialog-description{color:var(--color-text-secondary);margin-bottom:1.5rem;font-size:.875rem;line-height:1.5}.dialog-actions{justify-content:flex-end;gap:.75rem;display:flex}@keyframes skeleton-pulse{0%{opacity:.6}50%{opacity:.3}to{opacity:.6}}.skeleton{background:var(--color-border);border-radius:4px;animation:1.5s ease-in-out infinite skeleton-pulse}.skeleton-text{width:60%;height:.875rem}.skeleton-text-short{width:35%;height:.875rem}.skeleton-btn{border-radius:var(--radius);width:3.5rem;height:1.75rem}.skeleton-stat-value{width:50%;height:1.125rem;margin-top:.25rem}.skeleton-row td{border-bottom:1px solid var(--color-border);padding:.75rem 1rem}.skeleton-row:last-child td{border-bottom:none}.locale-switcher{appearance:none;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-secondary);cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23718096' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;outline:none;padding:.375rem 1.5rem .375rem .625rem;font-size:.8125rem}.locale-switcher:hover{border-color:var(--color-primary)}.login-footer{justify-content:center;margin-top:1.25rem;display:flex}
