.layout{display:flex;min-height:100vh}.sidebar{background:linear-gradient(180deg,#1a1a2e,#16213e);color:#fff;display:flex;flex-direction:column;height:100vh;position:fixed;width:260px;z-index:100}.sidebar-header{border-bottom:1px solid #ffffff1a;padding:1.5rem}.sidebar-header h1{font-size:1.25rem;font-weight:700;margin:0}.sidebar-header .subtitle{color:#fff9;font-size:.75rem;letter-spacing:1px;text-transform:uppercase}.sidebar-nav{flex:1 1;overflow-y:auto;padding:1rem 0}.nav-item{align-items:center;color:#ffffffb3;display:flex;gap:.75rem;padding:.875rem 1.5rem;text-decoration:none;transition:all .2s}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:#ffffff26;border-left:3px solid #4ecdc4;color:#fff}.nav-icon{font-size:1.25rem}.nav-label{font-size:.9rem;font-weight:500}.sidebar-footer{border-top:1px solid #ffffff1a;padding:1rem 1.5rem}.api-link{align-items:center;color:#fff9;display:flex;font-size:.85rem;gap:.5rem;text-decoration:none;transition:color .2s}.api-link:hover{color:#fff}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:260px}.top-header{background:#fff;box-shadow:0 2px 4px #0000000a;justify-content:space-between;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:50}.header-left,.top-header{align-items:center;display:flex}.header-left{gap:1rem}.current-time{color:#666;font-size:.9rem}.header-right{align-items:center;display:flex;gap:1rem}.user-info{align-items:center;background:#f8f9fa;border-radius:20px;color:#333;font-size:.875rem;gap:.5rem;padding:.5rem 1rem}.content-area{background:#f5f6fa;flex:1 1;padding:2rem}@media (max-width:768px){.sidebar{width:70px}.nav-label,.sidebar-footer,.sidebar-header .subtitle,.sidebar-header h1{display:none}.nav-item{justify-content:center;padding:1rem}.main-content{margin-left:70px}}.connection-badge{align-items:center;border-radius:9999px;display:inline-flex;font-weight:500;gap:.25rem;padding:.25rem .625rem;transition:all .3s ease;white-space:nowrap}.connection-badge--small{font-size:.75rem;padding:.125rem .375rem}.connection-badge--medium{font-size:.875rem}.connection-badge--large{font-size:1rem;padding:.375rem .875rem}.connection-badge--green{background-color:#dcfce7;color:#166534}.connection-badge--red{background-color:#fee2e2;color:#991b1b}.connection-badge--gray{background-color:#f3f4f6;color:#6b7280}.connection-badge--animating{animation:badge-pulse .5s ease-in-out}@keyframes badge-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}.connection-badge__icon{font-size:.75em;line-height:1}.connection-badge__refresh-indicator{animation:spin 2s linear infinite;font-size:.7em;margin-left:.125rem;opacity:.6}.inventory-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem}.inventory-card--matched{border-left:4px solid #22c55e}.inventory-card--unmatched{background:#fffbeb;border-left:4px solid #f59e0b}.inventory-card__header{align-items:center;display:flex;gap:.5rem;margin-bottom:.75rem}.inventory-card__title{font-size:.9375rem;font-weight:600}.inventory-card__description{color:#6b7280;font-size:.875rem;margin:0}.inventory-card__device{align-items:center;background:#f9fafb;border-radius:.375rem;display:flex;gap:.75rem;margin-bottom:.75rem;padding:.625rem}.inventory-card__device-icon{font-size:1.5rem}.inventory-card__device-info{display:flex;flex-direction:column}.inventory-card__device-name{color:#111827;font-weight:600}.inventory-card__device-meta{color:#6b7280;font-size:.8125rem;margin-top:.125rem}.inventory-card__details{display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;margin-bottom:.75rem}.inventory-card__detail{align-items:center;display:flex;font-size:.875rem;gap:.375rem}.inventory-card__detail-label{color:#6b7280;font-weight:500}.inventory-card__detail-value{color:#374151}.inventory-card__actions{margin-top:.5rem}.connection-timeline{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem}.connection-timeline__header{align-items:center;display:flex;font-size:.9375rem;font-weight:500;justify-content:space-between;margin-bottom:.875rem}.connection-timeline__uptime{color:#059669;font-size:.875rem;font-weight:600}.connection-timeline__chart{margin-bottom:.875rem}.connection-timeline__bar{background:#f3f4f6;border-radius:4px;height:24px;overflow:hidden;position:relative}.connection-timeline__segment{cursor:pointer;height:100%;position:absolute;top:0;transition:opacity .15s}.connection-timeline__segment:hover{opacity:.75}.connection-timeline__segment--online{background:#22c55e}.connection-timeline__segment--offline{background:#ef4444}.connection-timeline__no-events{align-items:center;color:#9ca3af;display:flex;font-size:.8125rem;height:100%;justify-content:center}.connection-timeline__labels{color:#6b7280;display:flex;font-size:.75rem;justify-content:space-between;margin-top:.25rem}.connection-timeline__summary{border-top:1px solid #f3f4f6;display:flex;gap:2rem;padding-top:.5rem}.connection-timeline__stat{align-items:baseline;display:flex;gap:.3rem}.connection-timeline__stat-value{color:#111827;font-size:1.125rem;font-weight:600}.connection-timeline__stat-label{color:#6b7280;font-size:.8125rem}.connection-timeline--empty,.connection-timeline--error,.connection-timeline--loading{color:#6b7280;font-size:.875rem;padding:2rem;text-align:center}.connection-timeline--error{color:#dc2626}.ggos-modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.ggos-modal{background:#fff;border-radius:.75rem;box-shadow:0 20px 60px #0003;max-height:90vh;max-width:480px;overflow-y:auto;width:100%}.ggos-modal--wide{max-width:600px}.ggos-modal__header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.ggos-modal__title{color:#111827;font-size:1.125rem;font-weight:600;margin:0}.ggos-modal__close{background:none;border:none;color:#6b7280;cursor:pointer;font-size:1.5rem;line-height:1;padding:0 .25rem;transition:color .15s}.ggos-modal__close:hover{color:#111827}.ggos-modal__body{padding:1.25rem 1.5rem}.ggos-modal__footer{border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem}.ggos-modal__warning{background:#fef3c7;border:1px solid #fbbf24;border-radius:.5rem;font-size:.875rem;margin-bottom:1rem;padding:.875rem 1rem}.ggos-modal__warning p{margin:0 0 .5rem}.ggos-modal__warning p:last-child{margin-bottom:0}.ggos-modal__warning ul{margin:.375rem 0 .5rem 1.25rem;padding:0}.ggos-modal__warning li{margin-bottom:.25rem}.ggos-modal__error{background:#fee2e2;border:1px solid #fca5a5;border-radius:.375rem;color:#991b1b;font-size:.875rem;margin-bottom:1rem;padding:.625rem .875rem}.cert-info{gap:1rem}.cert-info,.cert-info__item{display:flex;flex-direction:column}.cert-info__item{gap:.375rem}.cert-info__label{color:#6b7280;font-size:.8125rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.cert-info__value-row{align-items:center;display:flex;gap:.5rem}.cert-info__value{background:#f3f4f6;border-radius:.375rem;color:#374151;flex:1 1;font-size:.8125rem;padding:.375rem .625rem;word-break:break-all}.cert-info__value--small{font-size:.75rem}.cert-info__copy{background:none;border:1px solid #e5e7eb;border-radius:.375rem;cursor:pointer;flex-shrink:0;font-size:.875rem;padding:.25rem .5rem;transition:background .15s}.cert-info__copy:hover{background:#f3f4f6}.cert-info__note{background:#eff6ff;border:1px solid #bfdbfe;border-radius:.375rem;color:#1e40af;font-size:.8125rem;padding:.625rem .875rem}.actions-dropdown__caret{font-size:.65em;margin-left:.25rem;vertical-align:middle}.actions-dropdown__menu{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 8px 24px #0000001f;min-width:180px;overflow:hidden;position:absolute;right:0;top:calc(100% + .375rem);z-index:500}.actions-dropdown__item{align-items:center;background:none;border:none;color:#374151;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;padding:.625rem 1rem;text-align:left;transition:background .1s;width:100%}.actions-dropdown__item:hover:not(:disabled){background:#f9fafb}.actions-dropdown__item:disabled{cursor:not-allowed;opacity:.45}.actions-dropdown__item--danger{color:#dc2626}.actions-dropdown__item--danger:hover:not(:disabled){background:#fef2f2}.actions-dropdown__item-icon{flex-shrink:0;text-align:center;width:1.125rem}.actions-dropdown__divider{background:#e5e7eb;height:1px;margin:.25rem 0}.command-panel{background:#fff;background:var(--bg-primary,#fff);border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.command-panel-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.command-panel-header h2{font-size:1.25rem;font-weight:600;margin:0}.tab-buttons{display:flex;gap:.5rem}.tab-btn{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:6px;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .15s ease}.tab-btn:hover{background:#f3f4f6;background:var(--bg-hover,#f3f4f6)}.tab-btn.active{background:#3b82f6;background:var(--primary-color,#3b82f6);border-color:#3b82f6;border-color:var(--primary-color,#3b82f6);color:#fff}.warning-banner{background:#fef3c7;border:1px solid #f59e0b;border-radius:6px;color:#92400e;font-size:.875rem;padding:.75rem 1rem}.category-filter,.warning-banner{margin-bottom:1rem}.category-filter select{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:6px;font-size:.875rem;padding:.5rem;width:100%}.command-selector{margin-bottom:1.5rem}.command-selector label{color:#6b7280;color:var(--text-secondary,#6b7280);display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.command-selector select{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:6px;cursor:pointer;font-size:1rem;padding:.75rem;width:100%}.command-selector select:focus{border-color:#3b82f6;border-color:var(--primary-color,#3b82f6);box-shadow:0 0 0 3px #3b82f61a;outline:none}.command-form{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border-radius:8px;padding:1.25rem}.command-info{margin-bottom:1.25rem}.command-description{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.9rem;margin:0 0 .75rem}.command-badges{display:flex;flex-wrap:wrap;gap:.5rem}.badge{border-radius:4px;font-size:.75rem;padding:.25rem .5rem}.badge.risk-safe{background:#d1fae5;color:#065f46}.badge.risk-medium{background:#fef3c7;color:#92400e}.badge.risk-critical{background:#fee2e2;color:#991b1b}.badge-permission{background:#e0e7ff;color:#3730a3}.params-section{margin-bottom:1.25rem}.params-section h4{color:#111827;color:var(--text-primary,#111827);font-size:.875rem;font-weight:600;margin:0 0 .75rem}.params-grid{gap:1rem}.param-field,.params-grid{display:flex;flex-direction:column}.param-field{gap:.25rem}.param-field label{color:#111827;color:var(--text-primary,#111827);font-size:.875rem;font-weight:500}.param-field .required{color:#dc2626}.param-field input[type=number],.param-field input[type=text]{border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:6px;font-size:.875rem;padding:.5rem .75rem}.param-field input:focus{border-color:#3b82f6;border-color:var(--primary-color,#3b82f6);box-shadow:0 0 0 3px #3b82f61a;outline:none}.param-description{color:#9ca3af;color:var(--text-muted,#9ca3af);font-size:.75rem}.checkbox-label{align-items:flex-start;cursor:pointer;display:flex;gap:.5rem}.checkbox-label input[type=checkbox]{cursor:pointer;height:1rem;margin-top:.25rem;width:1rem}.checkbox-label span{font-size:.875rem;font-weight:500}.checkbox-label small{display:block;margin-top:.125rem}.execute-btn{background:#3b82f6;background:var(--primary-color,#3b82f6);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1rem;transition:all .15s ease;width:100%}.execute-btn:hover:not(:disabled){background:#2563eb;background:var(--primary-hover,#2563eb)}.execute-btn:disabled{cursor:not-allowed;opacity:.6}.execute-btn.critical{background:#dc2626}.execute-btn.critical:hover:not(:disabled){background:#b91c1c}.critical-warning{background:#fee2e2;border:1px solid #fca5a5;border-radius:6px;color:#991b1b;font-size:.875rem;margin-top:.75rem;padding:.75rem}.result{border-radius:6px;margin-top:1rem;padding:1rem}.result.success{background:#d1fae5;border:1px solid #6ee7b7}.result.error{background:#fee2e2;border:1px solid #fca5a5}.result-success{color:#065f46}.result-success strong{display:block;margin-bottom:.5rem}.result-details{display:flex;flex-direction:column;font-size:.875rem;gap:.25rem}.result-details code{background:#0000001a;border-radius:4px;font-family:monospace;font-size:.75rem;padding:.125rem .375rem}.result-error{color:#991b1b}.result-error strong{display:block;margin-bottom:.5rem}.result-error p{font-size:.875rem;margin:0}.loading{color:#9ca3af;color:var(--text-muted,#9ca3af);padding:1rem;text-align:center}.command-history{min-height:200px}.history-table{border-collapse:collapse;font-size:.875rem;width:100%}.history-table td,.history-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);padding:.75rem;text-align:left}.history-table th{background:#f9fafb;background:var(--bg-secondary,#f9fafb);color:#6b7280;color:var(--text-secondary,#6b7280);font-weight:600}.history-table tr:hover{background:#f9fafb;background:var(--bg-hover,#f9fafb)}.status-badge{border-radius:4px;padding:.25rem .5rem}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.executed{background:#d1fae5;color:#065f46}.status-badge.failed{background:#fee2e2;color:#991b1b}.pagination{gap:.5rem;justify-content:center;margin-top:1rem}.pagination button{border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:4px;font-size:.875rem;padding:.5rem .75rem}.pagination span{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem}.empty-state{color:#9ca3af;color:var(--text-muted,#9ca3af)}.location-map-card{background:#fff;background:var(--card-background,#fff);border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:12px;margin-bottom:1rem;overflow:hidden}.location-map-card.no-location{padding:1rem}.location-header{align-items:center;background:#f8f9fa;background:var(--header-background,#f8f9fa);border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color,#e0e0e0);display:flex;justify-content:space-between;padding:.75rem 1rem}.location-header h4{color:#333;color:var(--text-primary,#333);font-size:1rem;font-weight:600;margin:0}.location-update-time{color:#666;color:var(--text-secondary,#666);font-size:.75rem}.location-content{grid-gap:0;display:grid;gap:0;grid-template-columns:1fr}@media (min-width:640px){.location-content{grid-template-columns:1.5fr 1fr}}.map-container{background:#e8e8e8;height:200px;position:relative}@media (min-width:640px){.map-container{height:220px}}.map-loading{align-items:center;background:#f5f5f5;bottom:0;color:#666;display:flex;flex-direction:column;gap:.5rem;justify-content:center;left:0;position:absolute;right:0;top:0}.loading-spinner{border:3px solid #e0e0e0;border-top-color:#4285f4;height:24px;width:24px}.location-details{display:flex;flex-direction:column;gap:.75rem;padding:1rem}.location-address{align-items:flex-start;display:flex;gap:.5rem}.address-icon{flex-shrink:0}.address-text{color:#333;color:var(--text-primary,#333);font-size:.875rem;line-height:1.4}.address-coords{color:#666;color:var(--text-secondary,#666);font-family:monospace;font-size:.8rem}.address-loading{color:#888;color:var(--text-secondary,#888);font-size:.8rem;font-style:italic}.location-accuracy{align-items:center;color:#666;color:var(--text-secondary,#666);display:flex;font-size:.8rem;gap:.5rem}.accuracy-icon{flex-shrink:0}.location-actions{display:flex;gap:.5rem;margin-top:auto;padding-top:.5rem}.location-btn{align-items:center;background:#e8f0fe;background:var(--primary-light,#e8f0fe);border:none;border-radius:6px;color:#4285f4;color:var(--primary-color,#4285f4);cursor:pointer;display:inline-flex;flex:1 1;font-size:.75rem;font-weight:500;gap:.25rem;justify-content:center;padding:.5rem .75rem;text-decoration:none;transition:all .2s}.location-btn:hover{background:#4285f4;background:var(--primary-color,#4285f4);color:#fff}.no-location-message{align-items:center;color:#888;color:var(--text-secondary,#888);display:flex;flex-direction:column;justify-content:center;padding:2rem 1rem;text-align:center}.no-location-message span{font-size:2rem;margin-bottom:.5rem;opacity:.5}.no-location-message p{font-weight:500;margin:0}.no-location-message small{font-size:.75rem;margin-top:.25rem;opacity:.7}.country-code-badge{align-items:center;background:#e8f0fe;border-radius:4px;color:#4285f4;display:inline-flex;font-size:.65rem;font-weight:600;justify-content:center;letter-spacing:.5px;margin-left:.5rem;padding:.1rem .4rem;text-transform:uppercase}.location-poi{align-items:flex-start;background:linear-gradient(135deg,#fff9e6,#fff5cc);border-left:3px solid #f59e0b;border-radius:8px;display:flex;gap:.5rem;padding:.5rem}.poi-icon{flex-shrink:0;font-size:1rem}.poi-text{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#92400e;display:-webkit-box;font-size:.8rem;font-weight:500;line-height:1.3;overflow:hidden;text-overflow:ellipsis}.location-meta-row{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.details-toggle{background:none;border:none;border-radius:4px;color:#4285f4;cursor:pointer;font-size:.75rem;padding:.25rem .5rem;transition:background .2s}.details-toggle:hover{background:#e8f0fe}.location-expanded-details{background:#f8f9fa;background:var(--detail-bg,#f8f9fa);border:1px solid #e8e8e8;border:1px solid var(--border-color,#e8e8e8);border-radius:8px;display:flex;flex-direction:column;gap:.4rem;padding:.75rem}.detail-row{align-items:center;display:flex;font-size:.8rem;gap:.5rem}.detail-label{color:#666;color:var(--text-secondary,#666);flex-shrink:0;min-width:80px}.detail-value{color:#333;color:var(--text-primary,#333);font-weight:500}@media (prefers-color-scheme:dark){.location-map-card{background:#1e1e1e;border-color:#333}.location-header{background:#252525;border-color:#333}.address-text,.location-header h4{color:#e0e0e0}.map-loading{background:#2a2a2a;color:#aaa}.location-btn{background:#2a3a50;color:#82b1ff}.location-btn:hover{background:#4285f4;color:#fff}.country-code-badge{background:#2a3a50;color:#82b1ff}.location-poi{background:linear-gradient(135deg,#3d3000,#2a2000);border-left-color:#f59e0b}.poi-text{color:#fcd34d}.details-toggle{color:#82b1ff}.details-toggle:hover{background:#2a3a50}.location-expanded-details{background:#252525;border-color:#333}.detail-label{color:#aaa}.detail-value{color:#e0e0e0}}.snapshot-card{background:#fff;background:var(--bg-primary,#fff);border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;padding:1.5rem}.snapshot-card.empty,.snapshot-card.error,.snapshot-card.loading{display:flex;flex-direction:column;min-height:200px}.snapshot-card-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.snapshot-card-header h3{color:#111827;color:var(--text-primary,#111827);font-size:1.25rem;font-weight:600;margin:0}.snapshot-age{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border-radius:4px;font-size:.875rem;padding:.25rem .75rem}.snapshot-age,.snapshot-loading{color:#6b7280;color:var(--text-secondary,#6b7280)}.snapshot-loading{align-items:center;display:flex;flex:1 1;gap:.75rem;justify-content:center}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #e5e7eb;border-top-color:#3b82f6;border:2px solid var(--border-color,#e5e7eb);border-radius:50%;border-top-color:var(--primary-color,#3b82f6);height:20px;width:20px}.snapshot-error{align-items:center;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;flex:1 1;flex-direction:column;gap:.75rem;justify-content:center}.error-icon{font-size:2rem}.retry-btn{background:#3b82f6;background:var(--primary-color,#3b82f6);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;margin-top:.5rem;padding:.5rem 1rem;transition:background .15s ease}.retry-btn:hover{background:#2563eb;background:var(--primary-hover,#2563eb)}.snapshot-empty{align-items:center;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;flex:1 1;flex-direction:column;justify-content:center;text-align:center}.snapshot-hint{font-size:.8rem;margin-top:.5rem;opacity:.8}.snapshot-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.snapshot-section{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;padding:1rem}.snapshot-section-title{color:#111827;color:var(--text-primary,#111827);font-size:.9rem;font-weight:600;margin:0 0 .75rem}.snapshot-section-content{display:flex;flex-direction:column;gap:.5rem}.snapshot-row{align-items:center;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-color-light,#f3f4f6);display:flex;justify-content:space-between;padding:.35rem 0}.snapshot-row:last-child{border-bottom:none}.snapshot-row.warning{background:#f59e0b1a;border-radius:4px;margin:0 -.5rem;padding:.35rem .5rem}.snapshot-label{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.85rem}.snapshot-value{color:#111827;color:var(--text-primary,#111827);font-size:.85rem;font-weight:500;max-width:60%;text-align:right;word-break:break-word}.snapshot-footer{align-items:center;border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;margin-top:1.5rem;padding-top:1rem}.refresh-btn{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:6px;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .15s ease}.refresh-btn:hover{background:#f3f4f6;background:var(--bg-hover,#f3f4f6);border-color:#d1d5db;border-color:var(--border-hover,#d1d5db)}.auto-refresh-hint{color:#9ca3af;color:var(--text-muted,#9ca3af);font-size:.75rem}@media (max-width:768px){.snapshot-card{padding:1rem}.snapshot-grid{grid-template-columns:1fr}.snapshot-card-header{align-items:flex-start;flex-direction:column;gap:.75rem}.snapshot-age{align-self:flex-end}}.token-card{position:relative}.token-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.token-header h2{margin:0}.token-refresh-btn{font-size:.85rem;padding:.25rem .5rem!important}.token-error,.token-loading{color:#6b7280;color:var(--text-secondary,#6b7280);padding:1rem;text-align:center}.token-error{color:#dc2626}.token-alert{border-radius:6px;font-size:.85rem;margin-bottom:.75rem;padding:.5rem .75rem}.token-alert-success{background:#dcfce7;border:1px solid #bbf7d0;color:#166534}.token-alert-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.token-status-row{grid-gap:1rem;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));padding:.75rem 0}.token-status-item{display:flex;flex-direction:column;gap:.25rem}.token-label{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.token-value{color:#111827;color:var(--text-primary,#111827);font-size:.9rem}.token-preview{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border-radius:4px;font-family:monospace;font-size:.8rem;padding:.2rem .5rem;word-break:break-all}.token-badge{border-radius:9999px;display:inline-block;font-size:.75rem;font-weight:600;padding:.15rem .5rem}.token-badge-active{background:#dcfce7;color:#166534}.token-badge-missing{background:#fef3c7;color:#92400e}.token-actions{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;padding:.75rem 0}.token-rotate-btn{white-space:nowrap}.token-confirm{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.token-confirm-text{color:#92400e;font-size:.85rem;font-weight:500}.token-offline-hint{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.8rem}.token-history{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);margin-top:.25rem;padding-top:.75rem}.token-history h4{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.85rem;margin:0 0 .5rem}.token-history-table{border-collapse:collapse;font-size:.8rem;width:100%}.token-history-table th{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.7rem;font-weight:600;letter-spacing:.05em;text-align:left;text-transform:uppercase}.token-history-table td,.token-history-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);padding:.35rem .5rem}.manifest-card{position:relative}.manifest-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.manifest-header h2{margin:0}.manifest-header-actions{display:flex;gap:.5rem}.manifest-error,.manifest-loading{color:#6b7280;color:var(--text-secondary,#6b7280);padding:1rem;text-align:center}.manifest-error{color:#dc2626}.manifest-alert{border-radius:6px;font-size:.85rem;margin-bottom:.75rem;padding:.5rem .75rem}.manifest-alert-success{background:#dcfce7;border:1px solid #bbf7d0;color:#166534}.manifest-alert-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.manifest-stats{grid-gap:.75rem;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));padding:.75rem 0}.manifest-stat{align-items:center;display:flex;flex-direction:column;gap:.15rem}.manifest-stat-value{color:#111827;color:var(--text-primary,#111827);font-size:1.25rem;font-weight:700}.manifest-stat-label{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.7rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.manifest-assets{padding-top:.75rem}.manifest-assets h4{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.85rem;margin:0 0 .5rem}.manifest-assets-table{border-collapse:collapse;font-size:.8rem;width:100%}.manifest-assets-table th{border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--border-color,#e5e7eb);color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.7rem;font-weight:600;letter-spacing:.05em;padding:.4rem .5rem;text-align:left;text-transform:uppercase}.manifest-assets-table td{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);padding:.5rem;vertical-align:middle}.manifest-ad-name{color:#111827;color:var(--text-primary,#111827);font-weight:600}.manifest-type-badge{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border-radius:4px;display:inline-block;font-size:.75rem;padding:.1rem .4rem;white-space:nowrap}.manifest-size{font-family:monospace;white-space:nowrap}.manifest-sha{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border-radius:3px;font-family:monospace;font-size:.7rem;padding:.1rem .3rem}.manifest-sha-missing{color:#6b7280;color:var(--text-secondary,#6b7280)}.manifest-empty{padding:1.5rem;text-align:center}.manifest-empty p{margin:.25rem 0}.manifest-empty-hint{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.8rem}.manifest-history{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);margin-top:.5rem;padding-top:.75rem}.manifest-history h4{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.85rem;margin:0 0 .5rem}.manifest-history-table{border-collapse:collapse;font-size:.8rem;width:100%}.manifest-history-table th{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.7rem;font-weight:600;letter-spacing:.05em;text-align:left;text-transform:uppercase}.manifest-history-table td,.manifest-history-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);padding:.35rem .5rem}.manifest-status-badge{border-radius:9999px;display:inline-block;font-size:.7rem;font-weight:600;padding:.15rem .5rem}.manifest-status-executed,.manifest-status-pending{background:#dcfce7;color:#166534}.manifest-status-failed{background:#fef2f2;color:#991b1b}.manifest-offline-banner{background:#fef3c7;border:1px solid #fde68a;border-radius:6px;color:#92400e;font-size:.8rem;margin-top:.75rem;padding:.5rem .75rem}.app{min-height:100vh}.dashboard-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:1.5rem;transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.stat-card h3{color:#666;font-size:.875rem;font-weight:500;letter-spacing:.5px;margin:0 0 .5rem;text-transform:uppercase}.stat-card .value{color:#1a1a2e;font-size:2rem;font-weight:700}.stat-card.online .value{color:#27ae60}.stat-card.offline .value{color:#e74c3c}.stat-card.warning .value{color:#f39c12}.data-table{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:visible;position:relative;width:100%}.data-table table{border-collapse:collapse;width:100%}.data-table td,.data-table th{border-bottom:1px solid #eee;padding:1rem;text-align:left}.data-table th{background:#f8f9fa;color:#333;font-size:.875rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.data-table th:first-child{border-top-left-radius:12px}.data-table th:last-child{border-top-right-radius:12px}.data-table tr:hover{background:#f8f9fa}.data-table tr:last-child td{border-bottom:none}.data-table tr:last-child td:first-child{border-bottom-left-radius:12px}.data-table tr:last-child td:last-child{border-bottom-right-radius:12px}.status-badge{font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.online{background:#d4edda;color:#155724}.status-badge.offline{background:#f8d7da;color:#721c24}.status-badge.warning{background:#fff3cd;color:#856404}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.btn-primary{background:#1a1a2e;color:#fff}.btn-primary:hover{background:#2d2d44}.btn-secondary{background:#e9ecef;color:#333}.btn-secondary:hover{background:#dee2e6}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.page-header h1{color:#1a1a2e;font-size:1.75rem;margin:0}.loading{align-items:center;color:#666;display:flex;justify-content:center;min-height:200px}.spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#1a1a2e;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.device-detail-page{max-width:1000px}.device-detail{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:2rem}.device-detail h2{color:#1a1a2e;margin:0 0 1.5rem}.detail-grid{grid-gap:1.5rem;gap:1.5rem}.detail-item{padding:1rem}.detail-item span{font-size:1rem}.add-user-page .page-header{margin-bottom:2rem}.add-user-page .page-header h1{color:#1a1a2e;font-size:1.75rem;margin:0 0 .5rem}.add-user-page .page-header .subtitle{color:#666;font-size:.9rem}.form-container{grid-gap:2rem;align-items:start;display:grid;gap:2rem;grid-template-columns:1fr 300px}@media (max-width:900px){.form-container{grid-template-columns:1fr}}.user-form{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:2rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#333;display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.form-group input,.form-group select{background:#fff;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;padding:.75rem 1rem;transition:border-color .2s,box-shadow .2s;width:100%}.form-group input:focus,.form-group select:focus{border-color:#1a1a2e;box-shadow:0 0 0 3px #1a1a2e1a;outline:none}.form-group input:disabled,.form-group select:disabled{background:#f5f5f5;cursor:not-allowed}.form-hint{color:#888;display:block;font-size:.75rem;margin-top:.375rem}.form-row{display:flex;flex-wrap:wrap;gap:1rem}.form-row .form-group{flex:1 1 200px;min-width:0}.form-section{border-top:1px solid #eee;margin-top:1.5rem;padding-top:1rem}.form-section h3{color:#666;font-size:.9rem;font-weight:600;margin:0 0 1rem}.form-help{color:#999;display:block;font-size:.75rem;margin-top:.25rem}.form-actions{border-top:1px solid #eee;margin-top:2rem;padding-top:1.5rem}.btn-lg{font-size:1rem;padding:.875rem 2rem}.btn-spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:16px;margin-right:.5rem;width:16px}.alert{border-radius:8px;font-size:.9rem;margin-bottom:1.5rem;padding:1rem 1.25rem}.alert-success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.alert-error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.info-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:1.5rem}.info-card h3{color:#1a1a2e;font-size:1rem;margin:0 0 1rem}.info-card ul{margin:0;padding-left:1.25rem}.info-card li{color:#666;font-size:.85rem;line-height:1.5;margin-bottom:.5rem}.info-card li:last-child{margin-bottom:0}.users-page .page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.search-box input{border:2px solid #e9ecef;border-radius:8px;font-size:.9rem;padding:.75rem 1rem;width:300px}.search-box input:focus{border-color:#1a1a2e;outline:none}.filters-bar select{background:#fff;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;font-size:.9rem;padding:.75rem 1rem}.user-cell{gap:.75rem}.user-avatar,.user-cell{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:50%;color:#fff;font-size:1rem;font-weight:600;height:40px;justify-content:center;width:40px}.user-info{display:flex;flex-direction:column}.user-name{color:#1a1a2e;font-weight:600}.user-email{color:#666;font-size:.85rem}.status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.8rem;font-weight:500;padding:.25rem .75rem}.status-active{background:#d4edda;color:#155724}.status-pending{background:#fff3cd;color:#856404}.status-disabled{background:#f8d7da;color:#721c24}.actions-dropdown{display:inline-block;position:relative}.actions-dropdown .dropdown-menu{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;display:none;min-width:180px;overflow:visible;position:absolute;right:0;top:100%;z-index:1000}.actions-dropdown:hover .dropdown-menu{display:block}.data-table td:last-child{overflow:visible;position:relative}.dropdown-item{background:none;border:none;color:#333;cursor:pointer;display:block;font-size:.9rem;padding:.75rem 1rem;text-align:left;text-decoration:none;width:100%}.dropdown-item:hover{background:#f5f6fa}.dropdown-item.text-warning{color:#f39c12}.dropdown-item.text-success{color:#27ae60}.dropdown-item.text-danger{color:#e74c3c}.btn-sm{font-size:.875rem;padding:.375rem .75rem}.pagination{margin-top:1.5rem;padding:1rem}.pagination-buttons{display:flex;gap:.5rem}.pagination button{background:#fff;border:1px solid #e9ecef;border-radius:6px;cursor:pointer;padding:.5rem 1rem}.pagination button:disabled{cursor:not-allowed;opacity:.5}.pagination button:hover:not(:disabled){background:#f5f6fa}.empty-state{padding:3rem!important}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;margin:auto;max-height:calc(100vh - 2rem);max-width:500px;overflow-y:auto;width:100%}.modal.modal-sm{max-width:400px}.modal.modal-lg{max-width:700px}@media (max-width:768px){.modal-overlay{align-items:flex-start;padding:.5rem}.modal{border-radius:8px;max-height:calc(100vh - 1rem)}.modal,.modal.modal-lg{max-width:100%}.modal-header{padding:1rem}.modal-header h2{font-size:1.1rem}.modal-body{padding:1rem}.modal-footer{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem}.modal-footer .btn{flex:1 1 auto;justify-content:center}.form-row{flex-direction:column}.form-row .form-group{width:100%}}.modal-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.modal-header h2{color:#1a1a2e;font-size:1.25rem;margin:0}.modal-close{background:none;border:none;color:#666;cursor:pointer;font-size:1.5rem;line-height:1;padding:0}.modal-close:hover{color:#333}.modal-body{padding:1.5rem}.modal-body p{color:#666;margin:0 0 1rem}.modal-footer{background:#f8f9fa;border-top:1px solid #eee;display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem}.warning-list{color:#666;font-size:.9rem;margin:1rem 0;padding-left:1.25rem}.warning-list li{margin-bottom:.5rem}.btn-danger{background:#e74c3c;color:#fff}.btn-danger:hover{background:#c0392b}.btn-danger:disabled{background:#ccc;cursor:not-allowed}.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.sortable:hover{background:#e9ecef}.user-detail-page{max-width:1000px}.back-link{color:#666;font-size:.9rem;text-decoration:none}.back-link:hover{color:#1a1a2e}.header-actions{display:flex;gap:.75rem}.user-profile-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:1.5rem;padding:2rem}.profile-header{align-items:center;display:flex;gap:1.5rem}.user-avatar.large{font-size:2rem;height:80px;width:80px}.profile-info h1{color:#1a1a2e;font-size:1.5rem;margin:0 0 .25rem}.profile-info .email{color:#666;margin:0 0 .75rem}.status-desc{color:#888;font-size:.85rem;margin-left:.5rem}.detail-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:1.5rem;padding:1.5rem}.detail-section h2{border-bottom:1px solid #eee;color:#1a1a2e;font-size:1.1rem;margin:0 0 1rem;padding-bottom:.75rem}.detail-grid{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.detail-item{background:#f8f9fa;border-radius:8px;padding:.75rem}.detail-item label{display:block;font-size:.75rem;margin-bottom:.25rem}.detail-item span{color:#1a1a2e;font-size:.95rem;font-weight:500;word-break:break-all}.detail-item .mono{font-family:monospace;font-size:.85rem}.empty-state-small{color:#666;padding:2rem;text-align:center}.empty-state-small .muted{color:#999;font-size:.85rem}.input-disabled{background:#f0f0f0!important;color:#666;cursor:not-allowed}.tenant-badge-wrapper{display:inline-block;position:relative}.tenant-badge{background:#e3f2fd;border-radius:4px;color:#1976d2;display:inline-block;font-size:.75rem;padding:.25rem .5rem}.tenant-badge.tenant-none{background:#f5f5f5;color:#999}.tenant-tooltip{background:#fff;border-radius:8px;box-shadow:0 4px 16px #00000026;left:0;margin-top:.25rem;min-width:200px;padding:.5rem;position:absolute;top:100%;z-index:1000}.tenant-tooltip-item{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:.5rem}.tenant-tooltip-item:last-child{border-bottom:none}.role-badge{background:#f0f0f0;border-radius:3px;color:#666;display:inline-block;font-size:.65rem;padding:.125rem .375rem;text-transform:capitalize}.role-badge.role-tenant_admin{background:#fff3e0;color:#e65100}.role-badge.role-editor{background:#e8f5e9;color:#2e7d32}.role-badge.role-viewer{background:#e3f2fd;color:#1565c0}.section-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.section-header h2{border-bottom:none;margin:0;padding-bottom:0}.tenant-list{display:flex;flex-direction:column;gap:.5rem}.tenant-assignment-item{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;padding:.75rem 1rem}.tenant-info{align-items:center;display:flex;gap:.5rem}.tenant-name{color:#1a1a2e;font-weight:500}.tenant-plan{color:#666;font-size:.8rem}.tenant-role{margin-left:1rem;margin-right:auto}.loading-inline{color:#666;font-style:italic;padding:.5rem}.form-group textarea{border:2px solid #e9ecef;border-radius:8px;font-family:inherit;font-size:1rem;padding:.75rem 1rem;resize:vertical;transition:border-color .2s,box-shadow .2s;width:100%}.form-group textarea:focus{border-color:#1a1a2e;box-shadow:0 0 0 3px #1a1a2e1a;outline:none}.user-cell .user-name a{color:#1a1a2e;font-weight:600;text-decoration:none}.user-cell .user-name a:hover{color:#2d2d44;text-decoration:underline}.device-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.device-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;padding:1.25rem;transition:box-shadow .2s,transform .2s}.device-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.device-card-header{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.device-name{color:#1a1a2e;font-size:1.1rem;font-weight:600;text-decoration:none;transition:color .2s}.device-name:hover{color:#2d2d44;text-decoration:underline}.device-badges{display:flex;flex-wrap:wrap;gap:.5rem}.device-card-body{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.device-info-row{display:flex;flex-direction:column;gap:.25rem}.info-label{color:#666;font-size:.8rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.info-value{color:#1a1a2e;font-size:.95rem}.badge{align-items:center;border-radius:12px;display:inline-flex;font-size:.85rem;font-weight:500;padding:.35rem .75rem;white-space:nowrap}.badge-green{background:#e8f5e9;color:#2e7d32}.badge-red{background:#ffebee;color:#c62828}.badge-yellow{background:#fff8e1;color:#f57f17}.badge-gray{background:#f5f5f5;color:#757575}.badge-blue{background:#e3f2fd;color:#1565c0;text-decoration:none}.badge-blue:hover{background:#bbdefb}.detail-sections{display:flex;flex-direction:column;gap:1.5rem}.detail-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;padding:1.5rem}.detail-card h2{border-bottom:2px solid #f0f0f0;color:#1a1a2e;font-size:1.1rem;font-weight:600;margin-bottom:1rem;padding-bottom:.75rem}.detail-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.detail-item{display:flex;flex-direction:column;gap:.5rem}.detail-item label{color:#666;font-size:.85rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.detail-value{color:#1a1a2e;font-size:1rem;word-break:break-all}.detail-value.code{background:#f8f9fa;border-radius:4px;font-family:Courier New,monospace;font-size:.9rem;padding:.5rem}.license-info{padding:.5rem 0}.license-key{background:#e8f5e9;border-radius:8px;font-size:1.15rem;margin-bottom:1rem;padding:1rem}.inventory-info{padding:.5rem 0}.inventory-status{margin-bottom:1rem}.empty-state{color:#666;padding:2rem;text-align:center}.empty-state p{margin:.5rem 0}.text-muted{color:#999;font-size:.9rem}.filters-bar{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.search-box{flex:1 1;min-width:300px}.search-input{border:2px solid #e9ecef;border-radius:8px;font-size:1rem;padding:.75rem 1rem;transition:border-color .2s,box-shadow .2s;width:100%}.search-input:focus{border-color:#1a1a2e;box-shadow:0 0 0 3px #1a1a2e1a;outline:none}.filters-group{display:flex;flex-wrap:wrap;gap:.75rem}.filter-select{background:#fff;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;font-size:.95rem;padding:.75rem 1rem;transition:border-color .2s}.filter-select:focus{border-color:#1a1a2e;outline:none}.pagination{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:8px;display:flex;justify-content:space-between;padding:1.5rem 1rem}.pagination-btn{background:#1a1a2e;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.95rem;padding:.5rem 1rem;transition:background .2s}.pagination-btn:hover:not(:disabled){background:#2d2d44}.pagination-btn:disabled{background:#ccc;cursor:not-allowed}.pagination-info{color:#666;font-size:.95rem}@media (max-width:768px){.detail-grid,.device-card-body{grid-template-columns:1fr}.filters-bar{flex-direction:column}.search-box{min-width:100%}.filters-group{width:100%}.filter-select{flex:1 1}.pagination{flex-direction:column;gap:1rem}}.auto-refresh-toggle{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;color:#4b5563;cursor:pointer;display:flex;font-size:.8125rem;gap:.375rem;padding:.5rem .75rem;transition:all .15s;-webkit-user-select:none;user-select:none}.auto-refresh-toggle:hover{background:#f3f4f6;border-color:#d1d5db}.auto-refresh-toggle input[type=checkbox]{cursor:pointer;height:1rem;width:1rem}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f6fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
/*# sourceMappingURL=main.73f3da98.css.map*/