@import"https://fonts.googleapis.com/css2?family=DM+Mono:wght@300;400;500&family=Syne:wght@400;600;700;800&display=swap";:root{--bg: #0a0c10;--surface: #111318;--surface2: #1a1d25;--border: rgba(255,255,255,.08);--accent: #00e5c0;--accent2: #5b8fff;--text: #e8eaf0;--muted: #5a5f72;--red: #ef4444}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;position:relative}.auth-bg{position:fixed;inset:0;background:radial-gradient(ellipse 600px 400px at 20% 80%,rgba(91,143,255,.07) 0%,transparent 70%),radial-gradient(ellipse 500px 300px at 80% 20%,rgba(0,229,192,.06) 0%,transparent 70%);pointer-events:none}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:48px 44px;width:100%;max-width:420px;position:relative;box-shadow:0 32px 80px #00000080;animation:fadeUp .35s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.auth-logo{display:flex;align-items:center;gap:10px;margin-bottom:32px}.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}.logo-text{font-size:20px;font-weight:800}.auth-title{font-size:26px;font-weight:700;margin-bottom:6px}.auth-sub{font-size:13px;color:var(--muted);margin-bottom:28px;line-height:1.5}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:10px;padding:12px 16px;font-size:13px;color:var(--red);margin-bottom:16px}.field{margin-bottom:18px}.field label{display:block;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-family:DM Mono,monospace}.btn-primary{width:100%;padding:14px;background:var(--accent);color:var(--bg);border:none;border-radius:10px;font-family:Syne,sans-serif;font-size:14px;font-weight:700;cursor:pointer;letter-spacing:.04em;transition:all .2s;margin-top:8px}.btn-primary:hover{background:#00ffd5;box-shadow:0 0 24px #00e5c059}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.auth-footer{text-align:center;margin-top:24px;font-size:13px;color:var(--muted)}.auth-footer a{color:var(--accent);text-decoration:none}.pending-icon{font-size:48px;text-align:center;margin-bottom:16px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading{min-height:100vh;display:flex;align-items:center;justify-content:center;color:var(--muted);font-family:DM Mono,monospace;background:var(--bg)}.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px;border-radius:10px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-family:Syne,sans-serif;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s;margin-bottom:8px}.btn-google:hover{border-color:#fff3;background:var(--surface)}.auth-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--muted);font-size:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}:root{--bg:#0a0c10;--surface:#111318;--surface2:#1a1d25;--border:rgba(255,255,255,.08);--accent:#00e5c0;--accent2:#5b8fff;--warn:#ff6b35;--text:#e8eaf0;--muted:#5a5f72;--green:#22c55e}.dash-layout{display:flex;min-height:100vh}.sidebar{width:220px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);padding:24px 16px;display:flex;flex-direction:column;gap:4px}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:4px 8px 20px;border-bottom:1px solid var(--border);margin-bottom:8px}.sidebar-logo .logo-icon{width:28px;height:28px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px}.sidebar-logo .logo-text{font-size:16px;font-weight:800}.sidebar-logo .logo-text span{color:var(--accent)}.nav-section{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-family:DM Mono,monospace;padding:16px 12px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;font-size:13px;color:var(--muted);cursor:pointer;transition:all .2s}.nav-item:hover{color:var(--text);background:var(--surface2)}.nav-item.active{color:var(--accent);background:#00e5c014}.nav-icon{font-size:16px;width:20px;text-align:center}.sidebar-footer{margin-top:auto;border-top:1px solid var(--border);padding-top:14px}.dash-main{flex:1;padding:28px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.dash-header{display:flex;align-items:center;justify-content:space-between}.dash-title{font-size:22px;font-weight:700}.dash-sub{font-size:12px;color:var(--muted);font-family:DM Mono,monospace;margin-top:2px}.auto-banner{background:linear-gradient(135deg,#00e5c014,#5b8fff14);border:1px solid rgba(0,229,192,.2);border-radius:10px;padding:10px 16px;font-size:12px;color:#a0f0e0}.loading-bar{height:2px;border-radius:2px;background:linear-gradient(90deg,var(--accent),var(--accent2));animation:slide 1s infinite}@keyframes slide{0%{width:0%;margin-left:0}50%{width:60%;margin-left:20%}to{width:0%;margin-left:100%}}.section-title{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-family:DM Mono,monospace;display:flex;align-items:center;gap:10px}.section-title:after{content:"";flex:1;height:1px;background:var(--border)}.devices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}.device-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px;cursor:pointer;transition:all .2s}.device-card:hover{border-color:#ffffff2e;transform:translateY(-2px)}.device-card.on{border-color:#00e5c040}.device-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.device-icon-wrap{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--surface2)}.device-card.on .device-icon-wrap{background:#00e5c01f}.toggle{width:36px;height:20px;border-radius:20px;background:var(--surface2);border:1px solid var(--border);position:relative;transition:all .2s}.toggle.on{background:var(--accent);border-color:var(--accent)}.toggle:after{content:"";position:absolute;top:3px;left:3px;width:12px;height:12px;border-radius:50%;background:var(--muted);transition:all .2s}.toggle.on:after{left:19px;background:var(--bg)}.device-name{font-size:13px;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.device-room{font-size:11px;color:var(--muted);font-family:DM Mono,monospace}.device-value{font-size:16px;font-weight:700;color:var(--accent);margin-top:8px}.sensors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px}.sensor-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px}.sensor-label{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-family:DM Mono,monospace;margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sensor-icon{font-size:22px;margin-bottom:6px}.sensor-value{font-size:14px;font-weight:500;word-break:break-word;overflow:hidden;color:var(--text);letter-spacing:.01em}.sensor-unit{font-size:12px;font-weight:400;color:var(--muted);margin-left:2px}.btn-press{font-size:11px;color:var(--accent);background:#00e5c01a;border:1px solid rgba(0,229,192,.2);border-radius:8px;padding:4px 10px;font-family:DM Mono,monospace}.btn-device:hover .btn-press{background:#00e5c033}.dash-header-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px}.header-actions{display:flex;align-items:center;gap:8px}.btn-header{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 14px;color:var(--muted);font-size:12px;font-family:Syne,sans-serif;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-header:hover{color:var(--text);border-color:#fff3}.btn-logout:hover{color:var(--red);border-color:#ef44444d}:root{--bg:#0a0c10;--surface:#111318;--surface2:#1a1d25;--border:rgba(255,255,255,.08);--accent:#00e5c0;--accent2:#5b8fff;--text:#e8eaf0;--muted:#5a5f72;--green:#22c55e;--red:#ef4444;--warn:#ff6b35}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg);color:var(--text);font-family:Syne,sans-serif}.admin-layout{min-height:100vh;display:flex;flex-direction:column}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;border-bottom:1px solid var(--border);background:var(--surface)}.admin-logo{display:flex;align-items:center;gap:10px}.logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px}.logo-text{font-size:18px;font-weight:800}.logo-text span{color:var(--accent)}.btn-back{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 16px;color:var(--muted);font-size:13px;cursor:pointer;font-family:Syne,sans-serif;transition:all .2s}.btn-back:hover{color:var(--text);border-color:#fff3}.admin-msg{margin:16px 32px 0;background:#00e5c01a;border:1px solid rgba(0,229,192,.3);border-radius:10px;padding:12px 16px;font-size:13px;color:var(--accent);cursor:pointer}.admin-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);padding:0 32px}.admin-tab{padding:16px 24px;font-size:13px;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-tab:hover:not(.active){color:var(--text)}.admin-content{padding:28px 32px;flex:1}.cards-grid{display:flex;flex-direction:column;gap:12px}.empty{color:var(--muted);font-family:DM Mono,monospace;font-size:13px;padding:20px 0}.user-card{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px 20px;transition:border-color .2s}.user-card:hover{border-color:#ffffff26}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent2),#9b5bff);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:14px;font-weight:600;margin-bottom:2px}.user-email{font-size:12px;color:var(--muted);font-family:DM Mono,monospace}.user-reason{font-size:11px;color:var(--muted);margin-top:4px;font-style:italic}.badge-admin{background:#00e5c026;color:var(--accent);border-radius:6px;padding:2px 8px;font-size:10px;font-family:DM Mono,monospace;margin-left:6px}.user-actions{display:flex;gap:8px;flex-shrink:0}.btn-approve{padding:8px 16px;border-radius:8px;border:1px solid rgba(34,197,94,.3);background:#22c55e1a;color:var(--green);font-size:12px;font-weight:700;cursor:pointer;font-family:Syne,sans-serif;transition:all .2s}.btn-approve:hover{background:#22c55e33}.btn-deny{padding:8px 16px;border-radius:8px;border:1px solid rgba(239,68,68,.2);background:#ef444414;color:var(--red);font-size:12px;font-weight:700;cursor:pointer;font-family:Syne,sans-serif;transition:all .2s}.btn-deny:hover{background:#ef44442e}.status-pill{padding:4px 12px;border-radius:20px;font-size:11px;font-weight:600;font-family:DM Mono,monospace}.status-active{background:#22c55e26;color:var(--green)}.status-pending{background:#ff6b3526;color:var(--warn)}.status-revoked{background:#ef44441a;color:var(--red)}.host-form{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px}.host-form h3{font-size:14px;font-weight:700;margin-bottom:20px;color:var(--accent);letter-spacing:.04em}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.field{margin-bottom:16px}.field label{display:block;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-family:DM Mono,monospace}.field input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px 16px;color:var(--text);font-size:14px;font-family:Syne,sans-serif;outline:none;transition:border-color .2s}.field input:focus{border-color:var(--accent)}.field input::placeholder{color:var(--muted)}.btn-primary{padding:12px 24px;background:var(--accent);color:var(--bg);border:none;border-radius:10px;font-family:Syne,sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s}.btn-primary:hover{background:#00ffd5;box-shadow:0 0 20px #00e5c04d}.host-card{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px 20px}.host-card.active{border-color:#00e5c033}.host-icon{font-size:28px;flex-shrink:0}.host-info{flex:1;min-width:0}.host-name{font-size:14px;font-weight:600;margin-bottom:2px}.host-url{font-size:12px;color:var(--muted);font-family:DM Mono,monospace}.host-desc{font-size:11px;color:var(--muted);margin-top:2px}.host-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.btn-toggle{padding:6px 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--muted);font-size:12px;cursor:pointer;font-family:Syne,sans-serif;transition:all .2s}.btn-toggle:hover{color:var(--text);border-color:#fff3}.user-card.flexible{flex-wrap:wrap}.inline-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;width:100%;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}.select-sm{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:6px 10px;color:var(--text);font-size:12px;font-family:Syne,sans-serif;outline:none;cursor:pointer}.input-sm{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:6px 10px;color:var(--text);font-size:12px;font-family:Syne,sans-serif;outline:none;width:140px}.input-sm::placeholder{color:var(--muted)}.btn-xs{padding:5px 10px!important;font-size:11px!important}.role-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px;margin-bottom:16px}.role-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.role-name{font-size:15px;font-weight:700}.role-desc{font-size:12px;color:var(--muted);margin-top:2px}.perms-list{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.perm-row{display:flex;align-items:center;gap:8px;background:var(--surface2);border-radius:8px;padding:8px 12px;flex-wrap:wrap}.perm-host{font-size:12px;font-weight:600;flex-shrink:0}.perm-tag{font-size:11px;background:#5b8fff1a;border:1px solid rgba(91,143,255,.2);color:var(--accent2);border-radius:6px;padding:2px 8px;font-family:DM Mono,monospace}.perm-tag.full{background:#00e5c01a;border-color:#00e5c033;color:var(--accent)}.add-perm{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding-top:12px;border-top:1px solid var(--border)}.user-roles{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.role-chip{display:inline-flex;align-items:center;gap:6px;background:#5b8fff1f;border:1px solid rgba(91,143,255,.25);color:var(--accent2);border-radius:20px;padding:3px 10px;font-size:11px;font-family:DM Mono,monospace}.role-chip-remove{cursor:pointer;opacity:.6;font-size:10px}.role-chip-remove:hover{opacity:1;color:var(--red)}.assign-row{display:flex;align-items:center;gap:6px}.add-perm-section{border-top:1px solid var(--border);padding-top:16px;margin-top:8px}.add-perm-header{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-family:DM Mono,monospace;margin-bottom:12px}.add-perm-row{display:flex;align-items:center;gap:8px;margin-bottom:14px}.perm-picker{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:12px}.perm-loading{font-size:12px;color:var(--muted);font-family:DM Mono,monospace;padding:8px 0}.picker-col{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:10px;max-height:320px}.picker-title{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-family:DM Mono,monospace}.picker-count{color:var(--accent);margin-left:6px}.picker-search{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:7px 12px;color:var(--text);font-size:12px;font-family:Syne,sans-serif;outline:none}.picker-search:focus{border-color:var(--accent)}.picker-search::placeholder{color:var(--muted)}.picker-list{overflow-y:auto;display:flex;flex-direction:column;gap:2px;flex:1}.picker-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:7px;font-size:12px;font-family:DM Mono,monospace;cursor:pointer;color:var(--muted);transition:all .15s}.picker-item:hover{background:#ffffff0a;color:var(--text)}.picker-item.selected{background:#00e5c014;color:var(--accent)}.picker-check{width:14px;font-size:10px;color:var(--accent);flex-shrink:0}.picker-more{font-size:11px;color:var(--muted);text-align:center;padding:8px;font-family:DM Mono,monospace}.btn-2fa{padding:6px 12px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--muted);font-size:11px;cursor:pointer;font-family:DM Mono,monospace;transition:all .2s}.btn-2fa.active{background:#00e5c01a;border-color:#00e5c04d;color:var(--accent)}.btn-2fa:hover{border-color:#fff3;color:var(--text)}.host-edit-form{width:100%;padding:8px 0}.host-edit-form .field{margin-bottom:10px}.host-edit-form input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);font-size:13px;outline:none}.host-edit-form input:focus{border-color:var(--accent)}.views-admin{display:flex;flex-direction:column;gap:20px}.view-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px}.view-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.view-title{font-size:16px;font-weight:700;color:var(--text)}.view-meta{font-size:12px;color:var(--muted);font-family:DM Mono,monospace;margin-top:4px}.widgets-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.widget-row{display:flex;align-items:center;gap:10px;background:var(--surface2);border-radius:8px;padding:8px 12px;flex-wrap:wrap}.widget-icon{font-size:18px;min-width:24px}.widget-entity{font-family:DM Mono,monospace;font-size:12px;color:var(--accent);flex:1}.widget-label{font-size:13px;color:var(--muted)}.widget-size{font-size:11px;padding:2px 8px;border-radius:10px;background:var(--surface);color:var(--muted)}.size-small{opacity:.6}.size-large{color:var(--accent)}.widget-color-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0}.widget-edit-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;width:100%}.widget-edit-row input,.widget-edit-row select{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:6px 10px;color:var(--text);font-size:12px;flex:1;min-width:80px}.widget-add-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding-top:12px;border-top:1px solid var(--border)}.widget-add-row input,.widget-add-row select{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 10px;color:var(--text);font-size:13px;flex:1;min-width:100px}.entity-autocomplete{position:relative}.entity-autocomplete input{width:100%}.entity-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:10px;z-index:100;max-height:240px;overflow-y:auto;box-shadow:0 8px 24px #0000004d}.entity-option{padding:10px 14px;cursor:pointer;display:flex;flex-direction:column;gap:2px;border-bottom:1px solid var(--border);transition:background .15s}.entity-option:last-child{border-bottom:none}.entity-option:hover{background:var(--surface2)}.entity-option-id{font-family:DM Mono,monospace;font-size:12px;color:var(--accent)}.entity-option-name{font-size:12px;color:var(--muted)}.icon-picker{position:absolute;top:calc(100% + 4px);left:0;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:10px;display:flex;flex-wrap:wrap;gap:4px;width:280px;z-index:200;box-shadow:0 8px 24px #0006}.icon-opt{font-size:20px;padding:4px;border-radius:6px;cursor:pointer;transition:background .15s;line-height:1}.icon-opt:hover{background:var(--surface2)}.logs-section{padding:0 0 40px}.logs-filters{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.logs-filters select,.logs-filters input{padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-size:13px}.logs-table-wrap{overflow-x:auto;border-radius:10px;border:1px solid var(--border)}.logs-table{width:100%;border-collapse:collapse;font-size:13px}.logs-table thead tr{background:var(--surface2)}.logs-table th{padding:10px 14px;text-align:left;color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.05em}.logs-table td{padding:10px 14px;border-top:1px solid var(--border);vertical-align:middle}.logs-table tr:hover td{background:#ffffff05}.log-date{color:var(--muted);white-space:nowrap;font-family:DM Mono,monospace;font-size:12px}.log-email{color:var(--accent2)}.log-ip{color:var(--muted);font-family:DM Mono,monospace;font-size:12px}.log-detail{color:var(--text);max-width:300px}.log-action{padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600;font-family:DM Mono,monospace}.log-action--login{background:#22c55e26;color:#22c55e}.log-action--view_access{background:#5b8fff26;color:var(--accent2)}.log-action--widget_action{background:#00e5c026;color:var(--accent)}.log-action--admin_create_user{background:#ff6b3526;color:var(--warn)}.log-action--admin_delete_user{background:#ef444426;color:#ef4444}.profile-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;position:relative}.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;width:100%;max-width:900px;position:relative}@media(max-width:700px){.profile-grid{grid-template-columns:1fr}}.auth-success{background:#00e5c01a;border:1px solid rgba(0,229,192,.3);border-radius:10px;padding:12px 16px;font-size:13px;color:var(--accent);margin-bottom:16px}.totp-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px}.totp-icon{font-size:32px;flex-shrink:0}.totp-badge-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}.totp-badge{font-size:11px;font-family:DM Mono,monospace;padding:3px 10px;border-radius:20px}.totp-badge.on{background:#00e5c026;color:var(--accent)}.totp-badge.off{background:#ef44441a;color:var(--red)}.totp-badge.required{background:#ff6b3526;color:var(--warn)}.qr-wrapper{display:flex;justify-content:center;margin:16px 0;background:#fff;border-radius:16px;padding:16px}.qr-img{border-radius:12px;border:none;width:180px;height:180px;background:#fff;padding:12px;box-shadow:0 0 0 8px #fff}.secret-box{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px 16px;font-family:DM Mono,monospace;font-size:13px;letter-spacing:.1em;color:var(--accent);word-break:break-all;text-align:center}.totp-input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;color:var(--text);font-size:24px;font-family:DM Mono,monospace;letter-spacing:.3em;text-align:center;outline:none;transition:border-color .2s}.totp-input:focus{border-color:var(--accent)}.totp-input::placeholder{color:var(--muted);font-size:16px;letter-spacing:.1em}.btn-deny-full{width:100%;padding:14px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:var(--red);font-family:Syne,sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;margin-top:8px}.btn-deny-full:hover{background:#ef444433}.btn-deny-full:disabled{opacity:.5;cursor:not-allowed}.qr-wrapper{background:#fff;border-radius:16px;padding:16px;display:inline-flex;margin:16px auto}.profile-header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#111318d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.profile-header-logo{font-family:Syne,sans-serif;font-size:18px;font-weight:800;color:var(--text)}.profile-header-logo span{color:var(--accent)}.profile-logout-btn{padding:8px 18px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--muted);font-size:13px;font-family:Syne,sans-serif;font-weight:600;cursor:pointer;transition:all .2s}.profile-logout-btn:hover{color:var(--red);border-color:#ef44444d}.profile-shell{padding-top:70px}.profile-grid{display:flex;flex-wrap:wrap;gap:24px;justify-content:center;padding:32px 24px;max-width:900px;margin:0 auto}.profile-grid .auth-card{flex:1 1 340px;max-width:480px;width:100%}@media(max-width:600px){.profile-header{padding:12px 16px}.profile-grid{padding:16px 12px;gap:16px}.profile-grid .auth-card{flex:1 1 100%;max-width:100%}.auth-card{padding:24px 18px}.profile-logout-btn{padding:7px 12px;font-size:12px}}.cv-shell{min-height:100vh;background:var(--bg);display:flex;flex-direction:column}.cv-header{display:flex;flex-direction:column;background:var(--surface);border-bottom:1px solid var(--border)}.cv-topbar{display:flex;align-items:center;gap:12px;padding:12px 24px;border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between}.cv-titlebar{padding:50px 24px 24px;text-align:center}.cv-title{margin:0;font-family:Syne,sans-serif;font-size:22px;font-weight:800;color:var(--text)}.cv-back{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 16px;color:var(--muted);font-size:13px;cursor:pointer;font-family:Syne,sans-serif;transition:all .2s}.cv-back:hover{color:var(--text);border-color:#fff3}.cv-tabs{display:flex;gap:6px;flex-wrap:wrap}.cv-tab{padding:7px 16px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--muted);font-size:13px;font-family:Syne,sans-serif;font-weight:600;cursor:pointer;transition:all .2s}.cv-tab.active{background:#00e5c01a;border-color:#00e5c04d;color:var(--accent)}.cv-tab:hover:not(.active){color:var(--text);border-color:#fff3}.cv-grid{display:flex;flex-wrap:wrap;gap:20px;padding:32px;align-content:flex-start}.cv-loading,.cv-error{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--muted);font-size:16px}.cv-error{color:var(--red)}.cv-widget{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;display:flex;flex-direction:column;gap:10px;transition:all .3s;--widget-accent: var(--accent);position:relative;overflow:hidden}.cv-widget:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,229,192,.03) 0%,transparent 60%);pointer-events:none}.cv-widget.is-on{border-color:var(--widget-accent);box-shadow:0 0 20px #00e5c014}.cv-widget.is-on:before{background:linear-gradient(135deg,rgba(0,229,192,.06) 0%,transparent 60%)}.cv-widget--small{width:160px;min-height:140px}.cv-widget--medium{width:220px;min-height:180px}.cv-widget--large{width:320px;min-height:180px}.cv-widget-icon{font-size:28px;line-height:1}.cv-widget-label{font-family:Syne,sans-serif;font-size:14px;font-weight:700;color:var(--text)}.cv-widget-state{font-family:DM Mono,monospace;font-size:13px;color:var(--muted)}.cv-widget-state.state-on{color:var(--widget-accent)}.cv-btn{margin-top:auto;padding:10px 16px;border-radius:10px;border:none;font-family:Syne,sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;width:100%}.cv-btn--on{background:var(--widget-accent);color:var(--bg)}.cv-btn--off{background:var(--surface2);color:var(--muted);border:1px solid var(--border)}.cv-btn--off:hover{color:var(--red);border-color:#ef44444d}.cv-btn--press{background:#00e5c01a;color:var(--accent);border:1px solid rgba(0,229,192,.2)}.cv-btn--press:hover{background:#00e5c033}.cv-btn--on:hover{opacity:.85}@media(max-width:600px){.cv-topbar{padding:10px 14px;gap:8px}.cv-titlebar{padding:12px 14px}.cv-title{font-size:17px}.cv-tab,.cv-back{padding:6px 11px;font-size:12px}.cv-grid{padding:14px;gap:12px}.cv-widget--small,.cv-widget--medium,.cv-widget--large{width:100%}}
