*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f1f5f9;--surface: #ffffff;--border: #e2e8f0;--border-subtle: #f1f5f9;--text: #0f172a;--text-2: #334155;--muted: #64748b;--header: #0f172a;--accent: #4f46e5;--accent-bg: #eef2ff;--green: #059669;--green-bg: #ecfdf5;--green-border: #6ee7b7;--red: #dc2626;--red-bg: #fef2f2;--red-border: #fca5a5;--amber: #b45309;--amber-bg: #fffbeb;--radius-sm: 8px;--radius: 14px;--radius-lg: 18px;--shadow-sm: 0 1px 2px rgba(0,0,0,.06);--shadow: 0 2px 8px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.1), 0 2px 4px rgba(0,0,0,.06)}html{-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}.fab-upload{position:fixed;bottom:calc(28px + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);z-index:200;display:flex;align-items:center;gap:8px;padding:14px 26px;border-radius:50px;border:1px solid rgba(255,255,255,.25);background:#0f172ab8;backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);color:#fff;font-size:15px;font-weight:600;cursor:pointer;white-space:nowrap;box-shadow:0 8px 32px #00000038,0 2px 8px #0000001f;transition:transform .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent;letter-spacing:.01em}.fab-upload:active{transform:translate(-50%) scale(.96);box-shadow:0 4px 16px #0000002e}.fab-upload svg{width:17px;height:17px;opacity:.9}.app-main{padding:20px 16px;padding-top:calc(20px + env(safe-area-inset-top));padding-bottom:calc(100px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:20px;max-width:720px;margin:0 auto}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:60px 24px;gap:12px}.empty-icon{width:72px;height:72px;background:var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;margin-bottom:4px}.empty-title{font-size:18px;font-weight:600;color:var(--text)}.empty-sub{font-size:15px;color:var(--muted);line-height:1.5}.btn-upload-big{display:flex;align-items:center;gap:8px;background:var(--accent);color:#fff;border:none;border-radius:12px;padding:14px 28px;font-size:16px;font-weight:600;cursor:pointer;margin-top:8px;transition:background .15s,transform .1s;-webkit-tap-highlight-color:transparent}.btn-upload-big:active{transform:scale(.97);background:#4338ca}.loading-bar{background:var(--surface);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow)}.spinner{width:22px;height:22px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.loading-bar p{font-size:14px;color:var(--text-2);font-weight:500}.error-list{display:flex;flex-direction:column;gap:8px}.error-item{background:var(--red-bg);color:#991b1b;border:1px solid var(--red-border);border-radius:var(--radius-sm);padding:12px 14px;font-size:14px}.summary-strip{display:flex;gap:10px}.summary-chip{flex:1;background:var(--surface);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}.summary-chip.warn{border-color:var(--red-border);background:var(--red-bg)}.summary-chip.clickable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s,border-color .15s;-webkit-tap-highlight-color:transparent}.summary-chip.clickable:active,.summary-chip.clickable.active{background:var(--accent-bg);border-color:var(--accent)}.chip-number{font-size:26px;font-weight:700;line-height:1;color:var(--text)}.summary-chip.warn .chip-number{color:var(--red)}.chip-label{font-size:12px;color:var(--muted);margin-top:4px;font-weight:500}.records-row{display:flex;align-items:center;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.records-row::-webkit-scrollbar{display:none}.records-label{font-size:13px;color:var(--muted);white-space:nowrap;font-weight:500}.record-chip{display:flex;align-items:center;gap:5px;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:5px 10px 5px 12px;font-size:13px;font-weight:500;white-space:nowrap;flex-shrink:0}.chip-del{background:none;border:none;cursor:pointer;color:var(--muted);font-size:15px;line-height:1;padding:2px;display:flex;align-items:center;border-radius:50%;transition:color .1s,background .1s;-webkit-tap-highlight-color:transparent}.chip-del:active{color:var(--red);background:var(--red-bg)}.chart-group{display:flex;flex-direction:column;gap:12px}.group-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;width:100%;text-align:left;box-shadow:var(--shadow-sm);transition:background .15s;-webkit-tap-highlight-color:transparent}.group-header:active{background:var(--border-subtle)}.group-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.group-label{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-2);flex:1}.group-warn-badge{background:var(--red);color:#fff;font-size:11px;font-weight:700;border-radius:10px;padding:2px 7px;flex-shrink:0}.group-chevron{color:var(--muted);display:flex;align-items:center;flex-shrink:0}.group-ok-badge{color:var(--green);font-size:13px;font-weight:700;flex-shrink:0}.all-normal-card{display:flex;align-items:center;gap:10px;background:var(--green-bg);border:1px solid var(--green-border);border-radius:var(--radius);padding:16px 18px;font-size:15px;font-weight:600;color:var(--green)}.all-normal-icon{font-size:18px;font-weight:700}.charts-grid{display:grid;grid-template-columns:1fr;gap:12px}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.chart-card.out-of-range{border-color:var(--red-border)}.chart-card.out-of-range .card-top{background:var(--red-bg)}.card-top{padding:14px 16px 10px;border-bottom:1px solid var(--border-subtle)}.card-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.card-title{font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.status-badge{font-size:11px;font-weight:600;border-radius:6px;padding:3px 8px;letter-spacing:.02em}.status-badge.ok{background:var(--green-bg);color:var(--green)}.status-badge.high{background:var(--red-bg);color:var(--red)}.status-badge.low{background:var(--amber-bg);color:var(--amber)}.card-value-row{display:flex;align-items:baseline;gap:8px}.card-value{font-size:30px;font-weight:700;letter-spacing:-.5px;line-height:1;color:var(--text)}.card-unit{font-size:14px;color:var(--muted);font-weight:500}.card-meta{display:flex;align-items:center;gap:8px;margin-top:4px}.card-date{font-size:12px;color:var(--muted)}.trend{display:flex;align-items:center;gap:3px;font-size:12px;font-weight:600}.trend.up{color:var(--red)}.trend.down{color:var(--green)}.trend.stable{color:var(--muted)}.trend svg{width:12px;height:12px}.card-body{padding:8px 4px 4px}.chart-tooltip{background:var(--header);border-radius:10px;padding:10px 13px;font-size:13px;color:#fff;box-shadow:var(--shadow-md);min-width:130px}.tt-date{color:#94a3b8;font-size:11px;margin-bottom:5px}.tt-value{font-size:18px;font-weight:700;line-height:1}.tt-value.ok{color:#6ee7b7}.tt-value.high{color:#fca5a5}.tt-value.low{color:#fcd34d}.tt-range{color:#64748b;font-size:11px;margin-top:5px;line-height:1.4}@media(min-width:540px){.charts-grid{grid-template-columns:1fr 1fr}.app-main{padding:24px 20px}}@media(min-width:720px){.app-main{padding:28px 24px}}
