@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}.glass-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .75rem;font-size:.75rem;font-weight:500;font-family:inherit;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;-webkit-appearance:none;-moz-appearance:none;appearance:none;line-height:1.1;cursor:default}.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-pill-clickable{cursor:pointer;transition:background .15s ease,border-color .15s ease}.glass-pill-clickable:hover{background:#ffffff29;border-color:#ffffff40}.glass-pill-clickable:focus-visible{outline:2px solid rgba(129,140,248,.6);outline-offset:2px}.no-permission-widget{width:100%;height:100%;min-height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.85rem;padding:.9rem 1rem;text-align:center}.no-permission-widget__badge{width:3rem;height:3rem;border-radius:9999px;display:flex;align-items:center;justify-content:center;background:var(--color-surface-panel-soft);border:1px solid var(--color-glass-border-light);color:var(--color-white);box-shadow:0 10px 26px #0000002e;font-size:1.05rem}.no-permission-widget__body{min-width:0;width:100%;max-width:26rem}.no-permission-widget__title{font-weight:700;color:var(--color-white);letter-spacing:.08em;text-transform:uppercase;opacity:.9}.no-permission-widget__message{color:var(--color-secondary-xlight);opacity:.78;font-size:.98rem;line-height:1.3;max-width:none}.no-permission-widget__actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.35rem;justify-content:center}.no-permission-widget__login,.no-permission-widget__why{padding-left:.9rem;padding-right:.9rem}.widget-shell{position:relative;display:flex;flex-direction:column;height:100%;min-height:unset;overflow:hidden;transition:transform .15s ease}.widget-shell--error{min-height:120px}.widget-shell--edit-mode{cursor:default}.widget-shell--edit-mode .card-content{pointer-events:none}.widget-shell__edit-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;flex-direction:column;justify-content:space-between;padding:8px;pointer-events:none;background:#00000026;border-radius:inherit}.widget-shell__drag-handle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;margin:0 auto;color:var(--color-white);background:var(--color-glass-bg-strong);border-radius:8px;cursor:grab;pointer-events:auto;opacity:.9;transition:opacity .15s,background .15s}.widget-shell__drag-handle:hover{background:var(--color-glass-bg);opacity:1}.widget-shell__drag-handle:active{cursor:grabbing}.widget-shell__edit-actions{display:flex;gap:8px;justify-content:center;pointer-events:auto}.widget-shell__edit-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;color:var(--color-white);background:var(--color-glass-bg-strong);border:1px solid var(--color-glass-border-light);border-radius:10px;cursor:pointer;opacity:.9;transition:all .15s}.widget-shell__edit-btn:hover{opacity:1;transform:scale(1.05)}.widget-shell__edit-btn--settings:hover{background:var(--color-primary);border-color:var(--color-primary)}.widget-shell__edit-btn--remove:hover{background:var(--color-danger);border-color:var(--color-danger)}.widget-shell__content{display:flex;flex-direction:column;flex:1;min-height:0;transition:opacity .2s}.widget-shell__content--muted{opacity:.5}.widget-shell__header{padding:0 0 12px}.widget-shell__title-row{display:flex;align-items:center;gap:10px}.widget-shell__title-icon{font-size:1.05rem;color:var(--color-secondary-light)}.widget-shell__title{font-size:1.1rem;font-weight:600;color:var(--color-white);line-height:1.3}.widget-shell__subtitle{font-size:.85rem;color:var(--color-secondary-light);margin-top:2px}.widget-shell__loading{display:flex;align-items:center;justify-content:center;flex:1;min-height:80px}.widget-shell__spinner{width:32px;height:32px;border:3px solid var(--color-glass-border-light);border-top-color:var(--color-primary);border-radius:50%;animation:widget-spin .8s linear infinite}@keyframes widget-spin{to{transform:rotate(360deg)}}.widget-shell__error-message{display:flex;align-items:center;justify-content:center;flex:1;padding:16px;text-align:center;color:var(--color-danger-light, #fca5a5);font-size:.9rem}.glass-select{position:relative}.glass-select__trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:.85rem 1rem;border-radius:.9rem;border:1.5px solid rgba(60,70,90,.38);background:#ffffff12;color:var(--color-white);cursor:pointer}.glass-select__trigger:disabled{opacity:.55;cursor:not-allowed}.glass-select__trigger:focus-visible{outline:2px solid var(--color-glass-border-light);outline-offset:2px}.glass-select__value{min-width:0;text-align:left;font-size:.95rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.glass-select__value--placeholder{color:var(--color-secondary-light);font-weight:600}.glass-select__chev{opacity:.8;transition:transform .15s ease,opacity .15s ease}.glass-select__chev.open{transform:rotate(180deg);opacity:1}.glass-select__menu{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:9999;padding:8px;border-radius:14px;border:1px solid var(--color-glass-border-xlight);background:var(--color-surface-panel-alt);-webkit-backdrop-filter:blur(18px) saturate(120%);backdrop-filter:blur(18px) saturate(120%);max-height:260px;overflow:auto}.glass-select__menu--portal{position:fixed;left:auto;right:auto;top:auto;z-index:10050}.glass-select__option{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border-radius:12px;border:1px solid transparent;background:transparent;color:var(--color-white);cursor:pointer}.glass-select__option:hover{background:var(--color-glass-bg-light);border-color:var(--color-glass-border-xlight)}.glass-select__option.active{background:color-mix(in srgb,var(--color-primary) 18%,var(--color-surface-panel-alt));border-color:color-mix(in srgb,var(--color-primary) 22%,var(--color-glass-border-xlight))}.glass-select__option-label{min-width:0;text-align:left;font-weight:700;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.glass-select__check{opacity:.95}.glass-select__empty{padding:10px;color:var(--color-secondary-light);font-weight:600}.hn-searchbar{flex:1 1 280px;display:inline-flex;align-items:center;background:#0f1520d1;border-radius:999px;border:1px solid rgba(255,255,255,.08);padding:.35rem .75rem .35rem .9rem;gap:.55rem;position:relative;box-shadow:inset 0 0 0 1px #ffffff05;min-width:0;box-sizing:border-box;transition:border-color .16s ease,box-shadow .16s ease}.hn-searchbar:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),0 0 16px 0 var(--color-primary)}.hn-searchbar--active{border-color:#ffffff1f}.hn-searchbar--active:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),0 0 22px 0 var(--color-primary)}.hn-searchbar__icon{color:#ffffff8c;font-size:.95rem;flex:0 0 auto}.hn-searchbar__input{flex:1 1 auto;min-width:0;background:transparent;border:none;color:#ffffffe6;font-size:.9rem;padding:0}.hn-searchbar__input:focus{outline:none}.hn-searchbar__input::placeholder{color:#ffffff73}.hn-searchbar__clear{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:#22c55e29;color:#bbf7d0;border-radius:999px;cursor:pointer;transition:background .2s ease,color .2s ease;flex:0 0 auto}.hn-searchbar__clear:hover{background:#22c55e47;color:#ecfdf5}.weather-detail{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:16px;pointer-events:none}.weather-detail__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#04060885;-webkit-backdrop-filter:blur(6px) saturate(115%);backdrop-filter:blur(6px) saturate(115%);animation:weather-detail-fade .18s ease both;pointer-events:auto}.weather-detail__panel{position:relative;width:100%;max-width:980px;max-height:calc(100vh - 32px);border-radius:18px;border:1px solid var(--color-glass-border-xlight);background:#0e121857;-webkit-backdrop-filter:blur(18px) saturate(120%);backdrop-filter:blur(18px) saturate(120%);overflow:hidden;animation:weather-detail-panel-in .22s cubic-bezier(.2,.9,.2,1) both;box-shadow:0 18px 48px #0000006b;pointer-events:auto;outline:none}.weather-detail__background{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;opacity:1;overflow:hidden;--weather-detail-base: rgba(28,34,44,.68);background:radial-gradient(circle at top left,color-mix(in srgb,var(--color-weather-sun) 22%,transparent),var(--weather-detail-base))}.weather-detail--cloud .weather-detail__background,.weather-detail--wind .weather-detail__background,.weather-detail--fog .weather-detail__background{background:radial-gradient(circle at top left,color-mix(in srgb,var(--color-surface-iris) 65%,transparent),var(--weather-detail-base))}.weather-detail--rain .weather-detail__background{background:radial-gradient(circle at top left,color-mix(in srgb,var(--color-surface-iris) 75%,transparent),var(--weather-detail-base))}.weather-detail--storm .weather-detail__background{background:radial-gradient(circle at top left,color-mix(in srgb,var(--color-danger-surface-strong) 75%,transparent),var(--weather-detail-base))}.weather-detail--snow .weather-detail__background{background:radial-gradient(circle at top left,color-mix(in srgb,var(--color-surface-panel-soft) 75%,transparent),var(--weather-detail-base))}.weather-detail--sun .weather-detail__background{background:radial-gradient(circle at top left,color-mix(in srgb,var(--color-weather-sun) 22%,transparent),var(--weather-detail-base))}.weather-detail--closing .weather-detail__backdrop{animation:weather-detail-fade-out .18s ease both}.weather-detail--closing .weather-detail__panel{animation:weather-detail-panel-out .18s ease both}.weather-detail__panel:before{content:"";position:absolute;top:-40px;right:-40px;bottom:-40px;left:-40px;z-index:1;background:radial-gradient(900px 460px at 20% 10%,var(--color-primary) 0%,transparent 60%),radial-gradient(700px 420px at 80% 0%,var(--color-glass-border-light) 0%,transparent 55%),radial-gradient(900px 520px at 40% 100%,rgba(255,255,255,.08) 0%,transparent 60%);opacity:.12;filter:blur(12px);pointer-events:none}.weather-detail__panel:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;opacity:0}.weather-detail__header{position:relative;z-index:2;display:flex;align-items:center;gap:14px;padding:16px 16px 10px;border-bottom:1px solid rgba(255,255,255,.1)}.weather-detail__back{display:inline-flex;align-items:center;gap:10px;border:none;background:#ffffff0f;color:#ffffffe6;border:1px solid rgba(255,255,255,.1);border-radius:999px;padding:8px 12px;cursor:pointer}.weather-detail__back:hover{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),0 0 14px 0 var(--color-primary)}.weather-detail__title{display:flex;flex-direction:column;min-width:0}.weather-detail__title-main{font-size:1.25rem;font-weight:800;color:#fffffff2;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.weather-detail__title-sub{display:inline-flex;align-items:center;gap:8px;margin-top:4px;color:#ffffffbf;font-size:.95rem}.weather-detail__current-icon{font-size:1.05rem;filter:drop-shadow(0 2px 10px rgba(0,0,0,.35))}.weather-detail__current-icon--sun{color:var(--color-weather-sun)}.weather-detail__current-icon--cloud,.weather-detail__current-icon--wind,.weather-detail__current-icon--fog{color:#ffffffeb}.weather-detail__current-icon--rain{color:color-mix(in srgb,var(--color-surface-iris) 70%,rgba(160,210,255,1))}.weather-detail__current-icon--storm{color:color-mix(in srgb,var(--color-danger-surface-strong) 70%,rgba(255,255,255,.9))}.weather-detail__current-icon--snow{color:#fffffff5}.weather-detail__content{position:relative;z-index:2;padding:14px 16px 18px;height:calc(100% - 64px);overflow:auto}.weather-detail__hero{display:flex;flex-direction:column;align-items:flex-start;padding:10px 4px 18px}.weather-detail__hero-top{display:inline-flex;align-items:baseline;gap:14px}.weather-detail__hero-icon{font-size:2.6rem;line-height:1;filter:drop-shadow(0 8px 24px rgba(0,0,0,.4))}.weather-detail__hero-icon--sun{color:var(--color-weather-sun)}.weather-detail__hero-icon--cloud,.weather-detail__hero-icon--wind,.weather-detail__hero-icon--fog{color:#fffffff0}.weather-detail__hero-icon--rain{color:color-mix(in srgb,var(--color-surface-iris) 70%,rgba(160,210,255,1))}.weather-detail__hero-icon--storm{color:color-mix(in srgb,var(--color-danger-surface-strong) 70%,rgba(255,255,255,.9))}.weather-detail__hero-icon--snow{color:#fffffff5}.weather-detail__temp{font-size:3.2rem;font-weight:900;letter-spacing:-.02em;color:#fffffff5}.weather-detail__hero-desc{margin-top:6px;font-size:1rem;font-weight:800;color:#ffffffdb}.weather-detail__hilo{margin-top:6px;color:#ffffffb3}.weather-detail__loading,.weather-detail__error,.weather-detail__empty{color:#fffc;display:inline-flex;align-items:center;gap:10px;padding:10px 0}.weather-detail__section{border-top:1px solid rgba(255,255,255,.08);padding:14px 0}.weather-detail__section-title{display:inline-flex;align-items:center;gap:10px;font-size:.95rem;font-weight:800;color:#ffffffeb;margin-bottom:10px}.weather-detail__section-title svg{font-size:1.1rem;color:var(--color-primary)}.weather-detail__section-title--settings{display:flex;align-items:center;justify-content:space-between;width:100%}.weather-detail__section-title-left{display:inline-flex;align-items:center;gap:10px}.weather-detail__settings-toggle{width:36px;height:36px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#0f15208c;color:#ffffffe6;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.weather-detail__settings-toggle.open{transform:rotate(180deg)}.weather-detail__settings-toggle:hover{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),0 0 14px 0 var(--color-primary)}.weather-detail__hourly{display:flex;gap:12px;overflow-x:auto;overflow-y:hidden;padding-bottom:8px;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.weather-detail__hourly::-webkit-scrollbar{height:8px}.weather-detail__hourly::-webkit-scrollbar-track{background:#ffffff1f;border-radius:4px}.weather-detail__hourly::-webkit-scrollbar-thumb{background:#ffffff59;border-radius:4px;transition:background .15s ease}.weather-detail__hourly::-webkit-scrollbar-thumb:hover{background:#ffffff80}.weather-detail__hourly{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.35) rgba(255,255,255,.12)}.weather-detail__hour{flex:0 0 auto;min-width:80px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:#00000038;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:14px 12px;display:flex;flex-direction:column;align-items:center;gap:6px;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.weather-detail__hour:hover{transform:translateY(-2px);border-color:#ffffff38;box-shadow:0 6px 20px #00000040}.weather-detail__hour-icon{margin-top:4px;font-size:1.2rem;color:#ffffffeb}.weather-detail__hour-time{color:#ffffffa6;font-size:.82rem;font-weight:500;letter-spacing:.02em}.weather-detail__hour-temp{margin-top:2px;font-size:1rem;font-weight:700;color:#fffffff2}.weather-detail__weekly{display:grid;grid-template-columns:repeat(7,minmax(76px,1fr));gap:12px}.weather-detail__day{border-radius:16px;border:1px solid rgba(255,255,255,.12);background:#00000038;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:14px 10px;display:flex;flex-direction:column;align-items:center;gap:6px;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.weather-detail__day:hover{transform:translateY(-2px);border-color:#ffffff38;box-shadow:0 6px 20px #00000040}.weather-detail__day-icon{margin-top:4px;font-size:1.2rem;color:#ffffffeb}.weather-detail__day-name{color:#ffffffa6;font-size:.82rem;font-weight:500;letter-spacing:.02em}.weather-detail__day-temp{margin-top:2px;font-size:1rem;font-weight:700;color:#fffffff2}.weather-detail__settings{display:flex;flex-wrap:wrap;gap:12px}.weather-detail__settings-card{border-radius:16px;border:1px solid rgba(255,255,255,.1);background:#0000002e;padding:12px;flex:1 1 320px;min-width:260px;display:flex;flex-direction:column;gap:10px}.weather-detail__settings-card-title{display:inline-flex;align-items:center;gap:10px;font-weight:800;color:#ffffffeb;margin-bottom:0}.weather-detail__settings-card-title svg{font-size:1.1rem;color:var(--color-primary)}.weather-detail__settings-row{display:flex;align-items:center;gap:12px}.weather-detail__settings-row--stack{align-items:flex-start}.weather-detail__settings-row--stack .weather-detail__settings-label{padding-top:6px}.weather-detail__settings-row--current{align-items:flex-start}.weather-detail__settings-label{flex:0 0 92px;color:#fffc;font-weight:700}.weather-detail__settings-value{flex:1 1 auto;min-width:0}.weather-detail__settings-value-main{font-weight:800;color:#ffffffeb;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.weather-detail__settings-value-sub{margin-top:4px;font-size:.85rem;color:#ffffff9e}.weather-detail__settings-control{flex:0 1 220px;max-width:240px;min-width:140px}.weather-detail__geo{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f;color:#ffffffe6;cursor:pointer}.weather-detail__geo:hover{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),0 0 14px 0 var(--color-primary)}.weather-detail__location-search{position:relative;width:100%}.weather-detail__settings-row--stack .weather-detail__location-search{flex:1 1 auto;min-width:0}.weather-detail__searching{position:absolute;top:10px;right:16px;color:#ffffffb3}.weather-detail__results{position:absolute;z-index:2;left:0;right:0;margin-top:10px;border-radius:16px;border:1px solid rgba(255,255,255,.1);background:#0f1520eb;overflow:hidden}.weather-detail__results--portal{position:fixed;z-index:9999;margin-top:0;overflow:auto}.weather-detail__result{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;width:100%;padding:10px 12px;border:none;background:transparent;color:#ffffffe6;cursor:pointer;text-align:left}.weather-detail__result-main{display:flex;flex-direction:column;align-items:stretch;gap:6px;min-width:0}.weather-detail__result-name{flex:1 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.weather-detail__country-pill{align-self:flex-start;font-size:.8rem;font-weight:800;padding:2px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#ffffffbf}.weather-detail__result:hover{background:#ffffff0f}.weather-detail__country{color:#fff9;font-size:.85rem;margin-left:12px}@keyframes weather-detail-fade{0%{opacity:0}to{opacity:1}}@keyframes weather-detail-fade-out{0%{opacity:1}to{opacity:0}}@keyframes weather-detail-panel-in{0%{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes weather-detail-panel-out{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(10px) scale(.99)}}@media (max-width: 820px){.weather-detail__panel{max-height:calc(100vh - 20px)}.weather-detail__weekly{grid-template-columns:repeat(4,minmax(76px,1fr))}}@media (max-width: 480px){.weather-detail__weekly{grid-template-columns:repeat(3,minmax(76px,1fr))}.weather-detail__hour{min-width:72px;padding:12px 10px}}@media (prefers-reduced-motion: reduce){.weather-detail__panel,.weather-detail__backdrop,.weather-detail__panel:before,.weather-detail__panel:after,.weather-detail__background{animation:none!important}}.weather-widget{--weather-widget-base: rgba(28,34,44,.68);background:radial-gradient(circle at top left,color-mix(in srgb,var(--color-weather-sun) 22%,transparent),var(--weather-widget-base))}.weather-widget--cloud{background:radial-gradient(circle at top left,color-mix(in srgb,var(--color-surface-iris) 65%,transparent),var(--weather-widget-base))}.weather-widget--rain{background:radial-gradient(circle at top left,color-mix(in srgb,var(--color-surface-iris) 75%,transparent),var(--weather-widget-base))}.weather-widget--storm{background:radial-gradient(circle at top left,color-mix(in srgb,var(--color-danger-surface-strong) 75%,transparent),var(--weather-widget-base))}.weather-widget--snow{background:radial-gradient(circle at top left,color-mix(in srgb,var(--color-surface-panel-soft) 75%,transparent),var(--weather-widget-base))}.weather-widget--sun{background:radial-gradient(circle at top left,color-mix(in srgb,var(--color-weather-sun) 22%,transparent),var(--weather-widget-base))}.weather-widget__content{display:flex;flex-direction:column;justify-content:center;gap:10px;height:100%;min-height:0}.weather-widget__top-row{display:flex;align-items:center;justify-content:center;gap:20px;padding:.5rem 0}.weather-widget__main-icon{font-size:3rem;color:var(--color-weather-sun);filter:drop-shadow(0 3px 10px var(--color-shadow-weather-light))}.weather-widget__temp-block{display:flex;flex-direction:column;align-items:flex-start}.weather-widget__temp{font-size:2.4rem;font-weight:700;color:var(--color-white);line-height:1.1}.weather-widget__desc-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px}.weather-widget__desc{font-size:1rem;font-weight:500;color:var(--color-white)}.weather-widget__hilo{font-size:.85rem;color:var(--color-secondary-light)}.weather-widget__location{display:flex;align-items:center;justify-content:center;gap:6px;font-size:.85rem;color:var(--color-secondary-light)}.weather-widget__location-icon{font-size:.75rem;color:var(--color-primary)}.weather-widget__forecast-section{display:flex;flex-direction:column;gap:8px;margin-top:auto;padding-top:10px;border-top:1px solid var(--color-glass-border-xlight)}.weather-widget__forecast-controls{display:flex;align-items:center;justify-content:center}.weather-widget__tabs{display:flex;justify-content:center;gap:8px}.weather-widget__tabs button{padding:6px 18px;font-size:.8rem;font-weight:500;color:var(--color-secondary-light);background:var(--color-glass-bg-light);border:1px solid var(--color-glass-border-xlight);border-radius:20px;cursor:pointer;transition:all .15s}.weather-widget__tabs button.active{color:var(--color-white);background:var(--color-primary);border-color:var(--color-primary)}.weather-widget__tabs button:hover:not(.active):not(:disabled){background:var(--color-glass-bg);border-color:var(--color-glass-border-light)}.weather-widget__tabs button:disabled{cursor:default}.weather-widget__forecast-carousel{position:relative}.weather-widget__forecast-row{display:flex;flex-wrap:nowrap;justify-content:flex-start;gap:8px;padding:4px 0;overflow-x:auto;scroll-behavior:smooth;cursor:grab;-ms-overflow-style:none;scrollbar-width:none}.weather-widget__forecast-row::-webkit-scrollbar{display:none}.weather-widget__forecast-row:active{cursor:grabbing}.weather-widget__scroll-btn{position:absolute;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:10px;background:var(--color-glass-bg-light);border:1px solid var(--color-glass-border-xlight);color:var(--color-white);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2}.weather-widget__scroll-btn:hover:not(:disabled){background:var(--color-glass-bg);border-color:var(--color-glass-border-light)}.weather-widget__scroll-btn:disabled{opacity:.35;cursor:default}.weather-widget__scroll-btn--left{left:-2px}.weather-widget__scroll-btn--right{right:-2px}.weather-widget__forecast-item{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:6px;width:56px;padding:10px;background:var(--color-glass-bg-light);border:1px solid var(--color-glass-border-xlight);border-radius:12px;min-width:unset;transition:all .15s}.weather-widget__forecast-item:hover{background:var(--color-glass-bg);border-color:var(--color-glass-border-light)}.weather-widget__forecast-label{font-size:.75rem;font-weight:500;color:var(--color-secondary-light);white-space:nowrap}.weather-widget__forecast-icon{font-size:1.2rem;color:var(--color-weather-sun)}.weather-widget__forecast-temp{font-size:.85rem;font-weight:600;color:var(--color-white)}.weather-widget__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;height:100%;min-height:0}.weather-widget__empty-title{font-size:1rem;font-weight:600;color:var(--color-white)}.weather-widget__empty-subtitle{font-size:.85rem;color:var(--color-secondary-light);max-width:280px}.weather-widget__empty-btn{margin-top:4px;padding:8px 14px;border-radius:12px;border:1px solid var(--color-glass-border-light);background:var(--color-glass-bg-light);color:var(--color-white);cursor:pointer;transition:all .15s}.weather-widget__empty-btn:hover:not(:disabled){background:var(--color-glass-bg);border-color:var(--color-primary)}.weather-widget__empty-btn:disabled{opacity:.65;cursor:default}.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(calc(var(--switch-width) - var(--thumb-size) - 4px))}.hn-color-summary{display:flex;justify-content:flex-start}.hn-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}.hn-color-toggle:disabled{opacity:.65;cursor:not-allowed}.hn-color-toggle:not(:disabled):hover{border-color:#818cf880;background:#818cf82e}.hn-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}.hn-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}.hn-color-popover .react-colorful{width:100%;height:10rem}.hn-color-popover .react-colorful__saturation{border-radius:.75rem}.hn-color-popover .react-colorful__hue{height:.85rem;border-radius:999px;margin-top:.75rem}.hn-color-popover .react-colorful__pointer{width:1.1rem;height:1.1rem;border-radius:999px;box-shadow:0 4px 14px #0000004d;border:2px solid rgba(255,255,255,.9)}.hn-color-actions{margin-top:.75rem;display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;justify-content:space-between}.hn-color-input{flex:1 1 auto;min-width:8.5rem;border-radius:.65rem;border:1px solid rgba(255,255,255,.12);background:#0c121c80;color:#ffffffe0;padding:.45rem .6rem;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em}.hn-color-input:focus{outline:none;border-color:#818cf880;box-shadow:0 0 0 1px #818cf859}.hn-color-buttons{display:inline-flex;gap:.5rem;flex:0 0 auto}.hn-color-cancel,.hn-color-apply{border:1px solid rgba(255,255,255,.12);background:#ffffff0d;color:#ffffffd9;padding:.45rem .75rem;border-radius:.65rem;font-size:.78rem;font-weight:700;cursor:pointer;transition:background .2s ease,border-color .2s ease}.hn-color-apply{border-color:#22c55e59;background:#22c55e1f}.hn-color-cancel:hover{background:#f871711f;border-color:#f8717159}.hn-color-apply:not(:disabled):hover{background:#22c55e38;border-color:#22c55e80}.hn-color-apply:disabled{opacity:.7;cursor:not-allowed}.hn-color-value{margin-left:auto;opacity:.7;font-size:.85rem;flex-shrink:0;text-transform:uppercase;letter-spacing:.03em}.dcr-control-list{display:flex;flex-direction:column;gap:.65rem;width:100%}.dcr-layout-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.65rem;align-content:center}.dcr-layout-cards .dcr-control{box-shadow:0 1px 2px #0000000f;flex-direction:column;align-items:stretch;justify-content:space-between;gap:.55rem;min-height:92px;padding:.75rem .85rem}.dcr-layout-cards .dcr-control-label{width:100%}.dcr-layout-cards .dcr-control-label span{white-space:normal;overflow:hidden;text-overflow:ellipsis}.dcr-layout-cards .glass-switch{align-self:flex-end}.dcr-layout-cards .dcr-control-select,.dcr-layout-cards .dcr-control-number{width:100%;min-width:0}.dcr-layout-cards .dcr-control-wide{grid-column:1 / -1}.dcr-layout-list{display:flex;flex-direction:column;gap:0}.dcr-layout-list .dcr-control{flex-direction:row;align-items:center;justify-content:space-between;gap:.75rem;padding:.5rem 0;background:transparent;border:none;border-radius:0;box-shadow:none}.dcr-layout-list .dcr-control:first-child{padding-top:0}.dcr-layout-list .dcr-control:last-child{padding-bottom:0}.dcr-layout-list .dcr-control-wide{flex-direction:column;align-items:stretch}.dcr-control{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:.65rem;padding:.55rem .75rem;background:#ffffff0a;border-radius:.75rem;border:1px solid rgba(255,255,255,.08)}.dcr-control-wide{flex-direction:column;align-items:stretch}.dcr-control-label{display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--color-text);flex:1;min-width:0}.dcr-control-label svg{font-size:.82rem;opacity:.7;flex-shrink:0}.dcr-control-label span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dcr-control-value{margin-left:auto;opacity:.7;font-size:.82rem;flex-shrink:0}.dcr-control-slider{display:flex;flex-direction:column;gap:4px;width:100%}.dcr-control-range{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:8px;border-radius:4px;background:var(--color-glass-bg-light);outline:none;cursor:pointer}.dcr-control-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--color-primary);border:2px solid var(--color-glass-border);cursor:pointer;transition:transform .15s ease}.dcr-control-range::-webkit-slider-thumb:hover{transform:scale(1.1)}.dcr-control-range::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--color-primary);border:2px solid var(--color-glass-border);cursor:pointer}.dcr-control-slider-scale{display:flex;justify-content:space-between;font-size:.7rem;opacity:.5;padding:0 2px}.dcr-control-select{padding:6px 10px;border-radius:6px;background:var(--color-glass-bg-light);border:1px solid var(--color-glass-border-xlight);color:var(--color-text);font-size:.85rem;cursor:pointer;min-width:100px}.dcr-control-select:focus{outline:none;border-color:var(--color-primary)}.dcr-control-number{padding:6px 10px;border-radius:6px;background:rgba(var(--color-glass-bg-rgb),.5);border:1px solid rgba(var(--color-glass-border-rgb),.4);color:var(--color-text);font-size:.85rem;width:80px;text-align:right}.dcr-control-number:focus{outline:none;border-color:var(--color-primary)}.dcr-color-control{position:relative}.dcr-color-summary{display:flex;align-items:center;gap:10px;width:100%}.dcr-color-toggle{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;background:rgba(var(--color-glass-bg-rgb),.5);border:1px solid rgba(var(--color-glass-border-rgb),.4);color:var(--color-text);font-size:.85rem;cursor:pointer;width:100%;transition:border-color .15s ease}.dcr-color-toggle:hover:not(:disabled){border-color:var(--color-primary)}.dcr-color-swatch{width:24px;height:24px;border-radius:6px;border:2px solid rgba(var(--color-glass-border-rgb),.5);flex-shrink:0}.dcr-color-popover{margin-top:12px;padding:12px;background:rgba(var(--color-glass-bg-rgb),.9);border-radius:10px;border:1px solid rgba(var(--color-glass-border-rgb),.4);display:flex;flex-direction:column;gap:12px}.dcr-color-popover .react-colorful{width:100%;height:150px}.dcr-color-actions{display:flex;flex-direction:column;gap:8px}.dcr-color-input{padding:6px 10px;border-radius:6px;background:rgba(var(--color-glass-bg-rgb),.5);border:1px solid rgba(var(--color-glass-border-rgb),.4);color:var(--color-text);font-size:.85rem;font-family:monospace}.dcr-color-buttons{display:flex;gap:8px;justify-content:flex-end}.dcr-color-cancel,.dcr-color-apply{padding:6px 14px;border-radius:6px;font-size:.85rem;cursor:pointer;border:none}.dcr-color-cancel{background:rgba(var(--color-glass-bg-rgb),.6);color:var(--color-text)}.dcr-color-apply{background:var(--color-primary);color:#fff}.dcr-color-apply:disabled{opacity:.5;cursor:not-allowed}.dcr-controls-toggle{padding:8px 14px;border-radius:8px;background:rgba(var(--color-glass-bg-rgb),.3);border:1px solid rgba(var(--color-glass-border-rgb),.2);color:var(--color-text);font-size:.8rem;cursor:pointer;text-align:center;opacity:.8;transition:opacity .15s ease}.dcr-controls-toggle:hover{opacity:1}.glass-metric{display:flex;align-items:center;justify-content:space-between;gap:.9rem;padding:.35rem 0;color:#ffffffd9;min-width:0}.dmr-layout-list .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;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.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;min-width:0}.glass-metric-unit{margin-left:.2rem;font-size:.75rem;font-weight:500;color:#fff9}.glass-metric-hint{font-size:.7rem;color:#ffffff8c}.dmr-container{display:flex;flex-direction:column;gap:.65rem;width:100%}.dmr-binary-metrics{display:flex;flex-wrap:wrap;gap:.5rem}.dmr-numeric-metrics{display:flex;flex-wrap:wrap;gap:.65rem}.dmr-layout-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.65rem;align-content:center}.dmr-layout-cards .glass-metric{min-width:0;padding:.7rem .85rem;border-radius:.85rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}.dmr-layout-list{flex-direction:column;gap:.4rem}.dmr-layout-list .glass-metric{flex-direction:row;justify-content:space-between;width:100%;padding:.5rem .75rem}.dmr-metrics-toggle{padding:.4rem .75rem;border-radius:.5rem;background:var(--color-glass-bg-light);border:1px solid var(--color-glass-border-xlight);color:var(--color-white);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;text-align:center;opacity:.8;transition:opacity .15s ease,background .15s ease}.dmr-metrics-toggle:hover{opacity:1;background:var(--color-glass-bg)}.device-widget{cursor:pointer}.device-widget__content{display:flex;flex-direction:column;gap:1rem;min-height:0;padding-top:.25rem;flex:1;overflow:hidden}.device-widget__command-error{padding:.5rem .75rem;border-radius:.65rem;background:#dc262626;border:1px solid rgba(220,38,38,.3);color:var(--color-danger-light, #fca5a5);font-size:.78rem;font-weight:500}.device-widget__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:.55rem .25rem .85rem;border-bottom:1px solid var(--color-glass-border-xlight)}.device-widget__title-group{display:flex;align-items:center;justify-content:center;gap:1rem;flex:1;min-width:0}.device-widget__icon{font-size:1.4rem;color:#ffffffd1;flex-shrink:0;filter:none}.device-widget__title-info{display:flex;flex-direction:column;gap:.25rem;min-width:0}.device-widget__name{font-size:1.05rem;font-weight:600;color:var(--color-white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.device-widget__status{display:inline-flex;align-items:center;gap:.4rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;font-weight:600;color:#34d399e6}.device-widget__status:before{content:"";width:7px;height:7px;border-radius:50%;background:#34d399;box-shadow:0 0 8px #34d39999}.device-widget__status.offline{color:#f87171e6}.device-widget__status.offline:before{background:#f87171;box-shadow:0 0 8px #f8717199}.device-widget__toggle{flex-shrink:0}.device-widget__controls-area{display:flex;flex-direction:column;align-items:stretch;flex:1 1 auto;min-height:0;gap:.75rem;padding:0 .25rem;overflow:auto}.device-widget--empty,.device-widget--error{min-height:100px}.device-widget__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;flex:1;text-align:center;color:var(--color-secondary-light);font-size:.9rem;padding:2rem}.device-widget__empty-icon{font-size:2.5rem;opacity:.5;color:var(--color-primary)}.device-widget:not(.widget-shell--edit-mode):hover{transform:translateY(-2px);transition:transform .2s ease}.history-chart{display:flex;flex-direction:column;gap:.6rem;position:relative}.history-chart-title-row{display:flex;align-items:baseline;justify-content:space-between;gap:1rem}.history-chart-title{font-weight:700;color:#ffffffeb}.history-chart-latest{font-variant-numeric:tabular-nums;color:#ffffffc7}.history-chart-svg{width:100%;height:var(--history-chart-height, 180px);background:var(--color-surface-panel-soft);border:1px solid var(--color-glass-border-xlight);border-radius:14px;transition:height .26s cubic-bezier(.4,0,.2,1)}.history-chart-axis{fill:#ffffffa6;font-size:12px;font-variant-numeric:tabular-nums}.history-chart-axis-x{fill:#ffffff8c}.history-chart-line{fill:none;stroke:var(--color-primary);stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.history-chart-area{stroke:none}.history-chart-grid{fill:none;stroke:var(--color-glass-border-xlight);stroke-width:1}.history-chart-grid-soft{stroke:#ffffff0f}.history-chart-crosshair{fill:none;stroke:#ffffff2e;stroke-width:1}.history-chart-dot{fill:var(--color-primary);stroke:#00000059;stroke-width:1}.history-chart-tooltip{position:absolute;right:.1rem;bottom:.15rem;padding:.45rem .6rem;border-radius:12px;background:var(--color-surface-overlay);border:1px solid var(--color-glass-border-xlight);color:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);max-width:80%;pointer-events:none}.history-chart-tooltip-value{font-weight:800;font-variant-numeric:tabular-nums}.history-chart-tooltip-time{margin-top:.15rem;color:#ffffffb3;font-size:.78rem;font-variant-numeric:tabular-nums}.history-chart-empty{display:flex;flex-direction:column;gap:.75rem}.history-chart-placeholder{height:var(--history-chart-height, 180px);display:flex;align-items:center;justify-content:center;border:1px dashed var(--color-glass-border-xlight);border-radius:14px;color:#ffffffa6;background:var(--color-surface-panel-soft);transition:height .26s cubic-bezier(.4,0,.2,1)}@media (prefers-reduced-motion: reduce){.history-chart-svg,.history-chart-placeholder{transition:none}}.device-graph-widget__content{display:flex;flex-direction:column;flex:1;min-height:0}.device-graph-widget__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;flex:1;min-height:0;text-align:center;color:var(--color-secondary-light);font-size:.9rem}.device-graph-widget__empty-icon{font-size:2.3rem;opacity:.5;color:var(--color-primary)}.device-graph-widget__empty-text{max-width:280px}.map-widget{cursor:pointer}.map-widget:not(.widget-shell--edit-mode):hover{transform:translateY(-1px)}.map-widget__content{display:flex;flex-direction:column;justify-content:center;align-items:stretch;flex:1;min-height:0;gap:12px}.map-widget__preview{width:100%;flex:1;min-height:120px;display:flex;align-items:center;justify-content:center;background:var(--color-glass-bg-ultra);border:1px solid var(--color-glass-border-xlight);border-radius:12px;overflow:hidden;transition:border-color .2s}.map-widget:not(.widget-shell--edit-mode):hover .map-widget__preview{border-color:var(--color-glass-border-light)}.map-widget__svg{width:100%;height:100%}.map-widget__room{cursor:pointer;transition:fill .15s,stroke .15s}.map-widget__room:hover{fill:var(--color-glass-bg)!important;stroke:var(--color-primary)!important}.map-widget__room-label{font-size:10px;fill:var(--color-secondary-light);text-anchor:middle;pointer-events:none;-webkit-user-select:none;user-select:none}.map-widget__device{cursor:pointer;transition:fill .15s,opacity .15s}.map-widget__device:hover{fill:var(--color-success)!important;opacity:1!important}.map-widget__device-label{font-size:9px;fill:var(--color-white);text-anchor:middle;pointer-events:none;-webkit-user-select:none;user-select:none}.map-widget__device-state,.map-widget__device-favorite{fill:var(--color-secondary-light);font-size:8px}.map-widget__device-tooltip{position:absolute;padding:4px 8px;background:var(--color-surface-overlay);border-radius:6px;font-size:.75rem;color:var(--color-white);pointer-events:none;z-index:10;white-space:nowrap}.map-widget__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px;color:var(--color-secondary-light);font-size:.85rem}.map-widget__empty-icon{font-size:2rem;opacity:.5}.map-widget__actions{display:flex;justify-content:flex-end}.map-widget__open-btn{font-size:.8rem}.progress-bar{width:100%}.progress-bar__track{position:relative;width:100%;height:10px;background:var(--color-glass-bg-light);border:1px solid var(--color-glass-border-xlight);border-radius:999px;overflow:hidden}.progress-bar__fill{height:100%;width:0%;background:var(--color-primary);border-radius:999px;transition:width .18s ease-out}.progress-bar--indeterminate .progress-bar__fill{width:35%;position:absolute;left:-35%;animation:progress-bar-indeterminate 1.1s ease-in-out infinite}@keyframes progress-bar-indeterminate{0%{left:-35%}to{left:100%}}.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)}.automation-widget{cursor:pointer}.automation-widget:not(.widget-shell--edit-mode):hover{transform:translateY(-1px)}.automation-widget--empty{min-height:100px}.automation-widget__content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.25rem;height:100%;min-height:0;padding:.5rem 0}.automation-widget__header{display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center}.automation-widget__icon-wrapper{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:linear-gradient(135deg,#6366f140,#6366f11a);border:1px solid rgba(99,102,241,.3);border-radius:16px;transition:all .2s}.automation-widget__icon{font-size:1.5rem;color:var(--color-primary);filter:drop-shadow(0 2px 4px rgba(99,102,241,.3))}.automation-widget__workflow-name{font-size:1.1rem;font-weight:600;color:var(--color-white);line-height:1.3;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.automation-widget__subtitle{font-size:.8rem;color:var(--color-secondary-light);text-transform:uppercase;letter-spacing:.05em}.automation-widget__run-btn{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;min-width:120px}.automation-widget__run-btn:hover:not(:disabled){transform:translateY(-1px)}.automation-widget__run-btn:active:not(:disabled){transform:translateY(0)}.automation-widget__run-btn:disabled{opacity:.5;cursor:not-allowed}.automation-widget__run-btn--running{filter:saturate(.9)}.automation-widget__run-btn--running .automation-widget__run-btn-icon svg{animation:automation-spin 1s linear infinite}.automation-widget__run-btn-icon{display:inline-flex;align-items:center;justify-content:center}@keyframes automation-spin{to{transform:rotate(360deg)}}.automation-widget__status{display:flex;flex-direction:column;align-items:center;gap:.5rem;width:100%;max-width:200px}.automation-widget__progress{width:100%}.automation-widget__progress-text{font-size:.8rem;color:var(--color-secondary-light);text-align:center}.automation-widget__result{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-size:.85rem;font-weight:500}.automation-widget__result.success{background:#34d39926;color:var(--color-success)}.automation-widget__result.error{background:#f8717126;color:var(--color-danger-light, #fca5a5)}.automation-widget__not-found{padding:1rem;text-align:center;color:var(--color-secondary-light);font-size:.9rem}.automation-widget__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;flex:1;text-align:center;color:var(--color-secondary-light);font-size:.9rem;padding:2rem}.automation-widget__empty-icon{font-size:2.5rem;opacity:.5;color:var(--color-primary)}.automation-widget__empty-icon{font-size:2rem;opacity:.5}.page-header-flat{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;margin:10px 10px 12px;padding:0 8px;width:100%}.page-header-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;width:100%;justify-content:flex-start}.page-header-text{display:flex;flex-direction:column;min-width:0;align-items:flex-start;text-align:left}.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;overflow-wrap:anywhere}.page-header-extra{margin-top:.75rem;width:100%}.page-header-back-pill.glass-pill{font-size:.92rem;padding:.46rem .78rem;border-radius:999px;line-height:1;margin-top:.1rem}@media (max-width: 640px){.page-header-flat{margin:8px 6px 10px;padding:0 6px;align-items:center;text-align:center;width:calc(100% - 12px);box-sizing:border-box}.page-title{font-size:1.6rem;width:100%;text-align:center}.page-subtitle{font-size:.85rem;max-width:320px;width:100%;text-align:center}.page-header-row{flex-direction:column;align-items:center;gap:.6rem;width:100%;justify-content:center}.page-header-flat:not(.page-header--with-back) .page-header-text{width:100%;align-items:center;text-align:center}.page-header-flat.page-header--with-back{align-items:flex-start;text-align:left}.page-header-flat.page-header--with-back .page-header-row{flex-direction:row;align-items:center;justify-content:flex-start;flex-wrap:nowrap;gap:.6rem}.page-header-flat.page-header--with-back .page-header-text{align-items:flex-start;text-align:left}}.unauthorized-page{display:flex;flex-direction:column;gap:1.5rem;padding:0 1.5rem 3rem;color:var(--color-white)}.unauthorized-card{max-width:760px}.unauthorized-body{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:.25rem .25rem .6rem}.unauthorized-icon{position:relative;width:62px;height:62px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;background:#ffffff14;border:1px solid var(--color-glass-border-xlight)}.unauthorized-icon-badge{font-size:1.35rem;filter:saturate(.9)}.unauthorized-pulse{position:absolute;top:6px;right:6px;bottom:6px;left:6px;border-radius:16px;border:1px solid rgba(255,255,255,.16);animation:unauthorizedPulse 1.8s ease-in-out infinite}@keyframes unauthorizedPulse{0%{transform:scale(.98);opacity:.55}50%{transform:scale(1.02);opacity:.22}to{transform:scale(.98);opacity:.55}}.unauthorized-message{color:#ffffffe0;font-weight:700;text-align:center;padding:.35rem .25rem}.unauthorized-actions{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;justify-content:center;margin-top:.1rem}.unauthorized-note{margin-top:.25rem;color:#fff9;font-size:.85rem;text-align:center}@media (prefers-reduced-motion: reduce){.unauthorized-pulse{animation:none}}@media (max-width: 640px){.unauthorized-page{padding:0 1rem 3rem}}.loading-page{display:flex;flex-direction:column;gap:1.5rem;padding:0 1.5rem 3rem;color:var(--color-white)}.loading-card{max-width:760px}.loading-body{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.85rem;padding:1.1rem .75rem 1.25rem;min-height:180px}.loading-spinner{width:34px;height:34px;border:3px solid rgba(255,255,255,.22);border-top-color:var(--color-primary);border-radius:999px;animation:loadingSpin .9s linear infinite}@keyframes loadingSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-message{color:#ffffffd1;font-weight:700;text-align:center;padding:.25rem}@media (prefers-reduced-motion: reduce){.loading-spinner{animation:none}}@media (max-width: 640px){.loading-page{padding:0 1rem 3rem}}.unknown-widget{min-height:100px}.unknown-widget__content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%;text-align:center;padding:16px}.unknown-widget__icon{font-size:2.5rem;color:var(--color-secondary-light);opacity:.5}.unknown-widget__message{display:flex;flex-direction:column;gap:4px}.unknown-widget__title{font-size:.95rem;font-weight:500;color:var(--color-white)}.unknown-widget__type{font-size:.8rem;color:var(--color-secondary-light);font-family:monospace}.add-widget-modal__backdrop{z-index:9999}.widget-settings-modal.add-widget-modal{width:560px;max-width:95vw}.add-widget-modal__content{display:flex;flex-direction:column;gap:1rem;padding:0 2rem 1.7rem;min-height:0}.add-widget-modal__search{display:flex;min-width:0}.add-widget-modal__list{flex:1;min-height:0;overflow-y:auto;padding:0}.add-widget-modal__empty{padding:32px;text-align:center;color:var(--color-secondary-light);font-size:.9rem}.add-widget-modal__item{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--color-glass-bg-light);border:1px solid var(--color-glass-border-xlight);border-radius:14px;margin-bottom:10px;transition:all .15s}.add-widget-modal__item:hover{background:var(--color-glass-bg);border-color:var(--color-glass-border-light)}.add-widget-modal__item-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--color-glass-bg-strong);border-radius:12px;color:var(--color-primary);font-size:1.2rem;flex-shrink:0}.add-widget-modal__item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.add-widget-modal__item-name{font-size:.95rem;font-weight:500;color:var(--color-white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.add-widget-modal__item-desc{font-size:.8rem;color:var(--color-secondary-light);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.add-widget-modal__verified{display:inline-flex;align-items:center;gap:4px;margin-top:4px;padding:2px 8px;font-size:.7rem;font-weight:500;color:var(--color-success);background:var(--color-success-surface);border-radius:6px;width:fit-content}.add-widget-modal__item-add{display:flex;align-items:center;gap:6px;padding:10px 16px;font-size:.85rem;font-weight:500;color:var(--color-white);background:var(--color-primary);border:none;border-radius:10px;cursor:pointer;transition:all .15s;flex-shrink:0}.add-widget-modal__item-add:hover{background:var(--color-primary-dark);transform:scale(1.02)}.add-widget-modal__item-add:active{transform:scale(.98)}@media (max-width: 768px){.widget-settings-modal.add-widget-modal{width:calc(100vw - 1.5rem);max-width:calc(100vw - 1.5rem)}.add-widget-modal__content{padding:0 .9rem 1rem}}.widget-settings__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#2c364347;opacity:0;pointer-events:none;transition:opacity .28s cubic-bezier(.4,2,.6,1);touch-action:none}.widget-settings__backdrop.open{opacity:1;pointer-events:auto}.widget-settings-modal{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%);width:420px;max-width:95vw;max-height:85vh;display:flex;flex-direction:column;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);box-sizing:border-box}.widget-settings__backdrop.open .widget-settings-modal{opacity:1;transform:translateY(0) scale(1)}.widget-settings__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}.widget-settings__close:hover{color:var(--color-primary);opacity:1}.widget-settings__header{display:flex;align-items:center;gap:14px;padding:1.8rem 2rem 1rem}.widget-settings__icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-glass-bg-strong);border-radius:14px;color:var(--color-primary);font-size:1.3rem;flex-shrink:0}.widget-settings__header-text{display:flex;flex-direction:column;gap:2px}.widget-settings__title{font-size:1.15rem;font-weight:600;color:var(--color-white);margin:0}.widget-settings__type{font-size:.85rem;color:var(--color-secondary-light)}.widget-settings__btn--neutral{background:#ffffff12;border:1.5px solid rgba(60,70,90,.38);color:var(--color-white)}.widget-settings__btn--neutral:hover{background:#ffffff1a;border-color:var(--color-glass-border-light);transform:translateY(-1px)}.widget-settings__content{flex:1;overflow-y:auto;overflow-x:visible;padding:1rem 2rem 1.75rem}.widget-settings__field{position:relative}.widget-settings__field{margin-bottom:1.2rem}.widget-settings__field:last-child{margin-bottom:0}.widget-settings__label{display:block;margin-bottom:.5rem;font-size:.9rem;font-weight:500;color:var(--color-white)}.widget-settings__hint{margin-top:.4rem;font-size:.8rem;color:var(--color-secondary-light)}.widget-settings__section{margin-top:.25rem}.widget-settings__section-title{margin:0 0 .85rem;display:inline-flex;align-items:center;gap:.55rem;font-size:.95rem;font-weight:700;color:#ffffffeb}.widget-settings__input,.widget-settings__select{width:100%;padding:.85rem 1rem;font-size:.95rem;color:var(--color-white);background:#ffffff12;border:1.5px solid rgba(60,70,90,.38);border-radius:.9rem;outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.widget-settings__input::placeholder{color:var(--color-secondary-light)}.widget-settings__input:focus,.widget-settings__select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.18)}.widget-settings__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' viewBox='0 0 24 24' fill='%23a0a0a0'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding-right:40px}.widget-settings__checkboxes{display:flex;flex-wrap:wrap;gap:10px}.widget-settings__checkbox{display:flex;align-items:center;gap:8px;padding:.6rem 1rem;background:#ffffff0d;border:1px solid rgba(60,70,90,.3);border-radius:.7rem;cursor:pointer;transition:all .15s}.widget-settings__checkbox:hover{background:#ffffff14;border-color:#3c465a80}.widget-settings__checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.widget-settings__checkbox span{font-size:.85rem;color:var(--color-white)}.widget-settings__no-settings{padding:1.5rem;text-align:center;color:var(--color-secondary-light);font-size:.9rem;background:#ffffff08;border-radius:.9rem}.widget-settings__chip-row{display:flex;flex-wrap:wrap;gap:8px}.widget-settings__chip{display:inline-flex;align-items:center;gap:8px}.widget-settings__chip-check{font-size:.85em}.widget-settings__toggle-row{display:flex;gap:8px}.widget-settings__toggle-btn{display:inline-flex;align-items:center;gap:6px;padding:.5rem 1rem;font-size:.85rem;font-weight:500;color:var(--color-white);background:#ffffff12;border:1.5px solid rgba(60,70,90,.38);border-radius:999px;cursor:pointer;transition:all .15s ease}.widget-settings__toggle-btn:hover{background:#ffffff1a;border-color:#3c465a80}.widget-settings__toggle-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.widget-settings__toggle-btn.active:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.widget-settings__toggle-check{font-size:.8em}.widget-settings__picker-list{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.widget-settings__picker-empty{padding:.8rem 1rem;font-size:.85rem;color:var(--color-secondary-light);background:#ffffff08;border-radius:.7rem;text-align:center}.widget-settings__picker-item{display:flex;align-items:center;gap:10px;padding:.6rem .8rem;background:#ffffff0d;border:1px solid rgba(60,70,90,.3);border-radius:.7rem;transition:all .15s}.widget-settings__picker-item:hover{background:#ffffff14;border-color:#3c465a80}.widget-settings__picker-item-icon{color:var(--color-primary);font-size:.9rem;width:18px;text-align:center;flex-shrink:0}.widget-settings__picker-item-name{flex:1;font-size:.85rem;color:var(--color-white);text-transform:capitalize}.widget-settings__picker-item-remove{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:transparent;border:none;color:var(--color-secondary-light);border-radius:6px;cursor:pointer;transition:all .15s;flex-shrink:0}.widget-settings__picker-item-remove:hover{background:var(--color-danger-surface);color:var(--color-danger)}.widget-settings__picker-add{margin-top:4px}.widget-settings__picker-select{font-size:.85rem;padding:.6rem .8rem}.widget-settings__footer{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem 1.5rem;gap:12px}.widget-settings__btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:.75rem 1.5rem;font-size:.9rem;font-weight:600;border:none;border-radius:999px;cursor:pointer;transition:all .2s}.widget-settings__btn--remove{color:var(--color-danger);background:var(--color-danger-surface)}.widget-settings__btn--remove:hover{background:var(--color-danger);color:var(--color-white)}.widget-settings__btn--save{color:var(--color-white);background:var(--color-primary)}.widget-settings__btn--save:hover{background:var(--color-primary-dark)}.widget-settings__location-current{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:.7rem 1rem;margin-bottom:.75rem;background:rgba(var(--color-primary-rgb),.15);border:1.5px solid rgba(var(--color-primary-rgb),.3);border-radius:.9rem;color:var(--color-white);font-size:.9rem}.widget-settings__location-clear{background:none;border:none;color:var(--color-secondary-light);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.widget-settings__location-clear:hover{color:var(--color-danger, #ff6b6b)}.widget-settings__location-search{display:flex;gap:8px}.widget-settings__search-input-wrapper{position:relative;flex:1}.widget-settings__search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--color-secondary-light);font-size:.9rem;pointer-events:none}.widget-settings__input--search{padding-left:2.5rem;padding-right:2.5rem}.widget-settings__search-spinner{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:var(--color-primary);font-size:.9rem}.widget-settings__btn--geo{flex-shrink:0;width:44px;height:44px;padding:0;display:flex;align-items:center;justify-content:center;background:#ffffff12;border:1.5px solid rgba(60,70,90,.38);border-radius:.9rem;color:var(--color-white);cursor:pointer;transition:background .2s,border-color .2s,color .2s}.widget-settings__btn--geo:hover:not(:disabled){background:rgba(var(--color-primary-rgb),.2);border-color:var(--color-primary);color:var(--color-primary)}.widget-settings__btn--geo:disabled{opacity:.6;cursor:not-allowed}.widget-settings__search-results{position:absolute;top:100%;left:0;right:0;background:#1c222cfa;border:1.5px solid rgba(60,70,90,.5);border-radius:.9rem;box-shadow:0 8px 24px #0000004d;max-height:200px;overflow-y:auto;z-index:100;list-style:none;padding:.5rem 0;margin:4px 0 0}.widget-settings__search-results li{margin:0}.widget-settings__search-results button{width:100%;padding:.7rem 1rem;background:none;border:none;color:var(--color-white);font-size:.9rem;text-align:left;cursor:pointer;transition:background .15s;display:flex;align-items:center;gap:8px}.widget-settings__search-results button:hover{background:rgba(var(--color-primary-rgb),.15)}.widget-settings__search-country{color:var(--color-secondary-light);font-size:.8rem;margin-left:auto}@media (max-width: 700px){.widget-settings-modal{width:90vw;max-width:420px;margin:0 5vw;max-height:90vh}.widget-settings__header{padding:1.2rem 1.2rem .8rem}.widget-settings__content{padding:.8rem 1.2rem 1.2rem}.widget-settings__footer{padding:.8rem 1.2rem 1.2rem;flex-direction:column-reverse}.widget-settings__btn{width:100%}}.react-grid-layout{position:relative;transition:height .2s ease}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.resizing{transition:none;z-index:1;will-change:width,height}.react-grid-item.react-draggable-dragging{transition:none;z-index:3;will-change:transform}.react-grid-item.react-grid-placeholder{background:red;opacity:.2;transition-duration:.1s;z-index:2;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{position:absolute;width:20px;height:20px}.react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;border-right:2px solid rgba(0,0,0,.4);border-bottom:2px solid rgba(0,0,0,.4)}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-resizable{position:relative}.react-resizable-handle{position:absolute;width:20px;height:20px;background-repeat:no-repeat;background-origin:content-box;box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:bottom right;padding:0 3px 3px 0}.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.dashboard{position:relative;min-height:100%;padding-bottom:100px}.dashboard__grid-container,.dashboard__grid{width:100%;overflow:visible}.dashboard__widget-wrapper{display:flex;height:100%}.dashboard__widget-wrapper>*{width:100%;height:100%;min-height:unset}.dashboard__widget-wrapper .glass-card{min-width:unset;height:100%}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height;overflow:visible}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item>.dashboard__widget-wrapper{height:100%}.react-grid-item.react-draggable-dragging{transition:none;z-index:100;opacity:.95}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{background:var(--color-primary);opacity:.2;border-radius:16px;transition:all .2s ease;z-index:2}.dashboard .react-grid-item>.react-resizable-handle{display:none!important}.dashboard--edit .react-grid-item>.react-resizable-handle{display:block!important;position:absolute;z-index:10;width:18px;height:18px;background-color:var(--color-primary);opacity:.75;border-radius:8px;cursor:inherit;background-image:none!important;-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path d='M6 3 L11 8 L6 13' fill='none' stroke='black' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'/></svg>");mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path d='M6 3 L11 8 L6 13' fill='none' stroke='black' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'/></svg>");-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:14px 14px;mask-size:14px 14px;transform:rotate(var(--handle-rot, 0deg));transition:transform .14s ease,opacity .14s ease}@keyframes resize-handle-pulse{0%,to{opacity:.65}50%{opacity:.95}}.dashboard--edit .react-grid-item>.react-resizable-handle{animation:resize-handle-pulse 2s ease-in-out infinite}.dashboard--edit .react-grid-item>.react-resizable-handle:hover{opacity:1;animation:none;transform:rotate(var(--handle-rot, 0deg)) scale(1.12)}.dashboard--edit .react-grid-item>.react-resizable-handle-se{--handle-rot: 45deg}.dashboard--edit .react-grid-item>.react-resizable-handle-s{--handle-rot: 90deg}.dashboard--edit .react-grid-item>.react-resizable-handle-e{--handle-rot: 0deg}.dashboard--edit .react-grid-item>.react-resizable-handle-ne{--handle-rot: 315deg}.dashboard--edit .react-grid-item>.react-resizable-handle-n{--handle-rot: 270deg}.dashboard--edit .react-grid-item>.react-resizable-handle-nw{--handle-rot: 225deg}.dashboard--edit .react-grid-item>.react-resizable-handle-w{--handle-rot: 180deg}.dashboard--edit .react-grid-item>.react-resizable-handle-sw{--handle-rot: 135deg}.dashboard__trash-zone{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;padding:14px 28px;background:var(--color-glass-bg);border:2px dashed var(--color-glass-border-light);border-radius:16px;color:var(--color-secondary-light);font-size:.95rem;z-index:50;transition:all .2s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.dashboard__trash-zone--active{background:var(--color-danger-surface, rgba(127, 29, 29, .6));border-color:var(--color-danger, #ef4444);color:var(--color-white);transform:translate(-50%) scale(1.05)}.dashboard__trash-zone svg{font-size:1.1rem}.dashboard__fab-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:12px;z-index:100}.dashboard__fab{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:16px;border:none;cursor:pointer;font-size:1.25rem;color:var(--color-white);box-shadow:0 4px 20px #0000004d;transition:all .2s ease}.dashboard__fab:hover{transform:scale(1.05)}.dashboard__fab:active{transform:scale(.98)}.dashboard__fab--edit{background:var(--color-primary)}.dashboard__fab--add{background:var(--color-glass-bg-strong);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-glass-border)}.dashboard__fab--add:hover{background:var(--color-primary);border-color:var(--color-primary)}.dashboard__fab--done{background:var(--color-success)}.dashboard__saving-indicator{position:fixed;top:80px;right:24px;padding:8px 16px;background:var(--color-glass-bg-strong);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-glass-border-light);border-radius:8px;color:var(--color-white);font-size:.85rem;z-index:100;animation:dashboard-saving-pulse 1s ease-in-out infinite}@keyframes dashboard-saving-pulse{0%,to{opacity:.7}50%{opacity:1}}.dashboard-error{display:flex;align-items:center;justify-content:center;min-height:200px;padding:24px}.dashboard-error__message{padding:24px;background:var(--color-glass-bg);border:1px solid var(--color-danger, #ef4444);border-radius:16px;color:var(--color-danger-light, #fca5a5);text-align:center}@media (max-width: 768px){.dashboard__fab-container{bottom:80px;right:16px}.dashboard__trash-zone{bottom:80px;padding:12px 20px;font-size:.85rem}.dashboard__saving-indicator{top:auto;bottom:140px;right:16px}}.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-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)}.device-tile-card.device-tile-clickable{cursor:pointer}.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;flex-wrap:wrap}.device-title-leading{position:relative;display:inline-flex;align-items:center;gap:.45rem}.device-title-icon{font-size:1.1rem;color:#ffffffd1}.device-title-icon-button{border:none;background:transparent;padding:0;display:inline-flex;align-items:center;justify-content:center;cursor:default}.device-title-icon-button.editable{border-radius:.65rem;border:1px solid rgba(34,197,94,.6);padding:.15rem .35rem;margin-left:-.1rem;cursor:pointer;transition:border .2s ease,background .2s ease,box-shadow .2s ease;background:#22c55e14;animation:device-icon-pulse 2.4s ease-in-out infinite}.device-title-icon-button.editable:hover{border-color:#22c55ea6;background:#22c55e2e;animation:none}@keyframes device-icon-pulse{0%{box-shadow:0 0 #22c55e73}70%{box-shadow:0 0 0 8px #22c55e00}to{box-shadow:0 0 #22c55e00}}.device-icon-hint{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:#22c55ed9;font-weight:600}.device-icon-picker{position:absolute;top:2.5rem;left:0;width:230px;padding:.75rem;border-radius:.9rem;background:#070b12f2;border:1px solid rgba(129,140,248,.35);box-shadow:0 18px 38px #00000073;z-index:25}.device-icon-picker-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.45rem}.device-icon-choice{display:inline-flex;align-items:center;gap:.4rem;border-radius:.65rem;border:1px solid rgba(255,255,255,.15);background:#ffffff0a;color:#ffffffd1;padding:.35rem .55rem;font-size:.78rem;cursor:pointer;transition:border .2s ease,background .2s ease,color .2s ease}.device-icon-choice.active{border-color:#22c55eb3;background:#22c55e2e;color:#bbf7d0}.device-icon-choice:disabled{opacity:.5;cursor:not-allowed}.device-icon-error{margin-top:.5rem;font-size:.72rem;color:#fda4af;font-weight:600}.device-title{font-size:1.08rem;font-weight:600;color:var(--color-white);flex:1 1 auto;min-width:0}.device-title-edit-input{flex:1 1 auto;min-width:0;border:1px solid var(--color-glass-border-light);border-radius:.6rem;padding:.35rem .6rem;background:#070b12d9;color:#ffffffeb;font-size:1rem;font-weight:600;box-shadow:0 4px 18px #00000059}.device-title-edit-input:focus{outline:none;border-color:#22c55ecc;box-shadow:0 0 0 1px #22c55e8c}.device-title-actions{display:inline-flex;align-items:center;gap:.35rem;margin-left:auto;flex:0 0 auto;position:relative}.device-title-menu-wrapper{position:relative;display:inline-flex}.device-title-action{display:inline-flex;align-items:center;justify-content:center;width:1.8rem;height:1.8rem;border-radius:.5rem;border:1px solid var(--color-glass-border-xlight);background:#0c121c73;color:#ffffffc7;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-action.device-title-edit{border-color:#39aa7980;background:#39aa792e;color:#d1fae5}.device-title-menu{position:absolute;top:calc(100% + .4rem);right:0;min-width:9.5rem;border-radius:.9rem;border:1px solid rgba(255,255,255,.12);background:#090d16f5;box-shadow:0 12px 30px #00000073;padding:.35rem;display:flex;flex-direction:column;gap:.2rem;z-index:10}.device-title-menu button{width:100%;border:none;background:transparent;color:#ffffffd9;font-size:.88rem;padding:.45rem .6rem;border-radius:.65rem;display:flex;align-items:center;gap:.45rem;cursor:pointer;transition:background .2s ease,color .2s ease}.device-title-menu button:hover{background:#22c55e1f;color:#fffffffa}.device-title-menu button.danger{color:#fecaca}.device-title-menu button.danger:hover{background:#f871712e;color:#fee2e2}.device-title-action.device-title-delete{border-color:#f8717173;background:#ef444429;color:#fecaca}.device-title-action.device-title-delete:hover{border-color:#f87171cc;background:#f8717140;color:#fee2e2}.device-title-save{border-color:#0ea581a6;background:#10b98133;color:#bbf7d0}.device-title-cancel{border-color:#f8717180;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-grouping-pill-row{display:flex;flex-wrap:wrap;gap:.45rem}.device-grouping-pill-row .glass-pill{font-size:.78rem;padding:.3rem .7rem}.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:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;padding:.25rem .35rem .25rem 0;max-height:22rem;overflow-y:auto;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.device-controls::-webkit-scrollbar{width:.4rem}.device-controls::-webkit-scrollbar-thumb{border-radius:999px;background:#fff3}.device-controls::-webkit-scrollbar-track{background:transparent}.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;grid-column:1 / -1}.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-control-wide{grid-column:span 2}.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}@media (max-width: 720px){.device-controls{grid-template-columns:minmax(0,1fr);max-height:none;overflow:visible;padding-right:0}.device-control-wide,.device-controls-toggle{grid-column:span 1}}.device-footer{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:#fff9}.device-command-pending{font-weight:600;color:#ffffffbf}.device-delete-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top,#090d16bf,#02060ced);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;padding:2rem;z-index:1600;pointer-events:auto;overflow-y:auto}.device-delete-modal{width:min(420px,100%);border-radius:1rem;border:1px solid rgba(248,113,113,.35);background:#0a0e18f2;box-shadow:0 25px 65px #00000080}.device-delete-modal-body{padding:1.6rem;display:flex;flex-direction:column;gap:1rem}.device-delete-eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#f87171d9;font-weight:700;margin:0}.device-delete-modal h3{margin:0;font-size:1.25rem;color:#ffffffeb}.device-delete-modal p{margin:0;color:#ffffffb3;line-height:1.5}.device-delete-force-toggle{border:1px solid rgba(255,255,255,.12);border-radius:.9rem;padding:.9rem;display:flex;gap:.85rem;background:#ffffff08}.device-delete-force-toggle input{width:1.1rem;height:1.1rem;accent-color:#f87171;margin-top:.35rem}.device-delete-force-toggle span{font-weight:600;color:#ffffffd9;font-size:.92rem}.device-delete-force-toggle p{font-size:.8rem;color:#ffffffa6;margin-top:.15rem}.device-delete-error{padding:.65rem .85rem;border-radius:.8rem;background:#f871711f;border:1px solid rgba(248,113,113,.35);color:#fecaca;font-weight:600;font-size:.85rem}.device-delete-actions{display:flex;justify-content:flex-end;gap:.6rem}.device-delete-cancel,.device-delete-confirm{padding:.55rem 1.15rem;border-radius:.7rem;border:1px solid transparent;font-size:.85rem;font-weight:600;cursor:pointer;transition:transform .15s ease,border .2s ease,background .2s ease}.device-delete-cancel{background:transparent;border-color:#fff3;color:#fffc}.device-delete-cancel:hover{border-color:#ffffff59;transform:translateY(-1px)}.device-delete-confirm{background:#f871712e;border-color:#f8717180;color:#fee2e2;min-width:7rem}.device-delete-confirm:hover{background:#f8717147;border-color:#f87171cc;transform:translateY(-1px)}.device-delete-cancel:disabled,.device-delete-confirm:disabled{opacity:.6;cursor:not-allowed;transform:none}.add-device-modal-backdrop{z-index:12000;padding:1.5rem;background:#00000073;opacity:0;transition:opacity .3s cubic-bezier(.4,0,.2,1)}.add-device-modal-backdrop.open{opacity:1}.auth-modal-backdrop.add-device-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20000;display:flex;align-items:center;justify-content:center}.auth-modal-glass.add-device-modal-glass{width:min(1240px,96vw);min-width:min(900px,94vw);min-height:640px;height:min(760px,92vh);max-height:92vh;overflow:hidden;padding:2.1rem 2.05rem 2rem;border-radius:2rem;background:var(--color-modal-surface);border:1.5px solid rgba(60,70,90,.45);box-shadow:0 35px 90px var(--color-shadow-modal),0 0 0 1px #ffffff0d;-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);position:relative;z-index:12001;display:flex;flex-direction:column;color:rgba(var(--color-white-rgb),.92);opacity:0;transform:translateY(40px) scale(.95);transition:opacity .35s cubic-bezier(.34,1.56,.64,1),transform .35s cubic-bezier(.34,1.56,.64,1)}.auth-modal-glass.add-device-modal-glass.open{opacity:1;transform:translateY(0) scale(1)}.auth-modal-glass.add-device-modal-glass .auth-modal-content-outer{flex:1;min-height:0;overflow-y:auto;padding-bottom:1rem}.add-device-shell{display:flex;flex-direction:column;gap:1.75rem;flex:1;min-height:0}.add-device-toolbar{display:flex;flex-direction:column;gap:.4rem}.add-device-toolbar-title{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.25rem}.add-device-toolbar-title h2{margin:0;font-size:1.6rem;letter-spacing:-.01em}.add-device-toolbar-heading{display:flex;flex-direction:column;gap:.35rem}.add-device-step-chip{display:inline-flex;align-items:center;justify-content:center;padding:.35rem 1rem;border-radius:999px;border:1px solid rgba(var(--color-success-rgb),.4);background:rgba(var(--color-success-rgb),.08);font-size:.78rem;letter-spacing:.25em;text-transform:uppercase;color:var(--color-success-light)}.add-device-toolbar-progress{margin-top:.25rem}.add-device-step-tabs{display:flex;gap:.6rem;flex-wrap:nowrap;padding:.45rem 0 .85rem;margin-top:.25rem;overflow:visible;border-bottom:1px solid rgba(var(--color-white-rgb),.08)}.add-device-step-tab{display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.45rem .75rem;border-radius:999px;border:1px solid var(--color-glass-border-xlight);background:var(--color-glass-bg-ultra);font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:rgba(var(--color-white-rgb),.6);line-height:1.1;flex:1;min-width:0}.add-device-step-tab.complete{border-color:rgba(var(--color-success-rgb),.45);color:rgba(var(--color-white-rgb),.85)}.add-device-step-tab.active{border-color:rgba(var(--color-success-rgb),.7);background:rgba(var(--color-success-rgb),.08);color:var(--color-white)}.add-device-form{align-items:stretch;gap:1.5rem}.add-device-scroll-region{padding-right:.5rem}.add-device-form-shell{padding-right:0}.add-device-body-grid{display:flex;flex-direction:column;gap:1.75rem}.add-device-panel{display:flex;flex-direction:column;gap:1.25rem}.add-device-card{border-radius:1.35rem;border:1px solid rgba(var(--color-white-rgb),.08);background:var(--color-surface-card);padding:1.4rem 1.6rem;display:flex;flex-direction:column;gap:1rem}.add-device-card-emphasis{background:var(--gradient-card-emerald);border-color:rgba(var(--color-success-rgb),.25)}.add-device-card-head{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}.add-device-card-head-center{flex-direction:column;align-items:center;text-align:center;gap:.4rem}.add-device-card-head h4{margin:0;font-size:1.15rem}.add-device-card-head>p{margin:0;color:rgba(var(--color-white-rgb),.7);max-width:280px}.add-device-field{width:100%}.add-device-grid{display:grid;gap:.85rem 1rem}.add-device-basics-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.add-device-advanced-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.add-device-grid-span-2{grid-column:span 2}.add-device-section-card{width:100%;border-radius:1.25rem;border:1px solid rgba(var(--color-white-rgb),.08);background:var(--gradient-card-slate);padding:1.35rem 1.45rem;display:flex;flex-direction:column;gap:.9rem}.add-device-basics-card{padding:1.35rem 1.5rem}.add-device-section-head h4{margin:0;font-size:1.08rem}.add-device-section-head p{margin:.25rem 0 0;font-size:.9rem;color:rgba(var(--color-white-rgb),.72)}.add-device-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:2.4rem;cursor:pointer}.add-device-field-select .auth-modal-label{top:.4em;background:var(--color-surface-overlay);padding:0 .4em}.add-device-field-select.filled .auth-modal-label,.add-device-field-select .add-device-select:focus+.auth-modal-label{top:-.5em;font-size:.85rem;color:var(--color-primary)}.add-device-textarea{min-height:120px;resize:vertical}.add-device-modal-hint{display:block;margin-top:.25rem;font-size:.78rem;color:rgba(var(--color-white-rgb),.68)}.add-device-icon-field{width:100%;display:flex;flex-direction:column;gap:.45rem}.add-device-icon-label{text-transform:uppercase;font-size:.72rem;letter-spacing:.08em;color:rgba(var(--color-white-rgb),.6)}.add-device-icon-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));width:100%;gap:.65rem}.add-device-icon-grid .device-icon-choice{display:flex;justify-content:flex-start;width:100%;background:var(--color-surface-chip);padding:.55rem .7rem;gap:.45rem;transition:border .2s ease,background .2s ease,color .2s ease;font-size:.92rem}.add-device-icon-grid .device-icon-choice.active{border-color:rgba(var(--color-success-rgb),.8);background:rgba(var(--color-success-rgb),.12);color:var(--color-white)}.add-device-icon-grid .device-icon-choice:hover{border-color:rgba(var(--color-white-rgb),.45)}.add-device-description-field{margin-bottom:.4rem}.add-device-advanced-shell{width:100%;border-radius:1.25rem;border:1px solid rgba(var(--color-white-rgb),.08);background:var(--color-surface-panel);padding:.2rem .2rem .5rem}.add-device-advanced-toggle{width:100%;border-radius:1.05rem;border:none;background:transparent;color:rgba(var(--color-white-rgb),.95);font-weight:600;text-align:left;letter-spacing:.01em;padding:.85rem 1.1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;cursor:pointer;transition:border .2s ease,background .2s ease}.add-device-advanced-toggle:hover{background:rgba(var(--color-success-rgb),.09)}.add-device-advanced-toggle svg{transition:transform .2s ease}.add-device-advanced-toggle.open svg{transform:rotate(180deg)}.add-device-advanced-toggle div p{margin:.25rem 0 0;font-size:.86rem;font-weight:400;color:rgba(var(--color-white-rgb),.7)}.add-device-advanced{width:100%;display:none;flex-direction:column;gap:.9rem;padding:0 0 1rem;border-top:1px solid rgba(var(--color-white-rgb),.08);margin-top:.35rem}.add-device-advanced.open{display:flex}.add-device-advanced-actions{display:flex;flex-direction:column;gap:.6rem;margin-top:.4rem}.add-device-manual-btn{width:fit-content}.add-device-row{display:flex;gap:.7rem;width:100%}.add-device-row .add-device-field{flex:1 1 0}.add-device-error{margin-top:.2rem}.add-device-guided-card{padding:1.4rem 1.5rem;gap:1rem}.add-device-guidance-card{padding:1.4rem 1.5rem}.add-device-guided-actions{display:flex;flex-direction:column;gap:.5rem}.add-device-guided-action{width:100%;justify-content:center}.add-device-step{width:100%;display:flex;flex-direction:column;gap:1.25rem;align-items:stretch}.add-device-pairing-panel{border-radius:1.5rem;border:1px solid var(--color-glass-border-xlight);background:var(--gradient-card-emerald-soft);padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1.1rem}.add-device-pairing-progress{display:flex;flex-direction:column;gap:.8rem;align-items:center;width:100%}.add-device-pairing-stages{display:flex;flex-direction:column;gap:.65rem;width:100%}.add-device-pairing-timer{display:flex;flex-direction:column;gap:.6rem;align-items:center;text-align:center}.add-device-pairing-stage{display:flex;align-items:flex-start;gap:.65rem;padding:.45rem .75rem;border-radius:.95rem;border:1px solid rgba(var(--color-white-rgb),.08);background:var(--color-surface-panel-soft);transition:border .2s ease,background .2s ease}.add-device-pairing-stage-dot{width:.6rem;height:.6rem;border-radius:999px;margin-top:.2rem;background:rgba(var(--color-white-rgb),.4);box-shadow:0 0 0 1px rgba(var(--color-white-rgb),.15)}.add-device-pairing-stage-label{font-size:.8rem;font-weight:600;color:var(--color-white);display:block}.add-device-pairing-stage-body p{margin:.15rem 0 0;font-size:.7rem;color:rgba(var(--color-white-rgb),.7)}.add-device-pairing-stage.complete{border-color:rgba(var(--color-success-rgb),.45);background:var(--color-success-surface)}.add-device-pairing-stage.complete .add-device-pairing-stage-dot,.add-device-pairing-stage.active .add-device-pairing-stage-dot{background:var(--color-success);box-shadow:0 0 0 1px rgba(var(--color-success-rgb),.35),0 0 10px rgba(var(--color-success-rgb),.4)}.add-device-pairing-stage.active{border-color:rgba(var(--color-success-rgb),.65);background:rgba(var(--color-success-rgb),.14)}.add-device-pairing-stage.upcoming{opacity:.8}.add-device-pairing-stage-card{display:flex;align-items:center;gap:.65rem;padding:.55rem .9rem;border-radius:.95rem;border:1px solid rgba(var(--color-white-rgb),.08);background:var(--color-surface-panel-alt);width:100%}.add-device-pairing-stage-body{display:flex;flex-direction:column;gap:.1rem;text-align:left;color:rgba(var(--color-white-rgb),.78)}.add-device-pairing-stage-label{font-size:.85rem;font-weight:600;color:var(--color-white)}.add-device-pairing-stage-body p{font-size:.7rem;margin:0}.add-device-pairing-stage-card.complete{border-color:rgba(var(--color-success-rgb),.45);background:var(--color-success-surface-strong)}.add-device-pairing-stage-card.active{border-color:rgba(var(--color-success-rgb),.7);background:rgba(var(--color-success-rgb),.18)}.add-device-pairing-stage-index{width:1.4rem;height:1.4rem;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:600;background:rgba(var(--color-white-rgb),.12);color:rgba(var(--color-white-rgb),.85)}.add-device-pairing-stage-card.active .add-device-pairing-stage-index,.add-device-pairing-stage-card.complete .add-device-pairing-stage-index{background:var(--color-success);color:var(--color-success-contrast)}.add-device-pairing-inline-tips{display:flex;flex-wrap:wrap;gap:.4rem;font-size:.68rem;color:rgba(var(--color-white-rgb),.65)}.add-device-pairing-inline-tips span{padding:.35rem .55rem;border-radius:.75rem;background:var(--color-surface-panel-muted)}@media (min-width: 900px){.add-device-pairing-progress{flex-direction:row;justify-content:space-between;align-items:stretch;gap:1.5rem}.add-device-pairing-stages{flex:1 1 50%;max-width:50%;align-self:stretch}.add-device-pairing-timer{flex:1 1 50%;max-width:50%;align-items:center;justify-content:center;text-align:center}}.add-device-pairing-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.3em;color:rgba(var(--color-white-rgb),.6);margin-bottom:.35rem}.add-device-countdown-number{font-size:2.7rem;font-weight:700;letter-spacing:-.02em}.add-device-pairing-status-pill{border-radius:999px;padding:.45rem 1.15rem;border:1px solid var(--color-glass-border-xlight);background:var(--color-surface-panel-accent);text-transform:capitalize;letter-spacing:.08em;font-size:.82rem}.add-device-pairing-note{margin:0;color:rgba(var(--color-white-rgb),.85)}.add-device-pairing-actions,.add-device-success-actions{display:flex;flex-wrap:wrap;gap:.6rem}.add-device-pairing-actions{align-items:center}.add-device-secondary-btn{border:1px solid var(--color-glass-border-light);background:transparent;color:rgba(var(--color-white-rgb),.85);border-radius:.9rem;padding:.65rem 1.1rem;font-weight:600;transition:border .2s ease,color .2s ease;cursor:pointer}.add-device-secondary-btn:hover{border-color:rgba(var(--color-success-rgb),.6);color:var(--color-success)}.add-device-success-step{text-align:center;align-items:center}.add-device-success-icon{color:var(--color-success);font-size:3rem}@media (max-width: 1200px){.auth-modal-glass.add-device-modal-glass{min-width:unset}}@media (max-width: 960px){.auth-modal-glass.add-device-modal-glass{padding:2.25rem 2rem 2rem}}@media (max-width: 700px){.add-device-modal-backdrop{padding:0}.auth-modal-glass.add-device-modal-glass{margin:0;max-width:100vw;padding:1rem .5rem .9rem}.add-device-scroll-region{padding-right:0}.auth-modal-glass.add-device-modal-glass .auth-modal-form{padding-left:0!important;padding-right:0!important}.add-device-card{padding:1rem .75rem}.add-device-grid-span-2{grid-column:span 1}.add-device-row{flex-direction:column}.add-device-step-tabs{gap:.35rem}.add-device-step-tab{font-size:.7rem;letter-spacing:.08em;padding:.4rem .45rem}.auth-modal-glass.add-device-modal-glass{width:100vw;min-width:unset;height:100vh;max-height:100vh;border-radius:0;padding:1rem .5rem .9rem}.add-device-shell{gap:1rem}.add-device-toolbar-title{flex-direction:column;align-items:flex-start;gap:.35rem}.add-device-toolbar-title span{letter-spacing:.25em}.add-device-step-tabs{gap:.4rem}}@media (max-width: 640px){.add-device-modal-backdrop{padding:.75rem}.auth-modal-glass.add-device-modal-glass{border-radius:1.5rem;min-width:0;width:calc(100vw - 1.5rem);max-width:calc(100vw - 1.5rem);height:auto;max-height:calc(100vh - 1.5rem);min-height:auto}.add-device-icon-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}}@media (max-width: 520px){.add-device-section-card,.add-device-guided-card{padding:.95rem .75rem}}.devices-page{display:flex;flex-direction:column;gap:1.5rem;padding:0 1.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}.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-summary-card .devices-summary-content .glass-metric+.glass-metric{border-top:none;margin-top:0;padding-top:.35rem}.devices-integrations-row{display:flex;flex-wrap:wrap;gap:.5rem .85rem;margin-top:1rem;align-items:center}.devices-filter-chip-count{font-size:.72rem;font-weight:600;padding:.05rem .45rem;border-radius:999px;background:#ffffff1f;color:inherit}.devices-filter-clear{border:none;background:transparent;color:var(--color-primary);font-weight:600;cursor:pointer;font-size:.8rem;text-decoration:underline}.devices-filter-summary{margin:-.2rem 0 0 .2rem;color:#ffffffb3;font-size:.82rem}.devices-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.8rem;padding:.25rem .25rem .5rem}.devices-toolbar-meta{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:#ffffff80}.devices-toolbar-filters{display:inline-flex;align-items:center;gap:.6rem;margin-right:.8rem}.devices-group-toggle{display:inline-flex;align-items:center;gap:.4rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#0f1520d1;color:#ffffffd9;padding:.25rem .75rem;font-size:.72rem;cursor:pointer;transition:border .2s ease,background .2s ease,color .2s ease}.devices-group-toggle:hover{border-color:#ffffff2e}.devices-group-toggle.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.devices-group-toggle:focus-visible{outline:2px solid rgba(34,197,94,.6);outline-offset:2px}.devices-toolbar-filter{display:inline-flex;align-items:center;gap:.4rem}.devices-toolbar-filter span{font-size:.7rem}.devices-toolbar-filter select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#0f1520d1;border:1px solid rgba(255,255,255,.08);color:#ffffffd9;border-radius:999px;padding:.25rem .7rem;font-size:.72rem;text-transform:none;letter-spacing:normal}.devices-toolbar-filter select:focus{outline:none;border-color:#ffffff2e}.devices-integrations-label{text-transform:uppercase;font-size:.7rem;letter-spacing:.08em;color:#ffffffa6}.devices-integrations-list{display:flex;flex-wrap:wrap;gap:.4rem}.devices-filter-chip-list{flex:1 1 auto;display:flex;flex-wrap:wrap;gap:.4rem}.devices-integrations-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .65rem;border-radius:999px;font-size:.72rem;font-weight:600;border:1px solid rgba(255,255,255,.12);color:#ffffffd9}.devices-integrations-chip.filter-chip{background:#0d121cbf;cursor:pointer;padding:.35rem .85rem;min-width:3.2rem;justify-content:center;transition:border .2s ease,background .2s ease,color .2s ease,transform .2s ease;border-color:#ffffff2e;color:#ffffffd1;font-family:inherit}.devices-integrations-chip.filter-chip:hover{border-color:#3b82f68c;color:#dbeafe;transform:translateY(-1px)}.devices-integrations-chip.filter-chip.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 6px 18px #0f766e59}.devices-integrations-chip.filter-chip.active .devices-integrations-dot{background:#fff}.devices-integrations-chip.filter-chip.muted{opacity:.6}.devices-integrations-chip.filter-chip:focus-visible{outline:2px solid rgba(34,197,94,.6);outline-offset:2px}.devices-integrations-chip .devices-integrations-dot{width:.35rem;height:.35rem;border-radius:50%;background:#fffc;display:inline-block}.devices-integrations-chip.status-active{border-color:#4ade8059;color:#bbf7d0}.devices-integrations-chip.status-active .devices-integrations-dot{background:#4ade80}.devices-integrations-chip.status-experimental{border-color:#818cf866;color:#c7d2fe}.devices-integrations-chip.status-planned{border-color:#ffffff2e;color:#ffffffa6}.devices-integrations-chip.status-detected{border-color:#5eead440;color:#a7f3d0}.devices-integrations-chip.status-detected .devices-integrations-dot{background:#5eead4e6}.devices-integrations-chip.status-all{border-color:#ffffff40;color:#ffffffe6}.devices-integrations-chip.status-all .devices-integrations-dot{background:#ffffffe6}.devices-integrations-meta{display:inline-flex;gap:.5rem;align-items:center;font-size:.78rem;color:#ffffffb3;margin-left:auto}.devices-integrations-error{color:#fecaca}.devices-integrations-refresh{background:transparent;border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:.15rem .6rem;color:#fffc;font-size:.72rem;cursor:pointer}.devices-integrations-refresh:disabled{opacity:.6;cursor:not-allowed}.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-group-header{grid-column:1 / -1;display:flex;align-items:baseline;justify-content:space-between;padding:0 .25rem;margin:-.6rem 0 -1.2rem}.devices-group-title{font-size:.9rem;font-weight:700;color:#ffffffe0}.devices-group-count{font-size:.78rem;font-weight:700;color:#ffffff8c}.device-filter-empty-card{grid-column:1 / -1;text-align:center}.devices-filter-empty-text{font-size:.9rem;color:#ffffffb3}.devices-grid .glass-card{margin:0}.device-add-card .card-content{height:100%;padding:1.25rem;display:flex;align-items:stretch}.device-add-card-btn{border:1.5px dashed rgba(255,255,255,.25);border-radius:1rem;background:#0f1520a6;color:#ffffffe0;display:flex;flex-direction:column;gap:.6rem;padding:1.1rem;text-align:left;width:100%;cursor:pointer;transition:border .2s ease,background .2s ease,transform .2s ease;font-family:inherit}.device-add-card-btn:hover{border-color:#22c55e99;background:#22c55e1a;transform:translateY(-2px)}.device-add-card-icon{width:3rem;height:3rem;border-radius:1rem;background:#22c55e26;color:#bbf7d0;display:inline-flex;align-items:center;justify-content:center;font-size:1.35rem}.device-add-card-title{font-size:1.2rem;font-weight:700}.device-add-card-subtitle{font-size:.9rem;color:#ffffffb3}.device-add-card-cta{margin-top:auto;font-weight:600;font-size:.9rem;color:var(--color-primary)}.devices-fab{position:fixed;right:2.5rem;bottom:2.5rem;left:auto;z-index:140;display:inline-flex;align-items:center;gap:.65rem;padding:.85rem 1.6rem;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:#0f1520eb;color:var(--color-white);font-weight:700;font-size:.95rem;letter-spacing:.02em;box-shadow:0 12px 30px #0006;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.devices-fab-icon{width:1.8rem;height:1.8rem;border-radius:999px;background:#ffffff1f;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:1.15rem;line-height:1}.devices-fab:hover{transform:translateY(-3px);box-shadow:0 18px 40px #0f766e73;background:var(--color-primary)}.devices-fab:focus-visible{outline:2px solid rgba(255,255,255,.9);outline-offset:3px}@media (max-width: 768px){.devices-page{padding:0 1.25rem 3rem}.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}.devices-fab{right:1rem;left:auto;bottom:1.1rem;width:auto;min-width:unset;padding:.8rem 1.3rem;border-radius:.9rem;font-size:.95rem;background:var(--color-primary);border:none;box-shadow:0 10px 24px #0f766e59}.devices-fab-icon{width:1.6rem;height:1.6rem;font-size:1rem}@media (max-width: 480px){.devices-fab{right:.8rem;bottom:1rem;padding:.75rem 1.1rem;gap:.45rem}.devices-fab span:last-child{font-size:.9rem}}.device-add-card .card-content{padding:1rem}}.chip-multi-select-row{display:flex;flex-wrap:wrap;gap:8px}.chip-multi-select-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid var(--color-glass-border-xlight);background:var(--color-surface-panel-alt);font-weight:600;opacity:.95}.chip-multi-select-btn{border:1px solid var(--color-glass-border-xlight);background:var(--color-surface-panel-alt);color:inherit;cursor:pointer}.chip-multi-select-btn.active{background:color-mix(in srgb,var(--color-primary) 18%,var(--color-surface-panel-alt));border-color:color-mix(in srgb,var(--color-primary) 22%,var(--color-glass-border-xlight))}.chip-multi-select-btn:disabled{opacity:.45;cursor:not-allowed}.chip-multi-select-btn:focus-visible{outline:2px solid var(--color-glass-border-light);outline-offset:2px}.chip-multi-select-empty{opacity:.8;font-weight:600}.chip-multi-select-disabled{opacity:.8}.device-detail-page{display:flex;flex-direction:column;gap:1.5rem;padding:0 1.5rem 3rem;color:var(--color-white)}.device-detail-header{margin:10px 10px 12px;padding:0 8px}.device-detail-error-text,.device-detail-loading-text,.device-detail-missing-text{color:#ffffffd9;padding:.75rem .25rem}.device-detail-grid{display:grid;grid-template-columns:minmax(320px,520px) 1fr;gap:1.25rem;align-items:start}.device-detail-grid-left,.device-detail-grid-right{min-width:0}.device-detail-grid-right{display:flex;flex-direction:column;gap:1.35rem}.device-ers-meta-card,.device-history-controls-card{padding:.65rem .7rem .75rem}.device-history-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem .95rem .25rem}.device-history-title{display:inline-flex;align-items:center;gap:.6rem;font-weight:800;letter-spacing:-.2px}.device-history-icon{width:28px;height:28px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:#ffffff24;border:1px solid var(--color-glass-border-xlight);color:#fffffff0}.device-history-icon svg{width:14px;height:14px}.device-grouping-row{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.device-grouping-row-main{flex:1 1 auto;min-width:0;display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}.device-grouping-divider{width:1px;height:18px;background:#ffffff24;border-radius:999px}.device-grouping-tags{display:inline-flex;flex-wrap:wrap;gap:.45rem;min-width:0}.device-grouping-row .glass-pill{font-size:.82rem;padding:.35rem .8rem}.device-grouping-add{flex:0 0 auto;width:38px;height:38px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#0f15208c;color:#ffffffe6;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.device-grouping-add:hover{background:#0f1520b8;border-color:#ffffff2e}.device-grouping-add:disabled{opacity:.55;cursor:not-allowed}.device-history-controls{display:flex;flex-wrap:wrap;gap:.85rem;padding:.85rem .95rem .25rem}.device-history-field{flex:1 1 240px;min-width:220px}.device-history-field--range,.device-history-field--order,.device-history-field--limit{flex:0 0 190px;min-width:190px}.device-history-field--from,.device-history-field--to{flex:1 1 260px;min-width:240px}.device-history-controls label{display:flex;flex-direction:column;gap:.35rem;font-size:.82rem;color:#ffffffbf}.device-history-controls input,.device-history-controls select{border-radius:12px;padding:.55rem .65rem;border:1px solid rgba(255,255,255,.1);background:#0f1520b8;color:#ffffffe6;outline:none;width:100%;min-width:0;box-sizing:border-box;height:40px}.device-history-controls input[type=datetime-local]{font-variant-numeric:tabular-nums;font-size:.84rem}.device-history-datetime-split{display:flex;align-items:center;gap:.5rem}.device-history-date{flex:1 1 auto;min-width:0}.device-history-time{flex:0 0 120px}.device-history-time-colon{opacity:.65;font-variant-numeric:tabular-nums}.device-history-time-stepper{flex:0 0 auto;display:inline-flex;align-items:center;gap:.35rem}.device-history-time-input-wrap{position:relative;width:74px;display:inline-flex;align-items:stretch}.device-history-time-input-wrap input[type=number]{font-variant-numeric:tabular-nums;text-align:center;padding-right:2.2rem;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.device-history-time-input-wrap input[type=number]::-webkit-outer-spin-button,.device-history-time-input-wrap input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.device-history-limit-inline{display:flex;align-items:center;gap:.6rem}.device-history-limit-inline.off{justify-content:center}.device-history-limit-chip{height:40px;display:inline-flex;align-items:center;gap:.45rem;padding:0 .7rem;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#0f15208c;color:#ffffffc7;cursor:pointer;-webkit-user-select:none;user-select:none;line-height:1;white-space:nowrap}.device-history-limit-chip.off{width:40px;padding:0;justify-content:center;gap:0}.device-history-limit-chip:hover{border-color:#ffffff2e}.device-history-limit-chip.on{border-color:#ffffff38;background:#0f1520b8;color:#ffffffeb}.device-history-limit-check{width:18px;height:18px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.16);background:#ffffff0f;color:transparent;font-size:12px;transform:translateY(-.5px)}.device-history-limit-chip.on .device-history-limit-check{color:#ffffffeb;border-color:#ffffff38;background:#ffffff1a}.device-history-limit-input-wrap{position:relative;display:inline-flex;align-items:stretch;flex:1 1 auto;min-width:0}.device-history-limit-input-wrap input[type=number]{font-variant-numeric:tabular-nums;padding-right:2.2rem;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.device-history-limit-input-wrap input[type=number]::-webkit-outer-spin-button,.device-history-limit-input-wrap input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.device-history-stepper{position:absolute;right:6px;top:6px;bottom:6px;width:22px;display:flex;flex-direction:column;justify-content:space-between;gap:4px}.device-history-stepper-btn{flex:1 1 0;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#ffffff0f;color:#ffffffd9;font-size:10px;line-height:1;padding:0;cursor:pointer}.device-history-stepper-btn:hover{background:#ffffff1a;border-color:#ffffff29}.device-history-stepper-btn:active{transform:translateY(.5px)}.device-history-controls input:focus,.device-history-controls select:focus{border-color:#ffffff38}.device-history-error{padding:.5rem .95rem;color:#ffbebef2}.device-history-footer{padding:.5rem .95rem .75rem;color:#ffffffa6;font-size:.82rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.device-history-hint{color:#ffffff8c;font-size:.78rem}.device-history-query-pill.glass-pill{font-size:.92rem;padding:.45rem .75rem}.device-history-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1rem}.device-history-charts-area{position:relative;padding-top:1.75rem}.device-history-metric-card{padding:1rem 1.05rem;cursor:pointer;transform:translateZ(0);transition:transform .26s cubic-bezier(.4,0,.2,1),opacity .22s ease;will-change:transform}.device-history-metric-card.origin-hidden{opacity:0;pointer-events:none}.device-history-metric-card:active{transform:scale(.995)}.device-history-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999;display:flex;align-items:center;justify-content:center;padding:16px;pointer-events:none}.device-history-overlay-card{width:100%;max-width:980px;cursor:pointer;will-change:transform;position:relative;z-index:1;pointer-events:auto;max-height:calc(100vh - 32px);overflow:hidden}.device-history-overlay-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#04060885;-webkit-backdrop-filter:blur(4px) saturate(110%);backdrop-filter:blur(4px) saturate(110%);z-index:0;pointer-events:auto}.device-history-overlay-close{position:absolute;right:12px;top:12px;z-index:60;background:#0006;color:#fff;border:1px solid rgba(255,255,255,.06);width:36px;height:36px;border-radius:999px;font-size:18px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}body.overlay-open{overflow:hidden}@media (prefers-reduced-motion: reduce){.device-history-metric-card{transition:none}}.device-history-expanded-hint{margin-top:.4rem;color:#fff9;font-size:.78rem}.device-history-empty{padding:.6rem .85rem}.device-history-empty-text{color:#ffffffbf;padding:.4rem 0}.device-history-help-text{flex:1 1 100%;min-width:0;color:#ffffff9e;font-size:.8rem;line-height:1.35}.device-history-field-label{font-size:.82rem;color:#ffffffbf;margin-bottom:.35rem}@media (max-width: 640px){.device-detail-page{padding:0 1rem 2.5rem}.device-detail-grid{grid-template-columns:1fr}}@media (max-width: 1000px){.device-detail-grid{grid-template-columns:1fr}.device-history-controls{flex-direction:column;align-items:stretch;justify-content:flex-start}.device-history-controls label{align-items:flex-start;text-align:left}.device-history-field,.device-history-field--range,.device-history-field--order,.device-history-field--limit,.device-history-field--from,.device-history-field--to{flex:1 1 auto;min-width:0}.device-history-limit-inline.off{justify-content:flex-start}.device-history-datetime-split{width:100%}}.automation-page{display:flex;flex-direction:column;gap:1.5rem;padding:0 1.5rem 3rem;color:var(--color-white)}@media (max-width: 720px){.automation-page{padding:0 .75rem 2.5rem}}.automation-page .automation-form-header,.automation-page .automation-list-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.automation-page .automation-list-header .title{font-weight:600}.automation-page .automation-form .row{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1rem}@media (min-width: 980px){.automation-page .automation-form .row{grid-template-columns:1fr 1fr}}.automation-page .automation-form .field{display:flex;flex-direction:column;gap:.4rem}.automation-editor-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.automation-layout{display:flex;flex-direction:column;gap:1.2rem;padding:0;margin:0}.automation-editor-shell{width:100%}.automation-topbar{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:10px 12px;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);margin-bottom:12px}.automation-topbar-left,.automation-topbar-row{display:flex;align-items:center;gap:10px;min-width:0}.automation-topbar-saved{font-size:.85rem;white-space:nowrap}.automation-topbar-label{font-weight:600;opacity:.85}.automation-topbar-name{min-width:0;width:100%;max-width:520px}.automation-topbar-select{min-width:0;width:100%;max-width:320px;-moz-appearance:none;appearance:none;-webkit-appearance:none;font:inherit;color:#ffffffeb;border:1px solid var(--color-glass-border-xlight);background:var(--color-surface-panel-alt);border-radius:12px;padding:10px 38px 10px 12px;cursor:pointer}.automation-topbar-select:focus{outline:none;border-color:var(--color-glass-border-light)}.automation-topbar-select-wrap{position:relative;min-width:0;flex:0 0 260px;width:260px;max-width:260px;overflow:hidden;border-radius:12px}@media (max-width: 980px){.automation-topbar-select-wrap{flex:1 1 auto;width:100%;max-width:none}}.automation-topbar-select-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);opacity:.8;pointer-events:none}.automation-topbar-new{white-space:nowrap;flex:0 0 auto}.automation-topbar-right{display:flex;gap:10px;align-items:center;justify-content:flex-end;flex-wrap:nowrap}@media (max-width: 980px){.automation-topbar{grid-template-columns:1fr;gap:10px}.automation-topbar-left{min-width:0;flex-direction:column;align-items:stretch;gap:10px}.automation-topbar-row-select{width:100%}.automation-topbar-row-select .automation-topbar-label{flex:0 0 auto}.automation-topbar-row-select .automation-topbar-select-wrap{flex:1 1 auto;width:100%;max-width:none}.automation-topbar-row-select .automation-topbar-saved{margin-left:auto}.automation-topbar-row-primary{width:100%;justify-content:space-between;gap:10px}.automation-topbar-row-primary .btn-label{display:none!important}.automation-topbar-row-primary .btn-icon{margin-right:0}.automation-topbar-row-primary .automation-topbar-status{margin-left:auto;justify-content:flex-end}.automation-topbar-name{min-width:0;width:100%;max-width:none}.automation-topbar-right{justify-content:space-between;flex-wrap:nowrap;overflow:hidden;padding-bottom:0;-webkit-overflow-scrolling:auto;gap:8px}.automation-topbar-group{display:contents}.automation-topbar-iconbtn{padding:7px;border-radius:12px;width:44px;justify-content:center}.automation-topbar-right .btn-label{display:none!important}.automation-topbar-right .btn-icon{margin-right:0}}.automation-topbar-group{display:flex;gap:8px;align-items:center}.automation-topbar-status{display:inline-flex;align-items:center;gap:10px}.automation-topbar-switch .glass-switch{--switch-width: 36px;--switch-height: 20px;--thumb-size: 16px}.automation-topbar-iconbtn{padding:8px;border-radius:12px;border:1px solid transparent!important;background:transparent!important;box-shadow:none!important}.automation-topbar-iconbtn:hover:not(:disabled){background:color-mix(in srgb,var(--color-primary) 16%,rgba(255,255,255,.06))!important;border-color:transparent!important;box-shadow:0 0 0 1px color-mix(in srgb,var(--color-primary) 20%,transparent),0 0 18px color-mix(in srgb,var(--color-primary) 22%,transparent)!important;transform:translateY(-1px)}.automation-topbar-iconbtn:active:not(:disabled){transform:translateY(0)}.automation-topbar-iconbtn .btn-icon{margin-right:0}.automation-topbar .btn-label{max-width:0;opacity:0;margin-left:0;overflow:hidden;white-space:nowrap;transition:max-width .18s ease,opacity .18s ease,margin-left .18s ease}.automation-topbar .btn:hover .btn-label{max-width:160px;opacity:1;margin-left:8px}.automation-topbar-toggle{display:inline-flex;align-items:center;gap:10px;padding:8px 10px;border-radius:12px;border:1px solid color-mix(in srgb,var(--color-primary) 16%,var(--color-glass-border-xlight));background:var(--color-surface-panel-alt)}.automation-topbar-toggle-title{font-weight:800;opacity:.95}.automation-topbar-toggle-label{display:flex;flex-direction:column;gap:2px}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;margin-right:8px}.automation-editor-title{display:flex;flex-direction:column;gap:2px}.automation-editor-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.automation-editor{display:grid;grid-template-columns:280px 1fr 320px;gap:12px;align-items:stretch}.automation-page .automation-form .label{font-size:.9rem;opacity:.9}.automation-page .automation-form .textarea{min-height:120px}@media (max-width: 980px){.automation-editor{grid-template-columns:1fr}}.automation-left,.automation-right{display:flex;flex-direction:column;gap:10px;height:100%;min-height:0}.automation-properties-card.glass-card{padding:12px;border-radius:14px;font-size:1rem;font-weight:600;min-width:0;margin:0}.automation-properties-card.glass-card .card-content{gap:10px;min-height:0}.automation-left-section{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);padding:10px;display:flex;flex-direction:column;gap:10px;flex:1 1 auto;min-height:0}.automation-panel-title{font-weight:600;opacity:.9}.automation-page .input{font:inherit;color:#ffffffeb;border:1px solid var(--color-glass-border-xlight);background:var(--color-surface-panel-alt);border-radius:12px;padding:10px 12px}.automation-page .input:focus{outline:none;border-color:var(--color-glass-border-light)}.automation-workflow-name{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.automation-workflow-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow:auto;padding-right:4px}.automation-workflow-item{text-align:left;width:100%;-moz-appearance:none;appearance:none;-webkit-appearance:none;font:inherit;color:#ffffffeb;border:1px solid var(--color-glass-border-xlight);background:var(--color-surface-panel-alt);border-radius:12px;padding:10px;cursor:pointer}.automation-workflow-item:hover{background:#ffffff0d}.automation-workflow-item.selected{border-color:var(--color-glass-border-light);background:var(--color-surface-panel-muted)}.automation-workflow-item .name{font-weight:600;margin-bottom:4px;color:#ffffffeb}.automation-workflow-item .meta{display:flex;align-items:center;gap:8px}.automation-palette{display:flex;flex-direction:column;gap:10px;flex:1 1 auto;min-height:0;max-height:none;overflow:auto;padding-right:4px}.automation-runs-footer{display:flex;justify-content:center;margin-top:10px}.automation-runs-view-more{font-size:.82rem;opacity:.85}.automation-runs-runid{margin-top:2px;font-size:.78rem;opacity:.7;letter-spacing:.02em}@media (min-width: 1100px){.automation-runs-table th:nth-child(1),.automation-runs-table th:nth-child(2),.automation-runs-table td:nth-child(1),.automation-runs-table td:nth-child(2){white-space:nowrap}}.automation-palette-group{display:flex;flex-direction:column;gap:8px}.automation-palette-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.automation-palette-item{border:1px dashed var(--color-glass-border-xlight);background:var(--color-surface-panel-alt);border-radius:12px;padding:10px;cursor:grab;-webkit-user-select:none;user-select:none;transition:transform .12s ease,background .12s ease,border-color .12s ease}.automation-palette-item:hover{background:var(--color-surface-panel-muted);border-color:var(--color-glass-border-light);transform:translateY(-1px)}.automation-palette-item:active{cursor:grabbing}.automation-palette-item .label{display:inline-flex;align-items:center;gap:8px;font-weight:600;margin-bottom:2px}.palette-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;opacity:.9}.automation-center{min-height:420px}.automation-canvas{position:relative;min-height:420px;height:min(70vh,720px);border-radius:14px;border:1px solid color-mix(in srgb,var(--color-primary) 10%,var(--color-glass-border-xlight));background:linear-gradient(rgba(255,255,255,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px);overflow:hidden;overscroll-behavior:contain;touch-action:none}.automation-canvas-name{position:absolute;top:12px;right:12px;z-index:12;width:min(280px,calc(100% - 24px));border-radius:12px;border:1px solid color-mix(in srgb,var(--color-primary) 12%,var(--color-glass-border-xlight));background:color-mix(in srgb,var(--color-surface-panel-soft) 86%,transparent);padding:8px;display:flex;flex-direction:column;gap:6px}.automation-canvas-name-input{border-color:color-mix(in srgb,var(--color-primary) 18%,var(--color-glass-border-xlight));padding:8px 10px;font-size:.95rem}.automation-canvas-controls{position:absolute;right:10px;bottom:10px;z-index:10}.automation-connect-hint{position:absolute;left:10px;bottom:10px;z-index:10;padding:8px 10px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#0000002e;display:inline-flex;align-items:center}.automation-canvas-layer{position:absolute;top:0;right:0;bottom:0;left:0}.automation-edges{position:absolute;width:100%;height:100%}.automation-edge{fill:none;stroke:#ffffff8c;stroke-width:2;pointer-events:none}.automation-edge-hit{fill:none;stroke:#fff0;stroke-width:14;pointer-events:stroke;cursor:pointer}.automation-edge.automation-edge-preview{stroke-dasharray:6 6;opacity:.75;pointer-events:none}.automation-edge-dot{fill:#ffffffa6}.automation-edge-dot.automation-edge-dot-handle{pointer-events:all;cursor:crosshair;transition:transform .12s ease,fill .12s ease}.automation-edge-dot.automation-edge-dot-handle:hover{transform:scale(1.12);fill:#ffffffd9}.automation-canvas-empty{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#00000026}.automation-node{position:absolute;border-radius:14px;border:1px solid var(--color-glass-border-xlight);background:var(--color-surface-card);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 8px 24px #00000059;transition:border-color .12s ease,transform .12s ease}.automation-node-port{position:absolute;top:20px;width:18px;height:18px;border-radius:999px;transform:translateY(-50%);border:2px solid rgba(255,255,255,.55);background:#00000040;cursor:crosshair;padding:0}.automation-node-port.in{left:-9px}.automation-node-port.out{right:-9px}.automation-node-port:hover{border-color:#ffffffe6;background:#ffffff26}@keyframes automation-port-pulse{0%{transform:translateY(-50%) scale(1.05);box-shadow:0 0 color-mix(in srgb,var(--color-primary) 45%,transparent);border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 20%,transparent)}60%{transform:translateY(-50%) scale(1.32);box-shadow:0 0 0 16px color-mix(in srgb,var(--color-primary) 22%,transparent);border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 28%,transparent)}to{transform:translateY(-50%) scale(1.05);box-shadow:0 0 0 24px color-mix(in srgb,var(--color-primary) 0%,transparent);border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 20%,transparent)}}.automation-node.connect-hover .automation-node-port.in,.automation-node-port.in[data-connect-target=true]{animation:automation-port-pulse .9s ease-out infinite}.automation-props{text-align:left}.automation-props .field{display:flex;flex-direction:column;align-items:stretch;gap:6px}.automation-props .label{text-align:left;font-size:.86rem;font-weight:600;opacity:.9}.automation-props .input,.automation-props .automation-segmented{width:100%}.automation-props-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.automation-props-actions.compact{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.automation-btn-mini{padding:.42em .7em;font-size:.92rem;border-radius:.8rem}.automation-btn-mini .btn-icon{margin-right:0}.automation-btn-mini .btn-label{margin-left:8px;white-space:nowrap}.automation-node:hover{border-color:var(--color-glass-border-light);transform:translateY(-1px)}.automation-node.selected{border-color:var(--color-glass-border-light)}@keyframes automation-run-highlight{0%{box-shadow:0 0 color-mix(in srgb,var(--color-primary) 45%,transparent),0 8px 24px #00000059}to{box-shadow:0 0 0 18px color-mix(in srgb,var(--color-primary) 0%,transparent),0 8px 24px #00000059}}.automation-node.run-active{border-color:var(--color-primary);animation:automation-run-highlight .9s ease-out}.automation-node.run-live-active{border-color:var(--color-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-primary) 50%,transparent),0 10px 28px #00000059}@keyframes automation-run-fade{0%{box-shadow:0 0 0 2px color-mix(in srgb,var(--color-primary) 55%,transparent),0 10px 28px #00000059;opacity:1}to{box-shadow:0 0 0 18px color-mix(in srgb,var(--color-primary) 0%,transparent),0 10px 28px #00000059;opacity:.94}}.automation-node.run-live-done{border-color:var(--color-primary);animation:automation-run-fade 1.1s ease-out}.automation-node.run-live-failed{border-color:var(--color-primary);animation:automation-run-fade 1.8s ease-out}.automation-node.connect-eligible{border-color:#ffffff2e}.automation-node.connect-hover{border-color:var(--color-glass-border-light)}.automation-segmented{display:flex;border:1px solid var(--color-glass-border-xlight);border-radius:12px;overflow:hidden;background:var(--color-surface-panel-alt);position:relative}.automation-segmented button{flex:1;min-width:0;border:0;background:transparent;color:inherit;padding:7px 10px;font-weight:600;cursor:pointer;position:relative;z-index:1;transition:opacity .18s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.automation-segmented button+button{border-left:0}.automation-slide{border-radius:12px;border:1px solid var(--color-glass-border-xlight);background:color-mix(in srgb,var(--color-surface-panel-alt) 70%,transparent);overflow:hidden}.automation-slide-inner{display:grid;grid-template-columns:1fr 1fr;width:200%;transition:transform .45s cubic-bezier(.4,2,.6,1);will-change:transform}.automation-slide-inner.mode-builder{transform:translate(0)}.automation-slide-inner.mode-json{transform:translate(-50%)}.automation-slide-pane{width:100%;padding:10px}.automation-segmented button.active{opacity:1}.automation-segmented.slider:before{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;width:calc(50% - 2px);border-radius:10px;transform:translate(calc(var(--seg-pos, 0) * 100%));transition:transform .45s cubic-bezier(.4,2,.6,1);will-change:transform;background:color-mix(in srgb,var(--color-primary) 22%,var(--color-surface-panel-muted));border:1px solid color-mix(in srgb,var(--color-primary) 18%,var(--color-glass-border-xlight))}.automation-segmented.slider button:not(.active){opacity:.82}.automation-node-header-right{display:flex;align-items:center;gap:10px}.automation-node-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:inherit;cursor:pointer;transition:transform .12s ease,background .12s ease,border-color .12s ease,opacity .12s ease}.automation-node-icon-btn:hover:not(:disabled){transform:translateY(-1px);background:#ffffff12;border-color:#ffffff29}.automation-node-icon-btn:disabled{opacity:.45;cursor:not-allowed}.automation-node-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;cursor:grab;border-bottom:1px solid var(--color-glass-border-xlight)}.automation-node-header:active{cursor:grabbing}.automation-node-header .title{display:inline-flex;align-items:center;gap:8px;font-weight:700}.node-kind-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;opacity:.9}.automation-node-body{padding:10px 12px;line-height:1.3;font-size:.9rem}.automation-props{display:flex;flex-direction:column;gap:10px}.automation-props .muted{font-size:.86rem;opacity:.75}.automation-props-section{border:1px solid var(--color-glass-border-xlight);background:var(--color-surface-panel-soft);border-radius:14px;padding:10px;display:flex;flex-direction:column;gap:10px}.automation-props-section-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.automation-props-section-title{font-weight:700;opacity:.92;color:color-mix(in srgb,var(--color-primary) 70%,rgba(255,255,255,.92))}.automation-props-section-subtitle{font-size:.86rem;opacity:.78;line-height:1.25}.automation-props-kv{display:flex;align-items:center;justify-content:space-between;gap:10px}.automation-toggle-pill-group{display:flex;flex-wrap:wrap;gap:8px}.automation-toggle-pill{border:1px solid var(--color-glass-border-xlight);background:var(--color-surface-panel-alt);color:inherit;padding:8px 10px;border-radius:999px;cursor:pointer;font-weight:600;opacity:.95}.automation-toggle-pill:hover{border-color:var(--color-glass-border-light)}.automation-toggle-pill.active{background:var(--color-surface-panel-muted);border-color:var(--color-glass-border-light)}.automation-toggle-pill:disabled{opacity:.45;cursor:not-allowed}.automation-chip-row{display:flex;flex-wrap:wrap;gap:8px}.automation-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid var(--color-glass-border-xlight);background:var(--color-surface-panel-alt);font-weight:600;opacity:.95}.automation-chip-btn{border:1px solid var(--color-glass-border-xlight);background:var(--color-surface-panel-alt);color:inherit;cursor:pointer}.automation-chip-btn.active{background:color-mix(in srgb,var(--color-primary) 18%,var(--color-surface-panel-alt));border-color:color-mix(in srgb,var(--color-primary) 22%,var(--color-glass-border-xlight))}.automation-chip .subtle{font-weight:600;opacity:.7}.automation-chip-remove{border:0;background:transparent;color:inherit;cursor:pointer;opacity:.8;font-weight:800;line-height:1}.automation-chip-remove:hover{opacity:1}.automation-scrollbox{border:1px solid var(--color-glass-border-xlight);background:var(--color-surface-panel-alt);border-radius:12px;max-height:260px;overflow:auto}.automation-scrollbox input[type=checkbox]{width:16px;height:16px}.automation-user-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 12px}.automation-user-row.disabled{opacity:.55;cursor:not-allowed}.automation-user-row+.automation-user-row{border-top:1px solid var(--color-glass-border-xlight)}.automation-user-row-main{min-width:0;display:flex;flex-direction:column;gap:2px}.automation-user-row-title{font-weight:700;opacity:.95;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.automation-user-row-subtitle{font-size:.84rem;opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.automation-user-row-actions{display:flex;gap:8px;align-items:center}.automation-props select.input{background:var(--color-surface-panel-alt);color:#ffffffeb}.automation-props select.input option{background:var(--color-surface-overlay);color:var(--color-white)}.automation-page .checkbox{display:flex;align-items:center;gap:.5rem;font-size:.9rem;opacity:.9}.automation-page .actions{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.automation-page .actions.compact{gap:.5rem}.automation-page .link-btn{background:none;border:none;padding:0;color:inherit;text-align:left;cursor:pointer;font-weight:600}.map-page{display:flex;flex-direction:column;gap:1.5rem;padding:0 1.5rem 3rem;color:var(--color-white)}@media (max-width: 720px){.map-page{padding:0 .75rem 2.5rem}}.map-layout{display:grid;gap:16px;align-items:stretch}.map-layout.edit{grid-template-columns:minmax(220px,320px) 1fr}.map-layout.view{grid-template-columns:1fr}@media (max-width: 920px){.map-layout,.map-layout.edit{grid-template-columns:1fr}.map-left{order:2}.map-center{order:1}}.map-canvas{height:min(70vh,720px);overscroll-behavior:contain}.map-panel{left:12px;right:auto}.map-svg{display:block}.map-device-grid{grid-template-columns:1fr}.map-footer{margin-top:16px;padding:12px}.map-panel-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.map-panel-sections{margin-top:10px;display:flex;flex-direction:column;gap:14px}.map-panel-section{display:flex;flex-direction:column;gap:6px}.map-panel-section+.map-panel-section{padding-top:12px;border-top:1px solid var(--color-glass-border-xlight)}.map-snap-chip{display:inline-flex;align-items:center;gap:6px}.map-snap-chip svg{opacity:.9}.map-draw-room-btn{width:100%;display:inline-flex;align-items:center;justify-content:center}.map-room-row,.map-wall-row{display:flex;align-items:center;gap:10px;min-width:0}.map-room-input{flex:1 1 auto;min-width:0}.map-room-row .glass-pill{flex:0 0 auto;white-space:nowrap}.map-device-card{position:absolute;top:12px;right:12px;z-index:5;width:min(380px,calc(100% - 24px))}@media (max-width: 720px){.map-device-card{top:auto;bottom:62px;left:12px;right:12px;width:auto}}.map-device-group{cursor:pointer}.map-device-group.editable{cursor:grab}.map-device-group.editable:active{cursor:grabbing}.map-device-popover{position:absolute;z-index:6;transform:translate(14px,-50%);width:min(360px,calc(100% - 24px));pointer-events:auto}.map-popover-card{border:1px solid var(--color-glass-border-light)}.map-popover-scroll{box-sizing:border-box;max-height:min(420px,calc(100vh - 140px));overflow:auto;padding:10px 10px 12px}.map-popover-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-bottom:8px;margin-bottom:8px;border-bottom:1px solid var(--color-glass-border-xlight)}.map-popover-title{min-width:0;font-weight:900;letter-spacing:-.2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.map-popover-actions{flex:0 0 auto;display:inline-flex;align-items:center;gap:8px}.map-popover-icon-btn{width:34px;height:34px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#0f15208c;color:#ffffffe6;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.map-popover-icon-btn:hover{background:#0f1520b8;border-color:#ffffff2e}.map-popover-icon-btn:active{transform:translateY(.5px)}.map-popover-icon-btn.active{border-color:#ffffff42;background:#0f1520d1}.map-popover-subrow{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.map-popover-subrow .glass-pill{font-size:.82rem;padding:.35rem .7rem}.map-popover-meta{display:inline-flex;align-items:center;gap:6px;min-width:0;max-width:100%;color:#ffffffb8;font-size:.82rem}.map-popover-meta span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.map-popover-facts{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.map-popover-facts .glass-pill{max-width:100%}.map-popover-tags{margin-top:10px}.map-popover-editor{margin-top:12px;padding-top:10px;border-top:1px solid var(--color-glass-border-xlight)}.map-popover-editor-title{display:inline-flex;align-items:center;gap:8px;font-weight:800;color:#ffffffdb;margin-bottom:8px}@media (max-width: 720px){.map-device-popover{left:12px!important;right:12px;top:auto!important;bottom:62px;transform:none;width:auto}.map-popover-scroll{max-height:min(420px,calc(100vh - 180px))}}.hover-desc-anchor{display:inline-flex;align-items:center}.hover-desc-pop{position:fixed;z-index:50;max-width:min(320px,calc(100vw - 24px));padding:10px 12px;border-radius:12px;background:var(--color-surface-panel-alt);border:1px solid var(--color-glass-border-xlight);box-shadow:0 10px 30px 0 var(--color-shadow-card);color:#ffffffeb;pointer-events:none}.hover-desc-title{font-weight:900;letter-spacing:-.2px;margin-bottom:4px}.hover-desc-body{font-size:.9rem;line-height:1.25rem;color:#ffffffc7}.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}.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{display:flex;flex-direction:column;gap:1.5rem;padding:0 1.5rem 3rem;color:var(--color-white)}.users-page .masonry-dashboard{column-count:1!important;margin-left:0;margin-right:0;padding:0}.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}.users-mobile-view{display:none}.users-table-view{display:block}.users-mobile-card{border:1px solid rgba(255,255,255,.1);background:#ffffff0a;border-radius:14px;overflow:hidden;margin-bottom:.6rem}.users-mobile-item{width:100%;border:none;background:transparent;color:inherit;padding:.85rem;display:flex;align-items:center;justify-content:space-between;gap:.85rem;text-align:left;cursor:pointer}.users-mobile-item:active{background:#ffffff0a}.users-mobile-meta{min-width:0;display:flex;flex-direction:column;justify-content:center}.users-mobile-meta .muted{font-weight:700}.users-mobile-email{font-size:.85rem;margin-top:.15rem;word-break:break-word}.users-mobile-badges{display:inline-flex;flex-direction:column;gap:.35rem;flex:0 0 auto;align-items:flex-end}.users-mobile-actions{display:flex;flex-direction:column;gap:.6rem;align-items:stretch;padding:.75rem .85rem .9rem;border-top:1px solid rgba(255,255,255,.08)}.users-mobile-email{font-size:.85rem;word-break:break-word}.users-mobile-actions-row{display:flex;gap:.6rem;align-items:center;width:100%}.users-mobile-actions .role-select{flex:1 1 auto;min-width:0}.users-mobile-actions .btn{flex:0 0 auto;white-space:nowrap}.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){.users-page{padding:0 1rem 3rem}.users-mobile-view{display:block}.users-table-view{display:none}.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-white-rgb: 255, 255, 255;--color-black: #000;--color-black-rgb: 0, 0, 0;--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-bg-ultra: rgba(255,255,255,.02);--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-modal: rgba(0, 0, 0, .65);--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-success: #22c55e;--color-success-light: #dcfce7;--color-success-rgb: 34, 197, 94;--color-success-contrast: #051407;--color-success-surface: rgba(16, 37, 26, .75);--color-success-surface-strong: rgba(16, 37, 26, .85);--color-danger: #ef4444;--color-danger-light: #fca5a5;--color-danger-dark: #dc2626;--color-danger-rgb: 239, 68, 68;--color-danger-surface: rgba(127, 29, 29, .6);--color-danger-surface-strong: rgba(127, 29, 29, .8);--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%);--gradient-card-emerald: radial-gradient(circle at top left, rgba(var(--color-success-rgb), .18), var(--color-surface-card-strong));--gradient-card-emerald-soft: radial-gradient(circle at top left, rgba(var(--color-success-rgb), .08), var(--color-surface-panel-muted));--gradient-card-slate: radial-gradient(circle at top left, var(--color-surface-iris), var(--color-surface-shadow));--color-modal-surface: rgba(5, 9, 20, .92);--color-surface-card: rgba(8, 11, 22, .78);--color-surface-card-strong: rgba(8, 11, 22, .75);--color-surface-overlay: rgba(28, 34, 44, .92);--color-surface-panel: rgba(12, 17, 30, .72);--color-surface-panel-soft: rgba(12, 17, 30, .55);--color-surface-panel-alt: rgba(10, 15, 24, .7);--color-surface-panel-muted: rgba(12, 18, 30, .8);--color-surface-panel-accent: rgba(15, 23, 36, .65);--color-surface-shadow: rgba(12, 16, 26, .9);--color-surface-chip: rgba(8, 11, 20, .6);--color-surface-iris: rgba(32, 41, 70, .38)}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%)}.hn-route-view{animation:hn-route-fade-in .22s ease both}@keyframes hn-route-fade-in{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion: reduce){.hn-route-view{animation:none}}
