@import"https://fonts.googleapis.com/css2?family=Montserrat:wght@700;900&display=swap";@import"https://fonts.googleapis.com/css2?family=Manrope:wght@800;900&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@600;700;900&display=swap";@tailwind base;@tailwind components;@tailwind utilities;.sidebar{font-family:Inter,Segoe UI,Arial,sans-serif;background:#1c222cb8;border-radius:1.5rem;box-shadow:0 8px 32px #0000002e;border:1.2px solid rgba(60,70,90,.32);backdrop-filter:blur(36px) saturate(120%);-webkit-backdrop-filter:blur(36px) saturate(120%);transition:box-shadow .7s cubic-bezier(.4,2,.6,1),border .7s,transform .6s cubic-bezier(.4,2,.6,1),filter .6s;padding:2rem 1.1rem;margin-top:2.5rem;margin-bottom:2.5rem;width:15rem;min-width:15rem;max-width:15rem;height:calc(100vh - 8rem);min-height:calc(100vh - 8rem);display:flex;flex-direction:column;justify-content:flex-start;z-index:200}@media (min-width: 1399px){.sidebar{position:fixed;top:2.5rem;left:1.5rem;width:320px;height:100vh;z-index:200;margin-top:0!important;margin-bottom:0!important;height:calc(100vh - 10rem);min-height:calc(100vh - 10rem);overflow-y:auto}}@media (max-width: 1399px){.sidebar{background:#1c222ceb;border:1.2px solid rgba(60,70,90,.38);box-shadow:2px 0 24px #00000038;border-radius:0 1.5rem 1.5rem 0;position:fixed;left:0;top:0;height:100vh;min-height:100vh;padding:1.5rem .7rem;z-index:100;margin:0;transform:translate(-100%);transition:transform .35s cubic-bezier(.4,.2,.2,1),opacity .25s;opacity:0;pointer-events:none}.sidebar.open{transform:translate(0);opacity:1;pointer-events:auto}}.sidebar nav{display:flex;flex-direction:column;gap:1.2rem;margin-top:1.2rem;overflow-y:auto;scrollbar-width:none}.sidebar nav::-webkit-scrollbar{display:none}.sidebar-group{margin-bottom:.7rem}.sidebar-group-header{font-size:.92rem;font-weight:600;color:var(--color-secondary-light);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.3rem;padding-left:.7rem;opacity:.85}.sidebar-group-list{list-style:none;margin:0 -.2rem;padding:0;display:flex;flex-direction:column;gap:.2rem;width:calc(100% + 1rem)}.menu-item{margin:0;display:flex;align-items:center;gap:.7rem;padding:.48rem 1.1rem;border-radius:1.1rem;font-size:1.01rem;font-weight:500;color:var(--color-secondary-light);background:#28303c52;border:none;outline:none;transition:background .22s,color .22s,box-shadow .22s,transform .18s;box-shadow:none;cursor:pointer;min-height:2.2rem;width:100%;justify-content:flex-start;box-sizing:border-box;position:relative;overflow:visible}.menu-item .menu-icon{color:var(--color-secondary-xlight)!important;font-size:1.25em;display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 1px 2px var(--color-shadow-menu));transition:color .22s}.menu-label{color:var(--color-white);font-size:1.05rem;font-weight:600;letter-spacing:.01em;font-family:Segoe UI,Arial,sans-serif;transition:color .22s}.menu-item:hover,.menu-item:focus{background:#3c465a61;color:var(--color-primary);box-shadow:0 2px 12px #2c364321;transform:translateY(-1px) scale(1.03)}.menu-item.active{background:linear-gradient(90deg,#39aa792e,#3c465a61);color:var(--color-primary);font-weight:700;box-shadow:none;transform:scale(1.04);z-index:1;position:relative;overflow:visible}.menu-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:100%;height:100%;border-radius:1.2rem;box-shadow:0 0 16px 0 var(--color-primary);opacity:.1;pointer-events:none;z-index:-1;filter:blur(2.5px)}.menu-item.active .menu-icon,.menu-item:hover .menu-icon{color:var(--color-primary)!important;filter:none}.menu-item:active{background:#39aa7938;color:var(--color-primary-dark)}.glass-logo,.homenavi-logo-btn{font-family:Manrope,Montserrat,Inter,Segoe UI,Arial,sans-serif;font-size:1.45rem;font-weight:900;letter-spacing:.18em;color:var(--color-secondary-xlight);text-transform:uppercase;background:none;text-shadow:0 2px 12px var(--color-secondary-xlight);filter:blur(.1px) brightness(1.08);border:none;outline:none;cursor:pointer;padding:.1em .2em;transition:color .18s,text-shadow .18s,filter .18s;display:inline-block}.homenavi-logo-btn:hover,.homenavi-logo-btn:focus{color:var(--color-primary);text-shadow:0 4px 18px var(--color-primary);filter:brightness(1.15)}.menu-btn{background:#28303cb8;border:2px solid rgba(60,70,90,.32);border-radius:1.2rem;color:var(--color-secondary-light);font-size:1.5rem;width:44px;height:44px;padding:0;box-shadow:0 2px 8px #2c36431a;transition:background .2s,color .2s,box-shadow .2s,border .2s;cursor:pointer;outline:none;margin-left:0;position:fixed;top:24px;left:36px;z-index:50;display:flex;flex-direction:column;justify-content:space-between;align-items:center;gap:0}.menu-btn:hover{background:#39aa792e;color:var(--color-primary);box-shadow:0 4px 16px 0 var(--color-primary);border:2px solid var(--color-primary)}.menu-btn:active{background:var(--color-secondary-xlight);color:var(--color-primary)}.glass-card{background:#1c222cad;border-radius:1.5rem;box-shadow:0 8px 32px #0000002e;backdrop-filter:blur(32px) saturate(120%);-webkit-backdrop-filter:blur(32px) saturate(120%);border:1.2px solid rgba(60,70,90,.38);transition:box-shadow .7s cubic-bezier(.4,0,.2,1),border .7s,transform .6s cubic-bezier(.4,0,.2,1),filter .6s;min-width:clamp(180px,30vw,320px);max-width:100%;width:100%;font-weight:700;font-size:1.18rem;display:flex;flex-direction:column;justify-content:center;align-items:stretch;margin:0 auto;color:var(--color-white);padding:clamp(1.2rem,4vw,2.2rem) clamp(1rem,3vw,2rem);box-sizing:border-box;position:relative;z-index:2;font-family:Inter,Segoe UI,Arial,sans-serif}.glass-card:hover{border:1.4px solid var(--color-primary);transform:translateY(-1px) scale(1.01);filter:brightness(1.05) saturate(1.07)}.glass-card.no-hover:hover{border:1.2px solid rgba(60,70,90,.38);transform:none;filter:none}.glass-card .card-content{width:100%;height:100%;display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch;gap:.5rem;border-radius:1.25rem;background:none}.glass-card .card-title{font-size:1.25rem;font-weight:600;color:var(--color-secondary);margin-bottom:.2rem;letter-spacing:-.5px}.glass-card .card-value{font-size:2.2rem;font-weight:700;color:var(--color-primary);margin-bottom:.2rem;letter-spacing:-1px}.glass-card .card-desc{font-size:1rem;color:var(--color-secondary-light);font-weight:400}.card-content-col{display:flex;flex-direction:row;align-items:center;height:100%}.card-content-icon{flex:0 0 48%;display:flex;align-items:center;justify-content:center;height:100%}.card-content-details{flex:1;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:.5rem;padding-left:.5rem}.card-content-details span{display:block;margin-bottom:.2em}.weather-card{min-height:320px;max-height:360px}.weather-cc-vertical{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.1rem;width:100%;height:100%}.weather-cc-header{display:flex;align-items:center;gap:1.2rem;margin-bottom:.2rem}.weather-cc-toprow{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:1.5rem;width:100%}.weather-cc-icon{color:var(--color-weather-sun);filter:drop-shadow(0 2px 12px var(--color-shadow-weather));font-size:4.2rem!important}.weather-cc-tempblock{display:flex;align-items:center;height:100%}.weather-cc-temp{font-size:3.2rem;font-weight:800;color:var(--color-white);letter-spacing:-1px;line-height:1.1;text-align:left;text-shadow:0 2px 12px var(--color-shadow-card)}.weather-cc-descrow{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:1.2rem;width:100%;margin-bottom:.1em}.weather-cc-desc{font-size:1.1rem;font-weight:600;color:var(--color-white);letter-spacing:.08em;opacity:.85}.weather-cc-hilo{font-size:1.1rem;color:var(--color-secondary-xlight);opacity:.85;font-weight:500;letter-spacing:.04em}.weather-cc-location{display:flex;align-items:center;gap:.4rem;font-size:1.1rem;color:var(--color-secondary-xlight);opacity:.85;font-weight:500;letter-spacing:.04em;text-align:center}.weather-cc-location-icon{color:var(--color-primary);font-size:1.2em}.weather-cc-carousel{width:100%;margin-top:1.1rem}.weather-cc-carousel-rowwrap{display:flex;align-items:center;justify-content:center;width:100%;position:relative}.weather-cc-arrow{background:none;border:none;box-shadow:none;color:var(--color-white);font-size:1.6em;width:36px;height:36px;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;margin:0 .2rem;cursor:pointer;transition:color .2s,filter .5s;outline:none;z-index:3;-webkit-user-select:none;user-select:none;filter:none}.weather-cc-arrow:hover,.weather-cc-arrow:focus{color:var(--color-weather-sun);filter:drop-shadow(0 0 8px var(--color-shadow-weather));background:none;border:none}.weather-cc-arrow:active{color:var(--color-weather-sun);filter:drop-shadow(0 0 8px var(--color-shadow-weather));background:none;border:none;animation:weather-cc-arrow-glow-fade .5s forwards}@keyframes weather-cc-arrow-glow-fade{0%{filter:drop-shadow(0 0 8px #FFD93B88)}to{filter:none}}.weather-cc-arrow.left{order:0}.weather-cc-arrow.right{order:2}.weather-cc-tabs{display:flex;justify-content:center;gap:1.2rem;margin-bottom:.5rem}.weather-cc-tabs button{background:#ffffff21;border:none;color:var(--color-white);font-weight:600;font-size:1rem;padding:.4em 1.2em;border-radius:999px;cursor:pointer;transition:background .2s,color .2s;outline:none}.weather-cc-tabs button.active{background:var(--color-primary);color:var(--color-white)}.weather-cc-forecast-row{order:1;flex:1 1 auto;display:flex;align-items:flex-end;gap:1.1rem;width:100%;padding:0;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;position:relative;box-sizing:border-box;max-width:100%}.weather-cc-forecast-row:active{cursor:grabbing}.weather-cc-forecast-row::-webkit-scrollbar{display:none}.weather-cc-forecast-row.scrollable{white-space:nowrap;padding-bottom:.2rem;padding-left:0;padding-right:0}.weather-cc-forecast-item{display:inline-flex;flex-direction:column;align-items:center;gap:.2rem;min-width:56px}.weather-cc-forecast-label{font-size:.95rem;color:var(--color-secondary-xlight);opacity:.8;font-weight:500}.weather-cc-forecast-icon{font-size:1.5rem;color:var(--color-weather-sun);filter:drop-shadow(0 1px 4px var(--color-shadow-weather-light))}.weather-cc-forecast-temp{font-size:1.1rem;color:var(--color-white);font-weight:600}.weather-cc-scroll-hint.left,.weather-cc-scroll-hint.right{position:absolute;top:50%;width:28px;height:48px;pointer-events:none;z-index:2;background:linear-gradient(to right,var(--color-bg) 60%,transparent 100%);border-radius:1.2rem;opacity:.7}.weather-cc-scroll-hint.right{right:0;left:auto;background:linear-gradient(to left,var(--color-bg) 60%,transparent 100%)}.weather-cc-scroll-hint.left{left:0;right:auto}.glass-switch{--switch-width: 48px;--switch-height: 28px;--thumb-size: 24px;--glass-bg: rgba(255,255,255,.18);--glass-border: rgba(255,255,255,.35);--glass-shadow: 0 4px 24px 0 rgba(0,0,0,.12);--active-color: var(--color-primary);width:var(--switch-width);height:var(--switch-height);border:none;background:none;padding:0;cursor:pointer;outline:none;display:inline-flex;align-items:center;transition:filter .2s}.glass-switch.disabled{opacity:.5;pointer-events:none}.glass-switch-track{width:100%;height:100%;border-radius:999px;background:var(--glass-bg);border:1.5px solid var(--glass-border);box-shadow:var(--glass-shadow);display:flex;align-items:center;transition:background .2s,border .2s;position:relative}.glass-switch.checked .glass-switch-track{background:linear-gradient(90deg,var(--active-color) 60%,#b6f7c1 100%);border-color:var(--active-color)}.glass-switch-thumb{width:var(--thumb-size);height:var(--thumb-size);border-radius:50%;background:#ffffffb3;box-shadow:0 2px 8px #0000001a;position:absolute;left:2px;top:50%;transform:translateY(-50%) translate(0);transition:transform .25s cubic-bezier(.4,2,.6,1),background .2s}.glass-switch.checked .glass-switch-thumb{background:#fff;transform:translateY(-50%) translate(20px)}.device-card{min-height:240px;max-height:280px}.glass-btn{background:var(--color-glass-bg-strong);border:1.5px solid var(--color-glass-border);box-shadow:0 2px 12px #0000001a;border-radius:999px;color:var(--color-white);transition:background .2s,border .2s,box-shadow .2s;outline:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:1.2em}.glass-btn:hover,.glass-btn:focus{background:#ffffff47;border-color:var(--color-white);box-shadow:0 4px 16px #00000029}.devicecard-row{display:flex;align-items:center;gap:1.2rem;width:100%;height:100%;padding:.2rem .1rem}.devicecard-vertical{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;width:100%;height:100%;margin:0 auto}.devicecard-toprow{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:1.1rem;margin-bottom:.5rem}.devicecard-iconwrap{display:flex;align-items:center;justify-content:center;height:48px;width:48px;background:var(--color-glass-bg-light);border-radius:1.1rem;box-shadow:0 2px 8px #00000014}.devicecard-icon{filter:drop-shadow(0 1px 4px var(--color-shadow-device))}.devicecard-details{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.1rem;min-width:0;text-align:center}.devicecard-title{font-size:1.25rem;font-weight:700;color:var(--color-white);letter-spacing:-.5px;padding-bottom:.1em;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.devicecard-sub{font-size:1rem;color:var(--color-secondary-xlight);opacity:.7;font-weight:500;letter-spacing:.04em}.devicecard-controls{display:flex;align-items:center;gap:.7rem;margin-left:auto}.devicecard-controls-below{display:flex;align-items:center;justify-content:center;gap:1.1rem;margin-top:.7rem}.glass-switch{height:30px;min-width:40px;max-width:50px;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.devicecard-btn{padding:.4em .7em;font-size:1.1em;height:33px;min-width:40px;max-width:50px;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.spotify-card{min-height:380px;max-height:420px}.spotify-cc-vertical{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.1rem;width:100%;height:100%}.spotify-cc-header{display:flex;align-items:center;gap:.7rem;margin-bottom:.2rem}.spotify-cc-logo{color:var(--color-spotify);filter:drop-shadow(0 1px 4px var(--color-shadow-spotify))}.spotify-cc-label{font-size:1.1rem;font-weight:600;color:var(--color-white);letter-spacing:.08em;opacity:.85}.spotify-cc-songinfo{display:flex;flex-direction:column;align-items:center;gap:.1rem}.spotify-cc-title{font-size:1.25rem;font-weight:700;color:var(--color-white);letter-spacing:-.5px;margin-bottom:.1em;line-height:1.1;text-align:center}.spotify-cc-artist{font-size:1rem;color:var(--color-secondary-xlight);opacity:.7;font-weight:500;letter-spacing:.04em;text-align:center}.spotify-cc-slider{width:90%;height:6px;background:var(--color-shadow-card);border-radius:3px;margin:.2rem auto;position:relative}.spotify-cc-slider-bar{height:100%;background:var(--color-spotify);border-radius:3px;position:absolute;left:0;top:0}.spotify-cc-controls{display:flex;gap:1.5rem;align-items:center;justify-content:center;margin-top:.2rem}.spotify-cc-btn{background:var(--color-glass-bg-strong);border:1.5px solid var(--color-glass-border);color:var(--color-white);font-size:1.3em;transition:background .2s,border .2s,box-shadow .2s,color .2s;outline:none;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:999px;padding:.5em .9em;box-shadow:0 2px 8px #0000001a}.spotify-cc-btn.play{background:var(--color-spotify);color:var(--color-white);border:none;font-size:1.5em;box-shadow:0 2px 12px 0 var(--color-shadow-spotify)}.spotify-cc-btn:hover,.spotify-cc-btn:active{background:#ffffff47;border-color:var(--color-white);color:var(--color-spotify)}.spotify-cc-btn.play:hover,.spotify-cc-btn.play:focus{background:var(--color-primary-dark);color:var(--color-white)}.map-card{min-height:300px;max-height:340px}.map-card-svg{width:100%;height:120px;object-fit:cover;border-radius:1.2rem 1.2rem 0 0;margin-bottom:.5rem}.map-card-bottom{position:absolute;left:0;right:0;bottom:0;width:100%;display:flex;justify-content:space-between;align-items:flex-end;padding:.7rem 1.1rem;background:var(--gradient-map-card);border-radius:0 0 1.2rem 1.2rem}.map-card-label{color:var(--color-white);font-size:1.1rem;font-weight:700;letter-spacing:.12em;text-shadow:0 2px 8px var(--color-shadow-dark)}.map-card-btn{border:1.5px solid var(--color-white);background:var(--color-glass-bg-light);color:var(--color-white);border-radius:9999px;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;transition:background .2s,border .2s}.map-card-btn:hover{background:var(--color-white);color:var(--color-secondary);border:1.5px solid var(--color-primary)}.add-device-plus{font-size:4.5rem;color:var(--color-white);margin:0 auto;margin-top:1.2rem;margin-bottom:.5rem;filter:drop-shadow(0 2px 8px var(--color-shadow-menu))}.add-device-label{color:var(--color-white);font-size:1.1rem;font-weight:600;margin-top:auto;margin-bottom:1.2rem;letter-spacing:.08em}.masonry-dashboard{column-count:1;column-gap:1.2rem;padding:0 .5rem;max-width:100%;box-sizing:border-box;margin-right:10px;margin-left:10px}@media (min-width: 500px){.masonry-dashboard{column-count:2;column-gap:1.5rem}}@media (min-width: 1200px){.masonry-dashboard{column-count:3;column-gap:2rem}}@media (min-width: 1800px){.masonry-dashboard{column-count:4;column-gap:2.5rem}}.masonry-dashboard>*{break-inside:avoid;margin-bottom:1.8rem;width:100%;max-width:100%;box-sizing:border-box}.dashboard-greeting{padding-left:1.5rem;padding-right:2.5rem;font-size:2.4rem;font-weight:900;color:var(--color-white);padding-left:5rem;padding-bottom:.5rem;letter-spacing:-1px;text-shadow:0 2px 12px var(--color-shadow-dark);display:flex;align-items:flex-end;margin-bottom:1.2rem;position:relative;z-index:2}.dashboard-greeting--with-profile-btn{margin-right:7.5rem}@media (max-width: 700px){.dashboard-greeting{font-size:2rem;min-height:2.2rem}.dashboard-greeting--with-profile-btn{margin-right:3.5rem}}.glass-metric{display:flex;align-items:center;justify-content:space-between;gap:.9rem;padding:.35rem 0;color:#ffffffd9}.glass-metric+.glass-metric{border-top:1px solid rgba(255,255,255,.05);margin-top:.25rem;padding-top:.6rem}.glass-metric-label{display:flex;align-items:center;gap:.5rem;font-size:.82rem;text-transform:capitalize;color:#ffffffb3}.glass-metric-icon{font-size:.9rem;color:#ffffffa6}.glass-metric-value{display:flex;align-items:baseline;gap:.4rem;font-weight:600;font-size:.95rem;color:#fff}.glass-metric-unit{margin-left:.2rem;font-size:.75rem;font-weight:500;color:#fff9}.glass-metric-hint{font-size:.7rem;color:#ffffff8c}.glass-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .75rem;font-size:.75rem;font-weight:500;border-radius:999px;border:1px solid rgba(255,255,255,.15);background:#ffffff14;color:#ffffffd1;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);white-space:nowrap}.glass-pill-icon{font-size:.8rem;opacity:.9}.glass-pill-default{border-color:#ffffff1f}.glass-pill-success{border-color:#4ade8059;background:#22c55e24;color:#bbf7d0}.glass-pill-warning{border-color:#fbbf2466;background:#f59e0b24;color:#fde68a}.glass-pill-danger{border-color:#f8717173;background:#ef444429;color:#fecaca}.glass-card.device-tile-card .card-content{display:flex;flex-direction:column;gap:.85rem;padding:1.25rem 1.4rem;min-height:100%}.glass-card.device-tile-card{position:relative;z-index:1;min-width:0;margin:0}.glass-card.device-tile-card:hover{z-index:4;transform:translateY(-6px)}.glass-card.device-tile-card:hover,.glass-card.device-tile-card:focus-within{transform:translateY(-6px)}.glass-card.device-tile-card.device-offline{opacity:.92}.device-tile{display:flex;flex-direction:column;gap:.85rem}.device-tile-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.device-title-container{display:flex;flex-direction:column;gap:.35rem}.device-title-row{display:flex;align-items:center;gap:.55rem}.device-title-icon{font-size:1.1rem;color:#ffffffd1}.device-title{font-size:1.08rem;font-weight:600;color:#fff;flex:1 1 auto}.device-title-edit-input{flex:1 1 auto;min-width:0;border:1px solid rgba(129,140,248,.4);border-radius:.6rem;padding:.35rem .6rem;background:#10162099;color:#ffffffeb;font-size:1rem;font-weight:600}.device-title-edit-input:focus{outline:none;border-color:#818cf8bf;box-shadow:0 0 0 2px #818cf833}.device-title-actions{display:inline-flex;align-items:center;gap:.35rem;margin-left:auto}.device-title-action{display:inline-flex;align-items:center;justify-content:center;width:1.8rem;height:1.8rem;border-radius:.5rem;border:1px solid rgba(255,255,255,.14);background:#0c121c73;color:#ffffffbf;cursor:pointer;transition:border .2s ease,background .2s ease,color .2s ease;font-size:.85rem}.device-title-action:hover{border-color:#818cf873;background:#818cf838;color:#d0d6fff2}.device-title-action:disabled{opacity:.6;cursor:not-allowed}.device-title-save{border-color:#818cf88c;background:#818cf82e;color:#d0d6fff2}.device-title-cancel{border-color:#f8717166;background:#ef44442e;color:#fecaca}.device-rename-error{margin-top:.35rem;font-size:.72rem;color:#f87171;font-weight:600}.device-meta{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem;margin-top:.25rem;font-size:.82rem;color:#fff9}.device-meta-dot{color:#ffffff59}.device-status{display:inline-flex;align-items:center;gap:.35rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600;padding:.35rem .6rem;border-radius:999px;background:#34d3992e;color:#ffffffbf;flex-shrink:0;max-width:100%;white-space:nowrap}.device-status-dot{width:.55rem;height:.55rem;border-radius:50%;background:#34d399}.device-status.offline .device-status-dot{background:#f87171}.device-status.offline{background:#f871712e}.device-pill-row{display:flex;flex-wrap:wrap;gap:.5rem}.device-state-pills{display:flex;flex-wrap:wrap;gap:.45rem}.device-description{margin:0;font-size:.84rem;line-height:1.5;color:#ffffffb8}.device-controls{display:flex;flex-direction:column;gap:.75rem;padding:.25rem 0}.device-controls-toggle{margin-top:.3rem;align-self:flex-start;padding:.32rem .65rem;border-radius:.6rem;border:1px solid rgba(129,140,248,.35);background:#818cf81a;color:#ffffffc7;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:background .2s ease,border .2s ease}.device-controls-toggle:hover{background:#818cf833;border-color:#818cf899}.device-control{display:flex;flex-direction:column;gap:.4rem;padding:.55rem .65rem;border-radius:.85rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}.device-color-control{position:relative;gap:.65rem}.device-color-summary{display:flex;justify-content:flex-start}.device-color-toggle{display:inline-flex;align-items:center;gap:.6rem;padding:.45rem .75rem;border-radius:.7rem;border:1px solid rgba(255,255,255,.12);background:#0c121c59;color:#ffffffd9;font-size:.8rem;font-weight:600;cursor:pointer;transition:border .2s ease,background .2s ease}.device-color-toggle:disabled{opacity:.65;cursor:not-allowed}.device-color-toggle:not(:disabled):hover{border-color:#818cf880;background:#818cf82e}.device-color-swatch{width:1.75rem;height:1.75rem;border-radius:.6rem;border:1px solid rgba(255,255,255,.2);box-shadow:inset 0 0 0 1px #0000001a}.device-color-popover{margin-top:.6rem;padding:.75rem;border-radius:.9rem;background:#0a0e18d9;border:1px solid rgba(129,140,248,.25);box-shadow:0 12px 28px #00000059;display:flex;flex-direction:column;gap:.65rem}.device-color-popover .react-colorful{width:100%!important}.device-color-actions{display:flex;flex-direction:column;gap:.5rem}.device-color-input{width:100%;border-radius:.65rem;border:1px solid rgba(255,255,255,.16);background:#0c121c80;padding:.45rem .75rem;color:#ffffffe6;font-size:.82rem;font-family:JetBrains Mono,Fira Code,monospace}.device-color-input:focus{outline:none;border-color:#818cf8b3;box-shadow:0 0 0 2px #818cf833}.device-color-buttons{display:flex;justify-content:flex-end;gap:.5rem}.device-color-cancel,.device-color-apply{padding:.35rem .9rem;border-radius:.55rem;border:1px solid transparent;font-size:.78rem;font-weight:600;cursor:pointer}.device-color-cancel{background:transparent;border-color:#ffffff24;color:#ffffffbf}.device-color-cancel:hover{border-color:#ffffff4d}.device-color-apply{background:#818cf829;border-color:#818cf88c;color:#c5ccfff2}.device-color-apply:disabled{opacity:.6;cursor:not-allowed}.device-color-apply:not(:disabled):hover{background:#818cf847}.device-control-label{display:flex;align-items:center;gap:.55rem;font-size:.82rem;color:#fffc;font-weight:600}.device-control-label svg{font-size:.9rem;color:#ffffffa6}.device-control-value{margin-left:auto;font-size:.78rem;color:#fff9;text-transform:uppercase;letter-spacing:.04em}.device-control-slider{display:flex;flex-direction:column;gap:.35rem}.device-control-range{width:100%;accent-color:var(--color-primary, #818cf8)}.device-control-range:focus-visible{outline:none;box-shadow:0 0 0 2px #818cf859;border-radius:999px}.device-control-slider-scale{display:flex;justify-content:space-between;font-size:.68rem;color:#ffffff73}.device-control-select,.device-control-number{width:100%;border-radius:.65rem;border:1px solid rgba(255,255,255,.12);background:#0c121c59;padding:.5rem .75rem;color:#ffffffd9;font-size:.84rem;font-weight:500;box-sizing:border-box}.device-control-select:focus,.device-control-number:focus{outline:none;border-color:#818cf8b3;box-shadow:0 0 0 2px #818cf838}.device-control-color{width:3rem;height:2rem;border:none;border-radius:.6rem;padding:.2rem;background:none;cursor:pointer}.device-control-color:disabled{cursor:not-allowed;opacity:.7}.device-metrics-toggle{margin-top:.6rem;align-self:flex-start;padding:.35rem .7rem;border-radius:.6rem;border:1px solid rgba(129,140,248,.45);background:#818cf81f;color:#ffffffbf;font-size:.74rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:background .2s ease,border .2s ease}.device-metrics-toggle:hover{background:#818cf838;border-color:#818cf8b3}.device-metrics{display:flex;flex-direction:column;gap:.35rem;max-height:220px;overflow-y:auto;padding-right:.25rem}.device-metrics::-webkit-scrollbar{width:4px}.device-metrics::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}.device-footer{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:#fff9}.device-command-pending{font-weight:600;color:#ffffffbf}.devices-page{display:flex;flex-direction:column;gap:1.5rem;padding:0 2.5rem 3rem;color:var(--color-white)}.devices-page .card{color:var(--color-gray-900, #1f2937)}.devices-header-pills{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.devices-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.devices-summary-card .devices-summary-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.5rem 1rem}.devices-error-card{border:1px solid rgba(248,113,113,.4)}.devices-error-text{color:#fecaca;font-size:.85rem}.devices-loading-card{display:flex;justify-content:center}.devices-loading{display:flex;align-items:center;gap:.9rem;font-size:.9rem;color:#ffffffbf}.devices-spinner{width:1.1rem;height:1.1rem;border-radius:50%;border:2px solid rgba(255,255,255,.18);border-top-color:#ffffffb3;animation:devices-spin .8s linear infinite}@keyframes devices-spin{to{transform:rotate(360deg)}}.devices-empty-card{text-align:center}.devices-empty{font-size:.9rem;color:#ffffffa6}.devices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2.2rem;align-items:stretch}.devices-grid .glass-card{margin:0}@media (max-width: 768px){.devices-page{padding:0 1.25rem 3rem}.page-header-flat{margin:8px 6px 10px;padding:0 6px;align-items:center;text-align:center}.page-title{font-size:1.6rem}.page-subtitle{font-size:.85rem;max-width:320px}.devices-header-pills{justify-content:center}.devices-summary-card .devices-summary-content{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.devices-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.6rem}}.btn{width:auto;background:var(--color-primary);color:#fff;font-size:1.02rem;font-weight:700;border:none;border-radius:.9rem;padding:.6em 1.1em;cursor:pointer;transition:background .2s,transform .2s,filter .2s;box-shadow:0 2px 8px 0 var(--color-shadow-card);font-family:inherit}.btn:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0);filter:brightness(.98)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn.secondary{background:var(--color-glass-bg-light);color:var(--color-primary);border:1.2px solid var(--color-glass-border)}.btn.secondary:hover:not(:disabled){background:#fff3;transform:translateY(-1px)}.btn.ghost{background:transparent;color:var(--color-white);border:1.2px solid var(--color-glass-border)}.snackbar{position:fixed;top:32px;left:50%;transform:translate(-50%) scale(.98);min-width:240px;max-width:90vw;background:#232b36;color:#fff;padding:.9rem 1.8rem;border-radius:12px;box-shadow:0 4px 24px #0000002e;font-size:1.02rem;font-weight:600;letter-spacing:.01em;opacity:0;pointer-events:none;z-index:9999;transition:opacity .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1)}.snackbar--show{opacity:1;transform:translate(-50%) scale(1);pointer-events:auto}@media (max-width: 600px){.snackbar{min-width:160px;padding:.75rem 1.2rem;font-size:.95rem}}.role-select{position:relative;display:inline-block;font-size:.9rem}.role-select-trigger{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#fff;padding:.45rem 2.2rem .45rem .8rem;border-radius:10px;cursor:pointer;font-weight:600;font-size:.85rem;display:flex;align-items:center;gap:.4rem;min-width:110px;position:relative}.role-select-trigger:hover:not(:disabled){background:#ffffff29}.role-select.disabled .role-select-trigger{opacity:.6;cursor:not-allowed}.role-select .caret{position:absolute;right:.7rem;top:50%;transform:translateY(-50%) rotate(0);font-size:.9rem;opacity:.8;transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .25s;text-shadow:0 0 4px rgba(0,0,0,.4)}.role-select.open .caret{transform:translateY(-50%) rotate(180deg)}.role-select-menu{background:#1c222cf2;-webkit-backdrop-filter:blur(18px) saturate(140%);backdrop-filter:blur(18px) saturate(140%);border:1px solid rgba(255,255,255,.18);border-radius:12px;padding:.4rem;list-style:none;margin:0;z-index:9999;box-shadow:0 4px 28px #00000059;display:flex;flex-direction:column;gap:2px;animation:dropdownFade .18s cubic-bezier(.4,0,.2,1);transform-origin:top center;max-height:240px;overflow-y:auto;overscroll-behavior:contain;scrollbar-width:thin}.role-select-menu.drop-up{transform-origin:bottom center}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.role-select-menu li{padding:.5rem .75rem;border-radius:8px;cursor:pointer;font-weight:600;letter-spacing:.25px;color:#ffffffe6;display:flex;align-items:center;justify-content:space-between;font-size:.83rem}.role-select-menu li.active{background:var(--color-primary);color:#fff}.role-select-menu li.focus:not(.active){background:#ffffff2e}.role-select-menu li:hover:not(.active){background:#ffffff1f}.role-select-menu li:active:not(.active){background:#ffffff38}.role-select-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite;position:absolute;right:.6rem;top:50%;transform:translateY(-50%)}@keyframes spin{to{transform:translateY(-50%) rotate(360deg)}}.users-page{padding:0 1rem}.users-page .masonry-dashboard{column-count:1!important}.fade-in{animation:fadeIn .2s ease-out}.row-fade{animation:fadeIn .18s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.card-body{padding:.5rem .25rem}.users-toolbar{display:flex;gap:.75rem;align-items:center;margin-bottom:.25rem}.input,.select{background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:10px;color:#fff;padding:.6rem .8rem}.input::placeholder{color:#fff9}.alert.error{background:#ff666626;border:1px solid rgba(255,102,102,.3);color:#fcc;padding:.75rem 1rem;border-radius:10px;margin-bottom:1rem}.table-wrapper{overflow:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:.75rem .6rem;border-bottom:1px solid rgba(255,255,255,.06);text-align:left}.table th{font-weight:600}.table tbody tr{transition:background .15s ease}.table tbody tr:hover{background:#ffffff08}.table tbody tr:active{background:#ffffff0f}.user-cell{display:flex;gap:.6rem;align-items:center}.avatar{width:32px;height:32px;border-radius:50%;background:#fff3}.name{font-weight:600}.muted{color:#ffffffb3}.badge{padding:.18rem .55rem;border-radius:999px;font-size:.8rem;font-weight:700;letter-spacing:-.2px}.badge.success{background:#66ffb226;border:1px solid rgba(102,255,178,.35);color:#d6ffef}.badge.muted{background:#ffffff14;border:1px solid rgba(255,255,255,.18);color:#fffc}.badge.error{background:#ff66662e;border:1px solid rgba(255,102,102,.4);color:#fcc}.actions{display:flex;gap:.5rem}.pagination{display:flex;align-items:center;gap:.75rem;margin-top:1rem}.page-header-flat{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;margin:10px 10px 12px;padding:0 8px}.page-title{font-size:1.8rem;font-weight:800;letter-spacing:-.5px;margin:0;color:var(--color-white)}.page-subtitle{color:#ffffffbf;margin-top:.2rem}.span-all{width:100%}.masonry-dashboard>.span-all{break-inside:avoid;display:block}.page-header-inner{display:none}.skeleton-row .skeleton-line{height:18px;background:linear-gradient(90deg,#ffffff14 25%,#ffffff29,#ffffff14 75%);background-size:400% 100%;border-radius:6px;animation:skeleton 1.2s ease-in-out infinite}@keyframes skeleton{0%{background-position:0% 50%}to{background-position:-200% 50%}}@media (max-width: 720px){.page-header-flat{margin:8px 6px 10px;padding:0 6px;align-items:center;text-align:center}.page-title{font-size:1.6rem}.page-subtitle{font-size:.85rem;max-width:320px}.users-toolbar{flex-wrap:wrap;justify-content:center}.users-toolbar .input{flex:1 1 100%;min-width:0}.users-toolbar>*{flex:0 0 auto}.users-toolbar .role-select,.users-toolbar .btn{margin-top:.4rem}.card-body{padding:.5rem .4rem}.pagination{justify-content:center}.table th:nth-child(2),.table td:nth-child(2){display:none}.table th:nth-child(5),.table td:nth-child(5){white-space:nowrap}}.profile-btn-wrap{display:flex;align-items:center;gap:.2rem;position:relative;z-index:400}.profile-login-text{background:none;border:none;color:var(--color-white);font-size:1.1rem;font-weight:600;margin-right:.1rem;cursor:pointer;opacity:.85;transition:color .2s;padding:0 .2rem}.profile-login-text:hover{color:var(--color-primary)}.profile-login-text.hide-on-mobile{display:inline-block}@media (max-width: 700px){.profile-login-text.hide-on-mobile{display:none}}.profile-avatar-btn{background:#1c222cb8;border:2px solid rgba(60,70,90,.32);border-radius:50%;width:48px;height:48px;padding:0;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px #0000002e;cursor:pointer;transition:border .2s,box-shadow .2s;outline:none;backdrop-filter:blur(32px) saturate(120%);-webkit-backdrop-filter:blur(32px) saturate(120%)}.profile-avatar-btn:hover,.profile-avatar-btn:focus{border:2px solid var(--color-primary);box-shadow:0 4px 16px 0 var(--color-primary)}.profile-avatar-img{width:38px;height:38px;border-radius:50%;object-fit:cover;background:#fff}.profile-avatar-icon{font-size:2.1rem;color:var(--color-secondary-xlight)}.profile-popover{position:absolute;top:54px;right:0;min-width:210px;background:#1c222ceb;border:1.5px solid rgba(60,70,90,.38);border-radius:1.2rem;box-shadow:0 8px 32px #0000002e;padding:1.1rem 1.2rem 1.2rem;z-index:999;display:flex;flex-direction:column;gap:.5rem;animation:profile-popover-in .18s cubic-bezier(.4,2,.6,1);backdrop-filter:blur(36px) saturate(120%);-webkit-backdrop-filter:blur(36px) saturate(120%)}@keyframes profile-popover-in{0%{opacity:0;transform:translateY(-12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.profile-popover-solid{background:#1c222ceb;border:1.5px solid rgba(60,70,90,.38);backdrop-filter:blur(36px) saturate(120%);-webkit-backdrop-filter:blur(36px) saturate(120%)}.profile-menu-header{display:flex;align-items:center;gap:.7rem;margin-bottom:.5rem}.profile-menu-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;background:#fff;font-size:2rem;color:var(--color-secondary-xlight)}.profile-menu-name{font-size:1.1rem;font-weight:700;color:var(--color-white);letter-spacing:.01em}.profile-menu-item{background:none;border:none;color:var(--color-white);font-size:1rem;font-weight:600;padding:.5em .2em;border-radius:.7rem;display:flex;align-items:center;gap:.7rem;cursor:pointer;transition:background .32s cubic-bezier(.4,2,.6,1),color .18s,box-shadow .18s}.profile-menu-item .profile-menu-icon{color:var(--color-white);font-size:1.3em;transition:color .18s;filter:drop-shadow(0 1px 2px var(--color-shadow-menu))}.profile-menu-item:hover,.profile-menu-item:focus{background:#e5e4e321;box-shadow:0 2px 8px #2c36431a}.profile-menu-item:hover .profile-menu-icon,.profile-menu-item:focus .profile-menu-icon{color:var(--color-primary);filter:none}.profile-menu-divider{height:1px;background:var(--color-glass-border);margin:.7rem 0;border-radius:1px}.profile-menu-oauth{display:flex;flex-direction:column;gap:.3rem;align-items:flex-start}.profile-menu-oauth-dev{display:flex;flex-direction:column;gap:.1rem;color:var(--color-secondary-xlight);font-size:.98rem;opacity:.8}.profile-menu-oauth-dev-badge{font-size:.85rem;color:var(--color-primary);background:var(--color-glass-bg-light);border-radius:.5em;padding:.1em .5em;margin-top:.1em;font-weight:700;letter-spacing:.04em}.profile-menu-input{width:100%;margin-bottom:.7rem;padding:.5em .9em;border-radius:.7rem;border:1.2px solid var(--color-glass-border);background:var(--color-glass-bg-light);color:var(--color-white);font-size:1rem;font-weight:500;outline:none;transition:border .2s,background .2s}.profile-menu-input:focus{border:1.2px solid var(--color-primary);background:var(--color-glass-bg-strong)}.profile-menu-error{color:#e53e3e;font-size:.98rem;margin-bottom:.5rem}.profile-toast{position:fixed;top:32px;left:50%;transform:translate(-50%) scale(.98);min-width:240px;max-width:90vw;background:#232b36;color:#fff;padding:1rem 2rem;border-radius:12px;box-shadow:0 4px 24px #0000002e;font-size:1.05rem;font-weight:500;letter-spacing:.01em;opacity:0;pointer-events:none;z-index:9999;transition:opacity .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1)}.profile-toast--show{opacity:1;transform:translate(-50%) scale(1);pointer-events:auto}@media (max-width: 600px){.profile-toast{min-width:160px;padding:.75rem 1.2rem;font-size:.98rem}}.auth-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#2c364347;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .28s cubic-bezier(.4,2,.6,1);touch-action:none}.auth-modal-backdrop.open{opacity:1;pointer-events:auto}.auth-modal-glass{background:#1c222ceb;border-radius:2rem;box-shadow:0 8px 48px #00000038;border:1.5px solid rgba(60,70,90,.38);backdrop-filter:blur(36px) saturate(120%);-webkit-backdrop-filter:blur(36px) saturate(120%);min-width:340px;max-width:95vw;width:400px;padding:2.2rem 0 1.5rem;position:relative;opacity:0;transform:translateY(32px) scale(.98);transition:opacity .28s cubic-bezier(.4,2,.6,1),transform .28s cubic-bezier(.4,2,.6,1);display:flex;flex-direction:column;align-items:center;box-sizing:border-box}@media (max-width: 700px){.auth-modal-glass{min-width:unset;width:90vw;max-width:420px;margin:0 5vw;padding:1.2rem 0}.auth-modal-content-inner{flex-direction:row!important;width:200%;transform:none}.auth-modal-form{max-width:100%;min-width:100%;padding:0 .7rem}}.auth-modal-glass.open{opacity:1;transform:translateY(0) scale(1)}.auth-modal-close{position:absolute;top:1.2rem;right:1.5rem;background:none;border:none;color:var(--color-secondary-xlight);font-size:2.1rem;font-weight:700;cursor:pointer;opacity:.7;transition:color .2s,opacity .2s;z-index:2;line-height:1;padding:0}.auth-modal-close:hover{color:var(--color-primary);opacity:1}.auth-modal-tabs{display:flex;gap:1.2rem;margin-bottom:1.2rem;width:100%;justify-content:center}.auth-modal-tabs button{background:#ffffff21;border:none;color:var(--color-white);font-weight:700;font-size:1.1rem;padding:.5em 1.5em;border-radius:999px;cursor:pointer;transition:background .2s,color .2s;outline:none}.auth-modal-tabs button.active{background:var(--color-primary);color:var(--color-white)}.auth-modal-content{width:100%;display:flex;flex-direction:column;align-items:center}.auth-modal-header{display:flex;flex-direction:column;align-items:center;gap:.6rem;margin-bottom:1.2rem}.auth-modal-avatar{font-size:3.2rem;color:var(--color-secondary-xlight)}.auth-modal-title{font-size:1.4rem;font-weight:800;color:var(--color-white);letter-spacing:.01em}.auth-modal-subtitle{font-size:.9rem;color:var(--color-secondary-light);margin-top:.5rem;text-align:center;line-height:1.4}.auth-modal-form{width:100%;max-width:340px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:.7rem;min-width:100%;box-sizing:border-box;flex-shrink:0;padding:0 2.2rem}@media (max-width: 700px){.auth-modal-form{max-width:100%;min-width:100%;padding:0 .7rem}.auth-modal-content-inner{flex-direction:row!important;width:200%;transform:none}}.auth-modal-field{width:100%;position:relative;margin-bottom:.2rem}.auth-modal-input{width:100%;padding:1.1em 1.1em .7em;border-radius:.9rem;border:1.2px solid var(--color-glass-border);background:#28303c52;color:var(--color-white);font-size:1.08rem;font-weight:500;outline:none;transition:border .2s,background .2s;box-sizing:border-box;position:relative;z-index:1}.auth-modal-input:focus{border:1.2px solid var(--color-primary);background:#28303c61}.auth-modal-label{position:absolute;left:1.1em;top:1.05em;font-size:1.08rem;color:var(--color-secondary-xlight);font-weight:600;pointer-events:none;transition:all .18s cubic-bezier(.4,2,.6,1);opacity:.85;background:transparent;z-index:2;line-height:1.2}.auth-modal-input:focus+.auth-modal-label,.auth-modal-input:not(:placeholder-shown)+.auth-modal-label{top:.1em;left:1.1em;font-size:.93rem;color:var(--color-primary);opacity:1;background:var(--color-glass-bg-light);padding:0 .2em;border-radius:.5em}.auth-modal-btn{width:100%;background:var(--color-primary);color:#fff;font-size:1.1rem;font-weight:700;border:none;border-radius:.9rem;padding:.7em 1.1em;margin-top:.2rem;cursor:pointer;transition:background .2s;box-shadow:0 2px 8px 0 var(--color-shadow-card)}.auth-modal-btn.secondary{background:var(--color-glass-bg-light);color:var(--color-primary);font-weight:600;margin-top:0;margin-bottom:.2rem}.auth-modal-btn:disabled{opacity:.6;cursor:not-allowed}.auth-modal-error{color:#e53e3e;font-size:1rem;margin-bottom:.2rem;font-weight:600;width:100%;text-align:center}.auth-modal-divider{height:1px;background:var(--color-glass-border);margin:1.2rem 0 .7rem;border-radius:1px;width:100%}.auth-modal-oauth-btns{width:100%;display:flex;flex-direction:column;gap:.5rem;margin-top:.2rem}.auth-modal-oauth-btn{width:100%;background:var(--color-glass-bg-light);color:var(--color-secondary-xlight);font-size:1.08rem;font-weight:700;border:1.2px solid var(--color-glass-border);border-radius:.9rem;padding:.5em 1.1em;cursor:pointer;display:flex;align-items:center;gap:.7rem;opacity:1;transition:background .2s,color .2s,border .2s;box-shadow:0 2px 8px 0 var(--color-shadow-card)}.auth-modal-oauth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-modal-oauth-btn .oauth-icon{width:1.5em;height:1.5em;display:inline-block;margin-right:.7em;background:none;font-size:1.5em}.auth-modal-oauth-btn.google .oauth-icon{color:#ea4335}.auth-modal-oauth-btn.github .oauth-icon{color:#24292f}.auth-modal-oauth-label{text-align:center;color:var(--color-secondary-xlight);font-size:1rem;font-weight:600;margin-bottom:.2rem;opacity:.85}.auth-modal-content-outer{width:100%;overflow:hidden;position:relative;min-height:320px;display:flex;justify-content:center;align-items:stretch}.auth-modal-content-inner{display:flex;width:100%;transition:transform .45s cubic-bezier(.4,2,.6,1);will-change:transform}.auth-modal-content-inner.login{transform:translate(0)}.auth-modal-content-inner.signup{transform:translate(-100%)}.auth-modal-content-inner.login .auth-modal-form:nth-child(2) .auth-modal-btn,.auth-modal-content-inner.login .auth-modal-form:nth-child(2) .auth-modal-btn.secondary,.auth-modal-content-inner.signup .auth-modal-form:nth-child(1) .auth-modal-btn,.auth-modal-content-inner.signup .auth-modal-form:nth-child(1) .auth-modal-btn.secondary{box-shadow:none!important;opacity:0!important;pointer-events:none!important;visibility:hidden!important;height:0!important;margin:0!important;padding:0!important}.auth-modal-content-inner.login .auth-modal-form:nth-child(2) .auth-modal-oauth-btns,.auth-modal-content-inner.login .auth-modal-form:nth-child(2) .auth-modal-oauth-label,.auth-modal-content-inner.login .auth-modal-form:nth-child(2) .auth-modal-divider,.auth-modal-content-inner.signup .auth-modal-form:nth-child(1) .auth-modal-oauth-btns,.auth-modal-content-inner.signup .auth-modal-form:nth-child(1) .auth-modal-oauth-label,.auth-modal-content-inner.signup .auth-modal-form:nth-child(1) .auth-modal-divider{opacity:0!important;pointer-events:none!important;visibility:hidden!important;height:0!important;margin:0!important;padding:0!important}.auth-modal-forgot-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#1c222cf2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:2rem;display:flex;align-items:center;justify-content:center;z-index:10}.auth-modal-forgot-content{width:100%;max-width:340px;padding:0 2.2rem;box-sizing:border-box}.auth-modal-forgot-content .auth-modal-btn{margin-bottom:.7rem}.auth-modal-forgot-content .auth-modal-btn:last-child{margin-bottom:0}@media (max-width: 700px){.auth-modal-forgot-content{padding:0 .7rem}}.user-settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#2c364347;display:flex;align-items:center;justify-content:center;opacity:1;pointer-events:auto;transition:opacity .28s cubic-bezier(.4,2,.6,1);touch-action:none}.user-settings{background:#1c222ceb;border-radius:2rem;box-shadow:0 8px 48px #00000038;border:1.5px solid rgba(60,70,90,.38);backdrop-filter:blur(36px) saturate(120%);-webkit-backdrop-filter:blur(36px) saturate(120%);min-width:340px;max-width:95vw;width:700px;max-height:90vh;overflow-y:auto;padding:2.2rem 0 1.5rem;position:relative;opacity:1;transform:translateY(0) scale(1);transition:opacity .28s cubic-bezier(.4,2,.6,1),transform .28s cubic-bezier(.4,2,.6,1);display:flex;flex-direction:column;align-items:center;box-sizing:border-box;font-family:Inter,Segoe UI,Arial,sans-serif}@media (max-width: 700px){.user-settings{min-width:unset;width:90vw;max-width:420px;margin:0 5vw;padding:1.2rem 0}}.user-settings-header{display:flex;justify-content:center;align-items:center;margin-bottom:2rem;width:100%;padding:0 2.2rem;box-sizing:border-box;position:relative}.user-settings h2{color:var(--color-white);margin:0;font-size:1.4rem;font-weight:800;letter-spacing:.01em}.user-settings-close{position:absolute;top:1.1rem;right:1.2rem;background:none!important;border:none;color:var(--color-secondary-xlight);font-size:2.1rem!important;font-weight:700;cursor:pointer;opacity:.7;transition:color .2s,opacity .2s;z-index:2;line-height:1;padding:0!important;margin:0!important;border-radius:0!important;box-shadow:none!important;transform:none!important}.user-settings-close:hover{color:var(--color-primary);opacity:1;background:none!important;transform:none!important}.user-settings-card{background:#1c222cad;border-radius:1.5rem;box-shadow:0 8px 32px #0000002e;backdrop-filter:blur(32px) saturate(120%);-webkit-backdrop-filter:blur(32px) saturate(120%);border:1.2px solid rgba(60,70,90,.38);transition:box-shadow .7s cubic-bezier(.4,0,.2,1),border .7s,transform .6s cubic-bezier(.4,0,.2,1),filter .6s;width:100%;max-width:600px;margin:0 0 2rem;padding:clamp(1.2rem,4vw,2.2rem) clamp(1rem,3vw,2rem);box-sizing:border-box;position:relative;z-index:2}.user-settings-card:first-child{margin-top:.5rem}.user-settings-card:hover{border:1.4px solid var(--color-primary);transform:translateY(-1px) scale(1.01);filter:brightness(1.08) saturate(1.13);box-shadow:0 12px 48px #39aa7926,0 8px 32px #0000002e}.user-settings-card h3{color:var(--color-white);margin:0 0 1.2rem;font-size:1.25rem;font-weight:700;display:flex;align-items:center;gap:.7rem;letter-spacing:-.5px}.user-settings-card-icon{font-size:1.4rem}.profile-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:1.2rem}.profile-avatar-container{position:relative;cursor:pointer;width:64px;height:64px;border-radius:50%;overflow:hidden}.profile-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.6rem;font-weight:700;flex-shrink:0;box-shadow:0 4px 16px #00000026;transition:transform .2s ease}.profile-avatar-image{width:100%;height:100%;object-fit:cover;border-radius:50%}.profile-avatar-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#1c222cd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;color:var(--color-white);font-size:.75rem;font-weight:600;gap:.2rem}.profile-avatar-container:hover .profile-avatar-overlay{opacity:1}.profile-avatar-container:hover .profile-avatar{transform:scale(1.05)}.profile-info{flex:1}.profile-name{color:var(--color-white);font-size:1.4rem;font-weight:700;margin:0 0 .3rem;letter-spacing:-.5px}.profile-email{color:var(--color-secondary-light);font-size:1rem;margin:0;font-weight:500}.user-settings-field{margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.user-settings-field strong{color:var(--color-white);font-weight:600;font-size:1.08rem}.status-indicator{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;font-size:1rem}.status-indicator.verified{color:var(--color-primary)}.status-indicator.unverified{color:var(--color-secondary-light)}.user-settings-input-group{display:flex;flex-direction:column;gap:.7rem;margin-top:1.2rem;width:100%}.user-settings-input-group input{width:100%;padding:1.1em 1.1em .7em;border-radius:.9rem;border:1.2px solid var(--color-glass-border);background:#28303c52;color:var(--color-white);font-size:1.08rem;font-weight:500;outline:none;transition:border .2s,background .2s;box-sizing:border-box}.user-settings-input-group input:focus{border:1.2px solid var(--color-primary);background:#28303c61}.user-settings-input-group input::placeholder{color:var(--color-secondary-xlight);opacity:.8}.user-settings button{background:var(--color-primary);color:#fff;font-size:1.1rem;font-weight:700;border:none;border-radius:.9rem;padding:.7em 1.1em;margin-top:.2rem;cursor:pointer;transition:background .2s,transform .2s;box-shadow:0 2px 8px 0 var(--color-shadow-card);font-family:inherit}.user-settings button:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px)}.user-settings button:disabled{opacity:.6;cursor:not-allowed;transform:none}.user-settings button.secondary{background:var(--color-glass-bg-light);color:var(--color-primary);font-weight:600;margin-top:0;margin-bottom:.2rem}.user-settings button.secondary:hover:not(:disabled){background:#fff3}.user-settings button.danger{background:#e53e3e;color:#fff}.user-settings button.danger:hover:not(:disabled){background:#c53030}.card-status{margin-top:1.2rem;padding:.8rem 1.1rem;border-radius:.9rem;font-size:1rem;font-weight:600;text-align:center}.card-status.success{background:#39aa7933;color:var(--color-primary);border:1.2px solid rgba(57,170,121,.3)}.card-status.error{color:#e53e3e;background:#e53e3e1a;border:1.2px solid rgba(229,62,62,.2)}.button-group{display:flex;gap:.7rem;margin-top:1.2rem;width:100%}.button-group button{flex:1}.edit-profile-form{display:flex;flex-direction:column;gap:1rem;margin-top:1.2rem;width:100%}.edit-profile-form .name-inputs{display:flex;gap:1rem;width:100%}.edit-profile-form .name-inputs .user-settings-field-input{flex:1}.edit-profile-form input{width:100%;padding:1.1em 1.1em .7em;border-radius:.9rem;border:1.2px solid var(--color-glass-border);background:#28303c52;color:var(--color-white);font-size:1.08rem;font-weight:500;outline:none;transition:border .2s,background .2s;box-sizing:border-box}.edit-profile-form input:focus{border:1.2px solid var(--color-primary);background:#28303c61}.user-settings-field-input{position:relative;width:100%;flex:1}.user-settings-field-input input{width:100%;padding:1.1em 1.1em .7em;border-radius:.9rem;border:1.2px solid var(--color-glass-border);background:#28303c52;color:var(--color-white);font-size:1.08rem;font-weight:500;outline:none;transition:border .2s,background .2s;box-sizing:border-box}.user-settings-field-input input:focus{border:1.2px solid var(--color-primary);background:#28303c61}.user-settings-field-input label{position:absolute;left:1.1em;top:1.05em;font-size:1.08rem;color:var(--color-secondary-xlight);font-weight:600;pointer-events:none;transition:all .18s cubic-bezier(.4,2,.6,1);opacity:.85;background:transparent;z-index:2;line-height:1.2}.user-settings-field-input input:focus+label,.user-settings-field-input input:not(:placeholder-shown)+label{top:.1em;left:1.1em;font-size:.93rem;color:var(--color-primary);opacity:1;background:var(--color-glass-bg-light);padding:0 .2em;border-radius:.5em;line-height:1.1}.user-settings-content-outer{width:100%;overflow-y:auto;overflow-x:hidden;position:relative;display:flex;justify-content:center;align-items:flex-start;flex:1;padding:0 0 1rem}.user-settings-content{width:100%;padding:0 2.2rem;box-sizing:border-box;display:flex;flex-direction:column;align-items:center}@media (max-width: 700px){.user-settings-content,.user-settings-header{padding:0 .7rem}.user-settings-close{right:1rem}.edit-profile-form .name-inputs{flex-direction:column;gap:.7rem}.button-group{flex-direction:column;gap:.5rem}}.user-settings-tabs{display:flex;gap:1.2rem;margin-bottom:1.2rem;width:100%;justify-content:center}.user-settings-tabs button{background:#ffffff21;border:none;color:var(--color-white);font-weight:700;font-size:1.1rem;padding:.5em 1.5em;border-radius:999px;cursor:pointer;transition:background .2s,color .2s;outline:none}.user-settings-tabs button.active{background:var(--color-primary);color:var(--color-white)}.profile-picture-modal{position:absolute;top:0;left:0;right:0;bottom:0;background:#1c222cf2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:2rem;display:flex;align-items:center;justify-content:center;z-index:10}.profile-picture-modal-content{width:100%;max-width:400px;padding:0 2rem;text-align:center}.profile-picture-modal-content h3{color:var(--color-white);margin:0 0 2rem;font-size:1.4rem;font-weight:700}.profile-picture-options{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.profile-picture-option{display:flex;flex-direction:column;align-items:center;gap:.5rem}.profile-picture-option p{margin:0;color:var(--color-secondary-light);font-size:.9rem}.profile-picture-divider{color:var(--color-secondary-light);font-size:.9rem;font-weight:600;margin:.5rem 0}.upload-label{background:var(--color-glass-bg-light);color:var(--color-primary);font-size:1.1rem;font-weight:700;border:none;border-radius:.9rem;padding:.7em 1.1em;cursor:pointer;transition:background .2s,transform .2s;box-shadow:0 2px 8px 0 var(--color-shadow-card);font-family:inherit;display:inline-block}.upload-label:hover{background:#fff3;transform:translateY(-1px)}.file-selected{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:.5rem;padding:.7rem;background:#39aa791a;border:1px solid rgba(57,170,121,.3);border-radius:.5rem}.file-selected span{color:var(--color-primary);font-size:.9rem;font-weight:500}.file-selected button{background:var(--color-primary);color:#fff;border:none;padding:.4rem .8rem;border-radius:.4rem;font-size:.9rem;font-weight:600;cursor:pointer}@media (max-width: 700px){.profile-picture-modal-content{padding:0 1rem}}:root{--color-white: #fff;--color-black: #000;--color-bg: #242e3a;--color-bg-secondary: #32404d;--color-glass-bg: rgba(255,255,255,.13);--color-glass-bg-strong: rgba(255,255,255,.18);--color-glass-bg-light: rgba(255,255,255,.1);--color-glass-border: rgba(255,255,255,.32);--color-glass-border-strong: rgba(255,255,255,.38);--color-glass-border-light: rgba(255,255,255,.22);--color-glass-border-xlight: rgba(255,255,255,.12);--color-shadow: #e5e4e3;--color-shadow-dark: #040913;--color-shadow-spotify: #1db95444;--color-shadow-weather: #FFD93B66;--color-shadow-weather-light: #FFD93B33;--color-shadow-menu: #fff8;--color-shadow-device: #fff6;--color-shadow-card: #fff3;--color-primary: #39aa79;--color-primary-light: #b6f7c1;--color-primary-dark: #17a74a;--color-secondary: #2f3c49;--color-secondary-light: #7c848d;--color-secondary-xlight: #e5e4e3;--color-secondary-dark: #57616d;--color-spotify: #1DB954;--color-weather-sun: #FFD93B;--color-link: #646cff;--color-link-hover: #535bf2;--color-profile-btn: #2563eb;--color-profile-btn-hover: #1d4ed8;--gradient-bg: linear-gradient(120deg, var(--color-bg) 0%, var(--color-bg-secondary) 100%);--gradient-map-card: linear-gradient(0deg, rgba(44,54,67,.18) 80%, transparent 100%);--gradient-weather-cc-checked: linear-gradient(90deg, #4cd964 60%, var(--color-primary-light) 100%)}html{box-sizing:content-box}*,*:before,*:after{box-sizing:inherit}#root{max-width:none;margin:0;padding:0;text-align:center}body{font-family:Inter,Segoe UI,Arial,sans-serif}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}body{min-height:100vh;background:var(--gradient-bg);position:relative}body:before{content:"";position:fixed;top:0;bottom:0;left:0;right:0;width:100%;z-index:0;pointer-events:none;background:radial-gradient(ellipse at 60% 40%,var(--color-secondary) 60%,transparent 100%),radial-gradient(ellipse at 20% 80%,var(--color-secondary-dark) 40%,transparent 100%),radial-gradient(ellipse at 80% 70%,#071324 30%,transparent 100%);opacity:.7;filter:blur(48px) saturate(120%)}
