.site-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--gap-sm);padding:1rem 1.5rem;margin:0 auto;max-width:840px;width:100%;background:var(--primary);border-bottom:1px solid var(--border);border-radius:0 0 12px 12px}.site-header .logo-link{font-size:1.25rem;font-weight:700;letter-spacing:-.03em;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none}.site-header .logo-link:hover{opacity:.9}.site-nav{display:flex;align-items:center;gap:var(--gap-xl);margin-left:auto}.site-nav a{font-size:.9rem;font-weight:500;color:var(--text-muted);text-decoration:none}.site-nav a:hover{color:var(--accent)}.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem .25rem;color:var(--text-muted);z-index:101;margin-left:auto}.menu-toggle:hover{color:var(--accent)}.hamburger{display:flex;flex-direction:column;gap:var(--gap-xs);width:24px}.hamburger span{display:block;width:100%;height:2px;background:currentColor;border-radius:2px;transition:transform var(--transition-slow),opacity var(--transition-slow)}.menu-toggle.active .hamburger span:nth-child(1){transform:translateY(6px) rotate(45deg)}.menu-toggle.active .hamburger span:nth-child(2){opacity:0}.menu-toggle.active .hamburger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}@media(max-width:768px){.menu-toggle{display:block;padding:.5rem 0}.menu{position:absolute;top:100%;left:0;right:0;background:var(--primary);border-top:1px solid var(--border);border-radius:12px;flex-direction:column;align-items:stretch;gap:0;padding:0;max-height:0;overflow:hidden;opacity:0;transition:max-height .3s,opacity .3s}.menu.active{max-height:400px;opacity:1}.menu a{padding:.75rem 1.5rem;border-top:1px solid rgba(42,48,60,.5)}.menu a:first-child{border-top:none}.menu a:last-child{border-bottom:1px solid rgba(42,48,60,.5);border-radius:0 0 12px 12px}.menu a:hover{background:var(--secondary)}.menu a:first-child:hover{border-radius:0}.menu a:last-child:hover{border-radius:0 0 12px 12px}.site-header{position:relative}}.user-nav-wrapper{position:relative;margin-left:.5rem}.user-nav{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--secondary);border:1px solid var(--border);color:var(--text-muted);text-decoration:none;flex-shrink:0;transition:border-color .2s,color .2s;font-size:.75rem;font-weight:600;line-height:1;overflow:visible;position:relative;cursor:pointer;padding:0;font-family:inherit}.user-nav:hover,.user-nav-wrapper.active .user-nav{border-color:var(--accent);color:var(--accent)}.user-nav svg{width:var(--icon-md);height:var(--icon-md)}.user-nav-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:200px;background:var(--primary);border:1px solid var(--border);border-radius:8px;padding:0;opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity .2s,transform .2s,visibility .2s;box-shadow:0 4px 12px #0000004d;z-index:200}.user-nav-wrapper.active .user-nav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.user-nav-dropdown a{display:flex;align-items:center;gap:var(--gap-sm);padding:.625rem 1rem;color:var(--text-muted);text-decoration:none;font-size:.9rem;transition:background .15s,color .15s;position:relative}.user-nav-dropdown a:not(:first-child):before{content:"";position:absolute;top:0;left:1rem;right:1rem;height:1px;background:var(--border)}.user-nav-dropdown a:first-child{border-radius:8px 8px 0 0}.user-nav-dropdown a:last-child{border-radius:0 0 8px 8px}.user-nav-dropdown a svg{width:18px;height:18px;flex-shrink:0}.user-nav-dropdown a:hover{background:var(--secondary);color:var(--accent)}.dropdown-subheader{display:block;padding:.75rem 1rem;color:var(--accent);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;position:relative}.dropdown-subheader:before{content:"";position:absolute;top:0;left:1rem;right:1rem;height:1px;background:var(--border)}.dropdown-subheader:after{content:"";position:absolute;bottom:0;left:1rem;right:1rem;height:1px;background:var(--accent)}.hero{min-height:auto;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-md) var(--space-2xl) var(--space-3xl);position:relative}.hero:before{content:"";position:absolute;width:120%;height:60%;top:50%;left:50%;transform:translate(-50%,-50%);background:radial-gradient(ellipse at center,var(--accent-dim) 0%,transparent 65%);pointer-events:none}.hero-content{text-align:center;position:relative;z-index:1;width:100%;max-width:100%;display:flex;flex-direction:column;align-items:center}.hero-title-gradient{font-size:clamp(2.5rem,8vw,4rem);font-weight:var(--weight-bold);letter-spacing:-.04em;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-sm);padding:0 var(--space-xs)}.hero-tagline{font-size:clamp(.9rem,2.2vw,1.1rem);color:var(--text-muted);font-weight:var(--weight-medium);margin-bottom:var(--space-xl);max-width:var(--container-sm);margin-left:auto;margin-right:auto}.device-label{margin-top:var(--space-sm);font-size:var(--font-sm);color:var(--text-muted);letter-spacing:.05em}.hero-actions{display:flex;flex-wrap:wrap;gap:var(--gap-md);justify-content:center}.hero-links{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--gap-md);margin-top:var(--space-xl);font-size:var(--font-sm)}.hero-links-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--gap-sm) var(--gap-md)}.hero-links a{color:var(--text-muted);text-decoration:none;display:inline-flex;align-items:center;gap:var(--gap-xs)}.hero-links a:hover{color:var(--accent)}.hero-links a svg{width:var(--icon-lg);height:var(--icon-lg)}.alert-box{max-width:var(--container-sm);margin:0 auto var(--space-2xl);padding:var(--space-lg) var(--space-xl);border-radius:var(--radius-xl);text-align:left;border:1px solid transparent}.alert-box-title{font-size:var(--font-md);font-weight:var(--weight-semibold);margin-bottom:var(--space-sm);display:flex;align-items:center;gap:var(--gap-sm);color:inherit}.alert-box-title svg{width:var(--icon-md);height:var(--icon-md);flex-shrink:0}.alert-box-text{font-size:var(--font-sm);line-height:1.5;margin:0;color:inherit}.alert-box-link{text-decoration:none;font-weight:var(--weight-medium);color:inherit}.alert-box-link:hover{text-decoration:underline}.alert-success{background:var(--alert-success-dim);border-color:var(--alert-success);color:var(--alert-success)}.alert-error{background:var(--alert-error-dim);border-color:var(--alert-error);color:var(--alert-error)}.alert-warning{background:var(--alert-warning-dim);border-color:var(--alert-warning);color:var(--alert-warning)}.alert-info{background:var(--alert-info-dim);border-color:var(--alert-info);color:var(--alert-info)}.btn{display:inline-flex;align-items:center;gap:var(--gap-xs);padding:var(--space-md) var(--space-2xl);font-family:inherit;font-size:var(--font-md);font-weight:var(--weight-semibold);border-radius:var(--radius-lg);text-decoration:none;transition:transform var(--transition-base),box-shadow var(--transition-base);border:none;cursor:pointer}.btn:active{transform:scale(.98)}.btn-sm{padding:var(--space-sm) var(--space-lg);font-size:var(--font-sm)}.btn-primary{background:var(--btn-primary);color:var(--secondary)!important;box-shadow:var(--shadow-md)}.btn-primary:hover{box-shadow:var(--shadow-lg);text-decoration:none}.btn-secondary{background:var(--secondary);color:var(--text-muted)!important;border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)!important;text-decoration:none}.btn-info{background:transparent;color:var(--btn-info);border:1px solid var(--btn-info)}.btn-info:hover{background:var(--btn-info-dim);border-color:var(--btn-info)}.btn-table-action{display:inline-flex;align-items:center;gap:.4rem;padding:.75rem 1.25rem;font-family:inherit;font-size:.9rem;font-weight:600;color:#0c0e12!important;background:var(--accent)!important;border:none;border-radius:10px;cursor:pointer;text-decoration:none!important;transition:box-shadow .2s,opacity .2s;flex-shrink:0}.btn-table-action:hover{box-shadow:0 4px 20px var(--glow);opacity:.95}.btn-table-action:focus{outline:none;box-shadow:0 0 0 3px var(--accent-dim)}.btn-table-action svg{width:18px;height:18px;stroke:currentColor}.action-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:8px;background:transparent;color:var(--text-muted);cursor:pointer;transition:color .2s,background .2s,opacity .2s}.action-btn.action-edit{background:var(--btn-primary-dim);color:var(--btn-primary)}.action-btn.action-delete{background:var(--btn-danger-dim);color:var(--btn-danger)}.action-btn.action-favourite-btn{color:var(--btn-warning)!important;background:var(--btn-warning-dim)!important}.action-btn.action-unlinked-btn{color:var(--btn-pending)!important;background:var(--btn-pending-dim)!important}.action-btn.action-more{background:var(--btn-info-dim);color:var(--btn-info)}.action-btn svg{width:18px;height:18px}.modal-btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-md) var(--space-xl);font-family:inherit;font-size:var(--font-md);font-weight:var(--weight-semibold);border-radius:var(--radius-lg);border:none;cursor:pointer;transition:opacity var(--transition-base),box-shadow var(--transition-base)}.modal-btn:active{transform:scale(.98)}.modal-btn-cancel{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.modal-btn-cancel:hover{background:var(--primary);color:var(--text)}.modal-btn-confirm{background:var(--btn-danger);color:#fff}.modal-btn-confirm:hover{box-shadow:0 0 0 3px var(--btn-danger-dim)}.modal-btn:focus{outline:none}.modal-btn-cancel:focus{box-shadow:0 0 0 2px var(--border)}.modal-btn-confirm:focus{box-shadow:0 0 0 3px var(--btn-danger-dim)}.viewer-count-btn{background:none;border:none;padding:0;cursor:pointer;font-family:inherit}.viewer-count-btn .nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:var(--icon-sm);height:var(--icon-sm);color:var(--bg);font-size:var(--font-xs);font-weight:var(--weight-bold);border-radius:var(--radius-full);line-height:1}.viewer-count-btn[data-device=living-room] .nav-badge{background:var(--status-success)}.viewer-count-btn[data-device=computer-desk] .nav-badge{background:var(--status-pending)}.notification-badge{position:absolute;top:-5px;right:-5px;min-width:var(--icon-md);height:var(--icon-md);background:var(--status-warning);color:var(--bg);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:var(--weight-bold);padding:0 4px;line-height:1;border:2px solid var(--primary);z-index:10;pointer-events:none}.inline-badge{margin-left:auto;min-width:var(--icon-md);height:var(--icon-md);background:var(--status-warning);color:var(--secondary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:var(--weight-bold);padding:0 5px;line-height:1}.status-badge{display:inline-block;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-xxs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.05em}.status-badge.status-success{background:var(--alert-success-dim);color:var(--status-success)}.status-badge.status-error{background:var(--alert-error-dim);color:var(--status-error)}.status-badge.status-pending{background:var(--status-pending-dim);color:var(--status-pending)}.table-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;min-width:20px;min-height:20px;border-radius:50%;background:var(--accent);flex-shrink:0;color:var(--bg)}.table-badge svg{width:12px;height:12px}.table-badge-error{background:var(--status-error)}.role-badge{display:inline-block;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-xxs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.05em}.role-badge.admin{background:var(--status-warning-dim);color:var(--status-warning)}.role-badge.user{background:var(--status-success-dim);color:var(--status-success)}.role-badge.viewer{background:var(--status-info-dim);color:var(--status-info)}.mini-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--secondary);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--font-xs);color:var(--text);white-space:nowrap;line-height:1.4}button.mini-badge{cursor:pointer;font-family:inherit;background:var(--status-pending);border-color:var(--status-pending);color:var(--bg)}.device-wrapper{position:relative;margin:0 auto 1.5rem;width:100%;max-width:680px;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:0 clamp(.5rem,2vw,1rem);box-sizing:border-box}.device-frame{box-sizing:border-box;width:100%;max-width:100%;aspect-ratio:680 / 520;padding:clamp(8px,1.5vw,20px);background:linear-gradient(145deg,#1c1f26,#0f1115);border-radius:clamp(10px,2vw,20px);box-shadow:0 0 0 1px #ffffff0f,0 6px 28px #00000080,inset 0 1px #ffffff0a;position:relative;margin:0 auto}.device-frame:before{content:"";position:absolute;inset:clamp(4px,1vw,6px);border-radius:clamp(8px,1.5vw,14px);box-shadow:inset 0 0 16px #0006;pointer-events:none}.device-screen{box-sizing:border-box;width:100%;height:auto;margin:0;padding:0;border-radius:clamp(6px,1.2vw,14px);overflow:hidden;background:#000;box-shadow:inset 0 0 0 1px #00000080;position:relative}.device-screen iframe{display:block;width:640px;height:480px;border:none;border-radius:clamp(6px,1.2vw,14px);transform-origin:top left}.device-details-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--gap-xs);margin-top:var(--space-xs);font-size:var(--font-xs);color:var(--text-muted);line-height:1.6}.device-details-row>span{display:flex;align-items:center;gap:var(--gap-xs);flex-wrap:wrap}.device-details-row svg{flex-shrink:0;opacity:.7}.main{max-width:var(--container-md)!important;margin:0 auto!important;padding:var(--space-3xl) var(--space-2xl) var(--space-md)}.main h1{font-size:var(--font-xl);font-weight:var(--weight-semibold);margin-bottom:var(--space-sm);color:var(--text)}.main .content-label{display:block;font-size:var(--font-xs);font-weight:var(--weight-semibold);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--space-lg)}.main .content-intro{color:var(--text-muted);font-size:var(--font-md);margin-bottom:var(--space-lg)}.main .get-started-benefits{list-style:none;padding-left:0;margin:0 0 var(--space-2xl)}.main .get-started-benefits li{position:relative;padding-left:var(--space-xl);margin-bottom:var(--space-sm);color:var(--text-muted);font-size:var(--font-md)}.main .get-started-benefits li:before{content:"";position:absolute;left:0;top:.5em;width:6px;height:6px;border-radius:50%;background:var(--accent)}.main h2{font-size:var(--font-lg);font-weight:var(--weight-semibold);margin:var(--space-3xl) 0 var(--space-md);color:var(--text)}.main h2:first-line{color:var(--accent)}.main p{color:var(--text-muted);font-size:var(--font-md);margin-bottom:var(--space-lg)}.main .alert-box-text{font-size:var(--font-sm)!important;margin:0!important;line-height:1.5!important}.main strong{color:var(--text)}.main ul,.main ol{color:var(--text-muted);font-size:var(--font-md);padding-left:var(--space-2xl);margin:var(--space-sm) 0 var(--space-lg)}.main ol{list-style:none;counter-reset:item}.main ol li{counter-increment:item;position:relative;padding-left:var(--space-sm)}.main ol li:before{content:counter(item) ". ";color:var(--accent);font-weight:var(--weight-semibold)}.main a{color:var(--accent);text-decoration:none;font-weight:var(--weight-medium)}.main code,.main pre{background:var(--secondary);padding:.2em .5em;border-radius:var(--radius-sm);font-size:var(--font-md)}.main pre{display:block;padding:var(--space-lg);overflow-x:auto;margin:var(--space-md) 0;white-space:pre-wrap}.main .divider{border:none;border-top:1px solid var(--border);margin:var(--space-3xl) 0}.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap-xl);margin-top:var(--space-2xl)}.card{background:var(--secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);transition:border-color .2s ease,box-shadow .2s ease}.card:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-dim)}.card h3{display:flex;align-items:center;gap:var(--gap-md);margin:0 0 var(--space-md);font-size:var(--font-lg);font-weight:var(--weight-semibold);color:var(--text)}.card h3 svg{flex-shrink:0;width:var(--icon-lg);height:var(--icon-lg);color:var(--accent)}.card p{margin:0;font-size:var(--font-md);color:var(--text-muted);line-height:1.5}.card p a{color:var(--accent);text-decoration:none}.card p a:hover{text-decoration:underline}.detail-card{background:var(--primary);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-xl)}.detail-card-header{display:flex;align-items:center;gap:var(--gap-md)}.detail-card-info{flex:1;min-width:0}.detail-card-title{font-size:var(--font-base);font-weight:var(--weight-semibold);margin:0 0 .15rem;color:var(--text)}.detail-card-desc{font-size:var(--font-sm);color:var(--text-muted);margin:0;line-height:1.4}.detail-card-actions{display:flex;gap:var(--gap-sm);margin-left:auto}.detail-card-form{margin-top:var(--space-xl);padding-top:var(--space-xl);border-top:1px solid var(--border)}.detail-card-form .form-actions{display:flex;flex-wrap:wrap;gap:var(--gap-md);margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--border)}.detail-card-placeholder{opacity:.85}.stat-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap-lg);margin-bottom:var(--space-2xl)}@media(max-width:720px){.stat-cards{grid-template-columns:1fr}}.stat-card{display:flex;flex-direction:column;gap:0;background:var(--primary);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-xl);padding-right:3.5rem;min-width:0;position:relative}.stat-card-label{font-size:var(--font-sm);font-weight:var(--weight-medium);color:var(--text-muted);line-height:1.3}.stat-card-icon{position:absolute;top:var(--space-xl);right:var(--space-xl);display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-lg)}.stat-card-icon svg{width:var(--icon-sm);height:var(--icon-sm);stroke:currentColor}.stat-card-icon.info{background:var(--status-info-dim);color:var(--status-info)}.stat-card-icon.success{background:var(--status-success-dim);color:var(--status-success)}.stat-card-icon.warning{background:var(--status-warning-dim);color:var(--status-warning)}.stat-card-value-wrap{display:flex;align-items:baseline;flex-wrap:wrap;gap:.35rem;margin-top:.15rem}.stat-card-value{font-size:1.75rem;font-weight:var(--weight-bold);font-variant-numeric:tabular-nums;color:var(--text);letter-spacing:-.02em;line-height:1.2}.stat-card-pct{font-size:var(--font-md);font-weight:var(--weight-semibold)}.stat-card-pct--up{color:var(--status-success)}.stat-card-pct--down{color:var(--status-pending)}.stat-card-desc{font-size:var(--font-sm);color:var(--text-muted);margin-top:.2rem}.auth-section{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;position:relative}.auth-section:before{content:"";position:absolute;width:120%;height:60%;top:50%;left:50%;transform:translate(-50%,-50%);background:radial-gradient(ellipse at center,var(--accent-dim) 0%,transparent 65%);pointer-events:none}.auth-wrapper{position:relative;z-index:1;width:100%;max-width:400px}.auth-card{background:var(--primary);border:1px solid var(--border);border-radius:16px;padding:2rem;box-shadow:0 0 0 1px #ffffff0a,0 8px 32px #0006}.auth-brand{font-size:clamp(1.75rem,5vw,2rem);font-weight:700;letter-spacing:-.04em;margin-bottom:1.5rem;text-align:center}.auth-brand .gradient{background:linear-gradient(90deg,#1e3c72,#2a5298,#00b09b,#96c93d);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-brand .plain{display:block;color:var(--text);margin-top:.35rem}.auth-intro{font-size:.9rem;color:var(--text-muted);line-height:1.5;margin:0 0 1.25rem}.auth-form .btn{width:100%;justify-content:center;margin-top:.5rem;padding:.85rem 1.5rem}.auth-footer{text-align:center;margin-top:1.5rem}.auth-footer a{font-size:.9rem;color:var(--text-muted);text-decoration:none;display:inline-flex;align-items:center;gap:.35rem}.auth-footer a:hover{color:var(--accent)}.auth-footer a svg{width:1rem;height:1rem;flex-shrink:0}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0 1rem;color:var(--text-muted);font-size:.875rem;font-weight:500}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-switch{text-align:center;font-size:.9rem;color:var(--text-muted);margin-top:.25rem}.auth-switch a{color:var(--accent);text-decoration:none;font-weight:600}.auth-switch a:hover{text-decoration:underline}.auth-link-button{background:none;border:none;font-size:.9rem;color:var(--text-muted);cursor:pointer;text-decoration:none;padding:0;font-family:inherit}.auth-link-button:hover{color:var(--accent)}.form-card{background:var(--primary);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-xl);width:100%;margin-bottom:var(--space-2xl)}.form-card .form-row{display:flex;gap:var(--gap-lg);flex-wrap:wrap;margin-bottom:var(--space-lg)}.form-card .form-row .form-group{flex:1;min-width:200px;margin-bottom:0}.form-label{display:flex;flex-direction:column;gap:var(--space-xs);font-size:var(--font-sm);font-weight:var(--weight-medium);color:var(--text)!important;margin-bottom:var(--space-sm)}.form-label-desc{font-size:var(--font-xs);font-weight:400;color:var(--text-muted)}.form-input,.form-select{width:100%;padding:var(--space-md) var(--space-lg);font-family:inherit;font-size:var(--font-md);color:var(--text);background:var(--secondary);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition-base),box-shadow var(--transition-base)}.form-input::placeholder{color:var(--text-muted);opacity:.6}.form-input:hover,.form-select:hover{border-color:#3a4150}.form-input:focus,.form-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238b92a0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-md) center;padding-right:2.5rem}.form-checkbox{display:flex;align-items:flex-start;gap:var(--gap-sm);margin-bottom:var(--space-xl)}.form-checkbox input{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:1.25rem;height:1.25rem;margin:0;margin-top:.15rem;flex-shrink:0;cursor:pointer;background:var(--secondary);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition-base),box-shadow var(--transition-base)}.form-checkbox input:hover{border-color:#3a4150}.form-checkbox input:checked{background-color:var(--accent);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230c0e12' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");background-size:.75rem;background-position:center;background-repeat:no-repeat;border-color:var(--accent)}.form-checkbox-label{font-size:var(--font-sm);color:var(--text-muted);line-height:1.5;cursor:pointer}.form-checkbox-label a{color:var(--accent);text-decoration:none}.form-checkbox-label a:hover{text-decoration:underline}.form-actions{display:flex;align-items:center;flex-wrap:wrap;gap:var(--gap-md);padding-top:var(--space-lg);border-top:1px solid var(--border)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.9rem;font-weight:500;color:var(--text-muted);margin-bottom:.4rem}.form-group input[type=text],.form-group input[type=password],.form-group input[type=email],.form-group input[type=url]{width:100%;padding:.75rem 1rem;font-family:inherit;font-size:1rem;color:var(--text);background:var(--secondary);border:1px solid var(--border);border-radius:10px;transition:border-color .2s,box-shadow .2s}.form-group input[type=text]::placeholder,.form-group input[type=password]::placeholder,.form-group input[type=email]::placeholder,.form-group input[type=url]::placeholder{color:var(--text-muted);opacity:.6}.form-group input[type=text]:hover,.form-group input[type=password]:hover,.form-group input[type=email]:hover,.form-group input[type=url]:hover{border-color:#3a4150}.form-group input[type=text]:focus,.form-group input[type=password]:focus,.form-group input[type=email]:focus,.form-group input[type=url]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-group input[type=text]:-webkit-autofill,.form-group input[type=password]:-webkit-autofill,.form-group input[type=email]:-webkit-autofill,.form-group input[type=url]:-webkit-autofill,.form-group input[type=text]:-webkit-autofill:hover,.form-group input[type=password]:-webkit-autofill:hover,.form-group input[type=email]:-webkit-autofill:hover,.form-group input[type=url]:-webkit-autofill:hover,.form-group input[type=text]:-webkit-autofill:focus,.form-group input[type=password]:-webkit-autofill:focus,.form-group input[type=email]:-webkit-autofill:focus,.form-group input[type=url]:-webkit-autofill:focus{-webkit-text-fill-color:var(--text);-webkit-box-shadow:0 0 0 1000px var(--secondary) inset;box-shadow:0 0 0 1000px var(--secondary) inset;transition:background-color 5000s ease-in-out 0s}.form-hint{display:block;font-size:.8rem;color:var(--text-muted);margin-top:.4rem}.label-optional{font-weight:400;color:var(--text-muted)}.form-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem;min-height:1.5rem}.remember-me{display:inline-flex;align-items:center;gap:.5rem;font-size:.9rem;line-height:1;min-height:1.5rem;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.remember-me input{-moz-appearance:none;appearance:none;-webkit-appearance:none;box-sizing:border-box;width:1.25rem;height:1.25rem;margin:0;padding:0;cursor:pointer;background:var(--secondary);border:1px solid var(--border);border-radius:6px;transition:border-color .2s,box-shadow .2s,transform .2s;flex-shrink:0;align-self:center;transform:translateY(.13em)}.remember-me input:hover{border-color:#3a4150}.remember-me input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.remember-me input:checked{background-color:var(--accent);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230c0e12' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");background-size:.75rem;background-position:center;background-repeat:no-repeat;border-color:var(--accent)}.forgot-link{display:inline-flex;align-items:center;font-size:.9rem;line-height:1;min-height:1.5rem;color:var(--text-muted);text-decoration:none}.forgot-link:hover{color:var(--accent)}.password-wrap{position:relative}.password-wrap input{padding-right:2.75rem}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;padding:.25rem;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;border-radius:6px;transition:color .2s,background .2s}.password-toggle:hover{color:var(--accent)}.password-toggle:focus{outline:none;box-shadow:0 0 0 2px var(--accent-dim)}.password-toggle svg{width:1.25rem;height:1.25rem}.table-search-wrap{position:relative;flex:1;min-width:0}.table-search-row .table-search-wrap{margin-bottom:0}.table-search-wrap svg{position:absolute;left:var(--space-lg);top:50%;transform:translateY(-50%);width:var(--icon-sm);height:var(--icon-sm);color:var(--text-muted);pointer-events:none}.table-search{width:100%;padding:var(--space-md) var(--space-lg) var(--space-md) calc(var(--space-2xl) + var(--space-xl));font-family:inherit;font-size:var(--font-md);color:var(--text);background:var(--secondary);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition-base),box-shadow var(--transition-base)}.table-search:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.per-page-wrap{display:flex;align-items:center;gap:var(--gap-sm);flex-shrink:0;margin-left:auto}.per-page-wrap label{font-size:var(--font-sm);color:var(--text-muted);white-space:nowrap}.per-page-selector{padding:var(--space-md) var(--space-2xl) var(--space-md) var(--space-lg);font-family:inherit;font-size:var(--font-sm);color:var(--text);background:var(--secondary);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--transition-base),box-shadow var(--transition-base);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238b92a0' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-md) center}.per-page-selector:hover{border-color:var(--accent)}.per-page-selector:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.table-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg);gap:var(--gap-lg);flex-wrap:wrap}.table-section-header h2{margin:0;font-size:var(--font-lg);font-weight:var(--weight-semibold);color:var(--text)}.table-search-row{display:flex;align-items:center;gap:var(--gap-md);margin-bottom:var(--space-lg)}.item-cell{display:flex;align-items:center;gap:var(--gap-md)}.item-cell-avatar{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--secondary);border:1px solid var(--border);color:var(--text-muted);font-size:var(--font-xs);font-weight:var(--weight-semibold);flex-shrink:0;overflow:hidden}.item-cell-avatar img{width:100%;height:100%;object-fit:cover}.item-cell-info{display:flex;flex-direction:column;gap:.15rem;min-width:0}.table-cell-name-wrap{display:flex;align-items:center;gap:var(--gap-sm)}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.online{background:var(--status-success);box-shadow:0 0 8px var(--status-success)}.status-dot.offline{background:var(--status-error);box-shadow:0 0 8px var(--status-error)}.table-cell-name{font-weight:var(--weight-semibold);font-size:var(--font-md);color:var(--text)}.table-cell-meta{display:flex;align-items:center;gap:var(--gap-lg);flex-wrap:wrap;font-size:var(--font-xs);color:var(--text-muted);margin-top:var(--space-xs)}.table-cell-meta span{display:flex;align-items:center;gap:var(--gap-xs)}.table-cell-meta svg{width:14px;height:14px;opacity:.7;flex-shrink:0}.table-cell-subtitle{font-size:var(--font-sm);color:var(--text-muted)}.table-cell-subtitle a{color:var(--text-muted);text-decoration:none;transition:color var(--transition-base)}.table-cell-subtitle a:hover{color:var(--accent);text-decoration:underline}.table-cell-subtitle a.link-accent{color:var(--accent)}.data-table-wrap.hidden{display:none}.data-table-wrap{overflow-x:auto!important;overflow-y:hidden;-webkit-overflow-scrolling:touch;background:var(--primary);border:1px solid var(--border);border-radius:var(--radius-xl);max-width:100%}.data-table{width:100%;min-width:700px;border-collapse:collapse;font-size:var(--font-sm)}.data-table th,.data-table td{text-align:left;padding:var(--space-md) var(--space-md);border-bottom:1px solid var(--border);vertical-align:middle;white-space:nowrap}.data-table th{font-weight:var(--weight-medium);background-color:var(--secondary);color:var(--text-muted);font-size:var(--font-xs);letter-spacing:.05em;text-transform:uppercase}.data-table td{color:var(--text)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:#2a303c4d}.data-table .col-actions,.data-table .col-center{width:1%;white-space:nowrap;text-align:right}.data-table .col-muted{color:var(--text-muted);font-size:var(--font-xs)}@media(max-width:768px){.table-section,.content-section,.main{width:100%;max-width:100%;overflow:visible}.data-table-wrap{overflow-x:scroll!important;width:100%;max-width:100vw;margin-left:0;margin-right:0}.table-section-header{flex-direction:row;gap:var(--gap-lg);align-items:center}.table-search-row{flex-direction:row;gap:var(--gap-sm)}.table-search-wrap{flex:1;min-width:0}.data-table{font-size:var(--font-sm)}.data-table th,.data-table td{padding:var(--space-md) var(--space-sm)}.table-cell-name{font-size:var(--font-sm)}.table-cell-subtitle{font-size:var(--font-xs)}}.table-pagination{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--gap-md);margin-top:var(--space-lg)}.table-pagination.hidden{display:none}.pagination-info{font-size:var(--font-sm);color:var(--text-muted)}.pagination-btns{display:flex;align-items:center;gap:var(--gap-sm)}#pagination-pages{display:inline-flex;align-items:center;gap:var(--gap-sm)}.pagination-btn{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 var(--space-md);font-family:inherit;font-size:var(--font-sm);font-weight:var(--weight-medium);color:var(--text);background:var(--primary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:color var(--transition-base),border-color var(--transition-base),background var(--transition-base)}.pagination-btn:hover:not(:disabled),.pagination-btn.active,.pagination-btn.active:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-btn.active{cursor:default}.table-no-results{display:none;text-align:center;padding:var(--space-3xl) var(--space-lg);color:var(--text-muted);font-size:var(--font-md);background:var(--primary);border:1px solid var(--border);border-radius:var(--radius-xl);margin-top:var(--space-sm)}.table-no-results.visible{display:block}#devices-list .item-row-actions{display:flex;flex-direction:column;gap:var(--gap-sm);margin-left:auto;width:auto!important;flex:0 0 auto;align-self:center}.item-row-actions-row{display:flex;gap:var(--gap-xs);justify-content:flex-end}.status-dot.pending{background:var(--status-pending);box-shadow:0 0 8px var(--status-pending)}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;position:relative;padding-right:20px}.data-table th.sortable:hover{color:var(--text);background-color:var(--secondary)}.data-table th.sortable:after{content:"";position:absolute;right:5px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;opacity:.3}.data-table th.sortable:hover:after{opacity:.6;border-top:4px solid var(--text-muted)}.data-table th.sort-asc:after{border-bottom:4px solid var(--accent);border-top:none;opacity:1}.data-table th.sort-desc:after{border-top:4px solid var(--accent);border-bottom:none;opacity:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-2xl);opacity:0;visibility:hidden;transition:opacity var(--transition-base),visibility var(--transition-base)}.modal-overlay.is-open{opacity:1;visibility:visible}.modal-dialog{background:var(--secondary);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);max-width:400px;width:100%;padding:var(--space-2xl);transform:scale(.95);transition:transform var(--transition-base)}.modal-overlay.is-open .modal-dialog{transform:scale(1)}.modal-title{font-size:var(--font-lg);font-weight:var(--weight-semibold);color:var(--text);margin-bottom:var(--space-sm)}.modal-message{font-size:var(--font-md);color:var(--text-muted);margin-bottom:var(--space-2xl);line-height:1.5}.modal-message strong{color:var(--text);font-weight:var(--weight-semibold)}.modal-actions{display:flex;gap:var(--gap-md);justify-content:flex-end}#viewer-list{gap:0}#viewer-list .item-row{padding:var(--space-xs);border:none;border-bottom:1px solid var(--border);flex-direction:row!important;align-items:center!important}#viewer-list .item-cell-avatar{width:32px;height:32px;font-size:var(--font-xs)}#viewer-list .item-cell-info{gap:0;display:flex;flex-direction:column;justify-content:center}#viewer-list .table-cell-name{font-size:var(--font-sm);line-height:1.2}#viewer-list .table-cell-meta{margin-top:0;font-size:11px;line-height:1.2}#viewer-list .item-row-actions{width:auto!important;margin-left:auto;flex-direction:row!important;padding-top:0!important;margin-top:0!important;gap:var(--gap-sm)}.modal-close-icon{position:absolute;top:var(--space-2xl);right:var(--space-2xl);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:color var(--transition-base)}.modal-close-icon:hover{color:var(--text)}.modal-close-icon svg{width:20px;height:20px}.viewer-list-modal .modal-title{padding-right:var(--space-xl);margin-top:0;line-height:1}.site-footer{margin:auto auto 0;padding:var(--space-lg) var(--space-2xl) var(--space-2xl);max-width:var(--container-md);width:100%;background:var(--primary);border-top:1px solid var(--border);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.footer-container{display:flex;flex-direction:column;gap:var(--gap-sm)}.footer-top{display:flex;justify-content:space-between;align-items:center;gap:var(--gap-2xl);flex-wrap:wrap}.footer-logo{font-size:var(--font-lg);font-weight:var(--weight-bold);letter-spacing:-.03em;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none;flex-shrink:0}.footer-logo:hover{opacity:.9}.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:var(--gap-2xl);padding-top:var(--space-lg);border-top:1px solid var(--border);flex-wrap:wrap}.footer-copyright{font-size:var(--font-sm);color:var(--text-muted)}.footer-links{display:flex;gap:var(--gap-sm);flex-wrap:wrap;align-items:center}.footer-links a{font-size:var(--font-sm);color:var(--text-muted);text-decoration:none;transition:color var(--transition-base)}.footer-links a:not(:last-child):after{content:"·";margin-left:var(--gap-sm);color:var(--text-muted)}.footer-links a:hover{color:var(--accent)}.footer-social{display:flex;gap:var(--gap-md);align-items:center}.footer-social a{display:inline-flex;align-items:center;color:var(--text-muted);text-decoration:none;transition:color var(--transition-base)}.footer-social a:hover{color:var(--accent)}.footer-social svg{width:var(--icon-md);height:var(--icon-md)}@media(max-width:768px){.site-footer{margin-top:auto;padding:var(--space-lg) var(--space-lg) var(--space-xl)}.footer-top{flex-direction:row;justify-content:space-between;align-items:center}.footer-bottom{flex-direction:column-reverse;align-items:center;text-align:center;gap:var(--gap-md)}}.dashboard-nav{display:flex;align-items:center;gap:var(--gap-md);padding:var(--space-md) var(--space-xl);margin-bottom:var(--space-2xl);background:var(--primary);border:1px solid var(--border);border-radius:var(--radius-xl)}.dashboard-nav a{display:inline-flex;align-items:center;gap:var(--gap-sm);font-size:var(--font-sm);font-weight:var(--weight-medium);color:var(--text-muted);text-decoration:none}.dashboard-nav a:hover,.dashboard-nav a.active{color:var(--accent)}.dashboard-nav a svg{width:var(--icon-md);height:var(--icon-md);flex-shrink:0}.dashboard-nav .nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:var(--icon-sm);height:var(--icon-sm);padding:0 var(--space-xs);background:var(--status-warning);color:var(--bg);font-size:var(--font-xs);font-weight:var(--weight-bold);border-radius:var(--radius-full);margin-left:var(--space-xs)}@media(max-width:768px){.dashboard-nav .dashboard-nav-text{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.dashboard-nav{gap:0;padding:var(--space-xs) var(--space-sm)}.dashboard-nav a{padding:var(--space-xs);min-width:44px;min-height:44px;justify-content:center;gap:0}}.list-section{margin-bottom:var(--space-2xl);width:100%}.list-section h2{font-size:var(--font-xs);font-weight:var(--weight-semibold);color:var(--text);margin:0 0 var(--space-md);text-transform:uppercase;letter-spacing:.05em}.list-section-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-lg)}.list-section-header h2{margin:0}.item-list{list-style:none!important;margin:0!important;padding:0!important;display:flex;flex-direction:column;gap:var(--space-md);width:100%;color:var(--text)}.item-row{display:flex;align-items:center;justify-content:space-between;gap:var(--gap-md);padding:var(--space-lg);background:var(--primary);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;box-sizing:border-box}.item-row .item-cell{flex:1;min-width:0}.item-row-actions{display:flex;gap:var(--gap-xs);margin-left:var(--space-md);flex-shrink:0}.list-empty{color:var(--text-muted);font-size:var(--font-sm);margin:0;padding:var(--space-sm) 0}:root{--bg: #0c0e12;--primary: #14171d;--secondary: #1a1e26;--border: #2a303c;--text: #e6e9ef;--text-muted: #8b92a0;--status-success: #7ed06b;--status-success-dim: rgba(126, 208, 107, .2);--status-warning: #fad01f;--status-warning-dim: rgba(250, 208, 31, .2);--status-error: #ef4444;--status-info: #3b82f6;--status-info-dim: rgba(59, 130, 246, .2);--status-pending: #e07c4c;--status-pending-dim: rgba(224, 124, 76, .2);--alert-success: #7ed06b;--alert-success-dim: rgba(126, 208, 107, .15);--alert-warning: #ffda3c;--alert-warning-dim: rgba(250, 208, 31, .15);--alert-error: #ef4444;--alert-error-dim: rgba(239, 68, 68, .15);--alert-info: #68bfd3;--alert-info-dim: rgba(104, 191, 211, .15);--btn-primary: #7ed06b;--btn-primary-dim: rgba(126, 208, 107, .15);--btn-primary-glow: rgba(126, 208, 107, .25);--btn-secondary: #1a1e26;--btn-secondary-dim: rgba(26, 30, 38, .15);--btn-secondary-glow: rgba(26, 30, 38, .25);--btn-info: #68bfd3;--btn-info-dim: rgba(104, 191, 211, .15);--btn-info-glow: rgba(104, 191, 211, .25);--btn-danger: #ef4444;--btn-danger-dim: rgba(239, 68, 68, .15);--btn-danger-glow: rgba(239, 68, 68, .25);--btn-warning: #fad01f;--btn-warning-dim: rgba(250, 208, 31, .15);--btn-warning-glow: rgba(250, 208, 31, .25);--btn-pending: #e07c4c;--btn-pending-dim: rgba(224, 124, 76, .2);--accent: #7ed06b;--accent-dim: rgba(126, 208, 107, .15);--glow: rgba(126, 208, 107, .25);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 10px;--radius-xl: 12px;--radius-full: 50%;--space-xs: .25rem;--space-sm: .5rem;--space-md: .75rem;--space-lg: 1rem;--space-xl: 1.25rem;--space-2xl: 1.5rem;--space-3xl: 2rem;--gap-xs: .25rem;--gap-sm: .5rem;--gap-md: .75rem;--gap-lg: 1rem;--gap-xl: 1.5rem;--gap-2xl: 2rem;--font-xxs: .6rem;--font-xs: .75rem;--font-sm: .85rem;--font-md: .95rem;--font-lg: 1.25rem;--font-xl: 1.5rem;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--icon-sm: 18px;--icon-md: 20px;--icon-lg: 24px;--container-sm: 720px;--container-md: 840px;--transition-fast: .15s;--transition-base: .2s;--transition-slow: .3s;--z-header: 100;--z-menu: 101;--z-dropdown: 200;--z-modal: 300;--shadow-sm: 0 4px 12px rgba(0, 0, 0, .3);--shadow-md: 0 4px 20px var(--glow);--shadow-lg: 0 6px 28px var(--glow);--gradient: linear-gradient(90deg, #1e3c72, #2a5298, #00b09b, #96c93d)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:DM Sans,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;overflow-x:hidden;display:flex;flex-direction:column}.main .content-two-col{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap-2xl);align-items:start}
