.device-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:20px 0}.device-card-wrapper{position:relative;overflow:visible}.device-card-link{text-decoration:none;color:inherit}.device-card{background:#fffffff2;border:1px solid #22c55e;border-radius:12px;padding:20px;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s}.device-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #22c55e4d;border-color:#22c55e}.device-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.device-header h3{margin:0;font-size:18px;color:#1f2937}.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;text-transform:uppercase}.status-badge.online{background:#2ed57333;color:#2ed573}.status-badge.offline{background:#ff6b6b33;color:#ff6b6b}.device-info p{margin:6px 0;color:#6b7280;font-size:14px}.current-weight{font-size:24px!important;color:#22c55e!important;font-weight:600;margin-top:12px!important}.loading{text-align:center;color:#6b7280;padding:40px}.empty-state{text-align:center;padding:60px 20px;color:#6b7280}.empty-state p{margin:8px 0}.hint{font-size:14px;color:#9ca3af}.delete-button{position:absolute;top:-8px;right:-8px;width:28px;height:28px;border-radius:50%;border:none;background:#ef4444;color:#fff;font-size:20px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s;z-index:10;line-height:1;padding:0;box-shadow:0 2px 8px #00000026}.delete-button:hover{background:#dc2626;transform:scale(1.1)}.delete-button:active{transform:scale(.95)}.settings-popup-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.settings-popup{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;width:90%;max-width:600px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #e5e7eb;background:#f9fafb;flex-shrink:0}.settings-header h3{margin:0;color:#1f2937;font-size:18px}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#6b7280;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s,color .2s}.close-btn:hover{background:#e5e7eb;color:#374151}.settings-content{padding:20px;overflow-y:auto;flex:1;color:#6b7280}.calibration-grid{display:flex;flex-direction:column;gap:16px;margin-bottom:16px}.calibration-step{display:flex;flex-direction:column;gap:8px}.calibration-label{font-size:14px;font-weight:500;color:#374151}.calibration-input-group{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.calibration-input{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;min-width:150px}.calibration-btn{padding:8px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:background .2s}.calibration-btn:hover:not(:disabled){background:#2563eb}.calibration-btn:disabled{background:#9ca3af;cursor:not-allowed}.calibration-value{font-size:13px;color:#6b7280;font-style:italic}.calibration-result{padding:12px;background:#f0fdf4;border:1px solid #86efac;border-radius:6px;color:#166534;font-size:14px}.target-weight-section{display:flex;flex-direction:column;gap:8px;padding-top:16px;border-top:1px solid #e5e7eb}.target-weight-header{display:flex;flex-direction:column;gap:4px}.target-weight-hint{font-size:12px;color:#6b7280;font-style:italic}.target-weight-example{font-size:12px;color:#6b7280;padding:8px;background:#f9fafb;border-radius:4px;margin-top:4px}.settings-group{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #e5e7eb}.settings-group:last-child{border-bottom:none;margin-bottom:0}.settings-group h4{margin:0 0 16px;color:#1f2937;font-size:16px;font-weight:600}.controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.control-item{display:flex;align-items:center;gap:8px;font-size:14px;color:#1f2937}.control-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.control-item input[type=number]{flex:1;padding:6px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;max-width:120px}.control-item input[type=number]:disabled{background:#f3f4f6;cursor:not-allowed}.control-item span:first-child{min-width:140px;color:#6b7280}.detail-header{display:flex;align-items:center;gap:16px;margin-bottom:16px;flex-shrink:0}.back-btn{background:#fffffff2;border:1px solid #22c55e;padding:8px 16px;border-radius:8px;color:#1f2937;cursor:pointer;font-size:14px;transition:border-color .2s,box-shadow .2s,transform .2s}.back-btn:hover{border-color:#16a34a;box-shadow:0 0 0 1px #16a34a;transform:translateY(-1px)}.detail-header h2{flex:1;margin:0;color:#e8f5e8;font-size:24px}.status-section{display:flex;align-items:center;gap:8px}.status-badge{padding:6px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.status-badge.online{background:#dcfce7;color:#166534}.status-badge.offline{background:#fee2e2;color:#991b1b}.settings-btn{background:#f3f4f6;border:none;padding:6px 8px;border-radius:12px;cursor:pointer;font-size:14px;font-weight:600;color:#374151;transition:background-color .2s,transform .2s;display:flex;align-items:center;justify-content:center;height:30px;box-sizing:border-box}.settings-btn:hover{background:#e5e7eb;transform:translateY(-1px)}@media(max-width:768px){.detail-header{gap:12px;margin-bottom:12px;padding:0 8px}.back-btn{padding:6px 12px;font-size:13px}.detail-header h2{font-size:18px}.status-badge{padding:4px 8px;font-size:11px}.settings-btn{padding:4px 6px;font-size:12px;height:26px}}@media(max-width:480px){.detail-header{gap:8px;margin-bottom:8px;padding:0 4px;flex-wrap:wrap}.back-btn{padding:5px 10px;font-size:12px}.detail-header h2{font-size:16px;width:100%;order:-1}.status-section{gap:6px}.status-badge{padding:3px 6px;font-size:10px}.settings-btn{padding:3px 5px;font-size:11px;height:24px}}.current-weight-card{background:#fffffff2;border:1px solid #22c55e;border-radius:16px;padding:24px;text-align:center;flex-shrink:0;width:100%;box-sizing:border-box}.current-weight-card h3{margin:0 0 16px;color:#22c55e;font-size:16px;font-weight:500;text-transform:uppercase;letter-spacing:1px}.weight-value{font-size:56px;font-weight:700;color:#1f2937;margin-bottom:8px}.last-update{color:#6b7280;font-size:14px;margin:0}.target-weight-indicator{font-size:16px;font-weight:500;color:#6b7280;margin-top:8px}.deviation{color:#ef4444;font-size:14px;margin-left:8px}.measurements-section{background:#fffffff2;border:1px solid #e5e7eb;border-radius:12px;padding:20px;display:flex;flex-direction:column;flex:1;min-height:0;width:100%;box-sizing:border-box}.measurements-section .section-header{flex-shrink:0;margin-bottom:20px}.measurements-section h3{margin:0;color:#1f2937;font-size:20px}.chart-container{flex:1;display:flex;flex-direction:column;min-height:0}.chart-container>div{flex:1!important;height:100%!important;width:100%!important}.chart-container canvas{width:100%!important;height:100%!important}.chart-container .ag-chart-wrapper{width:100%!important;height:100%!important}.loading-text,.empty-text{text-align:center;color:#6b7280;padding:20px}.chart-header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.chart-header-info{color:#6b7280;font-size:14px}@media(max-width:768px){.chart-header-content{flex-direction:column;align-items:flex-start;gap:8px}.chart-header-info{font-size:12px}}@media(max-width:480px){.chart-header-info{font-size:11px}}.stats-section{background:#fffffff2;border:1px solid #e5e7eb;border-radius:12px;padding:16px;flex-shrink:0;max-height:400px;overflow-x:auto;overflow-y:auto;width:100%}.stats-section .section-header{flex-shrink:0;margin-bottom:16px}.stats-header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.stats-header-info{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.stats-info-item{color:#6b7280;font-size:14px}.stats-section h3{margin:0;color:#1f2937;font-size:18px}.stats-table{width:100%;border-collapse:collapse;min-width:500px}.stats-table th,.stats-table td{padding:8px 10px;border-bottom:1px solid #e5e7eb;font-size:14px;color:#1f2937}.stats-table th{text-align:left;color:#6b7280;font-weight:600}.delete-range-btn{background:transparent;border:none;cursor:pointer;font-size:18px;padding:4px 8px;opacity:.5;transition:opacity .2s,transform .2s}.delete-range-btn:hover{opacity:1;transform:scale(1.2)}.empty-text{text-align:center;color:#6b7280;padding:20px}@media(max-width:768px){.stats-section{padding:12px;max-height:none}.stats-section h3{font-size:16px}.stats-header-content{flex-direction:column;align-items:flex-start;gap:8px}.stats-header-info{gap:12px}.stats-info-item{font-size:12px}.stats-table{font-size:12px;min-width:400px}.stats-table th,.stats-table td{padding:6px 4px}}@media(max-width:480px){.stats-section{padding:8px}.stats-section h3{font-size:14px}.stats-header-content{gap:6px}.stats-header-info{flex-direction:column;align-items:flex-start;gap:4px}.stats-info-item{font-size:11px}.stats-table{font-size:11px;min-width:350px}.stats-table th,.stats-table td{padding:4px 2px}}.device-detail{width:100%;height:100vh;height:100dvh;display:flex;flex-direction:column;box-sizing:border-box;overflow:hidden;position:relative}.main-layout{display:flex;flex-direction:column;gap:16px;flex:1;min-height:0;overflow:hidden}.left-column{display:flex;flex-direction:column;gap:16px;min-height:0;overflow-y:auto;width:100%}.left-column::-webkit-scrollbar{width:8px}.left-column::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}.left-column::-webkit-scrollbar-thumb{background:#22c55e;border-radius:4px}@media(max-width:768px){.main-layout{gap:12px}.device-detail{padding:0}.current-weight-card{padding:16px}.weight-value{font-size:40px}.measurements-section{padding:12px}.measurements-section h3{font-size:16px}.chart-container{height:250px;margin-top:12px}.stats-section{padding:12px;max-height:none}.stats-section h3{font-size:16px}.stats-table{font-size:12px}.stats-table th,.stats-table td{padding:6px 4px}.chart-tooltip{padding:8px}.tooltip-weight{font-size:14px}.tooltip-time{font-size:11px}}@media(max-width:480px){.main-layout{gap:8px}.current-weight-card{padding:12px}.weight-value{font-size:32px}.current-weight-card h3{font-size:14px}.measurements-section{padding:8px}.measurements-section h3{font-size:14px}.chart-container{height:200px}.stats-section{padding:8px}.stats-section h3{font-size:14px}.stats-table{font-size:11px}.stats-table th,.stats-table td{padding:4px 2px}}.measurements-list::-webkit-scrollbar{width:8px}.measurements-list::-webkit-scrollbar-track{background:#fff3;border-radius:4px}.measurements-list::-webkit-scrollbar-thumb{background:#22c55e;border-radius:4px}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#0d1b0d,#1a2e1a);color:#e8f5e8}.app{min-height:100vh;padding:20px}.app-header{margin:0 0 32px;display:flex;justify-content:space-between;align-items:center;padding-bottom:20px;border-bottom:1px solid #2d5a2d}.app-header h1{margin:0;font-size:28px;background:linear-gradient(135deg,#22c55e,#16a34a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-main{width:100%}@media(max-width:768px){.app{padding:16px}.app-header h1{font-size:22px}}
