*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0}body{overflow:hidden;color:#1d2027;background:#111318;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif}button,input{font:inherit}button{border:0}button:focus-visible{outline:2px solid rgba(255,255,255,.76);outline-offset:3px}.model-shell{position:relative;width:100vw;height:100vh;overflow:hidden;background:radial-gradient(circle at 20% 10%,var(--env-glow, rgba(255, 223, 188, .24)),transparent 28%),linear-gradient(135deg,#171a21 0%,var(--env-mid, #262b34) 50%,var(--env-end, #ece7dc) 100%);transition:background .42s ease}.model-stage{position:absolute;top:0;right:0;bottom:0;left:0;cursor:grab;touch-action:none}.model-stage:active{cursor:grabbing}.model-stage canvas{display:block;width:100%;height:100%}.webgl-fallback{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;gap:8px;padding:34px;color:#ffffffd1;background:linear-gradient(135deg,#1d2027,#2b3039);text-align:center}.webgl-fallback strong,.webgl-fallback span{display:block}.webgl-fallback strong{font-size:24px}.webgl-fallback span{max-width:360px;color:#ffffff9e}.floating-card{position:absolute;z-index:4;overflow:hidden;border:1px solid rgba(255,255,255,calc(var(--glass-edge, .56) * .52));border-radius:18px;background:linear-gradient(145deg,rgba(255,255,255,calc(var(--glass-glare, .42) * .5)),#ffffff09),linear-gradient(315deg,rgba(255,255,255,calc(var(--glass-glare, .42) * .32)),#ffffff04 42%),rgba(255,255,255,var(--glass-alpha, .16));box-shadow:inset 0 1px rgba(255,255,255,calc(var(--glass-edge, .56) * .95)),inset 0 -1px #ffffff29,inset 16px 0 36px #ffffff0d,0 18px 54px rgba(0,0,0,var(--glass-shadow, .18));backdrop-filter:blur(var(--glass-blur, 32px)) saturate(var(--glass-saturation, 176%));-webkit-backdrop-filter:blur(var(--glass-blur, 32px)) saturate(var(--glass-saturation, 176%));transition:opacity .24s ease,transform .24s ease,background .22s ease,border-color .22s ease}.floating-card:before{position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:inherit;background:linear-gradient(120deg,rgba(255,255,255,calc(var(--glass-glare, .42) * .86)),transparent 32%),radial-gradient(circle at 18% 0%,rgba(255,255,255,calc(var(--glass-glare, .42) * .68)),transparent 34%);content:"";pointer-events:none}.floating-card>*{position:relative;z-index:1}.eyebrow{margin:0 0 8px;color:#1f232b85;font-size:12px;font-weight:760;letter-spacing:.08em;text-transform:uppercase}.brand-mark{position:absolute;z-index:4;top:24px;left:24px;width:min(390px,calc(100vw - 48px));color:#fff;text-shadow:0 18px 48px rgba(0,0,0,.44);pointer-events:none}.brand-mark .eyebrow{color:#ffffff94}.brand-mark h1{margin:0;font-size:clamp(30px,4vw,56px);line-height:1.02;letter-spacing:0}.brand-mark p:last-child{margin:14px 0 0;color:#ffffffad;font-size:14px;line-height:1.52}.selected-device-line{display:inline-flex;align-items:center;gap:7px;margin:12px 0 0;color:#ffffffdb;font-size:13px;font-weight:720;line-height:1.35}.settings-button{position:absolute;z-index:8;top:24px;right:24px;display:grid;width:46px;height:46px;place-items:center;border:1px solid rgba(255,255,255,.45);border-radius:50%;color:#1f232b;background:linear-gradient(145deg,#ffffff94,#ffffff29),rgba(255,255,255,var(--glass-alpha, .16));box-shadow:inset 0 1px #ffffffa3,0 16px 44px #00000029;backdrop-filter:blur(var(--glass-blur, 32px)) saturate(var(--glass-saturation, 176%));-webkit-backdrop-filter:blur(var(--glass-blur, 32px)) saturate(var(--glass-saturation, 176%));cursor:pointer;transition:transform .22s ease,background .22s ease}.settings-button:hover,.settings-button.active{transform:translateY(-1px)}.camera-monitor{position:absolute;z-index:7;top:24px;left:50%;width:306px;border:1px solid rgba(255,255,255,calc(var(--glass-edge, .56) * .48));border-radius:24px;color:#1f232b;background:linear-gradient(145deg,#ffffff85,#ffffff21),rgba(255,255,255,calc(var(--glass-alpha, .12) + .06));box-shadow:inset 0 1px #ffffffa8,0 18px 52px #00000029;backdrop-filter:blur(var(--glass-blur, 32px)) saturate(var(--glass-saturation, 176%));-webkit-backdrop-filter:blur(var(--glass-blur, 32px)) saturate(var(--glass-saturation, 176%));transform:translate(-50%);overflow:hidden;transition:width .26s ease,background .22s ease,border-color .22s ease,box-shadow .22s ease}.camera-monitor.active{border-color:#8ee5ffa3;box-shadow:inset 0 1px #ffffffbd,0 0 34px #73d5ff29,0 18px 52px #00000029}.camera-monitor.expanded{width:min(420px,calc(100vw - 32px))}.camera-monitor-head{position:relative;z-index:2;display:grid;grid-template-columns:38px minmax(0,1fr) 16px;align-items:center;width:100%;gap:10px;padding:9px 12px 9px 10px;color:inherit;background:transparent;cursor:pointer}.camera-monitor-head>svg{color:#1f232b8a;transition:transform .22s ease}.camera-monitor.expanded .camera-monitor-head>svg{transform:rotate(180deg)}.camera-monitor-icon{display:grid;width:38px;height:38px;place-items:center;border-radius:50%;color:#1f232b8a;background:#fff6;box-shadow:inset 0 0 0 1px #ffffff5c;transition:color .22s ease,background .22s ease,box-shadow .22s ease,transform .22s ease}.camera-monitor.active .camera-monitor-icon{color:#062b35;background:radial-gradient(circle at 50% 42%,#8ee5ffeb,#8ee5ff66 46%,#ffffff47);box-shadow:0 0 20px #8ee5ffd1,0 0 46px #6bceff6b,inset 0 0 0 1px #ffffff94}.camera-monitor-head:hover .camera-monitor-icon{transform:translateY(-1px)}.camera-monitor-copy{display:grid;min-width:0;text-align:left}.camera-monitor-copy strong{overflow:hidden;font-size:13px;font-weight:820;text-overflow:ellipsis;white-space:nowrap}.camera-monitor-copy small{overflow:hidden;color:#1f232b85;font-size:11px;font-weight:680;text-overflow:ellipsis;white-space:nowrap}.camera-preview{position:relative;z-index:1;display:grid;gap:10px;max-height:430px;padding:0 12px 12px;opacity:1}.camera-monitor.expanded .camera-preview{max-height:430px!important;padding-bottom:12px;opacity:1!important;pointer-events:auto}.camera-monitor.collapsed .camera-preview{max-height:0;padding-top:0;padding-bottom:0;opacity:0;pointer-events:none}.camera-preview-frame{position:relative;height:168px;overflow:hidden;border-radius:18px;background:radial-gradient(circle at 50% 35%,rgba(142,229,255,.16),transparent 42%),linear-gradient(145deg,#1a1e27db,#090b0feb);box-shadow:inset 0 0 0 1px #ffffff24,inset 0 18px 54px #ffffff0d}.face-video-probe{display:block;width:100%;height:100%;object-fit:cover;transform:rotate(var(--camera-rotation, 0deg)) scaleX(-1);transition:transform .18s ease}.face-video-probe.virtualized{opacity:0}.face-avatar-canvas{position:absolute;z-index:1;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;pointer-events:none;transition:opacity .18s ease}.face-avatar-canvas.active{opacity:1}.face-avatar-3d-canvas{position:absolute;z-index:2;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;pointer-events:none;transition:opacity .22s ease}.face-avatar-3d-canvas.active{opacity:1}.avatar-loading-hint{position:absolute;z-index:3;left:12px;top:10px;border-radius:999px;background:#ffffffb8;color:#223046c7;font-size:10px;font-weight:780;letter-spacing:.04em;padding:6px 10px;pointer-events:none}.face-avatar-3d-canvas[data-avatar-status=professor-obj-visible]+.avatar-loading-hint{display:none}.camera-privacy-button{position:absolute;z-index:4;right:50px;bottom:10px;min-height:30px;padding:0 10px;border:0;border-radius:10px;color:#ebf9ffeb;background:#0811199e;box-shadow:inset 0 0 0 1px #82dcff33;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;font:inherit;font-size:10px;font-weight:780}.camera-rotate-button{position:absolute;z-index:4;top:10px;right:10px;display:grid;width:34px;height:34px;place-items:center;border-radius:50%;color:#ffffffe6;background:#080b107a;box-shadow:inset 0 0 0 1px #ffffff2e;cursor:pointer}.camera-rotate-button:hover{background:#080b10a8}.camera-monitor.offline .face-video-probe{opacity:0}.camera-preview-empty,.camera-preview-status{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;gap:8px;color:#ffffffb3;font-size:12px;font-weight:760;text-align:center}.camera-preview-empty{align-content:center}.camera-preview-empty svg{color:#ffffff6b}.camera-preview-status{background:#06090e47;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.camera-preview-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;align-items:center}.camera-preview-meta span{display:grid;min-height:46px;align-content:center;gap:2px;border-radius:14px;color:#1f232b85;background:#ffffff4d;padding:7px 9px;font-size:10px;font-weight:720}.camera-preview-meta b{overflow:hidden;color:#1f232b;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.camera-preview-meta button{min-height:46px;padding:0 12px;border-radius:14px;color:#fff;background:#1f232b;cursor:pointer;white-space:nowrap;transition:transform .18s ease,background .18s ease}.camera-preview-meta button{grid-column:span 1}.camera-preview-meta button:nth-of-type(1){grid-column:1 / span 2}.camera-preview-meta button:nth-of-type(2){grid-column:3}.camera-preview-meta button:hover{transform:translateY(-1px);background:#111318}.face-quality-panel{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:8px}.face-quality-panel span,.face-quality-panel button{min-height:34px;padding:0 10px;border:0;border-radius:12px;font:inherit;font-size:11px;font-weight:760}.face-quality-panel span{display:grid;align-items:center;color:#1f232bb3;background:#1f232b14}.face-quality-panel .quality-ok{color:#176f4d;background:#3eb88029}.face-quality-panel .quality-warn{color:#8a4d17;background:#ffab4a2e}.face-quality-panel button{color:#fff;background:#1f232b;cursor:pointer}.face-quality-panel button:disabled{opacity:.45;cursor:not-allowed}.face-alert-overlay{position:absolute;z-index:30;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;background:#080a0e47;backdrop-filter:blur(12px) saturate(130%);-webkit-backdrop-filter:blur(12px) saturate(130%)}.face-alert{display:grid;grid-template-columns:50px minmax(0,1fr);gap:14px;width:min(420px,calc(100vw - 48px));padding:18px;border:1px solid rgba(255,255,255,.48);border-radius:24px;color:#1f232b;background:linear-gradient(145deg,#ffffff9e,#fff3),#ffffff52;box-shadow:inset 0 1px #ffffffb8,0 24px 64px #00000038;backdrop-filter:blur(34px) saturate(180%);-webkit-backdrop-filter:blur(34px) saturate(180%)}.face-alert-icon{display:grid;width:50px;height:50px;place-items:center;border-radius:18px;color:#1f232bb8;background:#ffffff57}.face-alert h2{margin:2px 0 6px;font-size:18px}.face-alert p{margin:0;color:#1f232ba3;font-size:13px;line-height:1.55}.face-alert button{grid-column:1 / -1;min-height:42px;border-radius:16px;color:#fff;background:#1f232b;cursor:pointer}.settings-overlay{position:absolute;z-index:20;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 50% 42%,rgba(255,255,255,.12),transparent 34%),#0a0c1042;backdrop-filter:blur(14px) saturate(132%);-webkit-backdrop-filter:blur(14px) saturate(132%)}.settings-panel{position:relative;z-index:21;display:grid;grid-template-columns:234px minmax(0,1fr);width:min(960px,calc(100vw - 48px));max-height:min(680px,calc(100vh - 48px));padding:12px;border-radius:28px}.settings-open .action-card,.settings-open .light-card,.settings-open .data-card{opacity:.18;pointer-events:none;transform:translateY(8px) scale(.98)}.settings-sidebar{display:grid;align-content:start;gap:10px;overflow:auto;padding:14px 10px;border-right:1px solid rgba(255,255,255,.2)}.settings-brand h2{margin:0;color:#1f232b;font-size:24px;line-height:1}.settings-nav{display:grid;gap:4px}.settings-nav-item{display:flex;align-items:center;gap:10px;min-height:34px;padding:0 10px;border-radius:12px;color:#1f232bb8;background:transparent;cursor:pointer;text-align:left;transition:background .18s ease,color .18s ease,transform .18s ease}.settings-nav-item.active,.settings-nav-item:hover{color:#fff;background:#1f232bd6}.settings-detail{min-height:500px;max-height:calc(100vh - 72px);overflow:auto;padding:18px 20px 20px}.settings-title h2{margin:0 0 12px;color:#1f232b;font-size:30px;line-height:1.18}.settings-title{display:flex;align-items:start;justify-content:space-between;gap:18px;margin-bottom:12px}.settings-close{min-height:34px;padding:0 14px;border-radius:999px;color:#1f232b;background:#ffffff6b;cursor:pointer}.settings-reset{min-height:34px;padding:0 14px;border-radius:999px;color:#fff;background:#1f232b;cursor:pointer}.settings-module{display:grid;gap:14px}.setting-row{display:grid;grid-template-columns:74px 1fr 48px;align-items:center;gap:10px;min-height:34px}.setting-row.wide{grid-template-columns:92px minmax(0,1fr) 58px;min-height:42px;padding:10px 12px;border-radius:16px;background:#ffffff38}.setting-row span,.setting-row strong{color:#1f232bb8;font-size:12px;font-weight:720}.setting-row input{width:100%;accent-color:#1f232b}.source-group{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.24)}.source-group>div{display:flex;flex-wrap:wrap;gap:8px}.source-chip{min-height:30px;padding:0 11px;border-radius:999px;color:#1f232bb8;background:#ffffff47;cursor:pointer}.source-chip.active{color:#fff;background:#1f232be6}.mood-picker,.source-grid{display:flex;flex-wrap:wrap;gap:9px}.camera-source-panel{display:grid;gap:12px;padding:14px;border-radius:18px;color:#1f232b;background:#ffffff3d}.camera-source-panel strong{display:flex;align-items:center;gap:6px;margin-bottom:4px;font-size:14px}.camera-source-panel span{color:#1f232b94;font-size:12px;font-weight:680}.camera-source-controls{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px}.camera-source-controls select,.camera-source-controls button{min-height:38px;border:0;border-radius:14px;font:inherit}.camera-source-controls select{min-width:0;padding:0 12px;color:#1f232bc7;background:#ffffff6b}.camera-source-controls select:disabled{color:#1f232b5c}.camera-source-controls button{padding:0 12px;color:#1f232bc7;background:#ffffff57;cursor:pointer;white-space:nowrap}.camera-source-controls button.active,.camera-source-controls button:last-child{color:#fff;background:#1f232b}.weather-source-panel{gap:10px}.weather-source-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.weather-source-grid span{display:grid;gap:2px;min-height:54px;align-content:center;padding:8px 10px;border-radius:14px;background:#1f232b14}.weather-source-grid b{color:#1f232b;font-size:14px}.weather-location-line{display:grid;grid-template-columns:16px minmax(0,1fr) auto;align-items:center;gap:8px;color:#1f232b9e;font-size:12px;font-weight:680}.weather-location-line span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.weather-location-line button{min-height:34px;padding:0 12px;border-radius:12px;color:#fff;background:#1f232b;cursor:pointer}.weather-address-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.weather-address-form input,.weather-address-form button{min-height:36px;border:0;border-radius:12px;font:inherit}.weather-address-form input{min-width:0;padding:0 12px;color:#1f232bc7;background:#1f232b14}.weather-address-form button{padding:0 12px;color:#fff;background:#1f232b;cursor:pointer;white-space:nowrap}.weather-favorites{display:flex;flex-wrap:wrap;gap:8px}.weather-favorites button{min-height:30px;padding:0 10px;border:0;border-radius:999px;color:#1f232bc7;background:#1f232b14;cursor:pointer;font:inherit;font-size:12px;font-weight:720}.emotion-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.emotion-summary div{display:grid;gap:7px;min-height:82px;align-content:center;padding:12px;border-radius:18px;background:#ffffff3d}.emotion-summary span,.emotion-scale-labels span{color:#1f232b8f;font-size:12px;font-weight:720}.emotion-summary strong{color:#1f232b;font-size:20px;line-height:1.05}.emotion-scale-labels{display:flex;justify-content:space-between;margin:-6px 12px 0}.emotion-note{display:grid;gap:8px;padding:12px;border-radius:18px;background:#ffffff38}.emotion-note span{color:#1f232bad;font-size:12px;font-weight:760}.emotion-note textarea{width:100%;resize:vertical;border:0;border-radius:14px;padding:11px 12px;color:#1f232b;background:#ffffff6b;outline:none}.primary-setting-action{min-height:46px;border-radius:16px;color:#fff;background:#1f232b;cursor:pointer;box-shadow:0 18px 42px #1f232b38}.emotion-history{display:grid;gap:9px}.emotion-entry,.source-card{display:grid;gap:5px;padding:12px;border-radius:16px;color:#1f232b;background:#ffffff3d}.emotion-entry strong,.source-card strong{font-size:14px}.emotion-entry span,.source-card span{margin:0;color:#1f232b9e;font-size:12px;line-height:1.42}.source-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.source-card{min-height:92px;cursor:pointer;text-align:left}.source-card.active{color:#fff;background:#1f232be6}.source-card.active span{color:#ffffffad}.setting-toggle-row,.device-status-row,.privacy-row{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:68px;padding:13px 14px;border-radius:17px;color:#1f232b;background:#ffffff3b}.setting-toggle-row{cursor:pointer;text-align:left}.setting-toggle-row span,.device-status-row,.privacy-row{min-width:0}.setting-toggle-row strong,.device-status-row strong,.privacy-row strong{display:block;margin-bottom:4px;font-size:14px}.setting-toggle-row small,.device-status-row span,.privacy-row span{display:block;color:#1f232b99;font-size:12px;line-height:1.42}.setting-toggle-row i{display:grid;width:42px;height:26px;flex:0 0 auto;place-items:center;border-radius:999px;color:#1f232b9e;background:#ffffff61;font-size:12px;font-style:normal;font-weight:780}.setting-toggle-row.active i{color:#fff;background:#1f232b}.device-status-row{display:grid;grid-template-columns:minmax(84px,1fr) 96px 120px}.device-status-row em{color:#1f232bb3;font-size:12px;font-style:normal;font-weight:760;text-align:right}.glass-preview{display:flex;align-items:center;justify-content:space-between;min-height:90px;padding:16px;border-radius:22px;color:#fff;background:linear-gradient(135deg,#ffffff75,#ffffff14),linear-gradient(90deg,#34d39952,#60a5fa4d,#f472b647);box-shadow:inset 0 1px #ffffffb8,0 20px 48px rgba(0,0,0,var(--glass-shadow, .18));backdrop-filter:blur(var(--glass-blur, 32px)) saturate(var(--glass-saturation, 176%));-webkit-backdrop-filter:blur(var(--glass-blur, 32px)) saturate(var(--glass-saturation, 176%))}.glass-preview span{width:54px;height:54px;border-radius:18px;background:rgba(255,255,255,var(--glass-alpha, .16));box-shadow:inset 0 1px rgba(255,255,255,var(--glass-edge, .56)),0 12px 28px rgba(0,0,0,var(--glass-shadow, .18))}.setting-light-row{display:grid;grid-template-columns:84px minmax(0,1fr) 78px;align-items:center;gap:12px;padding:11px 12px;border-radius:16px;background:#ffffff38}.setting-light-row span,.setting-light-row strong{color:#1f232bb8;font-size:12px;font-weight:760}.palette-preset-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:9px}.palette-preset{display:grid;gap:6px;min-height:88px;padding:11px;border-radius:16px;color:#1f232bb3;background:#ffffff3d;cursor:pointer}.palette-preset small{min-height:28px;color:currentColor;opacity:.68;font-size:10px;line-height:1.35}.palette-preset.active{color:#fff;background:#1f232be0}.palette-preset i{display:grid;grid-template-columns:repeat(5,1fr);gap:4px}.palette-preset b{height:8px;border-radius:999px;box-shadow:inset 0 0 0 1px #1f232b14}.light-preset-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-radius:16px;background:#ffffff3d}.light-preset-bar.compact{padding:9px 10px}.light-preset-bar div{display:grid;gap:3px}.light-preset-bar span{color:#1f232b94;font-size:12px;font-weight:720}.light-preset-bar strong{color:#1f232b;font-size:14px}.light-preset-bar button{min-height:32px;padding:0 12px;border-radius:999px;color:#fff;background:#1f232be6;cursor:pointer;white-space:nowrap}.state-card{top:24px;right:84px;display:grid;grid-template-columns:1fr auto;gap:10px;width:268px;padding:12px}.state-card h2{margin:0;font-size:22px;line-height:1.05;letter-spacing:0}.state-card p:last-child{grid-column:1 / -1;margin:0;color:#1f232bad;display:-webkit-box;overflow:hidden;font-size:12px;line-height:1.4;-webkit-box-orient:vertical;-webkit-line-clamp:2}.data-card{top:236px;left:24px;width:300px;padding:13px;transition:width .26s ease,top .22s ease,transform .22s ease,opacity .22s ease}.data-card.expanded{width:clamp(560px,52vw,690px)!important;max-height:calc(100vh - 270px);overflow:auto}.data-card.collapsed{width:246px;cursor:pointer}.data-card-head{display:flex;align-items:start;justify-content:space-between;gap:12px;width:100%;padding:0;color:#1f232b;background:transparent;cursor:pointer;text-align:left;margin-bottom:11px}.data-card-head h2{margin:0;color:#1f232b;font-size:19px;line-height:1.08}.expand-hint,.panel-hint{color:#1f232b7a;font-size:11px;font-style:normal;font-weight:760}.expand-hint{display:block;margin-top:5px}.data-card.collapsed .data-card-head{align-items:center;margin-bottom:0}.data-card.collapsed .data-card-head h2{font-size:17px}.data-expanded-content{display:grid;gap:10px}.data-line,.data-collapsed-line{margin:0;color:#1f232ba8;font-size:12px;line-height:1.45}.data-collapsed-line{display:-webkit-box;overflow:hidden;margin-top:9px;-webkit-box-orient:vertical;-webkit-line-clamp:2}.data-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.data-tile{display:grid;gap:4px;min-height:70px;padding:10px;border-radius:15px;color:#1f232b;background:#ffffff3d;box-shadow:inset 0 1px #ffffff47}.data-tile span,.data-tile small{color:#1f232b94;font-size:11px;font-weight:720}.data-tile strong{overflow:hidden;color:#1f232b;font-size:17px;line-height:1.05;text-overflow:ellipsis;white-space:nowrap}.environment-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin-top:10px}.environment-strip span{display:grid;gap:2px;min-width:0;padding:8px 7px;border-radius:13px;color:#1f232bb8;background:#ffffff38;font-size:11px;font-weight:720;text-align:center}.environment-strip b{color:#1f232b7a;font-size:10px;font-weight:780}.emotion-trend{display:grid;gap:7px;padding:10px;border-radius:16px;background:#ffffff38}.trend-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.trend-head strong{color:#1f232b;font-size:13px}.trend-head span{color:#1f232b8f;font-size:11px;font-weight:720}.emotion-trend svg{width:100%;height:72px;overflow:visible}.emotion-trend polyline{fill:none;stroke:#1f232b;stroke-linecap:round;stroke-linejoin:round;stroke-width:4}.emotion-trend circle{fill:#fff;stroke:#1f232b;stroke-width:3}.trend-labels{display:grid;grid-template-columns:repeat(5,1fr);color:#1f232b80;font-size:10px;font-weight:720}.trend-labels span{text-align:center}.assessment-card{display:grid;gap:5px;padding:11px;border-radius:16px;color:#1f232b;background:#1f232b14}.assessment-card strong{font-size:13px}.assessment-card span{color:#1f232bad;font-size:12px;line-height:1.42}.reason-card{display:grid;gap:5px;padding:11px;border-radius:16px;color:#1f232b;background:#74a6d624}.reason-card strong{font-size:13px}.reason-card span{color:#1f232bb3;font-size:12px;line-height:1.42}.device-card{top:178px;left:24px;width:292px;padding:14px}.device-summary{display:grid;grid-template-columns:40px 1fr;gap:10px;align-items:center}.device-icon{display:grid;width:40px;height:40px;place-items:center;border-radius:16px;color:#fff;background:#1f232beb;box-shadow:0 14px 32px #1f232b33}.device-summary h3{margin:0;color:#1f232b;font-size:17px;line-height:1.1}.device-summary p{margin:5px 0 0;color:#1f232b9e;font-size:12px;line-height:1.35}.device-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px;padding-top:10px;border-top:1px solid rgba(255,255,255,.28)}.device-meta span{color:#1f232bb3;font-size:12px;font-weight:680}.mini-action{min-height:30px;padding:0 12px;border-radius:999px;color:#1f232b;background:#ffffff73;cursor:pointer;transition:transform .18s ease,background .18s ease}.mini-action:hover{transform:translateY(-1px);background:#ffffffad}.mini-action:focus-visible,.panel-head:focus-visible,.mode:focus-visible,.pill:focus-visible,.light-toggle:focus-visible{outline-color:#1f232b7a}.score-ring{display:grid;width:48px;height:48px;place-items:center;border-radius:50%;background:radial-gradient(circle at center,rgba(255,255,255,.95) 0 52%,transparent 53%),conic-gradient(#1f232b 0 var(--score-percent, 78%),rgba(31,35,43,.12) var(--score-percent, 78%) 100%);transition:background .22s ease}.score-ring span{font-size:16px;font-weight:780}.mode-card{bottom:24px;left:24px;width:316px;padding:12px}.mode-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.panel-head{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:42px;padding:2px 4px 8px;color:#1f232b;background:transparent;cursor:pointer}.panel-head .panel-hint{margin-left:auto;padding-right:4px;white-space:nowrap}.panel-head span{display:grid;gap:2px;text-align:left}.panel-head small{color:#1f232b7a;font-size:11px;font-weight:760;letter-spacing:.08em;text-transform:uppercase}.panel-head strong{font-size:14px}.panel-head svg{transition:transform .22s ease}.collapsed .panel-head{padding-bottom:2px}.collapsed .panel-head svg{transform:rotate(-90deg)}.collapsed .panel-body,.panel-body.is-collapsed{max-height:0;opacity:0;pointer-events:none;visibility:hidden}.panel-body{max-height:320px;overflow:hidden;opacity:1;pointer-events:auto;transition:max-height .26s ease,opacity .18s ease;visibility:visible}.mode,.pill,.light-toggle{cursor:pointer;transition:transform .22s ease,background .22s ease,color .22s ease,box-shadow .22s ease,border-color .22s ease}.mode{display:flex;align-items:center;justify-content:center;gap:8px;height:50px;border-radius:16px;color:#1f232bb8;background:#ffffff61;box-shadow:inset 0 0 0 1px #ffffff57}.mode.active{color:#fff;background:#1f232b;box-shadow:0 18px 40px #1f232b38}.light-card{right:24px;bottom:24px;width:392px;max-height:calc(100vh - 170px);overflow:hidden;padding:12px}.light-card:not(.collapsed) .panel-body{max-height:min(500px,calc(100vh - 252px));overflow:auto;padding-right:2px}.light-list{display:grid;gap:10px}.light-row{display:grid;grid-template-columns:34px 1fr 40px;align-items:start;gap:10px;padding:7px 0}.light-toggle{display:grid;width:34px;height:34px;place-items:center;border-radius:14px;color:#1f232b94;background:#ffffff57}.light-toggle.active{color:#fff;background:#1f232b}.light-slider{display:grid;gap:5px;min-width:0}.light-slider span:first-child{color:#1f232bb8;font-size:13px;font-weight:680}.light-row strong{color:#1f232b;font-size:13px;text-align:right}.slider-control{width:100%;height:14px;padding:0;background:transparent;cursor:pointer}.hue-control{width:100%;height:14px;padding:0;background:transparent;cursor:pointer;touch-action:none}.hue-track{position:relative;display:block;width:100%;height:4px;margin-top:5px;border-radius:999px;background:linear-gradient(90deg,#6fb7ff,#eef7ff 34%,#ffd9a6 68%,#ff7a3d);box-shadow:inset 0 0 0 1px #1f232b14}.hue-thumb{position:absolute;top:50%;width:10px;height:10px;border:2px solid rgba(255,255,255,.95);border-radius:50%;box-shadow:0 4px 10px #00000029;transform:translate(-50%,-50%);transition:box-shadow .18s ease,transform .18s ease}.hue-control:hover .hue-thumb,.hue-control:focus-visible .hue-thumb{box-shadow:0 5px 12px #0003,0 0 0 5px #1f232b14;transform:translate(-50%,-50%) scale(1.06)}.slider-control:focus-visible,.hue-control:focus-visible{outline:2px solid rgba(31,35,43,.42);outline-offset:3px;border-radius:999px}.slider-track{position:relative;display:block;width:100%;height:4px;margin-top:5px;border-radius:999px;background:#1f232b21}.slider-fill{position:absolute;inset:0 auto 0 0;border-radius:inherit;background:currentColor;transition:width .16s ease}.slider-thumb{position:absolute;top:50%;width:9px;height:9px;border:2px solid rgba(255,255,255,.92);border-radius:50%;background:#1f232b;box-shadow:0 4px 10px #00000029;transform:translate(-50%,-50%);transition:left .16s ease,transform .16s ease}.slider-control:hover .slider-thumb{transform:translate(-50%,-50%) scale(1.08)}.action-card{left:352px;top:auto;bottom:24px;padding:12px;width:292px}.action-list{display:flex;gap:8px;flex-wrap:wrap;min-height:86px;padding-top:2px}.action-list.panel-body{max-height:120px}.collapsed .action-list.panel-body,.action-list.panel-body.is-collapsed{min-height:0;max-height:0}.action-card:not(.collapsed) .action-list.panel-body{min-height:86px;max-height:120px;pointer-events:auto}.pill{display:inline-flex;align-items:center;gap:8px;min-height:38px;padding:0 12px;border-radius:999px;color:#1f232b;background:#ffffff6b;box-shadow:0 14px 34px #0000001f;white-space:nowrap}.pill.active{color:#fff;background:#16181deb}.pill:hover,.mode:hover,.light-toggle:hover{transform:translateY(-2px)}@media (max-width: 1120px){.brand-mark{width:330px}.brand-mark h1{font-size:38px}.state-card{right:84px;width:268px}.device-card{width:280px}.light-card{width:330px}}@media (max-height: 700px) and (min-width: 761px){.brand-mark{width:330px}.brand-mark h1{font-size:34px}.brand-mark p:last-child{display:none}.selected-device-line{margin-top:8px}.data-card{top:124px;width:246px;padding:11px}.data-card.expanded{width:clamp(500px,48vw,600px)!important}.data-card-head{margin-bottom:8px}.data-card-head h2{font-size:17px}.data-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.data-tile{min-height:54px;padding:8px}.data-tile strong{font-size:14px}.data-tile small,.environment-strip{display:none}.mode-card,.action-card,.light-card{bottom:18px}.mode-card{left:372px;width:304px}.action-card{left:24px}}@media (max-width: 900px){.brand-mark{width:330px}.state-card,.action-card{width:292px}.data-card{top:132px;width:292px}.data-card.expanded{width:clamp(420px,58vw,560px)!important}.device-card{top:176px;width:292px}.mode-card{width:292px}.light-card{right:24px;bottom:24px;width:316px}.light-row{grid-template-columns:32px 1fr 36px;gap:8px}.light-toggle{width:32px;height:32px}.action-card{top:auto;bottom:24px;right:auto;left:328px}}@media (max-width: 760px){.brand-mark{top:16px;left:16px;width:min(280px,calc(100vw - 32px))}.brand-mark h1{font-size:28px}.brand-mark p:last-child{display:none}.floating-card{border-radius:16px}.camera-monitor{top:14px;width:min(306px,calc(100vw - 32px))}.camera-monitor.expanded{width:min(420px,calc(100vw - 32px))}.state-card{top:76px;right:16px;width:236px;padding:12px}.data-card{top:116px;left:16px;width:236px}.data-card.expanded{width:calc(100vw - 32px)!important;max-height:calc(100vh - 250px)}.state-card h2{font-size:22px}.score-ring{width:50px;height:50px}.device-card{top:128px;left:16px;width:246px}.action-card{top:250px;right:auto;left:16px;width:246px}.settings-panel{top:auto;right:auto;left:auto;grid-template-columns:184px minmax(0,1fr);width:min(720px,calc(100vw - 32px))}.mode-card{left:16px;bottom:16px;width:min(292px,calc(50vw - 22px))}.light-card{right:16px;bottom:16px;width:min(292px,calc(50vw - 22px))}.mode{height:44px;gap:6px}.pill{min-height:34px;padding:0 10px}}@media (max-width: 540px){.brand-mark{width:calc(100vw - 32px)}.brand-mark .eyebrow{margin-bottom:4px}.brand-mark h1{max-width:240px;font-size:24px}.camera-monitor{top:12px;width:calc(100vw - 32px)}.camera-monitor.expanded{width:calc(100vw - 32px)}.camera-preview{max-height:420px}.camera-preview-frame{height:156px}.camera-preview-meta{grid-template-columns:repeat(2,minmax(0,1fr))}.camera-preview-meta span:nth-child(3){grid-column:1 / -1}.camera-preview-meta button:nth-of-type(1),.camera-preview-meta button:nth-of-type(2){grid-column:auto}.state-card{top:92px;left:16px;right:16px;width:auto}.data-card{top:108px;left:16px;width:min(236px,calc(100vw - 32px))}.data-card.expanded{width:calc(100vw - 32px)!important}.data-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.emotion-trend,.assessment-card,.device-card{display:none}.action-card{top:260px;left:16px;right:auto;width:min(246px,calc(100vw - 32px))}.settings-overlay{padding:16px}.settings-panel{grid-template-columns:1fr;max-height:calc(100vh - 32px)}.settings-sidebar{padding:14px 12px 4px;border-right:0;border-bottom:1px solid rgba(255,255,255,.2)}.settings-nav{grid-template-columns:repeat(2,minmax(0,1fr))}.settings-detail{min-height:0;padding:14px}.settings-title h2{font-size:24px}.source-grid,.emotion-summary,.setting-light-row,.palette-preset-grid,.device-status-row{grid-template-columns:1fr}.mode-card,.light-card{width:calc(50vw - 20px)}.mode-grid{grid-template-columns:1fr}.light-row{grid-template-columns:30px 1fr}.light-row strong{grid-column:2;text-align:left}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
