*,*:before,*:after{box-sizing:border-box}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color:#1f2937;background-color:#f3f4f6;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}a{font-weight:500;color:#667eea;text-decoration:none}a:hover{color:#5a6fd6}button{font-family:inherit;cursor:pointer}h1,h2,h3,h4,h5,h6{margin:0;line-height:1.3}.loading{text-align:center;padding:3rem;font-size:1.1rem;color:#6b7280}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#f3f4f6;color:#6b7280}.loading-screen .spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.loading-screen p{margin:0;font-size:1rem}.app-layout{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 10px #00000026;position:sticky;top:0;z-index:100}.header-content{display:flex;align-items:center;padding:0 24px;max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box;height:56px}.header-left{display:flex;align-items:center}.header-left h1{margin:0;font-size:1.2rem;font-weight:700;white-space:nowrap}.app-nav{display:flex;gap:2px;margin-left:32px;flex:1}.app-nav a{padding:8px 16px;color:#ffffffbf;text-decoration:none;border-radius:6px;font-weight:500;font-size:.9rem;transition:all .2s;display:flex;align-items:center;gap:6px}.app-nav a:hover{color:#fff;background:#ffffff1f}.app-nav a.active{color:#fff;background:#fff3}.badge{background:#ef4444;color:#fff;padding:1px 7px;border-radius:10px;font-size:.7rem;font-weight:700;line-height:1.3}.header-right{display:flex;align-items:center;gap:12px;margin-left:auto}.user-info{display:flex;flex-direction:column;align-items:flex-end;font-weight:500;font-size:.85rem;line-height:1.3}.user-role{font-size:.7rem;opacity:.7;text-transform:capitalize}.logout-btn{padding:6px 14px;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:6px;cursor:pointer;font-weight:500;font-size:.85rem;transition:background .2s}.logout-btn:hover{background:#ffffff40}.app-main{flex:1;background:#f3f4f6;padding:24px}@media (max-width: 768px){.header-content{padding:0 12px;height:48px}.header-left h1{font-size:1rem}.app-nav{margin-left:16px;gap:0}.app-nav a{padding:6px 10px;font-size:.8rem}.user-info{display:none}.app-main{padding:16px}}@media (max-width: 480px){.header-left h1{font-size:.85rem;white-space:nowrap}.app-nav{margin-left:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.app-nav::-webkit-scrollbar{display:none}.app-nav a,.logout-btn{padding:5px 8px;font-size:.75rem;white-space:nowrap}.app-main{padding:10px}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:400px;overflow:hidden}.login-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:30px;text-align:center}.login-header h1{margin:0;font-size:1.8rem;font-weight:700}.login-header p{margin:8px 0 0;opacity:.9;font-size:.95rem}.login-form{padding:30px}.login-error{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:.9rem;border:1px solid #fecaca}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#374151;font-size:.9rem}.form-group input{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-group input::placeholder{color:#9ca3af}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{flex:1;padding-right:45px}.password-toggle{position:absolute;right:12px;background:none;border:none;cursor:pointer;font-size:1.2rem;padding:8px;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.password-toggle:hover{opacity:.7}.password-toggle:focus{outline:none}.login-btn{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-footer{padding:20px 30px;background:#f9fafb;text-align:center;border-top:1px solid #e5e7eb}.login-footer p{margin:0;color:#6b7280;font-size:.85rem}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#f3f4f6}.spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}.dashboard{padding:0}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#6b7280}.loading-spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.org-group{margin-bottom:28px}.org-group-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:14px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.org-group-header:hover{background:#f9fafb}.org-group-left{display:flex;align-items:center;gap:10px}.org-group-chevron{font-size:.85rem;color:#6b7280;width:14px}.org-group-name{font-size:1rem;font-weight:700;color:#111827}.org-group-count{font-size:.8rem;color:#9ca3af;font-weight:500}.org-group-badges{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.org-group-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600}.org-group-badge--alert{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.org-group-badge--offline{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb}.org-group-badge--ok{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.sensor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.sensor-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.sensor-card:hover{transform:translateY(-3px);box-shadow:0 10px 25px #00000014,0 4px 10px #0000000a}.card-status-strip{height:4px}.strip-normal{background:linear-gradient(90deg,#22c55e,#16a34a)}.strip-alert{background:linear-gradient(90deg,#ef4444,#dc2626);animation:alertPulse 2s ease-in-out infinite}.strip-offline{background:#d1d5db}@keyframes alertPulse{0%,to{opacity:1}50%{opacity:.5}}.card-body{padding:20px}.card-footer{padding:8px 20px;border-top:1px solid #f3f4f6;background:#fafbfc}.product-info{font-size:.7rem;color:#9ca3af;text-transform:capitalize;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.card-title-group{display:flex;align-items:flex-start;gap:10px;min-width:0;flex:1}.card-type-icon{font-size:1.5rem;flex-shrink:0;line-height:1;margin-top:2px}.card-name{font-size:1rem;font-weight:700;color:#111827;margin:0;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-location{font-size:.8rem;color:#6b7280;display:block;margin-top:2px}.card-org-badge{display:inline-block;margin-top:4px;padding:1px 7px;background:#ede9fe;color:#6d28d9;border-radius:10px;font-size:.7rem;font-weight:600}.status-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:700;letter-spacing:.02em;white-space:nowrap;flex-shrink:0;margin-left:12px}.pill-icon{font-size:.7rem}.pill-normal{background:#dcfce7;color:#15803d}.pill-alert{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.pill-offline{background:#f3f4f6;color:#6b7280}.temp-display{text-align:center;padding:16px 0 12px;line-height:1}.temp-whole{font-size:3.2rem;font-weight:800;letter-spacing:-.02em}.temp-decimal{font-size:2rem;font-weight:600}.temp-unit{font-size:1.4rem;font-weight:600;margin-left:2px;vertical-align:super;opacity:.7}.temp-ok{color:#15803d}.temp-high{color:#dc2626}.temp-low{color:#2563eb}.temp-unknown{color:#9ca3af}.temp-range-bar{margin:8px 0 20px;padding:0 4px}.range-labels{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;color:#9ca3af;margin-bottom:6px;font-weight:600}.range-label-center{text-transform:uppercase;letter-spacing:.05em;font-size:.65rem}.range-track{height:6px;background:#f3f4f6;border-radius:3px;position:relative;overflow:visible}.range-fill{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#3b82f6,#22c55e 30%,#22c55e 70%,#ef4444);border-radius:3px;opacity:.25}.range-indicator{position:absolute;top:50%;width:12px;height:12px;border-radius:50%;transform:translate(-50%,-50%);border:2px solid white;box-shadow:0 1px 4px #0003}.indicator-ok{background:#22c55e}.indicator-high{background:#ef4444}.indicator-low{background:#3b82f6}.indicator-unknown{background:#d1d5db}.card-data-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:12px;padding-top:16px;border-top:1px solid #f3f4f6}.data-cell{display:flex;align-items:center;gap:8px;padding:8px;background:#f9fafb;border-radius:8px;transition:background .2s ease}.data-cell:hover{background:#f3f4f6}.data-icon{font-size:1.2rem;flex-shrink:0}.data-content{display:flex;flex-direction:column;min-width:0}.data-value{font-size:.95rem;font-weight:700;color:#111827;line-height:1.2}.battery-warning{display:inline-block;font-size:.85em;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.data-label{font-size:.7rem;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.03em;margin-top:1px}.alarm-text{color:#e74c3c}.card-meta{display:flex;align-items:center;gap:16px;padding-top:16px;border-top:1px solid #f3f4f6}.meta-item{display:flex;align-items:center;gap:4px}.meta-icon{font-size:.8rem}.meta-value{font-size:.8rem;font-weight:600;color:#4b5563}.meta-time{margin-left:auto}.meta-time .meta-value{color:#9ca3af;font-weight:500}.status-alert{border:1px solid #fecaca}.status-alert .card-body{background:linear-gradient(180deg,#fff5f5,#fff 40%)}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000000f}.empty-icon{font-size:3rem;margin-bottom:1rem}.empty-state h3{font-size:1.3rem;font-weight:700;color:#111827;margin-bottom:.5rem}.empty-state p{margin:.25rem 0;color:#6b7280;font-size:.95rem}.empty-hint{margin-top:1rem!important;font-size:.85rem!important;color:#9ca3af!important}@media (max-width: 768px){.sensor-grid{grid-template-columns:1fr;gap:14px}.card-body{padding:16px}.temp-whole{font-size:2.8rem}.temp-decimal{font-size:1.6rem}}@media (min-width: 1200px){.sensor-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}}.stats-bar{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:12px;padding:20px 24px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #0000001f;border:2px solid #e5e7eb;transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-card-alert{background:#fef3f2;border:2px solid #fda29b}.stat-card:nth-child(1){background:#fff;border-left:5px solid #3b82f6}.stat-card:nth-child(2){background:#fff;border-left:5px solid #10b981}.stat-card:nth-child(3){background:#fff;border-left:5px solid #6b7280}.stat-card:nth-child(4){background:#fff;border-left:5px solid #ef4444}.stat-card:nth-child(5){background:#fff;border-left:5px solid #a855f7}.stat-icon{font-size:1.3rem;width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:10px;flex-shrink:0}.stat-icon-total{background:#dbeafe}.stat-icon-online{background:#dcfce7}.stat-icon-offline{background:#f3f4f6}.stat-icon-alert{background:#fee2e2}.stat-icon-readings{background:#ede9fe}.stat-content{display:flex;flex-direction:column;min-width:0}.stat-number{font-size:2.2rem;font-weight:900;color:#000;line-height:1;letter-spacing:-.02em}.stat-green{color:#16a34a}.stat-amber{color:#d97706}.stat-red{color:#dc2626}.stat-label{font-size:.85rem;font-weight:700;color:#1f2937;text-transform:uppercase;letter-spacing:.05em;margin-top:6px;white-space:nowrap}@media (max-width: 1024px){.stats-bar{grid-template-columns:repeat(3,1fr)}}@media (max-width: 640px){.stats-bar{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}.stat-card{padding:12px 14px;gap:10px}.stat-icon{width:36px;height:36px;font-size:1.1rem;border-radius:8px}.stat-number{font-size:1.2rem}}.sensor-detail{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #00000014}.detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #eee;flex-wrap:wrap}.back-button{padding:.5rem 1rem;background:#f0f0f0;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s}.back-button:hover{background:#e0e0e0}.detail-header h2{margin:0;font-size:1.8rem;color:#333}.detail-location{color:#666;margin:.25rem 0 0}.current-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.detail-stat-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.detail-stat-card .stat-label{font-size:.9rem;color:#ffffffe6!important;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.detail-stat-card .stat-value{font-size:2rem;font-weight:700;color:#fff!important}.time-range-selector{display:flex;gap:.5rem;margin-bottom:1.5rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:wrap}.time-range-selector::-webkit-scrollbar{display:none}.time-range-selector button{padding:.5rem 1rem;background:#f0f0f0;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s}.time-range-selector button:hover{background:#e0e0e0}.time-range-selector button.active{background:#667eea;color:#fff}.chart-container{margin-bottom:2rem;padding:1.5rem;background:#f9f9f9;border-radius:12px}.chart-container h3{margin:0 0 1.5rem;color:#333}.empty-chart{text-align:center;padding:3rem;color:#999}.sensor-info{padding:1.5rem;background:#f9f9f9;border-radius:12px}.sensor-info h3{margin:0 0 1rem;color:#333}.sensor-info table{width:100%;border-collapse:collapse}.sensor-info td{padding:.75rem;border-bottom:1px solid #eee}.sensor-info td:first-child{font-weight:600;color:#666;width:140px;min-width:100px}.sensor-info code{background:#e0e0e0;padding:.25rem .5rem;border-radius:4px;font-family:monospace}.detail-stat-card-alarm{background:linear-gradient(135deg,#e74c3c,#c0392b)}.status-active{color:#4caf50;font-weight:600}.status-inactive{color:#999;font-weight:600}@media (max-width: 600px){.sensor-detail{padding:1rem}.detail-header h2{font-size:1.3rem}.current-stats{grid-template-columns:1fr 1fr;gap:.75rem}.detail-stat-card{padding:1rem}.detail-stat-card .stat-value{font-size:1.5rem}.time-range-selector button{padding:.4rem .75rem;font-size:.85rem}.chart-container,.sensor-info{padding:1rem}.sensor-info td{padding:.5rem;font-size:.85rem}.sensor-info td:first-child{width:110px;min-width:90px}}@media (max-width: 380px){.current-stats{grid-template-columns:1fr}}.cd-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;animation:cdFadeIn .15s ease;padding:16px}@keyframes cdFadeIn{0%{opacity:0}to{opacity:1}}.cd-box{background:#fff;border-radius:16px;padding:28px 28px 24px;max-width:400px;width:100%;box-shadow:0 20px 60px #0003;animation:cdSlideUp .18s ease;text-align:center}@keyframes cdSlideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.cd-icon{font-size:2.4rem;margin-bottom:12px;line-height:1}.cd-title{font-size:1.1rem;font-weight:700;color:#111827;margin:0 0 10px;line-height:1.3}.cd-message{font-size:.88rem;color:#6b7280;margin:0 0 22px;line-height:1.5}.cd-actions{display:flex;gap:10px;justify-content:center}.cd-btn{padding:9px 22px;border-radius:8px;font-size:.88rem;font-weight:600;cursor:pointer;border:none;transition:background .15s,transform .1s}.cd-btn:active{transform:scale(.97)}.cd-btn--cancel{background:#f3f4f6;color:#374151}.cd-btn--cancel:hover{background:#e5e7eb}.cd-btn--confirm{background:#3b82f6;color:#fff}.cd-btn--confirm:hover{background:#2563eb}.cd-btn--danger{background:#dc2626;color:#fff}.cd-btn--danger:hover{background:#b91c1c}.toast{position:fixed;top:20px;right:20px;z-index:1100;display:flex;align-items:center;gap:10px;padding:13px 16px;border-radius:12px;font-size:.9rem;font-weight:500;max-width:380px;box-shadow:0 8px 24px #0000001f;transition:transform .3s ease,opacity .3s ease}.toast--in{transform:translate(0);opacity:1}.toast--out{transform:translate(110%);opacity:0}.toast--success{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.toast--error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.toast-icon{font-size:1rem;flex-shrink:0}.toast-text{flex:1;line-height:1.4}.toast-close{background:none;border:none;cursor:pointer;font-size:.8rem;color:inherit;opacity:.6;padding:0 2px;flex-shrink:0;line-height:1}.toast-close:hover{opacity:1}@media (max-width: 480px){.toast{top:12px;right:12px;left:12px;max-width:none}}.sc-alert-summary{background:#f8faff;border:1px solid #dbeafe;border-radius:10px;padding:14px 16px;margin-bottom:20px}.sc-alert-summary-title{font-size:.78rem;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px}.sc-alert-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.sc-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:20px;font-size:.82rem;font-weight:600}.sc-chip--red{background:#fee2e2;color:#991b1b}.sc-chip--orange{background:#ffedd5;color:#9a3412}.sc-chip--gray{background:#f3f4f6;color:#374151}.sc-chip--green{background:#d1fae5;color:#065f46}.sc-alert-summary-note{font-size:.8rem;color:#6b7280;margin:0;line-height:1.5}.sc-list{display:flex;flex-direction:column;gap:6px}.sc-item{border:1px solid #e5e7eb;border-radius:10px;background:#fff;overflow:hidden;transition:box-shadow .2s,border-color .2s}.sc-item:hover{border-color:#cbd5e1}.sc-item--open{border-color:#3b82f6;box-shadow:0 2px 12px #3b82f61f}.sc-summary{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;gap:12px;-webkit-user-select:none;user-select:none;transition:background .15s}.sc-summary:hover{background:#f9fafb}.sc-item--open .sc-summary{border-bottom:1px solid #e5e7eb;cursor:default;background:#f0f7ff}.sc-summary-left{display:flex;align-items:center;gap:12px;min-width:0}.sc-badge{font-size:1.3rem;width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sc-badge--cooler{background:#e0f2fe}.sc-badge--freezer{background:#ede9fe}.sc-summary-info{display:flex;flex-direction:column;min-width:0}.sc-summary-name{font-weight:600;font-size:.95rem;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sc-summary-meta{font-size:.8rem;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sc-edit-hint{font-size:.8rem;color:#9ca3af;flex-shrink:0;transition:color .15s}.sc-summary:hover .sc-edit-hint{color:#3b82f6}.sc-edit{padding:16px;display:flex;flex-direction:column;gap:14px;background:#fafbfc}.sc-edit-id{font-size:.75rem;color:#9ca3af}.sc-edit-id code{background:#f3f4f6;padding:2px 6px;border-radius:4px;font-family:monospace;font-size:.75rem}.sc-row{display:flex;gap:12px;flex-wrap:wrap}.sc-field{display:flex;flex-direction:column;gap:4px;flex:1 1 160px;min-width:0}.sc-field--sm{flex:0 1 110px;min-width:80px}.sc-label{font-size:.78rem;font-weight:600;color:#374151}.sc-input{padding:8px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:.88rem;background:#fff;color:#111827;transition:border-color .15s;width:100%;box-sizing:border-box}.sc-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.sc-fieldset{border:1px solid #e5e7eb;border-radius:8px;padding:12px 14px 10px;margin:0}.sc-legend{font-size:.82rem;font-weight:600;color:#374151;padding:0 6px}.sc-range-row{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}.sc-range-sep{font-size:.82rem;color:#9ca3af;padding-bottom:10px}.sc-opt{font-weight:400;font-size:.72rem;color:#9ca3af;margin-left:4px}.sc-field>.sc-opt{display:block;margin-left:0;margin-top:3px;line-height:1.4}.sc-details{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.sc-details-toggle{padding:10px 14px;font-size:.82rem;font-weight:600;color:#374151;cursor:pointer;background:#f9fafb;list-style:none;-webkit-user-select:none;user-select:none;transition:background .15s}.sc-details-toggle:hover{background:#f3f4f6}.sc-details-toggle::-webkit-details-marker{display:none}.sc-details-toggle:before{content:"▸ ";display:inline;transition:transform .2s}.sc-details[open] .sc-details-toggle:before{content:"▾ "}.sc-details-body{padding:12px 14px;display:flex;flex-direction:column;gap:12px}.sc-check{display:flex;align-items:center;gap:8px;font-size:.85rem;color:#374151;cursor:pointer}.sc-check input[type=checkbox]{width:16px;height:16px;accent-color:#3b82f6}.sc-alerts-toggle{margin-top:4px;margin-bottom:12px;padding:10px 12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;gap:8px}.sc-muted-badge{margin-left:4px;padding:2px 8px;background:#fef3c7;color:#92400e;border-radius:10px;font-size:.72rem;font-weight:600}.sc-actions{display:flex;justify-content:space-between;align-items:center;gap:8px;padding-top:4px;border-top:1px solid #e5e7eb}.sc-actions-danger{display:flex;gap:8px;align-items:center}.sc-actions-right{display:flex;gap:8px}.sc-deactivate-btn{padding:6px 12px;border:1px solid #fecaca;background:#fff5f5;color:#dc2626;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.sc-deactivate-btn:hover{background:#fee2e2;border-color:#f87171}.sc-deactivate-btn:disabled{opacity:.5;cursor:not-allowed}.sc-delete-btn{padding:6px 12px;border:1px solid #dc2626;background:#dc2626;color:#fff;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.sc-delete-btn:hover{background:#b91c1c;border-color:#b91c1c}.sc-delete-btn:disabled{opacity:.5;cursor:not-allowed}.sc-org-chip{display:inline-block;margin-left:6px;padding:1px 7px;background:#ede9fe;color:#6d28d9;border-radius:10px;font-size:.68rem;font-weight:600;vertical-align:middle}@media (max-width: 600px){.sc-summary{padding:10px 12px}.sc-edit{padding:12px}.sc-row{flex-direction:column;gap:8px}.sc-field,.sc-field--sm{flex:1 1 100%}.sc-range-row{flex-direction:row;gap:6px}.sc-actions{flex-direction:column}.sc-actions .btn{width:100%;justify-content:center}}.add-sensor-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:12px}.add-sensor-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 20px;border:2px dashed #d1d5db;border-radius:12px;background:#f9fafb;cursor:pointer;transition:all .2s;text-align:center}.add-sensor-card:hover{border-color:#3b82f6;background:#eff6ff;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f626}.add-sensor-card .card-icon{font-size:2.5rem}.add-sensor-card .card-title{font-size:1.1rem;font-weight:600;color:#1f2937}.add-sensor-card .card-desc{font-size:.85rem;color:#6b7280;line-height:1.4}.scanner-container{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:12px}.qr-reader{width:100%;max-width:400px;border-radius:12px;overflow:hidden;border:2px solid #e5e7eb}.scanner-hint{color:#6b7280;font-size:.9rem;text-align:center}.claim-form{max-width:480px;margin-top:12px}.claim-form .form-group{margin-bottom:16px}.claim-form .form-group label{display:block;font-weight:600;font-size:.9rem;color:#374151;margin-bottom:6px}.claim-form .form-group input{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;color:#1f2937;background:#fff;transition:border-color .2s}.claim-form .form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.claim-form .form-group input.readonly{background:#f3f4f6;color:#6b7280;font-family:monospace;font-size:.95rem;letter-spacing:1px}.scanned-badge{display:inline-block;margin-top:4px;font-size:.8rem;color:#16a34a;font-weight:500}.claim-actions{display:flex;gap:12px;margin-top:20px}.claim-result{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:.95rem;font-weight:500}.claim-result-success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.claim-result-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.claim-result-info{background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}@media (max-width: 480px){.add-sensor-options{grid-template-columns:1fr}.qr-reader,.claim-form{max-width:100%}}.um-subtitle{color:#6b7280;font-size:.9rem;margin:-12px 0 20px}.um-cred-card{background:#d1fae5;border:1px solid #6ee7b7;border-radius:10px;padding:16px 18px;margin-bottom:20px;position:relative}.um-cred-title{font-weight:700;color:#065f46;margin-bottom:12px;font-size:.95rem}.um-cred-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.um-cred-label{font-size:.8rem;font-weight:600;color:#047857;width:60px;flex-shrink:0}.um-cred-value{background:#a7f3d0;color:#065f46;padding:3px 10px;border-radius:5px;font-family:monospace;font-size:.9rem}.um-cred-value--pw{letter-spacing:.04em;font-weight:700}.um-cred-note{font-size:.78rem;color:#047857;margin:10px 0 0}.um-cred-dismiss{position:absolute;top:12px;right:14px;background:none;border:none;color:#065f46;font-size:.8rem;cursor:pointer;text-decoration:underline;padding:0}.um-form-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:20px;margin-bottom:24px}.um-form-title{font-size:.95rem;font-weight:700;color:#111827;margin:0 0 16px}.um-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:16px}.um-field{display:flex;flex-direction:column;gap:5px}.um-label{font-size:.8rem;font-weight:600;color:#374151}.um-req{color:#ef4444;font-weight:700}.um-input{padding:9px 12px;border:1px solid #d1d5db;border-radius:7px;font-size:.9rem;font-family:inherit;color:#111827;background:#fff;width:100%;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.um-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1f}.um-pw-wrap{position:relative;display:flex;align-items:center}.um-pw-wrap .um-input{padding-right:40px}.um-eye-btn{position:absolute;right:9px;background:none;border:none;cursor:pointer;font-size:1rem;padding:0;color:#6b7280;line-height:1;display:flex;align-items:center}.um-form-footer{border-top:1px solid #f3f4f6;padding-top:14px}.um-user-list{display:flex;flex-direction:column;gap:6px}.um-user-row{display:flex;align-items:center;gap:14px;padding:12px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;transition:box-shadow .15s}.um-user-row:hover{box-shadow:0 2px 8px #0000000f}.um-user-row--inactive{opacity:.5}.um-user-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:700;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.um-user-info{flex:1;min-width:0}.um-user-name{font-weight:600;font-size:.92rem;color:#111827;display:flex;align-items:center;gap:6px}.um-user-email{font-size:.8rem;color:#6b7280;margin-top:1px}.um-you-badge{font-size:.68rem;background:#e0f2fe;color:#0369a1;padding:1px 7px;border-radius:10px;font-weight:700}.um-user-meta{display:flex;align-items:center;gap:8px;flex-shrink:0}.um-role-badge{padding:3px 10px;border-radius:12px;font-size:.76rem;font-weight:600;text-transform:capitalize;white-space:nowrap}.um-org-name{font-size:.8rem;color:#6b7280;white-space:nowrap}.um-user-status{display:flex;align-items:center;gap:5px;flex-shrink:0}.um-status-dot{width:7px;height:7px;border-radius:50%}.um-status-dot--active{background:#10b981}.um-status-dot--inactive{background:#d1d5db}.um-status-text{font-size:.8rem;color:#6b7280}.um-user-actions{flex-shrink:0;width:90px;display:flex;justify-content:flex-end}.um-deactivate-btn{padding:5px 12px;border:1px solid #fecaca;background:#fff5f5;color:#dc2626;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s;white-space:nowrap}.um-deactivate-btn:hover{background:#fee2e2;border-color:#f87171}@media (max-width: 600px){.um-user-meta,.um-user-status{display:none}.um-form-grid{grid-template-columns:1fr}}.webhook-setup h2{font-size:1.3rem;font-weight:700;color:#111827;margin:0 0 4px}.webhook-setup .section-desc{color:#6b7280;margin:0 0 24px;font-size:.9rem;line-height:1.5}.setup-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:20px 24px;margin-bottom:20px}.setup-card h3{font-size:1rem;font-weight:700;color:#111827;margin:0 0 6px}.setup-card p{color:#6b7280;margin:0 0 14px;font-size:.85rem;line-height:1.5}.card-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.url-box{display:flex;align-items:center;gap:12px;background:#1f2937;border-radius:8px;padding:12px 16px;margin-bottom:10px}.url-text{flex:1;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.9rem;color:#22d3ee;word-break:break-all;line-height:1.5}.copy-btn{padding:8px 16px;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .2s}.copy-btn:hover{background:#5a6fd6}.copy-btn-small{padding:6px 12px;font-size:.75rem;flex-shrink:0}.url-note{font-size:.78rem;color:#9ca3af}.url-note strong{color:#6b7280}.steps-list{margin:12px 0 0;padding-left:20px;list-style:decimal}.steps-list li{padding:8px 0;font-size:.9rem;color:#374151;line-height:1.6;border-bottom:1px solid #f3f4f6}.steps-list li:last-child{border-bottom:none}.steps-list li strong{color:#111827}.steps-list li ul{margin:8px 0 4px;padding-left:20px;list-style:disc}.steps-list li ul li{padding:3px 0;border-bottom:none;font-size:.85rem}.steps-list a{color:#667eea;font-weight:600}.code-block{background:#1f2937;color:#e5e7eb;padding:16px 20px;border-radius:8px;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.82rem;line-height:1.6;overflow-x:auto;margin:0 0 12px;white-space:pre}.code-terminal{color:#86efac}.template-note{font-size:.78rem;color:#6b7280;line-height:1.5}.template-note code{background:#e5e7eb;padding:1px 5px;border-radius:3px;font-size:.78rem;color:#374151}.field-table{width:100%;border-collapse:collapse;font-size:.85rem;margin-top:14px}.field-table th,.field-table td{padding:10px 14px;text-align:left;border-bottom:1px solid #e5e7eb}.field-table th{background:#f3f4f6;font-weight:600;color:#374151;font-size:.78rem;text-transform:uppercase;letter-spacing:.03em}.field-table td code{background:#eef2ff;color:#4338ca;padding:2px 6px;border-radius:4px;font-size:.8rem;font-weight:600}.field-table tr:last-child td{border-bottom:none}.card-info{background:#eff6ff;border-color:#bfdbfe}.card-info h3{color:#1e40af}.notes-list{margin:12px 0 0;padding-left:20px;list-style:disc}.notes-list li{padding:5px 0;font-size:.85rem;color:#374151;line-height:1.6}.notes-list li code{background:#dbeafe;color:#1e40af;padding:1px 5px;border-radius:3px;font-size:.8rem}@media (max-width: 640px){.url-box{flex-direction:column;align-items:stretch}.url-text{font-size:.8rem}.card-header-row{flex-direction:column}.field-table{font-size:.78rem}.field-table th,.field-table td{padding:8px 10px}}.data-export-container{max-width:900px;margin:0 auto}.data-export-container h2{font-size:1.8rem;margin-bottom:.5rem;color:#333}.section-desc{color:#666;margin-bottom:2rem;font-size:.95rem}.export-tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #eee;flex-wrap:wrap}.export-tabs button{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;color:#666;font-weight:500;cursor:pointer;transition:all .2s;font-size:.95rem}.export-tabs button:hover{color:#333;border-bottom-color:#ddd}.export-tabs button.active{color:#2563eb;border-bottom-color:#2563eb}.export-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000000d}.export-card h3{margin:0 0 .5rem;font-size:1.3rem;color:#333}.export-card>p{color:#666;margin-bottom:1.5rem;font-size:.95rem}.export-form{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:600;margin-bottom:.5rem;color:#333;font-size:.9rem}.form-group select,.form-group input{padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;font-family:inherit;background:#fff}.form-group select:focus,.form-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group select:disabled,.form-group input:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 600px){.form-row{grid-template-columns:1fr}}.btn-primary{padding:.75rem 1.5rem;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s;align-self:flex-start}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#fee2e2;border-left:4px solid #dc2626;color:#991b1b;padding:1rem;border-radius:6px;margin-bottom:1.5rem;font-size:.9rem}.success-message{background:#dcfce7;border-left:4px solid #16a34a;color:#15803d;padding:1rem;border-radius:6px;margin-bottom:1.5rem;font-size:.9rem}.report-preview{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem;margin-top:2rem}.report-preview h4{margin:0 0 1rem;font-size:1.1rem;color:#333}.report-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.summary-item{display:flex;flex-direction:column;gap:.25rem}.summary-item span{font-size:.85rem;color:#666}.summary-item strong{font-size:.95rem;color:#333}.text-danger{color:#dc2626!important}.text-success{color:#16a34a!important}.alerts-preview{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.alerts-preview h5{margin:0 0 .75rem;color:#333;font-size:.95rem}.alerts-preview ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.alerts-preview li{padding:.5rem;background:#fff;border-radius:6px;font-size:.85rem;color:#555;border-left:3px solid #ff9800}.note{margin-top:1rem;padding:1rem;background:#fffbeb;border-left:3px solid #f59e0b;color:#78350f;font-size:.9rem;border-radius:6px}.info-box{background:#eff6ff;border-left:3px solid #0284c7;border-radius:6px;padding:1rem;margin-top:1.5rem}.info-box h5{margin:0 0 .75rem;color:#0c4a6e;font-size:.95rem}.info-box ul{list-style:disc;padding-left:1.5rem;margin:0;font-size:.9rem;color:#0c4a6e}.info-box li{margin-bottom:.5rem}.daily-report-section{margin-bottom:1.75rem;padding-bottom:1.75rem;border-bottom:1px solid #f0f0f0}.daily-report-section h4{margin:0 0 1rem;font-size:1rem;color:#374151}.toggle-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:600;font-size:.95rem;color:#333}.toggle-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#2563eb}.field-hint{margin:.5rem 0 0;font-size:.85rem;color:#6b7280}.contact-checklist{display:flex;flex-direction:column;gap:.6rem}.contact-check-row{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:background .15s}.contact-check-row:hover{background:#f9fafb}.contact-check-row input[type=checkbox]{width:16px;height:16px;accent-color:#2563eb;cursor:pointer;flex-shrink:0}.contact-check-name{font-weight:600;color:#333;font-size:.9rem;flex:1}.contact-check-email{font-size:.85rem;color:#6b7280}.daily-report-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.5rem}.btn-secondary{padding:.75rem 1.5rem;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.loading-text{color:#6b7280;font-size:.95rem;padding:1rem 0}@media (max-width: 600px){.export-card{padding:1.5rem}.export-tabs{flex-direction:column;border-bottom:none}.export-tabs button{border-bottom:none;border-left:3px solid transparent;padding-left:1rem}.export-tabs button.active{border-bottom:none;border-left-color:#2563eb}.report-summary{grid-template-columns:1fr}}.profile-settings{max-width:560px}.profile-settings h2{margin-bottom:4px;font-size:1.4rem}.profile-desc{color:#6b7280;margin-bottom:24px;font-size:.9rem}.profile-card{background:#fff;border-radius:10px;border:1px solid #e5e7eb;padding:24px;margin-bottom:20px}.profile-card h3{font-size:1rem;font-weight:700;margin-bottom:12px;color:#111827}.profile-meta{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #f3f4f6}.profile-email{font-size:.9rem;color:#374151;font-weight:500}.profile-role-badge{background:#ede9fe;color:#7c3aed;padding:2px 10px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:capitalize}.profile-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-size:.85rem;font-weight:600;color:#374151}.form-group .optional{font-weight:400;color:#9ca3af;font-size:.8rem}.form-group input{padding:9px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;font-family:inherit;color:#111827;transition:border-color .15s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group small{font-size:.78rem;color:#9ca3af}.password-input-wrap{position:relative;display:flex;align-items:center}.password-input-wrap input{flex:1;padding-right:42px}.eye-btn{position:absolute;right:8px;background:none;border:none;padding:4px;cursor:pointer;font-size:1rem;line-height:1;color:#6b7280;display:flex;align-items:center}.form-msg{padding:8px 12px;border-radius:6px;font-size:.85rem;font-weight:500}.form-msg-success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.form-msg-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.save-btn{align-self:flex-start;padding:9px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .2s}.save-btn:hover{opacity:.9}.save-btn:disabled{opacity:.6;cursor:not-allowed}.settings-page{max-width:1200px;margin:0 auto}.settings-page h1{margin:0 0 24px;font-size:1.75rem;color:#1f2937}.settings-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:2px solid #e5e7eb;padding-bottom:0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.settings-tabs::-webkit-scrollbar{display:none}.settings-tabs button{padding:12px 16px;background:transparent;border:none;color:#6b7280;font-weight:500;cursor:pointer;transition:all .2s;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;flex-shrink:0}.settings-tabs button:hover{color:#374151}.settings-tabs button.active{color:#667eea;border-bottom-color:#667eea}.settings-content{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a}.settings-section h2{margin:0 0 20px;font-size:1.25rem;color:#1f2937}.settings-table{width:100%;border-collapse:collapse}.settings-table th,.settings-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #e5e7eb}.settings-table th{background:#f9fafb;font-weight:600;color:#374151;font-size:.875rem}.settings-table tr:hover{background:#f9fafb}.settings-table input,.settings-table select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;width:100%;box-sizing:border-box}.settings-table input:focus,.settings-table select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.add-form{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.add-form input,.add-form select{padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem}.add-form input:focus,.add-form select:focus{outline:none;border-color:#667eea}.btn{padding:10px 20px;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-small{padding:6px 12px;font-size:.85rem}.btn:disabled{opacity:.6;cursor:not-allowed}.success-message{background:#d1fae5;color:#065f46;padding:12px 16px;border-radius:8px;margin-bottom:16px}.error-message{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:16px}.empty-state{text-align:center;padding:40px;color:#6b7280}@media (max-width: 480px){.settings-tabs button{padding:10px 12px;font-size:.83rem}.settings-content{padding:14px;border-radius:8px}.settings-table th,.settings-table td{padding:10px;font-size:.85rem}}
