@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--primary:#16a34a;--primary-light:#22c55e;--primary-pale:#dcfce7;--primary-gradient:linear-gradient(135deg, #16a34a 0%, #22c55e 100%);--accent:#0ea5e9;--accent-light:#38bdf8;--bg:#f4f6f9;--bg-secondary:#eef2f7;--surface:#fff;--surface-border:#e2e8f0;--text:#0f172a;--text-muted:#64748b;--text-light:#94a3b8;--red:#ef4444;--red-light:#fee2e2;--blue:#3b82f6;--blue-light:#dbeafe;--sidebar-width:240px;--bottom-nav-height:62px;--radius:12px;--radius-sm:8px;--radius-lg:16px;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow:0 4px 12px #00000014, 0 2px 4px #0000000a;--shadow-lg:0 10px 30px #0000001a, 0 4px 8px #0000000d;--transition:.2s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{background-color:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;min-height:-webkit-fill-available;font-family:Inter,system-ui,-apple-system,sans-serif}#root{flex-direction:column;min-height:100vh;display:flex}a{color:inherit;text-decoration:none}button,a,label{-webkit-tap-highlight-color:transparent}.auth-page{background:var(--bg);grid-template-columns:1fr 460px;min-height:100vh;display:grid}.auth-hero{background:linear-gradient(150deg,#022c22 0%,#14532d 40%,#15803d 100%);flex-direction:column;justify-content:center;padding:4rem 3.5rem;display:flex;position:relative;overflow:hidden}.auth-hero:before{content:"";background:radial-gradient(at 20%,#22c55e33 0%,#0000 55%),radial-gradient(at 85% 10%,#0ea5e91f 0%,#0000 45%);position:absolute;inset:0}.auth-hero-content{z-index:1;position:relative}.auth-hero-icon{color:#4ade80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1a;border:1px solid #ffffff1f;border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:1.75rem;display:flex}.auth-hero h1{color:#fff;letter-spacing:-.02em;margin-bottom:1rem;font-size:2.25rem;font-weight:800;line-height:1.15}.auth-hero>.auth-hero-content>p{color:#fff9;font-size:1rem;line-height:1.75}.auth-hero-features{flex-direction:column;gap:.875rem;margin-top:2.5rem;display:flex}.auth-feature{color:#ffffffc7;align-items:center;gap:.75rem;font-size:.875rem;display:flex}.auth-feature svg{color:#4ade80;flex-shrink:0}.auth-right{background:#fff;justify-content:center;align-items:center;padding:2.5rem 2rem;display:flex;overflow-y:auto}.auth-form-wrap{width:100%;max-width:360px}.auth-form-wrap h2{color:var(--text);letter-spacing:-.02em;font-size:1.6rem;font-weight:700}.auth-sub{color:var(--text-muted);margin-top:.3rem;margin-bottom:2rem;font-size:.9rem}.form-group{margin-bottom:1rem}.form-group label{color:var(--text);letter-spacing:.01em;margin-bottom:.4rem;font-size:.8rem;font-weight:600;display:block}.form-input{border-radius:var(--radius-sm);border:1.5px solid var(--surface-border);width:100%;color:var(--text);transition:border-color var(--transition), box-shadow var(--transition);-webkit-appearance:none;background:#fff;outline:none;padding:11px 14px;font-family:inherit;font-size:.95rem}.form-input:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px #22c55e1a}input:not(.form-input):not(.edit-input-inline){border-radius:var(--radius-sm);border:1.5px solid var(--surface-border);color:var(--text);transition:border-color var(--transition), box-shadow var(--transition);-webkit-appearance:none;background:#fff;outline:none;padding:10px 14px;font-family:Inter,sans-serif;font-size:.925rem}input:not(.form-input):not(.edit-input-inline):focus{border-color:var(--primary-light);box-shadow:0 0 0 3px #22c55e1a}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;letter-spacing:.01em;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border:none;justify-content:center;align-items:center;gap:.45rem;padding:10px 18px;font-family:inherit;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex}.btn:active{opacity:.85;transform:scale(.98)}.btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:0 2px 8px #16a34a4d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px #16a34a6b}.btn-secondary{color:var(--text);border:1.5px solid var(--surface-border);background:#fff}.btn-secondary:hover{background:var(--bg);border-color:#cbd5e1}.btn-outline{color:var(--primary);border:1.5px solid var(--primary-light);background:0 0}.btn-outline:hover{background:var(--primary-pale)}.btn-ghost{color:var(--text-muted);background:0 0;border:none}.btn-ghost:hover{background:var(--bg-secondary);color:var(--text)}.btn-danger{background:var(--red-light);color:var(--red);border:1px solid #fca5a5}.btn-danger:hover{background:#fecaca}.btn-success{background:var(--primary-pale);color:var(--primary);border:1px solid #86efac}.btn-full{justify-content:center;width:100%;padding:12px}.btn-sm{border-radius:6px;padding:6px 12px;font-size:.8rem}@media (width<=640px){.btn{padding:11px 18px}.btn-sm{padding:8px 14px;font-size:.825rem}}button{font-family:Inter,sans-serif}.layout-root{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);z-index:200;background:#0d1f14;flex-direction:column;flex-shrink:0;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar-logo{border-bottom:1px solid #ffffff12;align-items:center;gap:.7rem;padding:1.25rem 1.25rem 1rem;display:flex}.sidebar-logo-icon{background:var(--primary-gradient);color:#fff;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex;box-shadow:0 2px 8px #16a34a66}.sidebar-logo-text{flex-direction:column;display:flex}.sidebar-logo-text span:first-child{color:#fff;font-size:.9rem;font-weight:700;line-height:1.2}.sidebar-logo-text span:last-child{color:#ffffff59;letter-spacing:.06em;text-transform:uppercase;font-size:.65rem}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:.75rem;display:flex}.sidebar-section-label{color:#ffffff40;text-transform:uppercase;letter-spacing:.12em;margin-top:.5rem;padding:.5rem .75rem;font-size:.6rem;font-weight:700}.sidebar-link{color:#ffffff80;transition:all var(--transition);cursor:pointer;border-radius:8px;align-items:center;gap:.7rem;padding:.6rem .75rem;font-size:.875rem;font-weight:500;display:flex}.sidebar-link:hover{color:#ffffffe0;background:#ffffff12}.sidebar-link.active{color:#4ade80;background:#22c55e24;font-weight:600}.sidebar-footer{border-top:1px solid #ffffff12;padding:.875rem .75rem}.sidebar-user{border-radius:8px;align-items:center;gap:.7rem;margin-bottom:.4rem;padding:.5rem .6rem;display:flex}.sidebar-avatar{background:var(--primary-gradient);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:.75rem;font-weight:700;display:flex}.sidebar-user-info span:first-child{color:#ffffffd1;text-overflow:ellipsis;white-space:nowrap;max-width:155px;font-size:.78rem;font-weight:600;display:block;overflow:hidden}.sidebar-user-info span:last-child{color:#ffffff4d;font-size:.68rem}.sidebar-logout{color:#ffffff61;cursor:pointer;transition:all var(--transition);text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:.7rem;width:100%;padding:.55rem .75rem;font-family:inherit;font-size:.85rem;font-weight:500;display:flex}.sidebar-logout:hover{color:#fca5a5;background:#ef44441f;transform:none}.main-content{margin-left:var(--sidebar-width);background:var(--bg);flex-direction:column;flex:1;min-height:100vh;display:flex}.page-header{border-bottom:1px solid var(--surface-border);z-index:10;background:#fff;justify-content:space-between;align-items:center;padding:1.25rem 2rem;display:flex;position:sticky;top:0}.page-header h1{color:var(--text);letter-spacing:-.01em;align-items:center;gap:.6rem;font-size:1.35rem;font-weight:700;display:flex}.page-header p{color:var(--text-muted);margin-top:.15rem;font-size:.82rem}.page-body{flex:1;padding:1.5rem 2rem}.bottom-nav{height:var(--bottom-nav-height);border-top:1px solid var(--surface-border);z-index:300;padding:0 .5rem;padding-bottom:env(safe-area-inset-bottom,0);background:#fff;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #00000012}.bottom-nav-inner{align-items:stretch;height:100%;display:flex}.bottom-nav-item{color:var(--text-light);cursor:pointer;transition:color var(--transition), background var(--transition);-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:10px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:8px 4px;font-family:inherit;font-size:.65rem;font-weight:500;text-decoration:none;display:flex}.bottom-nav-item svg{transition:color var(--transition)}.bottom-nav-item.active,.bottom-nav-item.active svg{color:var(--primary)}.bottom-nav-icon-wrap{width:32px;height:26px;transition:background var(--transition);border-radius:8px;justify-content:center;align-items:center;display:flex;position:relative}.bottom-nav-item.active .bottom-nav-icon-wrap{background:var(--primary-pale)}.mobile-sidebar-overlay{z-index:199;background:#00000080;display:none;position:fixed;inset:0}.card{border:1px solid var(--surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;overflow:hidden}.card-header{border-bottom:1px solid var(--surface-border);justify-content:space-between;align-items:center;padding:1.1rem 1.5rem;display:flex}.card-title{color:var(--text);font-size:.95rem;font-weight:700}.card-body{padding:1.5rem}.device-card{border:1px solid var(--surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition);background:#fff;margin-bottom:1.25rem;overflow:hidden}.device-card:hover{box-shadow:var(--shadow)}.device-card-header{border-bottom:1px solid var(--surface-border);background:#fff;justify-content:space-between;align-items:center;gap:.75rem;padding:1rem 1.25rem;display:flex}.device-card-name{color:var(--text);font-size:1rem;font-weight:700}.device-token-badge{color:var(--text-muted);background:var(--bg);border:1px solid var(--surface-border);border-radius:20px;padding:2px 7px;font-family:Courier New,monospace;font-size:.7rem}.status-badge{text-transform:capitalize;border-radius:20px;align-items:center;gap:.35rem;padding:3px 9px;font-size:.72rem;font-weight:700;display:inline-flex}.status-badge.online{color:#15803d;background:#dcfce7}.status-badge.offline{color:#64748b;background:#f1f5f9}.status-dot{background:currentColor;border-radius:50%;width:5px;height:5px}.status-badge.online .status-dot{animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.relay-list{flex-direction:column;gap:.75rem;padding:1rem;display:flex}.relay-item{background:var(--bg);border:1.5px solid var(--surface-border);transition:border-color var(--transition), box-shadow var(--transition);border-radius:10px;padding:.875rem 1rem}.relay-item:hover{box-shadow:var(--shadow-sm);border-color:#cbd5e1}.relay-item.active{background:#f0fdf4;border-color:#86efac}.relay-item-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.relay-name-group{flex-wrap:wrap;align-items:center;gap:.5rem;min-width:0;display:flex}.relay-name{color:var(--text);font-size:.9rem;font-weight:600}.relay-mode-badge{letter-spacing:.02em;border-radius:20px;align-items:center;gap:.25rem;padding:2px 7px;font-size:.68rem;font-weight:700;display:inline-flex}.relay-mode-badge.manual{color:#92400e;background:#fef3c7}.relay-mode-badge.auto{background:var(--blue-light);color:#1e40af}.relay-actions{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.toggle-switch{flex-shrink:0;width:48px;height:26px;position:relative}.toggle-switch input{display:none}.toggle-track{cursor:pointer;transition:background var(--transition);background:#e2e8f0;border-radius:13px;position:absolute;inset:0}.toggle-switch input:checked+.toggle-track{background:var(--primary)}.toggle-thumb{width:20px;height:20px;transition:transform var(--transition);pointer-events:none;background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #00000040}.toggle-switch input:checked~.toggle-thumb{transform:translate(22px)}.schedule-panel{border:1px solid var(--surface-border);background:#fff;border-radius:8px;margin-top:.75rem;overflow:hidden}.schedule-panel-header{background:var(--bg);border-bottom:1px solid var(--surface-border);justify-content:space-between;align-items:center;padding:.65rem 1rem;display:flex}.schedule-panel-header span{color:var(--text);font-size:.8rem;font-weight:600}.schedule-add-form{border-bottom:1px solid var(--surface-border);flex-wrap:wrap;align-items:center;gap:.5rem;padding:.875rem 1rem;display:flex}.schedule-list{padding:0}.schedule-entry{border-bottom:1px solid var(--surface-border);justify-content:space-between;align-items:center;gap:.5rem;padding:.65rem 1rem;font-size:.85rem;display:flex}.schedule-entry:last-child{border-bottom:none}.schedule-time{color:var(--text);align-items:center;gap:.4rem;font-weight:500;display:flex}.schedule-time-sep{color:var(--text-muted)}.landing-root{color:#fff;background:#071a0f;flex-direction:column;min-height:100vh;display:flex;position:relative;overflow:hidden}.landing-bg-orbs{pointer-events:none;z-index:0;position:fixed;inset:0}.orb{filter:blur(80px);border-radius:50%;position:absolute}.orb-1{background:radial-gradient(circle,#16a34a38,#0000 70%);width:700px;height:700px;top:-250px;right:-150px}.orb-2{background:radial-gradient(circle,#0ea5e91f,#0000 70%);width:500px;height:500px;bottom:-100px;left:5%}.orb-3{background:radial-gradient(circle,#22c55e1a,#0000 70%);width:350px;height:350px;top:45%;left:35%}.landing-nav{z-index:10;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:1.25rem 2rem;display:flex;position:relative}.landing-logo{align-items:center;gap:.65rem;font-size:1rem;font-weight:700;display:flex}.landing-logo-icon{background:var(--primary-gradient);color:#fff;border-radius:9px;justify-content:center;align-items:center;width:34px;height:34px;display:flex;box-shadow:0 2px 10px #16a34a73}.landing-hero{z-index:5;text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:5rem 2rem 3rem;display:flex;position:relative}.landing-badge{color:#86efac;letter-spacing:.05em;text-transform:uppercase;background:#22c55e14;border:1px solid #22c55e40;border-radius:20px;align-items:center;gap:.5rem;margin-bottom:1.75rem;padding:5px 14px;font-size:.75rem;font-weight:600;display:inline-flex}.landing-hero h1{letter-spacing:-.03em;max-width:680px;margin-bottom:1.25rem;font-size:clamp(2.25rem,7vw,4rem);font-weight:800;line-height:1.1}.landing-hero h1 span{background:linear-gradient(135deg,#4ade80 0%,#22d3ee 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.landing-hero>p{color:#ffffff8c;max-width:520px;margin-bottom:2.5rem;font-size:1.05rem;line-height:1.75}.landing-cta{justify-content:center;align-items:center;gap:1rem;display:flex}.landing-stats{border-top:1px solid #ffffff12;flex-wrap:wrap;justify-content:center;gap:2.5rem;margin-top:3.5rem;padding-top:2.5rem;display:flex}.landing-stat-value{color:#fff;letter-spacing:-.02em;font-size:1.4rem;font-weight:800}.landing-stat-label{color:#ffffff59;text-transform:uppercase;letter-spacing:.07em;margin-top:.2rem;font-size:.7rem}.landing-features{z-index:5;border-top:1px solid #ffffff0d;grid-template-columns:repeat(3,1fr);gap:1.25rem;width:100%;max-width:960px;margin:0 auto;padding:2.5rem 2rem;display:grid;position:relative}.feature-card{transition:all var(--transition);background:#ffffff0a;border:1px solid #ffffff12;border-radius:14px;padding:1.5rem}.feature-card:hover{background:#ffffff12;border-color:#ffffff1f;transform:translateY(-2px)}.feature-icon{border-radius:11px;justify-content:center;align-items:center;width:42px;height:42px;margin-bottom:1rem;display:flex}.feature-icon.green{color:#4ade80;background:#22c55e1f}.feature-icon.blue{color:#60a5fa;background:#3b82f61f}.feature-icon.orange{color:#fbbf24;background:#f59e0b1f}.feature-card h3{color:#fff;margin-bottom:.5rem;font-size:.95rem;font-weight:700}.feature-card p{color:#ffffff73;font-size:.82rem;line-height:1.65}.landing-footer{z-index:5;border-top:1px solid #ffffff0d;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 2rem;display:flex;position:relative}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1.5rem}.empty-state h3{color:var(--text);margin:.75rem 0 .35rem;font-size:.95rem;font-weight:600}.empty-state p{font-size:.85rem}.loading-screen{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.spinner{border:3px solid var(--surface-border);border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.edit-input-inline{border:1.5px solid var(--primary-light);color:var(--text);-webkit-appearance:none;background:#fff;border-radius:6px;outline:none;width:170px;padding:5px 10px;font-family:inherit;font-size:.875rem}.doc-section{border:1px solid var(--surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;margin-bottom:1rem;padding:1.5rem}.doc-section-header{align-items:center;margin-bottom:.75rem;display:flex}.doc-section-num{background:var(--primary-pale);width:28px;height:28px;color:var(--primary);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;margin-right:.7rem;font-size:.8rem;font-weight:700;display:inline-flex}.doc-section h3{color:var(--text);font-size:.975rem;font-weight:700}.doc-section p{color:var(--text-muted);font-size:.875rem;line-height:1.7}@media (width<=900px){.auth-page{grid-template-columns:1fr}.auth-hero{display:none}.auth-right{min-height:100vh;padding:2rem 1.5rem}.landing-features{grid-template-columns:1fr 1fr;padding:2rem 1.5rem}}@media (width<=640px){.sidebar{display:none}.main-content{padding-bottom:var(--bottom-nav-height);margin-left:0}.bottom-nav{display:flex}.page-header{padding:1rem 1.25rem;position:sticky;top:0}.page-header h1{font-size:1.15rem}.page-header p{font-size:.78rem}.page-body{padding:1rem}.auth-right{align-items:flex-start;padding:3rem 1.25rem 2rem}.landing-nav{padding:1rem 1.25rem}.landing-hero{padding:3rem 1.25rem 2rem}.landing-hero>p{font-size:.95rem}.landing-badge{font-size:.68rem}.landing-stats{gap:1.5rem;margin-top:2.5rem;padding-top:2rem}.landing-stat-value{font-size:1.2rem}.landing-features{grid-template-columns:1fr;gap:1rem;padding:1.5rem 1.25rem}.landing-footer{text-align:center;flex-direction:column;gap:.4rem;padding:1rem 1.25rem}.device-card-header{flex-direction:column;align-items:flex-start;gap:.5rem}.relay-item-header{flex-wrap:wrap}.relay-actions{justify-content:flex-end;width:100%;margin-top:.25rem}.schedule-add-form{flex-direction:column;align-items:stretch}.schedule-add-form input[type=time],.schedule-add-form .btn{width:100%}.card-body{padding:1.25rem}.card-header{padding:.9rem 1.25rem}.doc-section{padding:1.25rem}}@media (width<=380px){.landing-hero h1{font-size:2rem}.landing-stats{gap:1rem}}.ctrl-stats-bar{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.ctrl-stat-chip{border:1px solid #0000;border-radius:20px;align-items:center;gap:.4rem;padding:5px 12px;font-size:.78rem;font-weight:600;display:inline-flex}.ctrl-stat-chip.online{color:#15803d;background:#dcfce7;border-color:#bbf7d0}.ctrl-stat-chip.offline{color:#64748b;background:#f1f5f9;border-color:#e2e8f0}.ctrl-stat-chip.active{color:#854d0e;background:#fef9c3;border-color:#fde68a}.ctrl-stat-chip.total{color:#475569;background:#fff;border-color:#e2e8f0}.ctrl-header-right{align-items:center;gap:.75rem;margin-left:auto;display:flex}.ctrl-last-updated{color:var(--text-light);white-space:nowrap;font-size:.75rem}.ctrl-device-block{border:1px solid var(--surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;margin-bottom:1.5rem;overflow:hidden}.ctrl-device-header{border-bottom:1px solid var(--surface-border);background:linear-gradient(135deg,#fafafa,#fff);justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.ctrl-device-meta{align-items:center;gap:.75rem;display:flex}.ctrl-device-icon{width:38px;height:38px;color:var(--primary);background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.ctrl-device-name{color:var(--text);font-size:1rem;font-weight:700}.ctrl-device-token{color:var(--text-muted);background:var(--bg);border:1px solid var(--surface-border);border-radius:20px;margin-top:2px;padding:2px 7px;font-family:Courier New,monospace;font-size:.7rem;display:inline-block}.ctrl-device-actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.relay-grid{grid-template-columns:repeat(2,1fr);gap:1rem;padding:1.25rem;display:grid}.relay-tile{background:var(--bg);border:2px solid var(--surface-border);border-radius:var(--radius);cursor:default;flex-direction:column;gap:.75rem;padding:1.25rem;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.relay-tile.on{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#86efac}.relay-tile.auto-mode{opacity:.75}.relay-tile-glow{pointer-events:none;opacity:0;background:radial-gradient(circle,#22c55e40,#0000 70%);border-radius:50%;width:80px;height:80px;transition:opacity .3s;position:absolute;top:-20px;right:-20px}.relay-tile.on .relay-tile-glow{opacity:1}.relay-tile-top{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.relay-tile-number{width:26px;height:26px;color:var(--text-muted);background:#0000000d;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:flex}.relay-tile.on .relay-tile-number{color:var(--primary);background:#16a34a1f}.relay-tile-name{color:var(--text);flex:1;font-size:.9rem;font-weight:700;line-height:1.3}.relay-tile-status-dot{background:#cbd5e1;border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:4px;transition:all .3s}.relay-tile.on .relay-tile-status-dot{background:var(--primary);box-shadow:0 0 6px #22c55ecc}.relay-tile-bottom{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.relay-tile-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;font-weight:600}.relay-tile.on .relay-tile-label{color:#15803d}.relay-tile-btn{letter-spacing:.03em;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.4rem;min-width:80px;min-height:36px;padding:8px 16px;font-family:inherit;font-size:.8rem;font-weight:700;transition:all .2s;display:inline-flex}.relay-tile-btn.btn-on{background:var(--primary-gradient);color:#fff;box-shadow:0 2px 8px #16a34a4d}.relay-tile-btn.btn-on:hover{transform:translateY(-1px);box-shadow:0 4px 12px #16a34a73}.relay-tile-btn.btn-on:active{transform:scale(.97)}.relay-tile-btn.btn-off{color:var(--text);border:1.5px solid var(--surface-border);background:#fff}.relay-tile-btn.btn-off:hover{background:var(--bg);border-color:#cbd5e1}.relay-tile-btn.btn-off:active{transform:scale(.97)}.relay-tile-btn.btn-auto{background:var(--blue-light);color:var(--blue);cursor:not-allowed;opacity:.8;border:1.5px solid #bfdbfe}.relay-tile-btn:disabled{cursor:not-allowed;opacity:.6;box-shadow:none!important;transform:none!important}.btn-spinner{border:2px solid #ffffff59;border-top-color:currentColor;border-radius:50%;flex-shrink:0;width:13px;height:13px;animation:.6s linear infinite spin}.relay-tile-auto-notice{color:var(--blue);align-items:center;gap:.3rem;margin-top:.25rem;font-size:.72rem;display:flex}@media (width<=900px){.relay-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.relay-grid{grid-template-columns:1fr;gap:.75rem;padding:.875rem}.relay-tile{padding:1rem}.relay-tile-btn{min-height:42px;font-size:.875rem}.ctrl-device-header{flex-direction:column;align-items:flex-start}.ctrl-device-actions{justify-content:space-between;width:100%}.ctrl-stats-bar{gap:.5rem}.ctrl-stat-chip{padding:4px 10px;font-size:.72rem}.ctrl-last-updated{display:none}}.sensor-card{border-bottom:1px solid var(--surface-border);background:#fff;align-items:stretch;gap:1.5rem;padding:1.25rem;display:flex;position:relative}.sensor-card.skeleton{justify-content:center;align-items:center;min-height:80px;padding:2rem}.sensor-section{flex-direction:column;flex:1;display:flex}.sensor-divider{background:var(--surface-border);width:1px;margin:.5rem 0}.sensor-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:.4rem;margin-bottom:.5rem;font-size:.75rem;font-weight:600;display:flex}.sensor-value{color:var(--text);letter-spacing:-.03em;margin-bottom:.75rem;font-size:2rem;font-weight:800;line-height:1}.sensor-unit{color:var(--text-light);margin-left:.15rem;font-size:1rem;font-weight:600}.sensor-bar-bg{background:var(--bg-secondary);border-radius:4px;height:4px;margin-top:auto;overflow:hidden}.sensor-bar-fill{border-radius:4px;height:100%;transition:width .5s ease-out}.sensor-footer{color:var(--text-light);align-items:center;gap:.3rem;font-size:.7rem;display:flex;position:absolute;top:1rem;right:1.25rem}@media (width<=640px){.sensor-card{flex-direction:column;gap:1.25rem;padding-top:2.5rem}.sensor-divider{width:100%;height:1px;margin:0}}
