:root{--blue: #0075a9;--blue-dark: #005a82;--blue-darker: #003d5c;--blue-light: #e0f2fa;--blue-glow: rgba(0,117,169,.15);--bg: #0a0f1a;--bg-2: #0f1626;--bg-3: #151e2e;--surface: #1a2438;--surface-2: #1f2d42;--border: rgba(0,117,169,.2);--border-bright: rgba(0,117,169,.4);--text: #e8f4fa;--text-muted: #7a9ab5;--text-dim: #4a6a82;--success: #00d4aa;--success-bg: rgba(0,212,170,.1);--warning: #f5a623;--warning-bg: rgba(245,166,35,.1);--danger: #ff4757;--danger-bg: rgba(255,71,87,.1);--sensor-color: #00d4aa;--device-color: #f5a623;--mono: "Space Mono", monospace;--sans: "Inter", sans-serif;--radius: 8px;--radius-lg: 12px;--shadow: 0 2px 8px rgba(0,0,0,.4);--shadow-blue: 0 4px 20px rgba(0,117,169,.2)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:13px;line-height:1.5}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:var(--bg-2)}::-webkit-scrollbar-thumb{background:var(--blue-dark);border-radius:2px}.layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--bg-2);display:flex;flex-direction:column;position:fixed;height:100vh;overflow-y:auto;z-index:100;border-right:1px solid var(--border)}.sidebar-logo{padding:20px 20px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.sidebar-logo img{width:36px;height:auto;filter:brightness(1.1)}.sidebar-logo-text{display:flex;flex-direction:column}.sidebar-logo-text span{font-family:var(--mono);font-size:9px;color:var(--blue);letter-spacing:.1em;text-transform:uppercase}.sidebar-logo-text h2{font-size:13px;font-weight:600;color:var(--text);margin-top:1px}.sidebar nav{padding:10px 0;flex:1}.nav-section{padding:12px 16px 4px;font-size:9px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.12em}.nav-link{display:flex;align-items:center;gap:10px;padding:9px 16px;color:var(--text-muted);text-decoration:none;font-size:13px;font-weight:500;transition:all .15s;border-left:2px solid transparent;margin:1px 0}.nav-link:hover{color:var(--text);background:var(--blue-glow)}.nav-link.active{color:var(--blue);border-left-color:var(--blue);background:var(--blue-glow)}.nav-link svg{opacity:.7;flex-shrink:0}.nav-link.active svg{opacity:1}.sidebar-footer{padding:14px 16px;border-top:1px solid var(--border);font-size:11px}.sidebar-footer .user-name{color:var(--text);font-weight:500;margin-bottom:2px}.sidebar-footer .user-email{color:var(--text-dim);margin-bottom:10px}.main-content{margin-left:240px;flex:1;padding:24px;min-height:100vh}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-header h1{font-size:18px;font-weight:700;color:var(--text)}.page-title-sub{font-size:12px;color:var(--text-muted);margin-top:2px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow)}.card-title{font-size:10px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}.card+.card{margin-top:16px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:20px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--blue),transparent)}.stat-value{font-family:var(--mono);font-size:28px;font-weight:700;color:var(--blue);line-height:1}.stat-label{font-size:11px;color:var(--text-muted);margin-top:6px}.stat-card.success .stat-value{color:var(--success)}.stat-card.success:before{background:linear-gradient(90deg,var(--success),transparent)}.stat-card.danger .stat-value{color:var(--danger)}.stat-card.danger:before{background:linear-gradient(90deg,var(--danger),transparent)}.stat-card.warning .stat-value{color:var(--warning)}.stat-card.warning:before{background:linear-gradient(90deg,var(--warning),transparent)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:12px}th{text-align:left;padding:8px 12px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);border-bottom:1px solid var(--border);white-space:nowrap}td{padding:10px 12px;border-bottom:1px solid rgba(0,117,169,.08);color:var(--text-muted)}td strong{color:var(--text)}tr:hover td{background:var(--blue-glow)}tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:100px;font-size:10px;font-weight:600}.badge-online{background:var(--success-bg);color:var(--success)}.badge-offline{background:var(--danger-bg);color:var(--danger)}.badge-product{background:var(--blue-glow);color:var(--blue);border:1px solid var(--border)}.badge-sensor{background:rgba(0,212,170,.1);color:var(--sensor-color)}.badge-device{background:rgba(245,166,35,.1);color:var(--device-color)}.badge-provisioned{background:rgba(122,154,181,.1);color:var(--text-muted)}.badge-active{background:var(--success-bg);color:var(--success)}.badge-inactive{background:var(--warning-bg);color:var(--warning)}.badge-decommissioned{background:var(--danger-bg);color:var(--danger)}.badge-warn{background:var(--warning-bg);color:var(--warning)}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius);font-size:12px;font-weight:600;cursor:pointer;border:none;text-decoration:none;transition:all .15s;font-family:var(--sans);white-space:nowrap}.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{background:var(--blue-dark)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn-ghost:hover{border-color:var(--border-bright);color:var(--text)}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(255,71,87,.3)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-success{background:var(--success-bg);color:var(--success);border:1px solid rgba(0,212,170,.3)}.btn-sm{padding:5px 10px;font-size:11px}.btn-xs{padding:3px 8px;font-size:10px}.btn:disabled{opacity:.4;cursor:not-allowed}.form-group{margin-bottom:14px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}label{display:block;font-size:10px;font-weight:700;color:var(--text-dim);margin-bottom:5px;text-transform:uppercase;letter-spacing:.06em}label .req{color:var(--blue)}input,select,textarea{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:12px;font-family:var(--sans);background:var(--bg-3);color:var(--text);outline:none;transition:border-color .15s}input:focus,select:focus,textarea:focus{border-color:var(--blue);background:var(--bg-2)}input::placeholder,textarea::placeholder{color:var(--text-dim)}select option{background:var(--bg-3)}input[type=checkbox]{width:auto;accent-color:var(--blue);cursor:pointer}input[type=file]{padding:6px;cursor:pointer}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--surface);border:1px solid var(--border-bright);border-radius:var(--radius-lg);padding:24px;width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.modal-lg{width:700px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:15px;font-weight:700;color:var(--text)}.param-row{display:grid;grid-template-columns:44px 1fr 80px 90px 80px 80px 60px;gap:6px;align-items:center;padding:5px 0;border-bottom:1px solid rgba(0,117,169,.06)}.param-row:last-child{border-bottom:none}.param-idx{font-family:var(--mono);font-size:10px;color:var(--text-dim);text-align:right;padding-right:4px}.param-type-toggle{display:flex;border-radius:4px;overflow:hidden;border:1px solid var(--border)}.param-type-toggle button{padding:3px 6px;font-size:9px;font-weight:700;border:none;cursor:pointer;transition:all .15s;font-family:var(--sans)}.param-type-toggle button.sensor{background:transparent;color:var(--text-dim)}.param-type-toggle button.sensor.active{background:var(--success-bg);color:var(--sensor-color)}.param-type-toggle button.device{background:transparent;color:var(--text-dim)}.param-type-toggle button.device.active{background:var(--warning-bg);color:var(--device-color)}.api-key-display{display:flex;align-items:center;gap:8px;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px}.api-key-display code{font-family:var(--mono);font-size:11px;color:var(--blue);flex:1;word-break:break-all}.range-bar{height:3px;background:var(--border);border-radius:2px;margin-top:4px;position:relative;overflow:hidden}.range-bar-fill{height:100%;background:var(--success);border-radius:2px;transition:width .3s}.range-bar-fill.warn{background:var(--warning)}.range-bar-fill.danger{background:var(--danger)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,var(--blue-glow) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.login-card{background:var(--surface);border:1px solid var(--border-bright);border-radius:var(--radius-lg);padding:40px;width:380px;position:relative;z-index:1;box-shadow:var(--shadow-blue)}.login-logo{text-align:center;margin-bottom:28px}.login-logo img{width:52px;margin-bottom:10px;filter:brightness(1.1)}.login-logo h1{font-size:18px;font-weight:700;color:var(--text)}.login-logo span{font-family:var(--mono);font-size:9px;color:var(--blue);display:block;letter-spacing:.15em;text-transform:uppercase;margin-bottom:4px}.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:18px;gap:2px}.tab{padding:8px 14px;font-size:12px;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--blue);border-bottom-color:var(--blue)}.callout{padding:10px 14px;border-radius:var(--radius);font-size:12px;margin-bottom:14px}.callout-info{background:var(--blue-glow);border:1px solid var(--border);color:var(--text-muted)}.callout-warn{background:var(--warning-bg);border:1px solid rgba(245,166,35,.3);color:var(--warning)}.callout-success{background:var(--success-bg);border:1px solid rgba(0,212,170,.3);color:var(--success)}.callout-danger{background:var(--danger-bg);border:1px solid rgba(255,71,87,.3);color:var(--danger)}.flex{display:flex;align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.text-muted{color:var(--text-muted)}.text-dim{color:var(--text-dim)}.text-mono{font-family:var(--mono)}.text-blue{color:var(--blue)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.error-msg{color:var(--danger);font-size:11px;margin-top:6px}.w-full{width:100%}.leaflet-container{background:var(--bg-3)!important;border-radius:var(--radius)}.leaflet-popup-content-wrapper{background:var(--surface);color:var(--text);border:1px solid var(--border-bright);border-radius:var(--radius);box-shadow:var(--shadow-blue)}.leaflet-popup-tip{background:var(--surface)}.leaflet-popup-content{margin:12px 14px;font-family:var(--sans)}
