:root{color:#0d1b3e;--color-primary:#2d4fd6;--color-primary-dark:#1e3a8a;--color-primary-light:#e0e8ff;--color-normal:#0d9488;--color-normal-bg:#ccfbf1;--color-warning:#d97706;--color-warning-bg:#fef9c3;--color-critical:#dc2626;--color-critical-bg:#fee2e2;--color-muted:#6272a4;--color-border:#dde3f4;--color-surface:#fff;--radius-card:16px;--radius-btn:10px;--shadow-card:0 1px 3px #2d4fd60f, 0 4px 16px #1e3a8a12;--shadow-btn:0 2px 8px #1e3a8a66;background:#f0f4ff;font-family:Noto Sans JP,Inter,system-ui,-apple-system,sans-serif;line-height:1.6}*{box-sizing:border-box}body{min-height:100vh;margin:0}a{color:inherit;text-decoration:none}.app-shell-wrapper{flex-direction:column;min-height:100vh;display:flex}.app-header{color:#fff;z-index:200;background:linear-gradient(135deg,#0c1e4a 0%,#1e3a8a 50%,#2d4fd6 100%);position:sticky;top:0;box-shadow:0 2px 12px #1e3a8a73}.app-header-inner{align-items:center;max-width:1080px;height:60px;margin:0 auto;padding:0 20px;display:flex}.app-brand{color:#fff;align-items:center;gap:10px;text-decoration:none;display:flex}.app-brand-icon{filter:drop-shadow(0 1px 2px #0003);font-size:1.6rem;line-height:1}.app-brand-name{letter-spacing:.03em;font-size:1.15rem;font-weight:800;line-height:1.2}.app-brand-tagline{opacity:.8;letter-spacing:.02em;font-size:.7rem;font-weight:400;display:block}.app-shell{width:100%;max-width:1080px;margin:0 auto;padding:20px 16px 40px}.app-main{display:block}.page-stack{grid-template-columns:minmax(0,1fr);gap:18px;display:grid}.page-header{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;min-width:0;padding:18px 20px;display:flex}.page-header-text{flex-direction:column;gap:2px;display:flex}.page-title{color:#0d1b3e;letter-spacing:-.01em;margin:0;font-size:1.55rem;font-weight:800}.page-subtitle{color:var(--color-muted);margin:3px 0 0;font-size:.88rem}.page-meta{flex-wrap:wrap;gap:6px 10px;margin-top:6px;display:flex}.page-now,.page-last-fetched{color:var(--color-muted);background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;align-items:center;gap:4px;margin:0;padding:2px 8px;font-size:.8rem;display:inline-flex}.page-actions,.header-action-group{align-items:flex-start;gap:8px;display:flex}.btn{color:#fff;border-radius:var(--radius-btn);cursor:pointer;letter-spacing:.01em;box-shadow:var(--shadow-btn);white-space:nowrap;text-align:center;background:linear-gradient(135deg,#2d4fd6 0%,#1e3a8a 100%);border:none;align-items:center;gap:6px;padding:9px 18px;font-size:.88rem;font-weight:700;transition:opacity .15s,transform .1s,box-shadow .15s;display:inline-flex}.btn:hover{opacity:.88;box-shadow:0 4px 12px #1e3a8a73}.btn:active{transform:scale(.97)}.btn-secondary{background:var(--color-surface);color:var(--color-primary);border:2px solid var(--color-primary);box-shadow:none}.btn-secondary:hover{background:var(--color-primary-light);opacity:1}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);min-width:0;padding:18px 20px;overflow:hidden}.card-header-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:14px;display:flex}.card-title,.section-title{color:#0d1b3e;margin:0;font-size:1.05rem;font-weight:700}.card-title-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.muted{color:var(--color-muted);margin:0;font-size:.83rem}.device-card{border-top:3px solid var(--color-primary);transition:box-shadow .15s,transform .1s}.device-card:hover{transform:translateY(-1px);box-shadow:0 4px 20px #0000001a}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;display:grid}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-card);border-radius:14px;padding:14px 16px;position:relative;overflow:hidden}.stat-card:before{content:"";height:4px;position:absolute;top:0;left:0;right:0}.stat-card--total:before{background:#94a3b8}.stat-card--normal:before{background:var(--color-normal)}.stat-card--warning:before{background:var(--color-warning)}.stat-card--critical:before{background:var(--color-critical)}.stat-label{color:var(--color-muted);align-items:center;gap:5px;margin-bottom:4px;font-size:.78rem;font-weight:600;display:flex}.stat-label-icon{font-size:1rem;line-height:1}.stat-value{color:#0f172a;font-size:1.75rem;font-weight:800;line-height:1}.stat-card--normal .stat-value{color:var(--color-normal)}.stat-card--warning .stat-value{color:var(--color-warning)}.stat-card--critical .stat-value{color:var(--color-critical)}.devices-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px;display:grid}.data-list{border:1px solid var(--color-border);border-radius:10px;gap:0;margin:0 0 16px;display:grid;overflow:hidden}.data-list>div{border-bottom:1px solid var(--color-border);justify-content:space-between;gap:12px;padding:9px 12px;display:flex}.data-list>div:last-child{border-bottom:none}.data-list>div:nth-child(2n){background:#f8fafc}.data-list dt{color:var(--color-muted);font-size:.84rem;font-weight:500}.data-list dd{text-align:right;margin:0;font-size:.9rem;font-weight:600}.device-id-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.device-color-picker{cursor:pointer;justify-content:center;align-items:center;display:inline-flex;position:relative}.device-color-chip{color:#fff;border:2.5px solid #fff;border-radius:999px;justify-content:center;align-items:center;width:26px;height:26px;font-size:.7rem;font-weight:800;display:inline-flex;box-shadow:0 1px 5px #0000004d}.device-color-picker input[type=color]{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.status-badge{white-space:nowrap;border-radius:999px;align-items:center;gap:5px;padding:4px 12px;font-size:.78rem;font-weight:700;display:inline-flex}.status-badge:before{content:"";border-radius:50%;flex-shrink:0;width:7px;height:7px}.status-normal{background:var(--color-normal-bg);color:#14532d}.status-normal:before{background:var(--color-normal);box-shadow:0 0 0 2px #16a34a40}.status-warning{background:var(--color-warning-bg);color:#78350f}.status-warning:before{background:var(--color-warning);box-shadow:0 0 0 2px #d9770640}.status-critical{background:var(--color-critical-bg);color:#7f1d1d}.status-critical:before{background:var(--color-critical);box-shadow:0 0 0 2px #dc262640}.text-normal{color:var(--color-normal);font-weight:600}.text-warning{color:var(--color-warning);font-weight:600}.text-critical{color:var(--color-critical);font-weight:600}.state-box{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);text-align:center;color:var(--color-muted);flex-direction:column;align-items:center;gap:10px;padding:32px 20px;font-size:.95rem;display:flex}.state-error{color:#7f1d1d;background:#fff5f5;border-color:#fca5a5}.state-error p{margin:0;font-weight:600}.state-icon{font-size:2rem;line-height:1}@keyframes spin{to{transform:rotate(360deg)}}.loading-spinner{border:3px solid var(--color-primary-light);border-top-color:var(--color-primary);border-radius:50%;flex-shrink:0;width:32px;height:32px;animation:.8s linear infinite spin}.map-box{height:340px}.leaflet-map{border-radius:10px;width:100%;height:100%;overflow:hidden}.device-overview-marker{background:0 0;border:0}.device-overview-marker span{color:#fff;background:#2d4fd6;border:2.5px solid #fff;border-radius:999px;justify-content:center;align-items:center;width:30px;height:30px;font-size:.78rem;font-weight:800;display:inline-flex;box-shadow:0 2px 8px #00000059}.device-map-legend{gap:7px;margin:14px 0 0;padding:0;list-style:none;display:grid}.device-map-legend li{flex-wrap:wrap;align-items:center;gap:8px;font-size:.88rem;display:flex}.device-map-legend-index{color:#fff;border:2px solid #fff;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.72rem;font-weight:800;display:inline-flex;box-shadow:0 1px 4px #00000040}.table-wrap{border:1px solid var(--color-border);border-radius:10px;max-width:100%;margin-top:12px;overflow:auto}.history-table{border-collapse:collapse;width:100%;font-size:.88rem}.history-table thead{background:#f1f5f9;position:sticky;top:0}.history-table th{text-align:left;white-space:nowrap;color:#475569;letter-spacing:.02em;text-transform:uppercase;border-bottom:2px solid var(--color-border);padding:10px 12px;font-size:.8rem;font-weight:700}.history-table td{text-align:left;white-space:nowrap;color:#334155;border-bottom:1px solid #f1f5f9;padding:9px 12px}.history-table tbody tr:hover{background:#f8fafc}.history-table tbody tr:last-child td{border-bottom:none}.app-header-nav{align-items:center;gap:6px;margin-left:auto;display:flex}.app-nav-link{color:#ffffffe0;border-radius:8px;padding:6px 12px;font-size:.85rem;font-weight:600;text-decoration:none;transition:background .15s}.app-nav-link:hover{color:#fff;background:#ffffff26}.app-account{color:#fff;background:#ffffff1f;border:1px solid #fff3;border-radius:999px;align-items:center;gap:6px;padding:5px 12px 5px 8px;font-size:.82rem;font-weight:600;display:flex}.app-account-icon{font-size:1rem;line-height:1}.app-account-name{text-overflow:ellipsis;white-space:nowrap;max-width:120px;overflow:hidden}.app-logout-btn{color:#ffffffe6;cursor:pointer;white-space:nowrap;background:#ffffff1a;border:1px solid #ffffff4d;border-radius:8px;padding:6px 12px;font-size:.82rem;font-weight:600;transition:background .15s}.app-logout-btn:hover{color:#fff;background:#ffffff38}.login-page{background:linear-gradient(160deg,#0c1e4a 0%,#1e3a8a 45%,#2d4fd6 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px 16px;display:flex}.login-card{background:#fff;border-radius:24px;width:100%;max-width:400px;padding:40px 36px;box-shadow:0 24px 60px #00000040,0 4px 16px #0000001a}.login-brand{text-align:center;margin-bottom:32px}.login-brand-icon{filter:drop-shadow(0 2px 6px #1e3a8a4d);margin-bottom:10px;font-size:3rem;line-height:1;display:block}.login-brand-name{color:#0d1b3e;letter-spacing:-.01em;margin:0 0 4px;font-size:1.55rem;font-weight:800}.login-brand-tagline{color:var(--color-muted);margin:0;font-size:.82rem}.login-form{flex-direction:column;gap:18px;display:flex}.login-field{flex-direction:column;gap:6px;display:flex}.login-label{color:#334155;letter-spacing:.02em;font-size:.83rem;font-weight:700}.login-input{border:1.5px solid var(--color-border);color:#0d1b3e;background:#f8faff;border-radius:10px;outline:none;padding:11px 14px;font-family:inherit;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.login-input::placeholder{color:#94a3b8}.login-input:focus{border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 3px #2d4fd61f}.login-submit-btn{border-radius:12px;justify-content:center;width:100%;margin-top:4px;padding:13px;font-size:1rem}.login-note{text-align:center;color:#94a3b8;margin:18px 0 0;font-size:.75rem}.admin-badge{background:var(--color-primary-light);color:var(--color-primary-dark);border-radius:999px;padding:3px 12px;font-size:.78rem;font-weight:700}.admin-count{color:var(--color-muted);background:#f1f5f9;border-radius:999px;padding:3px 10px;font-size:.78rem;font-weight:600}.admin-dummy-note{text-align:center;color:#94a3b8;margin:0;padding:4px 0 8px;font-size:.78rem}.map-mode-toggle{border:1.5px solid var(--color-border);border-radius:10px;display:inline-flex;overflow:hidden}.map-mode-btn{background:var(--color-surface);color:var(--color-muted);cursor:pointer;white-space:nowrap;border:none;padding:6px 13px;font-family:inherit;font-size:.82rem;font-weight:600;transition:background .15s,color .15s}.map-mode-btn+.map-mode-btn{border-left:1.5px solid var(--color-border)}.map-mode-btn:hover{background:var(--color-primary-light);color:var(--color-primary-dark)}.map-mode-btn--active{background:var(--color-primary);color:#fff}.map-mode-btn--active:hover{background:var(--color-primary-dark);color:#fff}.status-inactive{color:#64748b;background:#f1f5f9}.status-inactive:before{background:#94a3b8}.text-inactive{color:#94a3b8}.device-awaiting-data{color:var(--color-muted);align-items:center;gap:6px;padding:10px 4px;font-size:.85rem;display:flex}.device-card--stale{opacity:.6;filter:grayscale(.4)}.device-card--stale:hover{opacity:.8;filter:grayscale(.2)}.battery-wrap{align-items:center;gap:5px;display:inline-flex}.battery-svg{color:#94a3b8;flex-shrink:0;display:block}.battery-label{font-size:.88rem;font-weight:700;line-height:1}.battery-warning-tag{color:#92400e;vertical-align:middle;white-space:nowrap;background:#fef3c7;border:1px solid #fcd34d;border-radius:999px;margin-left:6px;padding:1px 8px;font-size:.72rem;font-weight:700;display:inline-block}.device-toolbar{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.device-search{border:1.5px solid var(--color-border);color:#0d1b3e;background:var(--color-surface);border-radius:10px;outline:none;flex:200px;min-width:0;padding:9px 14px;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.device-search:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2d4fd61a}.device-sort-group{gap:4px;display:flex}.device-sort-select{border:1.5px solid var(--color-border);color:#0d1b3e;background:var(--color-surface);cursor:pointer;border-radius:10px;outline:none;padding:9px 12px;font-family:inherit;font-size:.88rem;transition:border-color .15s}.device-sort-select:focus{border-color:var(--color-primary)}.device-sort-dir-btn{border:1.5px solid var(--color-border);background:var(--color-surface);color:#0d1b3e;cursor:pointer;border-radius:10px;padding:9px 13px;font-size:1rem;font-weight:700;line-height:1;transition:background .15s,border-color .15s}.device-sort-dir-btn:hover{background:var(--color-primary-light);border-color:var(--color-primary)}.card-footer-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-top:4px;display:flex}.map-visibility-toggle{cursor:pointer;color:var(--color-muted);-webkit-user-select:none;user-select:none;align-items:center;gap:6px;font-size:.84rem;display:inline-flex}.map-visibility-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.map-visibility-toggle:hover{color:var(--color-primary)}.history-filter-bar{border:1px solid var(--color-border);box-sizing:border-box;background:#f8faff;border-radius:10px;flex-wrap:wrap;align-items:flex-end;gap:10px;max-width:100%;margin-bottom:4px;padding:12px 14px;display:flex}.history-filter-field{flex-direction:column;gap:4px;display:flex}.history-filter-label{color:var(--color-muted);letter-spacing:.02em;font-size:.75rem;font-weight:700}.history-filter-input{border:1.5px solid var(--color-border);color:#0d1b3e;background:var(--color-surface);border-radius:8px;outline:none;padding:7px 10px;font-family:inherit;font-size:.85rem;transition:border-color .15s}.history-filter-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2d4fd61a}.history-filter-sep{color:var(--color-muted);padding-bottom:6px;font-size:1rem}.history-filter-reset{align-self:flex-end;padding:7px 14px;font-size:.84rem}@media (width<=768px){.app-header-inner{padding:0 14px}.devices-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.history-filter-bar{gap:8px}}@media (width<=640px){.app-shell{padding:12px 12px 40px}.page-stack{gap:12px}.app-header-inner{height:50px}.app-brand-tagline{display:none}.app-brand-name{font-size:1rem}.app-brand-icon{font-size:1.35rem}.app-account-name{display:none}.app-nav-link{padding:5px 8px;font-size:.78rem}.app-account{padding:4px 8px}.app-logout-btn{padding:5px 10px;font-size:.78rem}.page-header{flex-direction:column;gap:10px;padding:14px 16px}.page-actions,.header-action-group{justify-content:flex-end;width:100%}.page-title{font-size:1.2rem}.page-meta{gap:6px}.page-now,.page-last-fetched{font-size:.75rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.stat-value{font-size:1.4rem}.stat-label{font-size:.72rem}.device-toolbar{flex-direction:column;align-items:stretch;gap:8px}.device-search{flex:none;width:100%}.device-sort-group{width:100%}.device-sort-select{flex:1}.card{padding:14px}.devices-grid{grid-template-columns:1fr}.card-footer-row{flex-direction:column;align-items:stretch;gap:8px}.card-footer-row .btn{justify-content:center;width:100%}.map-box{height:260px}.map-mode-toggle{flex-shrink:0}.map-mode-btn{padding:5px 10px;font-size:.76rem}.history-filter-bar{flex-direction:column;align-items:stretch;gap:8px}.history-filter-sep{display:none}.history-filter-field,.history-filter-input{width:100%}.history-filter-reset{align-self:flex-start}.data-list dt,.data-list dd{font-size:.82rem}.section-title,.card-title{font-size:.95rem}.history-table th,.history-table td{padding:8px 10px;font-size:.8rem}.login-card{padding:28px 20px}.login-brand-name{font-size:1.3rem}.admin-count,.admin-badge{font-size:.72rem}}.app-init-screen{background:linear-gradient(160deg,#0c1e4a 0%,#1e3a8a 45%,#2d4fd6 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.app-init-spinner{border:4px solid #ffffff40;border-top-color:#fff;border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.app-nav-link--active{color:#fff;background:#fff3}.app-account{text-decoration:none}.app-account--active{background:#ffffff38;border-color:#fff6}.app-account-dev-badge{color:#0d1b3e;letter-spacing:.04em;background:#f59e0b;border-radius:999px;margin-left:2px;padding:1px 6px;font-size:.62rem;font-weight:800}.login-error{background:var(--color-critical-bg);color:#7f1d1d;border:1px solid #fca5a5;border-radius:10px;margin:0;padding:10px 14px;font-size:.85rem;font-weight:600}.entity-card{border-top:3px solid var(--color-primary);transition:box-shadow .15s,transform .1s}.entity-card:hover{transform:translateY(-1px);box-shadow:0 4px 20px #0000001a}.entity-card--stale{opacity:.6;filter:grayscale(.4)}.entity-type-icon{flex-shrink:0;font-size:1.35rem;line-height:1}.entity-marker-num{background:var(--color-primary);color:#fff;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.7rem;font-weight:800;display:inline-flex}.entity-meta-row{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.entity-type-badge{background:var(--color-primary-light);color:var(--color-primary-dark);border-radius:999px;padding:2px 8px;font-size:.72rem;font-weight:700}.entity-visibility-badge{color:var(--color-muted);background:#f1f5f9;border-radius:999px;align-items:center;gap:3px;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-flex}.entity-no-device-badge{color:#92400e;white-space:nowrap;background:#fef3c7;border:1px solid #fcd34d;border-radius:999px;padding:3px 10px;font-size:.72rem;font-weight:700}.entity-device-link{color:var(--color-primary);text-underline-offset:2px;font-weight:600;text-decoration:underline}.entity-device-link:hover{color:var(--color-primary-dark)}.entity-map-link{color:var(--color-primary);font-size:.8rem;font-weight:600}.entity-form,.claim-form{flex-direction:column;gap:20px;display:flex}.form-field{flex-direction:column;gap:6px;display:flex}.form-label{color:#334155;letter-spacing:.02em;font-size:.85rem;font-weight:700}.form-required{color:var(--color-critical);margin-left:2px}.form-input,.form-select{border:1.5px solid var(--color-border);color:#0d1b3e;background:#f8faff;border-radius:10px;outline:none;padding:10px 14px;font-family:inherit;font-size:.92rem;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus{border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 3px #2d4fd61a}.form-hint{color:var(--color-muted);font-size:.78rem}.form-error{color:var(--color-critical);background:var(--color-critical-bg);border:1px solid #fca5a5;border-radius:8px;margin:0;padding:8px 12px;font-size:.84rem;font-weight:600}.form-success{color:#14532d;background:var(--color-normal-bg);border:1px solid #86efac;border-radius:8px;margin:0;padding:8px 12px;font-size:.84rem;font-weight:600}.form-actions{flex-wrap:wrap;gap:10px;margin-top:4px;display:flex}.entity-type-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px;display:grid}.entity-type-option{border:1.5px solid var(--color-border);cursor:pointer;text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;transition:border-color .15s,background .15s;display:flex}.entity-type-option input[type=radio]{opacity:0;width:0;height:0;position:absolute}.entity-type-option:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.entity-type-option--selected{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:0 0 0 2px #2d4fd633}.entity-type-option-icon{font-size:1.6rem;line-height:1}.entity-type-option-label{color:#334155;font-size:.8rem;font-weight:700}.entity-visibility-group{flex-direction:column;gap:8px;display:flex}.entity-visibility-option{border:1.5px solid var(--color-border);cursor:pointer;border-radius:10px;align-items:flex-start;gap:10px;padding:12px 14px;transition:border-color .15s,background .15s;display:flex}.entity-visibility-option input[type=radio]{opacity:0;width:0;height:0;position:absolute}.entity-visibility-option span:first-of-type{flex-shrink:0;font-size:.9rem;font-weight:700}.entity-visibility-option:hover,.entity-visibility-option--selected{border-color:var(--color-primary);background:var(--color-primary-light)}.claim-search-row{gap:8px;display:flex}.claim-search-row .form-input{flex:1}.claim-result-box{border:1.5px solid var(--color-border);background:#f8fafc;border-radius:10px;padding:14px 16px}.claim-result-box--ok{background:var(--color-normal-bg);border-color:#86efac}.claim-result-box--ng{background:var(--color-critical-bg);border-color:#fca5a5}.claim-result-device-id{color:#0d1b3e;margin:0 0 4px;font-family:monospace;font-size:1.1rem;font-weight:700}.claim-result-status{color:var(--color-muted);margin:0 0 4px;font-size:.85rem}.claim-result-claimable{color:var(--color-normal);margin:4px 0 0;font-size:.85rem;font-weight:700}.claim-result-not-claimable{color:var(--color-critical);margin:4px 0 0;font-size:.85rem;font-weight:700}.owned-devices-list{border:1px solid var(--color-border);border-radius:10px;flex-direction:column;gap:0;display:flex;overflow:hidden}.owned-device-row{border-bottom:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.owned-device-row:last-child{border-bottom:none}.owned-device-row:nth-child(2n){background:#f8fafc}.owned-device-info{flex-direction:column;gap:3px;min-width:0;display:flex}.owned-device-name{color:#0d1b3e;font-size:.95rem;font-weight:700}.owned-device-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.owned-device-entity-badge{color:var(--color-muted);align-items:center;gap:4px;font-size:.78rem;display:inline-flex}.owned-device-status{align-items:center;gap:10px;font-size:.8rem;display:flex}.owned-device-actions{flex-shrink:0;gap:6px;display:flex}.danger-zone{border-color:#fca5a5}.danger-zone-title{color:var(--color-critical)}.btn-danger{color:#fff;background:linear-gradient(135deg,#dc2626 0%,#991b1b 100%);box-shadow:0 2px 8px #dc262666}.btn-danger:hover{opacity:.88}.code-input-wrap{flex-direction:column;gap:6px;display:flex}.code-input-row{align-items:center;gap:6px;display:flex}.code-input-segments{flex-wrap:nowrap;align-items:center;gap:0;display:flex}.code-input-segment-wrap{align-items:center;display:flex}.code-input-sep{color:var(--color-muted);-webkit-user-select:none;user-select:none;padding:0 4px;font-family:Courier New,Courier,monospace;font-size:1.3rem;font-weight:700}.code-input-field{letter-spacing:.12em;text-transform:uppercase;border-radius:10px;flex:1;padding:11px 16px;font-family:Courier New,Courier,Noto Sans Mono,monospace;font-size:1.25rem;font-weight:700;transition:border-color .15s,box-shadow .15s,background .15s}.code-input-segment{text-align:center;flex:none}.code-input-field::placeholder{color:#94a3b8;letter-spacing:.05em;font-weight:400}.code-input-field--complete{border-color:var(--color-normal);background:var(--color-normal-bg);box-shadow:0 0 0 3px #0d94881f}.code-toggle-btn{border:1.5px solid var(--color-border);background:var(--color-surface);cursor:pointer;border-radius:10px;flex-shrink:0;padding:9px 11px;font-size:1rem;line-height:1;transition:background .15s}.code-toggle-btn:hover{background:var(--color-primary-light);border-color:var(--color-primary)}.code-input-meta{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.code-input-counter{color:var(--color-muted);font-size:.78rem;font-weight:500}.code-input-counter--warn{color:var(--color-warning);font-weight:700}.code-input-counter--ok{color:var(--color-normal);font-weight:700}.code-input-allowed{color:#94a3b8;letter-spacing:.06em;font-family:Courier New,Courier,monospace;font-size:.7rem}.claim-steps{flex-wrap:wrap;align-items:center;gap:8px;margin:16px 0 20px;display:flex}.claim-step{border:1.5px solid var(--color-border);color:var(--color-muted);background:#f8fafc;border-radius:999px;align-items:center;gap:7px;padding:6px 12px;font-size:.82rem;font-weight:600;display:flex}.claim-step--active{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary-dark)}.claim-step--done{border-color:var(--color-normal);background:var(--color-normal-bg);color:#14532d}.claim-step-num{color:#fff;background:currentColor;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:.72rem;font-weight:800;display:inline-flex}.claim-step--active .claim-step-num{background:var(--color-primary)}.claim-step--done .claim-step-num{background:var(--color-normal)}.claim-step-sep{color:var(--color-muted);font-size:.9rem}.claim-doc-hint{border:1px solid var(--color-border);background:#f8faff;border-radius:10px;align-items:flex-start;gap:12px;padding:12px 14px;display:flex}.claim-doc-hint-icon{flex-shrink:0;margin-top:1px;font-size:1.4rem;line-height:1}.claim-doc-hint-title{color:#0d1b3e;margin:0 0 3px;font-size:.88rem;font-weight:700}.claim-doc-hint-sub{color:var(--color-muted);margin:0;font-size:.78rem}.claim-result-header{align-items:center;gap:12px;margin-bottom:8px;display:flex}.claim-result-row{align-items:center;gap:10px;margin-bottom:8px;font-size:.85rem;display:flex}.claim-result-label{color:var(--color-muted);text-transform:uppercase;letter-spacing:.04em;min-width:80px;font-size:.75rem;font-weight:700}.claim-result-device-id{letter-spacing:.12em;color:#0d1b3e;font-family:Courier New,Courier,monospace;font-size:1.3rem;font-weight:800}.owned-device-id-code{letter-spacing:.06em;color:var(--color-muted);background:#f1f5f9;border-radius:5px;padding:1px 6px;font-family:Courier New,Courier,monospace;font-size:.82rem;font-weight:600}.assign-device-form{flex-direction:column;gap:12px;margin-top:8px;display:flex}@media (width<=400px){.app-brand-name{font-size:.9rem}.app-header-nav{gap:4px}.app-nav-link{padding:5px 6px;font-size:.72rem}.page-title{font-size:1.05rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:1.2rem}.map-box{height:220px}.map-mode-btn{padding:4px 8px;font-size:.7rem}.page-now,.page-last-fetched{font-size:.7rem}}.device-overview-marker--stale{opacity:.35;filter:grayscale(.7)}.entity-overview-card{flex-direction:column;gap:0;display:flex}.entity-mini-stats{flex-wrap:wrap;gap:20px;padding:4px 0 2px;display:flex}.entity-mini-stat{color:var(--color-muted);align-items:center;gap:6px;font-size:.82rem;display:flex}.entity-mini-stat-label{font-weight:500}.entity-mini-stat-value{color:#0f172a;font-size:1rem;font-weight:800}.entity-mini-stat--with-device .entity-mini-stat-value{color:var(--color-normal)}.entity-mini-stat--no-device .entity-mini-stat-value,.entity-mini-stat--warning .entity-mini-stat-value{color:var(--color-warning)}.entity-mini-stat--critical .entity-mini-stat-value{color:var(--color-critical)}.notification-area{flex-direction:column;gap:10px;display:flex}.notification-area-title{margin-bottom:2px}.alert-card{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-card);border-left:4px solid var(--color-warning);border-radius:12px;align-items:center;gap:12px;padding:12px 16px;display:flex}.alert-card--critical{border-left-color:var(--color-critical);background:var(--color-critical-bg)}.alert-card--warning{border-left-color:var(--color-warning);background:var(--color-warning-bg)}.alert-card-icon{flex-shrink:0;font-size:1.25rem;line-height:1}.alert-card-body{flex:1;min-width:0}.alert-card-title{color:#92400e;margin:0 0 2px;font-size:.9rem;font-weight:700}.alert-card--critical .alert-card-title{color:var(--color-critical)}.alert-card-sub{color:var(--color-muted);margin:0;font-size:.78rem;font-weight:500}.alert-card-link{color:var(--color-primary);white-space:nowrap;flex-shrink:0;font-size:.8rem;font-weight:700}.alert-card-link:hover{color:var(--color-primary-dark);text-decoration:underline}.area-notification-card{box-shadow:var(--shadow-card);background:#ecfdf5;border:1px solid #6ee7b7;border-left:4px solid #059669;border-radius:12px;align-items:center;gap:10px;padding:10px 16px;font-size:.9rem;display:flex}.area-notification-icon{flex-shrink:0;font-size:1.2rem;line-height:1}.area-notification-text{color:#065f46;font-weight:600}.area-list{border:1px solid var(--color-border);border-radius:10px;margin:0;padding:0;list-style:none;overflow:hidden}.area-list-item{border-bottom:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:11px 14px;display:flex}.area-list-item:last-child{border-bottom:none}.area-list-item:nth-child(2n){background:#f8fafc}.area-list-item-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.area-list-item-name{color:#0d1b3e;font-size:.95rem;font-weight:700}.area-list-item-meta{color:var(--color-muted);font-size:.78rem}.area-list-item-actions{flex-shrink:0;gap:6px;display:flex}.area-edit-btn,.area-delete-btn{flex-shrink:0;padding:5px 12px;font-size:.78rem}.area-map-manage-link-row{text-align:right;padding:6px 2px 2px}.area-map-manage-link{color:var(--color-primary);text-underline-offset:2px;font-size:.84rem;font-weight:600;text-decoration:underline}.area-map-manage-link:hover{color:var(--color-primary-dark)}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0d1b3e8c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-panel{background:var(--color-surface);border-radius:20px;flex-direction:column;width:100%;max-width:560px;max-height:92vh;display:flex;overflow-y:auto;box-shadow:0 24px 60px #00000047,0 4px 16px #0000001a}.modal-header{border-bottom:1px solid var(--color-border);background:var(--color-surface);z-index:1;border-radius:20px 20px 0 0;justify-content:space-between;align-items:center;padding:18px 22px 14px;display:flex;position:sticky;top:0}.modal-title{color:#0d1b3e;margin:0;font-size:1.1rem;font-weight:800}.modal-close-btn{border:1.5px solid var(--color-border);cursor:pointer;width:32px;height:32px;color:var(--color-muted);background:0 0;border-radius:8px;justify-content:center;align-items:center;font-size:.9rem;transition:background .15s,border-color .15s;display:flex}.modal-close-btn:hover{color:#0d1b3e;background:#f1f5f9;border-color:#94a3b8}.modal-body{flex-direction:column;gap:16px;padding:18px 22px 22px;display:flex}.modal-actions{margin-top:4px}.area-create-map-box{border:1.5px solid var(--color-border);cursor:crosshair;border-radius:10px;height:260px;overflow:hidden}.area-latlon-row{gap:10px;display:flex}.area-radius-slider{width:100%;accent-color:var(--color-primary);cursor:pointer;height:6px;margin:4px 0}.area-radius-labels{color:var(--color-muted);justify-content:space-between;margin-top:2px;font-size:.75rem;display:flex}.geo-search-row{gap:8px;display:flex}.geo-search-row .form-input{flex:1;min-width:0}.geo-search-btn{white-space:nowrap;flex-shrink:0;padding:9px 16px;font-size:.88rem}.geo-search-error{color:var(--color-warning);margin:4px 0 0;font-size:.82rem;font-weight:600}.geo-results-list{border:1.5px solid var(--color-border);background:var(--color-surface);border-radius:10px;margin:4px 0 0;padding:0;list-style:none;overflow:hidden;box-shadow:0 4px 16px #0000001a}.geo-result-item{text-align:left;border:none;border-bottom:1px solid var(--color-border);color:#0d1b3e;cursor:pointer;white-space:normal;word-break:break-all;background:0 0;width:100%;padding:9px 13px;font-family:inherit;font-size:.84rem;transition:background .12s;display:block}.geo-result-item:hover{background:var(--color-primary-light);color:var(--color-primary-dark)}.geo-results-close{text-align:center;width:100%;color:var(--color-muted);cursor:pointer;background:#f8fafc;border:none;padding:7px 13px;font-family:inherit;font-size:.78rem;transition:background .12s;display:block}.geo-results-close:hover{color:#334155;background:#f1f5f9}@media (width<=640px){.modal-panel{border-radius:14px;max-height:96vh}.modal-header{border-radius:14px 14px 0 0;padding:14px 16px 12px}.modal-body{padding:14px 16px 20px}.area-latlon-row{flex-direction:column;gap:8px}.area-list-item{flex-direction:column;align-items:flex-start;gap:8px}.area-list-item-actions{align-self:flex-end}}
