@font-face{font-family:MiSans;src:url(/fonts/misans-regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:MiSans;src:url(/fonts/misans-medium.ttf) format("truetype");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:MiSans;src:url(/fonts/misans-semibold.ttf) format("truetype");font-weight:600 800;font-style:normal;font-display:swap}:root{color:#151821;background:#f4f7fb;font-family:MiSans,PingFang SC,Microsoft YaHei,Noto Sans CJK SC,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#f4f7fbf2,#ffffffeb),repeating-linear-gradient(90deg,rgba(56,89,181,.05) 0 1px,transparent 1px 48px)}button,input,textarea{font:inherit}.app-shell{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:28px 0 42px}.topbar,.dashboard-grid,.history-section{margin-bottom:18px}.topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:18px}.eyebrow,.panel-label{margin:0 0 8px;color:#667085;font-size:13px;font-weight:700;letter-spacing:0;text-transform:uppercase}h1,h2,p{margin:0}h1{font-size:clamp(28px,4vw,44px);line-height:1.1}h2{font-size:22px;line-height:1.2}.status-pill,.range-tabs button,.primary-button{border-radius:8px}.status-pill{display:inline-flex;align-items:center;gap:8px;padding:10px 13px;background:#fff;color:#42526e;border:1px solid #e2e7f0;white-space:nowrap}.status-pill span{width:9px;height:9px;border-radius:999px;background:#c1c7d0}.status-pill.connected span{background:#1a7f52}.status-pill.disconnected span{background:#d92d20}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(260px,.6fr);gap:16px}.temperature-panel,.device-panel,.history-section,.stats-panel{background:#fff;border:1px solid #e6ebf3;border-radius:8px;box-shadow:0 16px 38px #10182812}.temperature-panel,.device-panel{padding:24px}.temperature-value{display:flex;align-items:baseline;gap:8px;color:#151821;font-size:clamp(56px,10vw,88px);font-weight:800;line-height:1}.temperature-value span{color:#e26d4f;font-size:30px}.muted{color:#667085;line-height:1.6}.error-text,.notice.error{color:#b42318}.history-section{padding:22px}.section-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.primary-button{border:0;background:#3859b5;color:#fff;padding:12px 18px;cursor:pointer}.primary-button:disabled{cursor:not-allowed;opacity:.62}.download-button{display:inline-flex;align-items:center;justify-content:center;min-height:42px;margin-top:18px;padding:10px 14px;border-radius:8px;background:#151821;color:#fff;font-weight:700;text-decoration:none;transition:background .16s ease,transform .16s ease}.download-button:hover{background:#2c3340;transform:translateY(-1px)}.download-actions{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:18px}.download-actions .download-button{margin-top:0}.auth-button,.secondary-button,.icon-button{border:1px solid #d7deea;background:#fff;color:#151821;border-radius:8px;cursor:pointer;font-weight:700}.auth-button{min-height:42px;padding:10px 14px}.auth-button:hover,.secondary-button:hover,.icon-button:hover{background:#f4f7fb}.controls{display:grid;grid-template-columns:repeat(6,minmax(130px,1fr));gap:12px;align-items:end;margin-bottom:16px}.range-tabs{display:flex;grid-column:1 / -1;gap:8px;overflow-x:auto;padding-bottom:2px}.range-tabs button{border:1px solid #d7deea;background:#f8fafd;color:#344054;padding:9px 13px;cursor:pointer;white-space:nowrap}.range-tabs button.active{border-color:#3859b5;background:#eef3ff;color:#26428d}label{display:flex;flex-direction:column;gap:7px;color:#4b5565;font-size:13px;font-weight:700}input{width:100%;min-height:42px;border:1px solid #d7deea;border-radius:8px;background:#fff;color:#151821;padding:9px 11px;outline:none}input:focus{border-color:#3859b5;box-shadow:0 0 0 3px #3859b51f}.switch-row{flex-direction:row;align-items:center;gap:10px;min-height:42px}.switch-row input{width:18px;min-height:18px}.notice{margin-bottom:16px;padding:12px 14px;border-radius:8px;background:#fff1f0;border:1px solid #ffd7d2}.chart-layout{display:grid;grid-template-columns:minmax(0,1fr) 170px;gap:16px}.chart,.empty-chart{width:100%;height:390px;border:1px solid #edf1f7;border-radius:8px;background:#fff}.empty-chart{display:grid;place-items:center;color:#667085}.stats-panel{display:grid;gap:10px;padding:14px;align-content:start;box-shadow:none}.stats-panel div{padding:13px;border-radius:8px;background:#f8fafd}.stats-panel p{margin-bottom:6px;color:#667085;font-size:13px}.stats-panel strong{color:#151821;font-size:18px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:18px;background:#0f172a61}.auth-modal{width:min(480px,100%);padding:20px;border:1px solid #e6ebf3;border-radius:8px;background:#fff;box-shadow:0 22px 70px #10182838}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.icon-button{width:36px;height:36px;font-size:24px;line-height:1}.full-width{width:100%;margin-top:12px}.secondary-button{min-height:42px;padding:10px 14px}.authorization-result{display:grid;gap:10px;margin-top:14px}.authorization-result textarea{width:100%;min-height:120px;resize:vertical;border:1px solid #d7deea;border-radius:8px;padding:10px 11px;color:#151821;background:#f8fafd;font:inherit;line-height:1.5}@media(max-width:860px){.topbar,.section-head{align-items:flex-start;flex-direction:column}.dashboard-grid,.chart-layout{grid-template-columns:1fr}.controls{grid-template-columns:1fr 1fr}.stats-panel{grid-template-columns:repeat(3,1fr)}}@media(max-width:560px){.app-shell{width:min(100% - 20px,1180px);padding-top:18px}.controls,.stats-panel{grid-template-columns:1fr}.temperature-panel,.device-panel,.history-section{padding:16px}}
