@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.auth-modal{background:var(--bg-primary, #0d0d1a);border-radius:12px;padding:2.5rem;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #00000080;border:1px solid var(--border, #1a1a2e)}.auth-modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--text-secondary, #888);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:color .2s,background .2s}.auth-modal-close:hover{color:var(--text-primary, #fff);background:var(--bg-tertiary, #1a1a2e)}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.auth-form-header{text-align:center;margin-bottom:.5rem}.auth-form-header h2{margin:0 0 .5rem;font-size:2rem;font-weight:700;color:var(--text-primary, #fff)}.auth-form-subtitle{margin:0;font-size:.9375rem;color:var(--text-secondary, #888)}.auth-form-fields{display:flex;flex-direction:column;gap:1.25rem}.auth-form-group{display:flex;flex-direction:column;gap:.5rem}.auth-label{font-size:.9375rem;font-weight:500;color:var(--text-primary, #fff)}.auth-input{width:100%;padding:.875rem 1rem;font-size:.9375rem;color:var(--text-primary, #fff);background:var(--bg-secondary, #1a1a2e);border:1px solid var(--border, #2a2a4a);border-radius:.5rem;outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.auth-input::placeholder{color:var(--text-muted, #666)}.auth-input:focus{border-color:var(--accent, #00dfff);box-shadow:0 0 0 3px #6bc5d81a}.auth-input:disabled{opacity:.6;cursor:not-allowed}.auth-input:-webkit-autofill,.auth-input:-webkit-autofill:hover,.auth-input:-webkit-autofill:focus,.auth-input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px var(--bg-secondary, #1a1a2e) inset!important;-webkit-text-fill-color:var(--text-primary, #fff)!important;caret-color:var(--text-primary, #fff);transition:background-color 5000s ease-in-out 0s}.auth-submit-button{width:100%;padding:.875rem 1rem;font-size:1rem;font-weight:600;background:var(--accent, #00dfff);color:#000;border:none;border-radius:.5rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem}.auth-submit-button:hover:not(:disabled){background:#00c8e8}.auth-submit-button:disabled{opacity:.7;cursor:not-allowed}.auth-link-inline{color:var(--accent, #00dfff);background:none;border:none;font-size:.875rem;cursor:pointer;text-decoration:none;padding:0}.auth-link-inline:hover{text-decoration:underline}.auth-checkbox-group{display:flex;flex-direction:column;gap:.75rem}.auth-checkbox-field{display:flex;align-items:flex-start;gap:.625rem}.auth-checkbox-field .auth-checkbox-label{font-size:.875rem;font-weight:400;color:var(--text-primary, #fff);line-height:1.4}.auth-checkbox{display:inline-flex;align-items:center;justify-content:center;width:1.125rem;height:1.125rem;padding:0;background:var(--bg-secondary, #1a1a2e);border:1px solid var(--border, #2a2a4a);border-radius:.25rem;cursor:pointer;transition:all .2s ease;flex-shrink:0;margin-top:.125rem}.auth-checkbox:hover:not(:disabled){border-color:var(--accent, #00dfff)}.auth-checkbox--checked{background:var(--accent, #00dfff);border-color:var(--accent, #00dfff)}.auth-checkbox:disabled{opacity:.5;cursor:not-allowed}.auth-checkbox-icon{color:#000}.auth-spinner{animation:auth-spin 1s linear infinite}@keyframes auth-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.user-menu{position:relative}.user-menu-button{display:flex;align-items:center;gap:.5rem;background:var(--bg-tertiary, #1a1a2e);border:1px solid var(--border, #2a2a4a);border-radius:8px;padding:.5rem .75rem;color:var(--text-primary, #fff);cursor:pointer;transition:background .2s,border-color .2s}.user-menu-button:hover{background:var(--bg-hover, #252540);border-color:var(--accent, #00dfff)}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent, #00dfff);display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;color:#000;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-name{font-size:.875rem;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--bg-secondary, #1a1a2e);border:1px solid var(--border, #2a2a4a);border-radius:8px;padding:.5rem;min-width:180px;box-shadow:0 10px 30px #0000004d;z-index:100}.user-menu-item{display:block;width:100%;padding:.625rem .75rem;background:none;border:none;border-radius:4px;color:var(--text-primary, #fff);font-size:.875rem;text-align:left;cursor:pointer;transition:background .2s}.user-menu-item:hover{background:var(--bg-tertiary, #252540)}.user-menu-item.danger{color:var(--error, #ef4444)}.user-menu-item.danger:hover{background:#ef44441a}@media (max-width: 480px){.auth-modal{padding:1.5rem;margin:1rem;max-width:calc(100% - 2rem)}.auth-form-header h2{font-size:1.5rem}.user-name{display:none}}.header{position:relative;display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:linear-gradient(180deg,#183a4df2,#122d3df2);border-bottom:1px solid var(--border-accent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-md)}.header-left{display:flex;align-items:center;gap:20px}.header-brand{display:flex;align-items:center;gap:12px;text-decoration:none;transition:transform .3s ease}.header-brand:hover{transform:scale(1.02)}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}.header-brand:hover .header-company span,.header-brand:hover .header-title{background:linear-gradient(90deg,#6bc5d8,#6bc5d8 40%,#fff,#204f6e 60%,#6bc5d8);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 2s linear infinite}.header-logo{flex-shrink:0;width:40px;height:40px;background:var(--bg-tertiary);border:1px solid var(--border-accent);border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.header-brand:hover .header-logo{filter:brightness(1.25)}.header-logo-text{font-size:14px;font-weight:600;color:#fff;letter-spacing:-.02em}.header-company{display:flex;flex-direction:column;line-height:1.15}.header-company span{font-size:11px;font-weight:700;letter-spacing:-.02em;background:linear-gradient(to right,#fff,#fffc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:all .3s ease}.header-brand:hover .header-company span{background:linear-gradient(to right,#6bc5d8,#204f6e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-divider{width:1px;height:32px;background:linear-gradient(to bottom,transparent,rgba(107,197,216,.4),transparent);margin:0 4px}.header-app-title{display:flex;flex-direction:column;gap:2px}.header-title{font-size:18px;font-weight:700;letter-spacing:-.02em;background:linear-gradient(to right,#fff,#fffc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:all .3s ease}.header-brand:hover .header-title{background:linear-gradient(to right,#6bc5d8,#204f6e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-subtitle{font-size:12px;font-weight:600;color:var(--accent);letter-spacing:.05em}.header-env-badge{padding:2px 8px;font-size:10px;font-weight:700;letter-spacing:.05em;background:#ff6b35;color:#fff;border-radius:4px;margin-left:12px;text-transform:uppercase}.header-center{position:absolute;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px}.header-file-info{display:flex;align-items:center;gap:12px;padding:8px 16px;background:#6bc5d81a;border:1px solid var(--border-accent);border-radius:var(--radius-lg)}.file-name{font-weight:500;color:var(--text-primary);font-size:13px}.file-meta{font-size:12px;color:var(--text-secondary)}.header-actions{display:flex;gap:12px}.header-loading{display:flex;align-items:center;gap:10px;padding:8px 16px;background:#204f6e4d;border:1px solid rgba(107,197,216,.3);border-radius:var(--radius-lg);color:var(--accent);font-size:13px;font-weight:500}.loading-spinner{width:16px;height:16px;border:2px solid var(--accent-secondary);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.btn{padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:6px}.btn-primary{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-secondary) 100%);border:none;color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 4px 20px #6bc5d866;transform:translateY(-1px)}.btn-secondary{background:#ffffff0d;border:1px solid var(--border);color:var(--text-secondary)}.btn-secondary:hover:not(:disabled){background:#ffffff1a;border-color:var(--border-accent);color:var(--text-primary)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:transparent;border:none;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){color:var(--text-primary);background:#ffffff0d}.btn-accent{background:var(--accent);border:none;color:var(--bg-tertiary);font-weight:600;transition:all .3s ease}.btn-accent:hover:not(:disabled){background:#8dd8e8;box-shadow:0 4px 20px #6bc5d866;transform:translateY(-1px)}.header-auth-buttons{display:flex;gap:8px;align-items:center;margin-left:8px;padding-left:16px;border-left:1px solid var(--border)}@media (max-width: 768px){.header{padding:12px 16px;flex-wrap:wrap;gap:10px}.header-left{gap:12px;flex:1;min-width:0}.header-logo{width:36px;height:36px}.header-logo-text{font-size:13px}.header-company{display:none}.header-divider{height:32px}.header-title{font-size:16px}.header-subtitle{font-size:10px}.header-center,.header-file-info{display:none}.header-actions{gap:8px}.btn{padding:10px 14px;font-size:13px;min-height:44px}.header-loading{padding:8px 12px;font-size:12px}}@media (max-width: 480px){.header{padding:10px 12px}.header-logo{width:32px;height:32px}.header-logo-text{font-size:11px}.header-divider{display:none}.header-app-title{gap:0}.header-title{font-size:14px}.header-subtitle{font-size:9px}.header-actions{gap:6px}.btn{padding:10px 12px;min-height:44px}.btn span:not(.btn-icon){display:none}.btn .btn-icon{margin:0}.header-loading{padding:6px 10px;font-size:11px}.header-loading span{display:none}.loading-spinner{width:14px;height:14px}}@media (hover: none) and (pointer: coarse){.btn{min-height:44px;min-width:44px}.btn:active{transform:scale(.97)}.btn-primary:active{box-shadow:0 2px 10px #6bc5d84d}}.async-media-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:var(--bg-tertiary, #1a1a2e);border:1px solid var(--border-color, #2a2a4a);border-radius:8px;color:var(--text-secondary, #888);min-height:100px;width:100%;height:100%}.async-media-placeholder.error{background:#ef44440d;border-color:#ef444433;color:#ef4444}.async-media-placeholder.audio{min-height:54px;flex-direction:row}.async-media-placeholder.image{min-height:60px}.async-media-placeholder.iframe{min-height:200px}.async-media-spinner,.async-link-spinner{width:20px;height:20px;border:2px solid var(--border-color, #2a2a4a);border-top-color:var(--accent-color, #8b5cf6);border-radius:50%;animation:async-spin .8s linear infinite}.async-link-spinner{width:14px;height:14px;display:inline-block;margin-right:6px;vertical-align:middle}@keyframes async-spin{to{transform:rotate(360deg)}}.async-media-text{font-size:.875rem}.async-media-icon{font-size:1.5rem}.async-link{display:inline-flex;align-items:center;transition:opacity .2s}.async-link-loading{opacity:.6;cursor:wait}.async-link-error{opacity:.5;cursor:not-allowed;text-decoration:line-through}.async-video{display:block;width:100%;max-width:100%;border-radius:8px;background:#000}.async-video-loading,.async-video-error{aspect-ratio:16 / 9;width:100%}.async-audio{display:block;width:100%}.async-audio-loading,.async-audio-error{height:54px;width:100%}.async-image{display:block;max-width:100%;border-radius:4px}.async-image-loading,.async-image-error{display:flex;align-items:center;justify-content:center}.async-iframe{display:block;width:100%;border:none;border-radius:8px;background:#fff}.async-iframe-loading,.async-iframe-error{min-height:300px;width:100%}.async-thumbnail{width:80px;height:45px;object-fit:cover;border-radius:4px}.async-thumbnail-loading,.async-thumbnail-error{width:80px;height:45px}.async-thumbnail-loading .async-media-placeholder,.async-thumbnail-error .async-media-placeholder{min-height:45px;border-radius:4px}.async-thumbnail-loading .async-media-spinner{width:16px;height:16px}.sidebar{position:relative;width:300px;min-width:200px;max-width:600px;background:linear-gradient(180deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);border-right:1px solid var(--border);overflow-y:auto;display:flex;flex-direction:column}.sidebar-resize-handle{position:absolute;top:0;right:0;width:4px;height:100%;cursor:col-resize;background:transparent;transition:background var(--transition-fast);z-index:10}.sidebar-resize-handle:hover{background:var(--accent)}.sidebar-open-file{padding:16px;border-bottom:1px solid var(--border)}.sidebar-open-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;font-size:14px}.sidebar-open-btn .btn-icon{font-size:16px}.sidebar-current-file{display:flex;align-items:center;gap:8px;margin-top:12px;padding:8px 12px;background:#0003;border-radius:var(--radius-md);border:1px solid var(--border)}.current-file-icon{font-size:14px;flex-shrink:0}.current-file-name{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-header{padding:16px;border-bottom:1px solid var(--border);background:#0003}.sidebar-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.sidebar-content{padding:12px;flex:1}.sidebar-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;color:var(--text-muted);text-align:center;padding:20px}.sidebar-empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.sidebar-empty-text{font-size:13px;line-height:1.6}.tree-item{-webkit-user-select:none;user-select:none}.tree-item-header{display:flex;align-items:center;padding:8px 12px;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);margin-bottom:2px}.tree-item-header:hover{background:#6bc5d81a}.tree-item-header.selected{background:linear-gradient(90deg,#6bc5d833,#204f6e26);border:1px solid var(--border-accent);box-shadow:0 0 12px #6bc5d826}.tree-item-header.selected .tree-label{color:var(--accent);font-weight:500}.tree-arrow{width:20px;font-size:10px;color:var(--text-secondary);transition:transform var(--transition-fast);display:flex;align-items:center;justify-content:center}.tree-arrow.open{transform:rotate(90deg);color:var(--accent)}.tree-arrow-placeholder{width:20px}.tree-label{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.tree-children{padding-left:20px;border-left:1px solid var(--border);margin-left:10px}.tree-download-btn{margin-left:auto;padding:2px 6px;background:#6bc5d826;border:1px solid var(--border-accent);border-radius:var(--radius-sm);color:var(--accent);text-decoration:none;font-size:12px;opacity:.7;transition:all var(--transition-fast)}.tree-download-btn:hover{opacity:1;background:#6bc5d840;box-shadow:0 0 8px #6bc5d84d}.tree-item-header:hover .tree-download-btn{opacity:1}.tree-item-header.esg-service{background:linear-gradient(90deg,rgba(32,79,110,.1) 0%,transparent 100%)}.tree-esg-badge{margin-left:auto;padding:2px 6px;background:#204f6e40;border:1px solid rgba(32,79,110,.4);border-radius:var(--radius-sm);color:#d17aff;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.tab-bar{background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:0 16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.tab-bar-inner{display:flex;gap:4px;padding-top:8px;flex-wrap:nowrap}.tab-item{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:transparent;border:none;border-radius:var(--radius-md) var(--radius-md) 0 0;color:var(--text-secondary);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);position:relative;min-height:44px;min-width:44px;flex-shrink:0;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:rgba(107,197,216,.2)}.tab-item:hover{color:var(--accent);background:#ffffff0d}.tab-item:before{content:"";position:absolute;bottom:1px;left:16px;right:16px;height:1px;background:linear-gradient(to right,transparent,var(--accent),transparent);opacity:0;transition:opacity .3s ease}.tab-item:hover:before{opacity:1}.tab-item.active{color:var(--accent);background:var(--bg-tertiary)}.tab-item.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--accent);border-radius:2px 2px 0 0}.tab-icon{font-size:14px;display:flex;align-items:center;justify-content:center}.tab-img-icon{width:18px;height:18px;border-radius:2px;object-fit:cover}.tab-label{white-space:nowrap}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:18px;padding:0 6px;background:#6bc5d833;color:var(--accent);font-size:11px;font-weight:600;border-radius:var(--radius-md)}.tab-item.active .tab-badge{background:var(--accent);color:#000}.tab-item.alp .tab-label{font-family:var(--font-mono, monospace);font-weight:600}.tab-item.alp.active{color:#00dfff}@media (max-width: 768px){.tab-bar{padding:0 12px}.tab-item{padding:12px 14px;font-size:12px}.tab-icon{font-size:16px}.tab-badge{min-width:18px;height:16px;font-size:10px;padding:0 4px}}@media (max-width: 480px){.tab-bar{padding:0 8px;scrollbar-width:none;-ms-overflow-style:none}.tab-bar::-webkit-scrollbar{display:none}.tab-bar-inner{gap:2px}.tab-item{padding:10px 12px;min-width:48px}.tab-label{display:none}.tab-icon{font-size:18px;margin:0}.tab-badge{display:none}.tab-item.active{background:var(--bg-tertiary)}.tab-item.active:after{height:3px}}@media (hover: none) and (pointer: coarse){.tab-item:active{background:#6bc5d826;transform:scale(.98)}}.overview-tab{padding:16px;overflow-y:auto;height:100%}.overview-summary{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.summary-card{flex:1;min-width:140px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;text-align:center}.summary-card-value{font-size:24px;font-weight:600;color:var(--accent);font-family:SF Mono,Monaco,Consolas,monospace;margin-bottom:4px}.summary-card-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.overview-section+.overview-section{margin-top:var(--space-md)}.overview-table-wrapper{overflow-x:auto}.overview-table{width:100%;border-collapse:collapse;font-size:12px}.overview-table th{text-align:left;padding:8px 12px;background:#0003;color:var(--text-secondary);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--border)}.overview-table th.right{text-align:right}.overview-table td{padding:8px 12px;color:var(--text-primary);border-bottom:1px solid var(--border)}.overview-table tr:last-child td{border-bottom:none}.overview-table tr:hover{background:#6bc5d80d}.overview-table tr.lls-row{background:#204f6e0d}.overview-table tr.lls-row:hover{background:#204f6e1a}.overview-table td.right{text-align:right;font-family:SF Mono,Monaco,Consolas,monospace}.overview-table td.destination{font-family:SF Mono,Monaco,Consolas,monospace;color:var(--accent)}.overview-table td.bytes{color:var(--text-secondary)}.overview-table .service-id{font-family:SF Mono,Monaco,Consolas,monospace;color:var(--text-primary)}.drm-warning{display:flex;gap:16px;padding:16px;margin-bottom:16px;background:linear-gradient(135deg,#ff950026,#ff3b3026);border:1px solid rgba(255,149,0,.4);border-radius:var(--radius-lg)}.drm-warning-icon{font-size:32px;line-height:1}.drm-warning-content{flex:1}.drm-warning-title{font-size:16px;font-weight:600;color:var(--warning);margin-bottom:6px}.drm-service-count{font-size:13px;font-weight:400;color:#ffb340;margin-left:8px}.drm-warning-details{display:flex;gap:16px;margin-bottom:8px}.drm-scheme{display:inline-block;padding:3px 10px;background:#ff950040;border-radius:var(--radius-sm);font-size:12px;font-weight:600;color:#ffb340}.drm-keyid{font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px;color:var(--text-secondary);padding:3px 8px;background:#0000004d;border-radius:var(--radius-sm)}.drm-warning-note{font-size:12px;color:var(--text-secondary);line-height:1.4}.bandwidth-chart{padding:16px}.bandwidth-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:8px}.bandwidth-header-left{display:flex;align-items:center;gap:12px}.bandwidth-header-right{display:flex;align-items:center;gap:8px}.bandwidth-title{font-size:13px;font-weight:600;color:var(--text-primary)}.bandwidth-duration{font-size:11px;color:var(--text-secondary);padding:3px 8px;background:#ffffff0d;border-radius:var(--radius-sm);cursor:help}.bandwidth-total-bitrate{font-size:12px;font-weight:600;color:var(--accent);font-family:SF Mono,Monaco,Consolas,monospace;padding:4px 10px;background:#6bc5d826;border-radius:var(--radius-sm)}.bandwidth-total{font-size:12px;color:var(--text-secondary);font-family:SF Mono,Monaco,Consolas,monospace;padding:4px 10px;background:#ffffff0d;border-radius:var(--radius-sm)}.bandwidth-bars{display:flex;flex-direction:column;gap:10px}.bandwidth-row{display:flex;align-items:center;gap:12px}.bandwidth-label{display:flex;align-items:center;gap:8px;min-width:140px;flex-shrink:0}.bandwidth-color{width:10px;height:10px;border-radius:2px;flex-shrink:0}.bandwidth-name{font-size:12px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bandwidth-bar-container{flex:1;height:20px;background:#ffffff0d;border-radius:var(--radius-sm);overflow:hidden;min-width:100px}.bandwidth-bar{height:100%;border-radius:var(--radius-sm);transition:width .3s ease;min-width:2px}.bandwidth-stats{display:flex;gap:8px;min-width:130px;justify-content:flex-end;flex-shrink:0}.bandwidth-bytes{font-size:11px;font-family:SF Mono,Monaco,Consolas,monospace;color:var(--text-primary);min-width:70px;text-align:right}.bandwidth-percent{font-size:11px;font-family:SF Mono,Monaco,Consolas,monospace;color:var(--text-secondary);min-width:45px;text-align:right}.bandwidth-bitrate{font-size:11px;font-family:SF Mono,Monaco,Consolas,monospace;color:var(--accent);min-width:75px;text-align:right}.bandwidth-note{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);font-size:10px;color:var(--text-muted);font-style:italic}.overview-section+.overview-section{margin-top:16px}.summary-card.stltp{background:linear-gradient(135deg,#204f6e1a,#6bc5d81a);border-color:#204f6e4d}.summary-card.stltp .summary-card-value{color:var(--accent-secondary)}.stltp-section{border-color:#204f6e4d}.stltp-section .overview-section-header{background:linear-gradient(135deg,#204f6e1a,#6bc5d80d)}.section-badge{font-size:9px;padding:2px 6px;border-radius:3px;font-weight:600;text-transform:uppercase}.section-badge.stltp{background:#204f6e40;color:var(--accent-secondary)}.plp-bars{display:flex;flex-direction:column;gap:10px}.plp-note{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);font-size:11px;color:var(--text-muted);font-style:italic}.l1-section:last-of-type{margin-bottom:8px}.l1-note{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);font-size:11px;color:var(--text-muted);font-style:italic}.protocol-flowchart{padding:16px}.protocol-flowchart-title{font-size:14px;font-weight:600;color:var(--accent);margin-bottom:4px}.protocol-flowchart-subtitle{font-size:11px;color:var(--text-secondary);margin-bottom:24px}.flowchart-container{display:flex;flex-direction:column;align-items:center;max-width:600px;margin:0 auto}.flowchart-box{border:2px solid rgba(255,255,255,.3);border-radius:var(--radius-lg);padding:16px 32px;text-align:center;background:#0000004d;min-width:280px}.flowchart-box.alp{border-color:var(--accent-secondary);background:linear-gradient(135deg,#204f6e26,#204f6e0d)}.flowchart-box.ip{border-color:var(--warning);background:linear-gradient(135deg,#ff950026,#ff95000d)}.flowchart-box-title{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.flowchart-box-stat{font-size:12px;color:var(--text-secondary);font-family:SF Mono,Monaco,Consolas,monospace}.flowchart-connector.vertical{width:2px;height:24px;background:#ffffff4d}.flowchart-connector.vertical.short{height:16px}.flowchart-branch-line{height:2px;background:#ffffff4d;width:calc(100% - 80px);max-width:calc(var(--branch-count, 2) * 140px - 60px);position:relative}.flowchart-branch-connectors{display:flex;justify-content:space-between;width:calc(100% - 80px);max-width:calc(var(--branch-count, 2) * 140px - 60px)}.flowchart-branches{display:flex;justify-content:center;gap:24px;width:100%}.flowchart-box.branch{min-width:120px;max-width:160px;padding:12px 20px;border-color:var(--box-color, #00dfff);background:linear-gradient(135deg,color-mix(in srgb,var(--box-color, #00dfff) 15%,transparent),color-mix(in srgb,var(--box-color, #00dfff) 5%,transparent))}.flowchart-box.branch.lls{border-color:var(--accent-secondary);background:linear-gradient(135deg,#204f6e26,#204f6e0d)}.flowchart-box.branch.route{border-color:var(--accent);background:linear-gradient(135deg,#6bc5d826,#6bc5d80d)}.flowchart-box.branch.mmtp{border-color:var(--success);background:linear-gradient(135deg,#4cd96426,#4cd9640d)}.flowchart-box.branch .flowchart-box-title{font-size:13px}.flowchart-box.branch .flowchart-box-stat{font-size:11px}.flowchart-branch-column{display:flex;flex-direction:column;align-items:center}.flowchart-sub-branch{display:flex;flex-direction:column;align-items:center;margin-top:0}.flowchart-sub-items{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;max-width:200px}.flowchart-sub-item{font-size:10px;font-weight:500;padding:3px 8px;border-radius:4px;background:color-mix(in srgb,var(--box-color, #204F6E) 20%,transparent);border:1px solid color-mix(in srgb,var(--box-color, #204F6E) 40%,transparent);color:var(--text-primary);font-family:SF Mono,Monaco,Consolas,monospace}@media (max-width: 500px){.flowchart-box{min-width:200px;padding:12px 20px}.flowchart-branches{flex-direction:column;align-items:center;gap:12px}.flowchart-branch-line,.flowchart-branch-connectors{display:none}.flowchart-box.branch{min-width:160px}.flowchart-sub-items{max-width:100%}}.stltp-charts-section{margin-top:20px;padding-top:16px;border-top:1px solid rgba(32,79,110,.2)}.stltp-charts-title{font-size:14px;font-weight:600;color:var(--accent-secondary);margin-bottom:16px}.stltp-charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:16px}.stltp-chart{background:#0003;border:1px solid rgba(32,79,110,.15);border-radius:var(--radius-lg);padding:16px}@media (max-width: 768px){.stltp-charts-grid{grid-template-columns:1fr}.radar-chart-container{flex-direction:column;align-items:center}.radar-legend{width:100%}.ti-row{flex-wrap:wrap}.ti-description{width:100%;margin-top:4px}.efficiency-row,.capacity-row{flex-wrap:wrap}.efficiency-label,.capacity-label{width:100%;margin-bottom:4px}.frame-allocation-legend{flex-direction:column;gap:6px}}.overview-tab.lls-view{padding:0;display:flex;flex-direction:column}.lls-viewer-full{flex:1;display:flex;flex-direction:column;background:var(--bg-secondary);border-radius:var(--radius-lg);margin:16px;border:1px solid var(--border);overflow:hidden}.lls-viewer-header{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-tertiary);border-bottom:1px solid var(--border)}.lls-close-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#6bc5d826;border:1px solid var(--border-accent);border-radius:var(--radius-md);color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);margin-right:12px}.lls-close-btn:hover{background:#6bc5d840;box-shadow:var(--glow-accent)}.lls-icon{font-size:20px}.lls-filename{font-size:15px;font-weight:600;color:var(--text-primary)}.lls-badge{padding:4px 10px;background:#204f6e33;border:1px solid rgba(32,79,110,.4);border-radius:var(--radius-sm);font-size:10px;font-weight:600;color:var(--accent-secondary);text-transform:uppercase}.lls-download-btn{margin-left:auto;display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:#6bc5d81a;border:1px solid var(--border-accent);border-radius:var(--radius-sm);color:var(--accent);font-size:12px;font-weight:500;text-decoration:none;cursor:pointer;transition:all var(--transition-fast)}.lls-download-btn:hover{background:#6bc5d833;box-shadow:var(--glow-accent)}.lls-viewer-body{flex:1;overflow:auto;padding:16px}.xml-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%;color:var(--text-secondary);font-size:14px}.lls-xml-viewer{background:#0000004d;border-radius:var(--radius-md);padding:16px;margin:0;min-height:100%;overflow:auto;font-family:SF Mono,Monaco,Consolas,monospace;font-size:13px;line-height:1.6;color:var(--text-primary);white-space:pre}.lls-xml-viewer code{font-family:inherit}.services-tab{padding:16px;overflow-y:auto;height:100%}.services-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.services-title{font-weight:600;font-size:14px;color:var(--accent)}.services-count{font-size:12px;color:var(--text-secondary);padding:2px 8px;background:#6bc5d81a;border-radius:var(--radius-sm)}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.service-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.service-card-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--bg-tertiary);border-bottom:1px solid var(--border)}.service-card-title{font-weight:600;font-size:14px;color:var(--accent)}.service-short-name{font-size:12px;color:var(--text-secondary);padding:3px 10px;background:#6bc5d81a;border-radius:var(--radius-sm)}.service-card-body{padding:12px 14px}.category-name{color:var(--text-secondary);margin-left:6px}.sls-files{display:flex;flex-wrap:wrap;gap:4px}.sls-file-held{background:#ff950033;color:var(--warning)}.sls-file-usbd{background:#6bc5d826;color:var(--accent)}.sls-file-stsid{background:#4cd96426;color:var(--success)}.sls-file-mpd{background:#204f6e26;color:var(--accent-secondary)}.sls-file-envelope,.sls-file-sls{background:#ffffff1a;color:var(--text-secondary)}.tsi-summary{display:flex;flex-wrap:wrap;gap:6px}.service-card.drm-protected{border-color:#ff950066}.service-card.drm-protected .service-card-header{background:linear-gradient(135deg,#ff95001a,#ff3b301a)}.service-card.esg-service{border-color:#204f6e66}.service-card.esg-service .service-card-header{background:linear-gradient(135deg,#204f6e1a,#5856d61a)}.service-esg-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;padding:3px 8px;background:#204f6e40;color:#d17aff;border-radius:var(--radius-sm);margin-left:auto;cursor:help;text-transform:uppercase;letter-spacing:.5px}.service-drm-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;padding:3px 8px;background:#ff950040;color:#ffb340;border-radius:var(--radius-sm);margin-left:auto;cursor:help}.health-indicator{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--radius-sm);font-size:10px;font-weight:600;cursor:help;margin-right:8px}.health-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.health-label{text-transform:uppercase;letter-spacing:.3px}.health-healthy{background:#4cd96426}.health-healthy .health-dot{background:var(--success);box-shadow:0 0 6px #4cd96480}.health-healthy .health-label{color:var(--success)}.health-warning{background:#ff950026}.health-warning .health-dot{background:var(--warning);box-shadow:0 0 6px #ff950080}.health-warning .health-label{color:#ffb340}.health-error{background:#ff3b3026}.health-error .health-dot{background:var(--error);box-shadow:0 0 6px #ff3b3080}.health-error .health-label{color:var(--error)}.media-tab{height:100%;overflow:hidden}.media-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary)}.media-empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.media-empty-text{font-size:14px}.media-browser{display:flex;height:100%}.media-list{width:280px;flex-shrink:0;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column}.media-list-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--bg-tertiary);border-bottom:1px solid var(--border)}.media-list-title{font-weight:600;font-size:13px;color:var(--accent)}.media-list-count{font-size:11px;color:var(--text-secondary);padding:2px 8px;background:#6bc5d81a;border-radius:var(--radius-sm)}.media-segments-toggle{padding:8px 12px;border-bottom:1px solid var(--border);background:#0000001a}.toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:12px;color:var(--text-secondary)}.toggle-label input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent);cursor:pointer}.toggle-label:hover{color:var(--text-primary)}.toggle-text{-webkit-user-select:none;user-select:none}.media-list-content{flex:1;overflow-y:auto;padding:8px}.media-group{margin-bottom:8px}.media-group-header{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;padding:6px 8px;margin-bottom:4px}.media-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.media-item:hover{background:#ffffff0d}.media-item.selected{background:#6bc5d826}.media-item.assembled{border-left:2px solid var(--accent);padding-left:8px}.media-item-icon{font-size:14px;flex-shrink:0}.media-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.media-item-name{font-size:12px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.media-item.selected .media-item-name{color:var(--accent)}.media-item-meta{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--text-secondary);font-family:SF Mono,Monaco,Consolas,monospace}.media-item-size{font-size:10px;color:var(--text-secondary);font-family:SF Mono,Monaco,Consolas,monospace}.media-item-badge{font-size:9px;padding:2px 5px;border-radius:3px;font-weight:600;text-transform:uppercase}.media-item-badge.video{background:#6bc5d833;color:var(--accent)}.media-thumbnail{width:64px;height:36px;flex-shrink:0;border-radius:var(--radius-sm);overflow:hidden;background:#0000004d;display:flex;align-items:center;justify-content:center;position:relative;border:1px solid var(--border);transition:all var(--transition-fast)}.media-thumbnail.selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.media-thumbnail img{width:100%;height:100%;object-fit:cover}.media-thumbnail .thumbnail-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;background:#0009;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;color:#fff;opacity:0;transition:opacity var(--transition-fast)}.media-item:hover .media-thumbnail .thumbnail-play{opacity:1}.media-thumbnail.audio{background:linear-gradient(135deg,#4cd96433,#4cd9641a)}.media-thumbnail .thumbnail-icon{font-size:20px;opacity:.7}.media-thumbnail.loading{background:#0003}.media-thumbnail .thumbnail-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.media-thumbnail.error{background:#ff3b301a}.media-thumbnail .thumbnail-drm{position:absolute;top:2px;right:2px;font-size:10px;background:#ff3b30e6;border-radius:3px;padding:1px 3px;line-height:1}.media-item-badge.audio{background:#4cd96433;color:var(--success)}.media-preview{flex:1;display:flex;flex-direction:column;overflow:hidden}.media-preview-header{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.media-preview-icon{font-size:18px}.media-preview-name{font-weight:600;font-size:14px;color:var(--text-primary)}.media-preview-size{margin-left:auto;font-size:12px;color:var(--text-secondary);font-family:SF Mono,Monaco,Consolas,monospace}.media-preview-content{flex:1;overflow-y:auto;padding:16px}.media-preview-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);font-size:14px}.media-player{max-width:800px;margin:0 auto}.media-player video,.media-player audio{width:100%;border-radius:var(--radius-lg);background:#000}.audio-player-wrapper{display:flex;flex-direction:column;align-items:center;gap:20px;padding:40px;background:var(--bg-secondary);border-radius:var(--radius-lg)}.audio-icon{font-size:64px;opacity:.5}.audio-player-wrapper audio{width:100%;max-width:400px}.media-fallback{margin-top:16px;padding:12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);text-align:center}.media-fallback p{font-size:12px;color:var(--text-secondary);margin-bottom:10px}.media-fallback .btn-download{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#6bc5d826;border:1px solid var(--border-accent);border-radius:var(--radius-md);color:var(--accent);font-size:12px;font-weight:500;text-decoration:none;cursor:pointer;transition:all var(--transition-fast)}.media-fallback .btn-download:hover{background:#6bc5d840;box-shadow:var(--glow-accent)}.media-item-badge.captions{background:#ff950033;color:var(--warning)}.media-thumbnail.captions{background:linear-gradient(135deg,#ff950033,#ff95001a)}.captions-player{max-width:600px;margin:0 auto}.captions-info{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px;background:var(--bg-secondary);border-radius:var(--radius-lg);text-align:center}.captions-icon{font-size:64px;opacity:.5}.captions-text h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.captions-text p{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-bottom:8px}.captions-text p:last-child{margin-bottom:0}.segment-player{max-width:600px;margin:0 auto}.segment-info{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px;background:var(--bg-secondary);border-radius:var(--radius-lg);text-align:center}.segment-icon{font-size:64px;opacity:.5}.segment-text h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.segment-text p{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-bottom:8px}.segment-text p:last-child{margin-bottom:0}.partial-warning{display:flex;gap:12px;padding:12px 16px;background:#ff950026;border:1px solid rgba(255,149,0,.3);border-radius:var(--radius-md);margin-bottom:16px}.partial-warning-icon{font-size:20px;flex-shrink:0}.partial-warning-text{flex:1}.partial-warning-text strong{display:block;font-size:13px;font-weight:600;color:var(--warning);margin-bottom:4px}.partial-warning-text p{font-size:12px;color:var(--text-secondary);margin:0;line-height:1.4}.sls-tab{padding:16px;overflow-y:auto;height:100%;display:flex;flex-direction:column;gap:16px}.sls-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary)}.sls-empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.sls-empty-text{font-size:14px}.sls-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.sls-section-header{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg-tertiary);border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast)}.sls-section-header:hover{background:#ffffff0d}.section-arrow{font-size:10px;color:var(--text-secondary);transition:transform var(--transition-fast)}.route-sessions-list{font-size:12px;overflow-x:auto}.route-filter-bar{display:flex;align-items:center;gap:6px;padding:10px 12px;background:#00000026;border-bottom:1px solid var(--border);flex-wrap:wrap}.filter-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-right:4px}.filter-btn{padding:5px 10px;background:#ffffff0d;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:11px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-transform:capitalize}.filter-btn:hover{background:#ffffff1a;color:var(--text-primary)}.filter-btn.active{background:#6bc5d833;border-color:var(--border-accent);color:var(--accent)}.filter-btn.filter-video.active{background:#6bc5d833;color:var(--accent)}.filter-btn.filter-audio.active{background:#4cd96433;color:var(--success)}.filter-btn.filter-SLS.active{background:#204f6e33;color:var(--accent-secondary)}.filter-btn.filter-app.active{background:#ff950033;color:var(--warning)}.filter-btn.filter-esg.active{background:#5856d633;color:var(--color-indigo)}.filter-spacer{flex:1}.collapse-all-btn{padding:5px 10px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:11px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.collapse-all-btn:hover{background:#ffffff0d;color:var(--text-primary)}.service-group{border-bottom:1px solid var(--border)}.service-group:last-child{border-bottom:none}.service-group-header{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#6bc5d80d;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast)}.service-group-header:hover{background:#6bc5d81a}.group-arrow{font-size:10px;color:var(--text-secondary);transition:transform var(--transition-fast)}.group-arrow.open{transform:rotate(90deg)}.group-title{font-weight:600;font-size:13px;color:var(--accent)}.group-name{font-size:12px;color:var(--text-secondary);padding:2px 8px;background:#6bc5d81a;border-radius:var(--radius-sm)}.group-stats{margin-left:auto;font-size:11px;color:var(--text-secondary)}.route-list-header,.route-list-row{display:flex;align-items:center;padding:8px 12px;gap:8px;min-width:max-content}.route-list-header{background:#0003;color:var(--text-secondary);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--border)}.route-list-row{border-bottom:1px solid var(--border)}.route-list-row:last-child{border-bottom:none}.route-list-row:hover{background:#6bc5d80d}.col-tsi{width:50px;flex-shrink:0;font-family:SF Mono,Monaco,Consolas,monospace}.col-type{width:110px;flex-shrink:0}.col-codec{width:180px;flex-shrink:0;font-size:11px}.col-payload{width:90px;flex-shrink:0;color:var(--text-secondary)}.col-fec{width:60px;flex-shrink:0;color:var(--text-secondary)}.col-packets{width:80px;flex-shrink:0;text-align:right;font-family:SF Mono,Monaco,Consolas,monospace}.col-bytes{width:90px;flex-shrink:0;text-align:right;font-family:SF Mono,Monaco,Consolas,monospace}.col-toi-count{width:50px;flex-shrink:0;text-align:right;font-family:SF Mono,Monaco,Consolas,monospace}.col-toi-list{flex:1;min-width:150px;font-family:SF Mono,Monaco,Consolas,monospace;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-download{width:70px;flex-shrink:0;text-align:center}.download-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:#6bc5d81a;border:1px solid var(--border-accent);border-radius:var(--radius-sm);text-decoration:none;font-size:14px;cursor:pointer;transition:all var(--transition-fast)}.download-btn:hover{background:#6bc5d833;box-shadow:var(--glow-accent)}.type-badge{display:inline-block;padding:3px 8px;border-radius:var(--radius-sm);font-size:10px;font-weight:600;text-transform:uppercase}.type-video{background:#6bc5d826;color:var(--accent)}.type-audio{background:#4cd96426;color:var(--success)}.type-app{background:#ff950026;color:var(--warning)}.type-esg{background:#5856d633;color:var(--color-indigo)}.type-SLS{background:#204f6e33;color:var(--accent-secondary)}.type-unknown{background:#ffffff1a;color:var(--text-secondary)}.lang-tag{margin-left:4px;font-size:9px;padding:1px 4px;background:#ffffff1a;border-radius:3px;color:var(--text-secondary)}.codec-info{display:inline-block;font-family:SF Mono,Monaco,Consolas,monospace;color:var(--text-primary);cursor:help}.file-viewer-section{flex:0 0 auto;max-height:60vh;display:flex;flex-direction:column}.file-viewer-section .sls-section-header{cursor:default}.file-viewer-content{flex:1;overflow:auto;padding:12px}.xml-viewer{background:#0003;border-radius:var(--radius-md);padding:12px;margin:0;overflow:auto;font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;line-height:1.5;color:var(--text-primary);white-space:pre}.xml-viewer code{font-family:inherit}.sls-hint{text-align:center;padding:24px;color:var(--text-secondary);font-size:13px}.expand-btn{margin-left:6px;padding:2px 6px;background:#ff950026;border:1px solid rgba(255,149,0,.3);border-radius:var(--radius-sm);color:var(--warning);font-size:10px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.expand-btn:hover{background:#ff950040;border-color:#ff950080}.route-list-row.expandable{cursor:default}.app-files-list{background:#ff95000d;border-top:1px solid rgba(255,149,0,.2);padding:8px 12px 8px 80px}.app-file-row{display:flex;align-items:center;gap:10px;padding:6px 10px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:4px;transition:all var(--transition-fast)}.app-file-row:last-child{margin-bottom:0}.app-file-row:hover{border-color:#ff950066;background:#ff950014}.app-file-icon{font-size:16px;flex-shrink:0}.app-file-name{flex:1;font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-file-size{font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px;color:var(--text-secondary);flex-shrink:0}.app-file-row .download-btn{flex-shrink:0}.header-download-btn{margin-left:auto;display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#6bc5d81a;border:1px solid var(--border-accent);border-radius:var(--radius-sm);color:var(--accent);font-size:11px;font-weight:500;text-decoration:none;cursor:pointer;transition:all var(--transition-fast)}.header-download-btn:hover{background:#6bc5d833;box-shadow:var(--glow-accent)}.code-viewer{background:#0003;border-radius:var(--radius-md);padding:12px;margin:0;overflow:auto;font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;line-height:1.5;color:var(--text-primary);white-space:pre}.code-viewer code{font-family:inherit}.html-viewer{color:#e6db74}.js-viewer{color:#a6e22e}.css-viewer{color:#66d9ef}.json-viewer{color:#fd971f}.html-view-toggle{display:flex;gap:2px;margin-left:12px;background:#0003;border-radius:var(--radius-sm);padding:2px}.html-view-toggle .toggle-btn{padding:4px 12px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:11px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.html-view-toggle .toggle-btn:hover{color:var(--text-primary);background:#ffffff0d}.html-view-toggle .toggle-btn.active{background:var(--accent);color:#000}.html-preview-container{background:#fff;border-radius:var(--radius-md);overflow:hidden;min-height:300px;height:100%}.html-preview-frame{width:100%;height:100%;min-height:400px;border:none;background:#fff}.esg-tab{height:100%;overflow:hidden;display:flex;flex-direction:column}.esg-loading-banner{background:linear-gradient(90deg,#5856d633,#204f6e33);border-bottom:1px solid rgba(32,79,110,.3);padding:8px 16px;font-size:12px;color:#d17aff;text-align:center;flex-shrink:0;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.7}50%{opacity:1}}.esg-loading-progress{margin-top:8px;font-size:12px;color:var(--text-secondary)}.esg-delivery-info{background:linear-gradient(135deg,#204f6e1a,#5856d61a);border-bottom:1px solid rgba(32,79,110,.3);padding:12px 16px;flex-shrink:0}.esg-delivery-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.esg-delivery-icon{font-size:18px}.esg-delivery-title{font-weight:600;font-size:14px;color:#d17aff}.esg-delivery-badge{font-size:10px;font-weight:600;padding:3px 8px;background:#204f6e40;color:#d17aff;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px}.esg-delivery-details{display:flex;flex-wrap:wrap;gap:16px}.esg-delivery-row{display:flex;align-items:center;gap:6px;font-size:12px}.esg-delivery-label{color:var(--text-secondary)}.esg-delivery-value{color:var(--text-primary)}.esg-delivery-value.mono{font-family:SF Mono,Monaco,Consolas,monospace;color:var(--accent)}.esg-service-selector{background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.esg-service-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.esg-service-title{font-weight:600;font-size:14px;color:var(--accent)}.esg-totals{display:flex;gap:8px}.esg-total-badge{padding:3px 8px;background:#204f6e26;border-radius:var(--radius-sm);font-size:11px;color:var(--accent-secondary)}.esg-service-tabs{display:flex;gap:4px;padding:8px 12px;overflow-x:auto}.esg-service-tab{display:flex;align-items:center;gap:8px;padding:8px 14px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-family:inherit;font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.esg-service-tab:hover{background:#ffffff0d;color:var(--text-primary)}.esg-service-tab.active{background:#6bc5d826;border-color:var(--border-accent);color:var(--accent)}.esg-service-tab-name{max-width:150px;overflow:hidden;text-overflow:ellipsis}.esg-service-tab-count{padding:2px 6px;background:#6bc5d833;border-radius:10px;font-size:10px;font-weight:600}.esg-service-tab.active .esg-service-tab-count{background:var(--accent);color:#000}.esg-content{flex:1;overflow-y:auto;padding:16px}.esg-sgdd-info{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;background:linear-gradient(135deg,#6bc5d81a,#204f6e14);border:1px solid var(--border-accent);border-radius:var(--radius-lg)}.esg-sgdd-badge{padding:4px 10px;background:#6bc5d833;border-radius:var(--radius-sm);font-size:12px;font-weight:600;color:var(--accent)}.esg-sgdd-entries{font-size:12px;color:var(--text-secondary)}.esg-section+.esg-section{margin-top:var(--space-md)}.esg-content-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}.esg-card{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition-fast)}.esg-card:hover{border-color:var(--border-accent)}.esg-card.compact{padding:12px}.esg-card-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#0003}.esg-card.compact .esg-card-header{padding:0;background:none;margin-bottom:8px}.esg-card-name{font-weight:600;font-size:13px;color:var(--text-primary)}.esg-card-badge{padding:2px 6px;background:#6bc5d826;border-radius:var(--radius-sm);font-size:10px;font-weight:500;color:var(--accent)}.esg-card-details{padding:10px 12px}.esg-card-description{color:var(--text-secondary);font-size:12px;margin-bottom:8px;line-height:1.4}.esg-card-meta{display:flex;gap:12px;flex-wrap:wrap}.esg-meta-item{font-size:11px;color:var(--text-secondary);font-family:SF Mono,Monaco,Consolas,monospace}.esg-detail-row{display:flex;padding:6px 0;border-bottom:1px solid var(--border);font-size:12px}.esg-detail-row:last-child{border-bottom:none}.esg-detail-label{min-width:90px;color:var(--text-secondary)}.esg-detail-value{color:var(--text-primary);font-family:SF Mono,Monaco,Consolas,monospace;word-break:break-all}.esg-events{padding:10px 12px;display:flex;flex-direction:column;gap:6px}.esg-event{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:11px}.esg-event-content{color:var(--text-primary);font-weight:500}.esg-event-time{color:var(--text-secondary);font-family:SF Mono,Monaco,Consolas,monospace}.esg-event-more{padding:6px;text-align:center;color:var(--text-muted);font-size:11px}.esg-schedule-id{margin-left:8px;padding:2px 6px;background:#204f6e26;border-radius:var(--radius-sm);font-size:10px;font-weight:400;color:var(--accent-secondary);font-family:SF Mono,Monaco,Consolas,monospace}.esg-sgdd-version{padding:2px 8px;background:#6bc5d833;border-radius:var(--radius-sm);font-size:11px;font-weight:600;color:var(--accent);margin-left:8px}.esg-sgdd-id{padding:2px 8px;background:#204f6e26;border-radius:var(--radius-sm);font-size:10px;color:var(--accent-secondary);font-family:SF Mono,Monaco,Consolas,monospace;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.esg-sgdd-description{font-size:12px;color:var(--text-secondary);margin-bottom:12px;padding:8px 12px;background:#0003;border-radius:var(--radius-sm);border-left:3px solid var(--accent)}.esg-transport-list{display:flex;flex-direction:column;gap:4px}.esg-transport-header{display:grid;grid-template-columns:1fr 180px 80px 180px;gap:12px;padding:8px 12px;font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);margin-bottom:4px}.esg-transport-entry{display:grid;grid-template-columns:1fr 180px 80px 180px;gap:12px;align-items:center;padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.esg-transport-entry:hover{border-color:var(--border-accent);background:#6bc5d80d}.esg-transport-criteria,.esg-transport-service{font-weight:500;font-size:12px;color:var(--text-primary)}.esg-time-window{display:flex;flex-direction:column;gap:2px;font-size:11px}.esg-time-label{font-size:10px;color:var(--text-muted);font-weight:600;text-transform:uppercase}.esg-no-criteria{color:var(--text-muted)}.esg-transport-fragments{text-align:center}.esg-fragment-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;background:#204f6e26;border-radius:12px;font-size:11px;font-weight:600;color:var(--accent-secondary);cursor:help}.esg-fragment-types{font-size:11px;color:var(--text-secondary)}.esg-transport-address{font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px;color:var(--accent)}.esg-transport-tsi{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--accent-secondary)}.esg-transport-details{display:flex;gap:8px;align-items:center}.transport-ip{padding:2px 6px;background:#6bc5d81a;border-radius:var(--radius-sm);color:var(--accent);font-size:11px;font-family:SF Mono,Monaco,Consolas,monospace}.transport-session{padding:2px 6px;background:#204f6e1a;border-radius:var(--radius-sm);color:var(--accent-secondary);font-size:11px}.transport-fdt{padding:2px 5px;background:#4cd96426;border-radius:var(--radius-sm);color:var(--success);font-size:10px;font-weight:600}.physical-layer-tab{padding:16px;overflow-y:auto;height:100%}.physical-layer-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary)}.physical-layer-empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.physical-layer-empty-text{font-size:14px}.physical-layer-empty-hint{font-size:12px;color:var(--text-muted);margin-top:8px}.physical-layer-summary{display:flex;gap:16px;margin-bottom:16px;padding:16px;background:linear-gradient(135deg,#204f6e26,#6bc5d81a);border:1px solid rgba(32,79,110,.3);border-radius:var(--radius-lg);flex-wrap:wrap}.pl-summary-item{display:flex;flex-direction:column;gap:2px;min-width:100px}.pl-summary-value{font-size:20px;font-weight:600;color:var(--accent);font-family:SF Mono,Monaco,Consolas,monospace}.pl-summary-label{font-size:10px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.physical-layer-section{background:var(--bg-secondary);border:1px solid rgba(32,79,110,.2);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:16px}.physical-layer-section-header{display:flex;align-items:center;gap:10px;padding:12px 14px;background:linear-gradient(135deg,#204f6e1a,#6bc5d80d);border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast)}.physical-layer-section-header:hover{background:#204f6e26}.physical-layer-section-header .section-arrow{font-size:10px;color:var(--text-secondary);transition:transform var(--transition-fast)}.physical-layer-section-header .section-arrow.open{transform:rotate(90deg)}.physical-layer-section-header .section-icon{font-size:16px}.physical-layer-section-header .section-title{font-weight:600;font-size:13px;color:var(--accent-secondary)}.physical-layer-section-header .section-count{margin-left:auto;font-size:12px;color:var(--text-secondary);padding:2px 8px;background:#204f6e26;border-radius:var(--radius-sm)}.physical-layer-table-wrapper{overflow-x:auto}.physical-layer-table{width:100%;border-collapse:collapse;font-size:12px}.physical-layer-table th{text-align:left;padding:8px 12px;background:#0003;color:var(--text-secondary);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--border)}.physical-layer-table th.right{text-align:right}.physical-layer-table td{padding:8px 12px;color:var(--text-primary);border-bottom:1px solid var(--border)}.physical-layer-table tr:last-child td{border-bottom:none}.physical-layer-table tr:hover{background:#204f6e0d}.physical-layer-table td.right{text-align:right;font-family:SF Mono,Monaco,Consolas,monospace}.plp-stats-content{padding:16px}.plp-stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.plp-total{font-size:13px;font-weight:600;color:var(--accent-secondary);font-family:SF Mono,Monaco,Consolas,monospace}.plp-packets{font-size:12px;color:var(--text-secondary);font-family:SF Mono,Monaco,Consolas,monospace}.plp-bars{display:flex;flex-direction:column;gap:10px;margin-top:16px}.plp-row{display:flex;align-items:center;gap:12px}.plp-label{display:flex;align-items:center;gap:8px;min-width:80px;flex-shrink:0}.plp-color{width:12px;height:12px;border-radius:3px;flex-shrink:0}.plp-name{font-size:13px;font-weight:600;color:var(--text-primary);font-family:SF Mono,Monaco,Consolas,monospace}.plp-bar-container{flex:1;height:24px;background:#ffffff0d;border-radius:var(--radius-sm);overflow:hidden;min-width:100px}.plp-bar{height:100%;border-radius:var(--radius-sm);transition:width .3s ease;min-width:4px}.plp-stats{display:flex;gap:12px;min-width:150px;justify-content:flex-end;flex-shrink:0}.plp-bytes{font-size:12px;font-family:SF Mono,Monaco,Consolas,monospace;color:var(--text-primary);min-width:80px;text-align:right}.plp-percent{font-size:12px;font-family:SF Mono,Monaco,Consolas,monospace;color:var(--accent-secondary);min-width:50px;text-align:right;font-weight:600}.plp-color-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:8px;vertical-align:middle}.l1-signaling-content{padding:16px}.l1-section{margin-bottom:16px}.l1-section:last-of-type{margin-bottom:0}.l1-section-title{font-size:12px;font-weight:600;color:var(--accent-secondary);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid rgba(32,79,110,.2)}.l1-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.l1-item{display:flex;flex-direction:column;gap:2px;padding:8px 10px;background:#00000026;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.03)}.l1-label{font-size:10px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.l1-value{font-size:13px;font-family:SF Mono,Monaco,Consolas,monospace;color:var(--text-primary);font-weight:500}.l1-value.l1-highlight{color:var(--accent);font-weight:600}.l1-value.l1-enabled{color:var(--success);font-weight:600}.l1-value.l1-warning{color:var(--warning);font-weight:600}.l1-modulation{color:var(--accent);font-family:SF Mono,Monaco,Consolas,monospace;font-weight:500}.l1-coderate{color:var(--accent-secondary);font-family:SF Mono,Monaco,Consolas,monospace}.stltp-charts-content{padding:16px}.stltp-charts-grid{display:flex;flex-direction:column;gap:16px}.stltp-chart{background:#0003;border:1px solid rgba(32,79,110,.15);border-radius:var(--radius-lg);padding:16px;overflow:hidden;position:relative;isolation:isolate}.stltp-chart-title{font-size:13px;font-weight:600;color:var(--accent);margin-bottom:4px}.stltp-chart-subtitle{font-size:11px;color:var(--text-secondary);margin-bottom:16px}.frame-allocation-container{display:flex;flex-direction:column;gap:8px}.frame-allocation-track{position:relative;height:40px;background:#ffffff08;border-radius:var(--radius-sm);overflow:hidden}.frame-allocation-block{position:absolute;top:4px;bottom:4px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:opacity .2s;cursor:pointer;box-shadow:0 1px 3px #0000004d}.frame-allocation-block:hover{opacity:.85;z-index:1}.frame-block-label{font-size:10px;font-weight:600;color:#000c;text-shadow:0 1px 1px rgba(255,255,255,.3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 4px}.frame-allocation-axis{display:flex;justify-content:space-between;font-size:10px;color:var(--text-secondary);font-family:SF Mono,Monaco,Consolas,monospace;padding:0 4px}.frame-allocation-legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.frame-legend-item{display:flex;align-items:center;gap:6px}.frame-legend-color{width:12px;height:12px;border-radius:3px}.frame-legend-text{font-size:11px;color:var(--text-primary);font-family:SF Mono,Monaco,Consolas,monospace}.efficiency-bars{display:flex;flex-direction:column;gap:10px}.efficiency-row{display:flex;align-items:center;gap:12px}.efficiency-label{display:flex;flex-direction:column;gap:1px;min-width:100px;flex-shrink:0}.efficiency-plp{font-size:12px;font-weight:600;color:var(--text-primary);font-family:SF Mono,Monaco,Consolas,monospace}.efficiency-config{font-size:10px;color:var(--text-secondary)}.efficiency-bar-container{flex:1;height:24px;background:#ffffff08;border-radius:var(--radius-sm);position:relative;overflow:hidden}.efficiency-bar{height:100%;border-radius:var(--radius-sm);transition:width .3s ease;min-width:4px}.efficiency-value{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:11px;font-weight:600;color:var(--text-primary);font-family:SF Mono,Monaco,Consolas,monospace;text-shadow:0 1px 2px rgba(0,0,0,.5)}.efficiency-note{margin-top:12px;font-size:10px;color:var(--text-muted);font-style:italic}.capacity-bars{display:flex;flex-direction:column;gap:10px}.capacity-row{display:flex;align-items:center;gap:12px}.capacity-label{min-width:60px;flex-shrink:0}.capacity-plp{font-size:12px;font-weight:600;color:var(--text-primary);font-family:SF Mono,Monaco,Consolas,monospace}.capacity-bar-container{flex:1;height:24px;background:#ffffff08;border-radius:var(--radius-sm);position:relative;overflow:hidden}.capacity-bar{height:100%;border-radius:var(--radius-sm);transition:width .3s ease;min-width:4px}.capacity-value{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:11px;font-weight:600;color:var(--text-primary);font-family:SF Mono,Monaco,Consolas,monospace;text-shadow:0 1px 2px rgba(0,0,0,.5)}.capacity-note{margin-top:12px;font-size:10px;color:var(--text-muted);font-style:italic}.ti-visualization{display:flex;flex-direction:column;gap:12px}.ti-row{display:flex;align-items:center;gap:16px;padding:8px 0}.ti-label{display:flex;flex-direction:column;gap:2px;min-width:90px;flex-shrink:0}.ti-plp{font-size:12px;font-weight:600;color:var(--text-primary);font-family:SF Mono,Monaco,Consolas,monospace}.ti-mode{font-size:10px;color:var(--text-secondary)}.ti-visual{display:flex;gap:4px;flex:1}.ti-bar{width:32px;height:24px;background:#ffffff0d;border-radius:var(--radius-sm);transition:background-color .2s,opacity .2s}.ti-bar.active{box-shadow:0 0 8px #6bc5d84d}.ti-description{min-width:100px;max-width:120px;flex-shrink:0;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ti-low{font-size:11px;color:var(--success);font-weight:500}.ti-medium{font-size:11px;color:var(--warning);font-weight:500}.ti-high{font-size:11px;color:var(--accent-secondary);font-weight:500}.ti-legend{display:flex;justify-content:space-between;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.ti-legend-item{font-size:10px;color:var(--text-muted)}.ti-arrow{font-size:12px;color:var(--text-secondary)}.radar-chart-container{display:flex;gap:20px;align-items:flex-start;flex-wrap:wrap}.radar-chart-svg{width:240px;height:200px;flex-shrink:0}.radar-grid-circle{fill:none;stroke:#ffffff40;stroke-width:1}.radar-axis-line{stroke:#ffffff4d;stroke-width:1}.radar-data-polygon{fill:#6bc5d833;stroke:var(--accent);stroke-width:2}.radar-data-point{fill:var(--accent);stroke:#fff;stroke-width:2}.radar-label{font-size:8px;fill:var(--text-secondary);font-family:SF Mono,Monaco,Consolas,monospace}.radar-legend{display:flex;flex-direction:column;gap:8px;min-width:180px}.radar-legend-item{display:flex;gap:8px;align-items:center;font-size:11px}.radar-legend-name{color:var(--text-secondary);min-width:80px}.radar-legend-value{color:var(--accent);font-weight:600;font-family:SF Mono,Monaco,Consolas,monospace;min-width:35px}.radar-legend-desc{color:var(--text-muted);font-size:10px}@media (max-width: 768px){.physical-layer-summary{flex-direction:column;gap:12px}.pl-summary-item{flex-direction:row;justify-content:space-between;min-width:auto}.stltp-charts-grid{grid-template-columns:1fr}.radar-chart-container{flex-direction:column;align-items:center}.ti-row{flex-wrap:wrap}.ti-description{width:100%;text-align:left;margin-top:4px}}.alp-tab{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.alp-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.alp-empty-icon{font-size:2.5rem;font-weight:700;color:var(--color-primary);background:var(--color-surface-elevated);padding:1rem 1.5rem;border-radius:12px;margin-bottom:1rem;font-family:var(--font-mono)}.alp-empty-text{font-size:1.1rem;color:var(--color-text-secondary)}.alp-empty-hint{font-size:.9rem;color:var(--color-text-tertiary);margin-top:.5rem}.alp-summary{display:flex;gap:1rem;flex-wrap:wrap}.alp-summary-item{flex:1;min-width:140px;background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:12px;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.25rem}.alp-summary-item.ts{border-color:var(--color-primary);background:linear-gradient(135deg,var(--color-surface-elevated),rgba(107,197,216,.05))}.alp-summary-value{font-size:1.5rem;font-weight:600;color:var(--color-text-primary);font-family:var(--font-mono)}.alp-summary-label{font-size:.8rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.alp-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;overflow:hidden}.alp-section-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;cursor:pointer;background:var(--color-surface-elevated);border-bottom:1px solid var(--color-border);transition:background-color .15s ease}.alp-section-header:hover{background:var(--color-surface-hover)}.section-arrow{font-size:.7rem;color:var(--color-text-tertiary);transition:transform .2s ease;font-family:var(--font-mono)}.section-icon{font-size:.75rem;font-weight:700;color:var(--color-primary);background:#6bc5d81a;padding:.25rem .5rem;border-radius:4px;font-family:var(--font-mono)}.section-title{font-weight:500;color:var(--color-text-primary)}.alp-stats-content{padding:1rem 1.25rem}.alp-stats-table-wrapper{overflow-x:auto}.alp-stats-table{width:100%;max-width:500px;border-collapse:collapse}.alp-stats-table td{padding:.5rem 0}.alp-stats-table .stat-label{color:var(--color-text-secondary);font-size:.9rem}.alp-stats-table .stat-value{text-align:right;font-family:var(--font-mono);font-size:.9rem;color:var(--color-text-primary)}.alp-stats-table .stat-percent{color:var(--color-text-tertiary);margin-left:.5rem;font-size:.85rem}.alp-stats-table .stat-separator td{height:1rem;border-bottom:1px solid var(--color-border)}.alp-charts-content{padding:1rem 1.25rem}.alp-charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.alp-chart{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem}.alp-chart-title{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.25rem}.alp-chart-subtitle{font-size:.8rem;color:var(--color-text-tertiary);margin-bottom:1rem}.composition-stacked-bar{display:flex;height:24px;border-radius:6px;overflow:hidden;margin-bottom:1rem}.composition-segment{height:100%;min-width:2px;transition:width .3s ease}.composition-legend{display:flex;flex-direction:column;gap:.5rem}.composition-legend-item{display:flex;align-items:center;gap:.75rem}.composition-color{width:12px;height:12px;border-radius:3px;flex-shrink:0}.composition-label{flex:1;font-size:.9rem;color:var(--color-text-secondary)}.composition-value{font-family:var(--font-mono);font-size:.9rem;color:var(--color-text-primary)}.composition-percent{font-family:var(--font-mono);font-size:.85rem;color:var(--color-text-tertiary);width:50px;text-align:right}.composition-note{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--color-border);font-size:.8rem;color:var(--color-text-tertiary);line-height:1.4}.ts-encapsulation{border-color:#6bc5d84d}.ts-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}.ts-stat-item{text-align:center;padding:.75rem;background:var(--color-surface);border-radius:8px}.ts-stat-item.error{background:#ff3b301a}.ts-stat-value{display:block;font-size:1.25rem;font-weight:600;font-family:var(--font-mono);color:var(--color-text-primary)}.ts-stat-item.error .ts-stat-value{color:#ff3b30}.ts-stat-label{display:block;font-size:.75rem;color:var(--color-text-tertiary);margin-top:.25rem}.ts-note{font-size:.8rem;color:var(--color-text-tertiary);line-height:1.4}.stream-health{display:flex;flex-direction:column}.health-score-container{display:flex;justify-content:center;margin-bottom:1rem}.health-score-ring{position:relative;width:100px;height:100px}.health-svg{transform:rotate(-90deg);width:100%;height:100%}.health-ring-bg{fill:none;stroke:var(--color-border);stroke-width:8}.health-ring-fill{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dasharray .5s ease}.health-score-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.health-score-value{display:block;font-size:1.5rem;font-weight:700;color:var(--color-text-primary);font-family:var(--font-mono)}.health-score-label{display:block;font-size:.7rem;color:var(--color-text-tertiary);text-transform:uppercase}.health-issues{display:flex;flex-direction:column;gap:.5rem}.health-issue{display:flex;gap:.75rem;padding:.75rem;border-radius:8px;background:var(--color-surface)}.health-issue.info{border-left:3px solid var(--color-primary)}.health-issue.warning{border-left:3px solid #ff9500;background:#ff95000d}.health-issue-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.health-issue.info .health-issue-icon{background:#6bc5d833;color:var(--color-primary)}.health-issue.warning .health-issue-icon{background:#ff950033;color:#ff9500}.health-issue-content{flex:1}.health-issue-message{font-size:.85rem;color:var(--color-text-primary)}.health-issue-detail{font-size:.75rem;color:var(--color-text-tertiary);margin-top:.25rem}.health-ok{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:#4cd9641a;border-radius:8px}.health-ok-icon{font-size:.75rem;font-weight:700;color:#4cd964;background:#4cd96433;padding:.25rem .5rem;border-radius:4px}.health-ok-text{font-size:.85rem;color:#4cd964}.alp-reference{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem}.alp-reference-title{font-size:.9rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.75rem}.alp-reference-content p{font-size:.85rem;color:var(--color-text-secondary);line-height:1.5;margin-bottom:1rem}.alp-reference-types{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.5rem}.alp-type-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--color-surface);border-radius:6px}.alp-type-code{font-family:var(--font-mono);font-size:.8rem;font-weight:600;color:var(--color-primary);background:#6bc5d81a;padding:.2rem .4rem;border-radius:4px}.alp-type-name{font-size:.85rem;color:var(--color-text-secondary)}.packet-types{grid-column:span 2}.type-distribution{display:flex;flex-direction:column;gap:.75rem}.type-row{display:flex;align-items:center;gap:1rem}.type-info{display:flex;align-items:center;gap:.5rem;min-width:140px}.type-code{font-family:var(--font-mono);font-size:.7rem;font-weight:600;color:#000;padding:.15rem .4rem;border-radius:4px}.type-label{font-size:.9rem;color:var(--color-text-secondary)}.type-bar-container{flex:1;height:20px;background:var(--color-surface);border-radius:4px;overflow:hidden}.type-bar{height:100%;border-radius:4px;transition:width .3s ease}.type-stats{display:flex;gap:.75rem;min-width:120px;justify-content:flex-end}.type-count{font-family:var(--font-mono);font-size:.85rem;color:var(--color-text-primary);min-width:60px;text-align:right}.type-percent{font-family:var(--font-mono);font-size:.85rem;color:var(--color-text-tertiary);min-width:50px;text-align:right}.type-note{margin-top:1rem;padding:.75rem;border-radius:8px;font-size:.8rem;color:var(--color-text-tertiary);line-height:1.4}.type-note.rohc-note{background:#ff95001a;border-left:3px solid #ff9500}.type-note.ts-note{background:#6bc5d81a;border-left:3px solid #00dfff}.payload-size{border-color:#4cd9644d}.payload-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1rem}.payload-stat{text-align:center;padding:.75rem;background:var(--color-surface);border-radius:8px}.payload-stat-value{display:block;font-size:1.1rem;font-weight:600;font-family:var(--font-mono);color:var(--color-text-primary)}.payload-stat-label{display:block;font-size:.75rem;color:var(--color-text-tertiary);margin-top:.25rem}.payload-histogram{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}.payload-row{display:flex;align-items:center;gap:.5rem}.payload-label{font-family:var(--font-mono);font-size:.75rem;color:var(--color-text-secondary);min-width:85px;text-align:right}.payload-bar-container{flex:1;height:14px;background:var(--color-surface);border-radius:3px;overflow:hidden}.payload-bar{height:100%;background:linear-gradient(90deg,#4cd964,#7ee890);border-radius:3px;transition:width .3s ease}.payload-count{font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-primary);min-width:55px;text-align:right}.payload-percent{font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-tertiary);min-width:45px;text-align:right}.payload-note{font-size:.8rem;color:var(--color-text-tertiary);line-height:1.4;padding:.75rem;background:#4cd9641a;border-left:3px solid #4cd964;border-radius:0 8px 8px 0}.concat-efficiency{border-color:#204f6e4d}.concat-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1rem}.concat-stat{text-align:center;padding:.75rem;background:var(--color-surface);border-radius:8px}.concat-stat.highlight{background:#204f6e1a;border:1px solid rgba(32,79,110,.3)}.concat-stat-value{display:block;font-size:1.25rem;font-weight:600;font-family:var(--font-mono);color:var(--color-text-primary)}.concat-stat.highlight .concat-stat-value{color:#204f6e}.concat-stat-label{display:block;font-size:.75rem;color:var(--color-text-tertiary);margin-top:.25rem}.concat-distribution{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.concat-row{display:flex;align-items:center;gap:.75rem}.concat-components{font-family:var(--font-mono);font-size:.85rem;font-weight:600;color:#204f6e;min-width:24px;text-align:center}.concat-bar-container{flex:1;height:16px;background:var(--color-surface);border-radius:4px;overflow:hidden}.concat-bar{height:100%;background:linear-gradient(90deg,#204f6e,#d580ff);border-radius:4px;transition:width .3s ease}.concat-count{font-family:var(--font-mono);font-size:.85rem;color:var(--color-text-primary);min-width:60px;text-align:right}.concat-percent{font-family:var(--font-mono);font-size:.85rem;color:var(--color-text-tertiary);min-width:50px;text-align:right}.concat-note{font-size:.8rem;color:var(--color-text-tertiary);line-height:1.4;padding:.75rem;background:#204f6e1a;border-left:3px solid #204F6E;border-radius:0 8px 8px 0}.sub-stream-ids{border-color:#ff95004d}.sid-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}.sid-stat{text-align:center;padding:.75rem;background:var(--color-surface);border-radius:8px}.sid-stat-value{display:block;font-size:1.25rem;font-weight:600;font-family:var(--font-mono);color:var(--color-text-primary)}.sid-stat-label{display:block;font-size:.75rem;color:var(--color-text-tertiary);margin-top:.25rem}.sid-distribution{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.sid-row{display:flex;align-items:center;gap:.75rem}.sid-id{font-family:var(--font-mono);font-size:.8rem;font-weight:600;color:#ff9500;min-width:55px}.sid-bar-container{flex:1;height:16px;background:var(--color-surface);border-radius:4px;overflow:hidden}.sid-bar{height:100%;background:linear-gradient(90deg,#ff9500,#fc0);border-radius:4px;transition:width .3s ease}.sid-count{font-family:var(--font-mono);font-size:.85rem;color:var(--color-text-primary);min-width:60px;text-align:right}.sid-percent{font-family:var(--font-mono);font-size:.85rem;color:var(--color-text-tertiary);min-width:50px;text-align:right}.sid-more{font-size:.8rem;color:var(--color-text-tertiary);text-align:center;padding-top:.5rem}.sid-note{font-size:.8rem;color:var(--color-text-tertiary);line-height:1.4;padding:.75rem;background:#ff95001a;border-left:3px solid #ff9500;border-radius:0 8px 8px 0}@media (max-width: 768px){.alp-summary{flex-direction:column}.alp-summary-item{min-width:auto}.alp-charts-grid{grid-template-columns:1fr}}.report-generator-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.report-generator-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);width:90%;max-width:480px;box-shadow:0 20px 60px #00000080}.report-generator-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--bg-tertiary);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.report-generator-title{font-size:16px;font-weight:600;color:var(--accent)}.report-generator-close{background:none;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;padding:0;line-height:1;transition:color var(--transition-fast)}.report-generator-close:hover{color:var(--text-primary)}.report-generator-body{padding:20px}.report-generator-body p{font-size:14px;color:var(--text-primary);margin-bottom:12px}.report-generator-body ul{margin:0 0 16px 20px;font-size:13px;color:var(--text-secondary)}.report-generator-body li{margin-bottom:6px}.report-generator-tip{font-size:12px!important;color:var(--text-muted)!important;background:#6bc5d81a;padding:10px 12px;border-radius:var(--radius-sm);border-left:3px solid var(--accent)}.report-generator-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid var(--border);background:var(--bg-tertiary);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.report-generator-btn{padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.report-generator-btn.secondary{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}.report-generator-btn.secondary:hover{background:#ffffff0d;color:var(--text-primary)}.report-generator-btn.primary{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-secondary) 100%);border:none;color:#fff}.report-generator-btn.primary:hover{box-shadow:0 4px 20px #6bc5d866;transform:translateY(-1px)}.report-generator-btn.primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.skeleton-container{padding:16px}.skeleton-summary-grid{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.skeleton-summary-grid .skeleton-stat{flex:1;min-width:140px;height:80px}.skeleton-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;margin-bottom:16px}.skeleton-flowchart{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px}.skeleton-box{width:280px;height:60px;border-radius:var(--radius-lg)}.skeleton-box-sm{width:120px;height:50px;border-radius:var(--radius-md)}.skeleton-connector{width:2px;height:24px}.skeleton-branches{display:flex;gap:24px}.skeleton-table{display:flex;flex-direction:column;gap:8px}.skeleton-row{height:40px;border-radius:var(--radius-sm)}.skeleton-services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.skeleton-title{height:20px;width:200px;margin-bottom:16px}.skeleton-title.short{width:150px}.skeleton-text{height:14px;width:100%;margin-bottom:8px}.skeleton-card{height:180px;border-radius:var(--radius-lg)}.page-loading-skeleton{position:relative;height:100%;overflow:hidden}.loading-content{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#150027e6;z-index:10}.loading-message{margin-top:16px;font-size:16px;font-weight:600;color:var(--accent)}.loading-hint{margin-top:8px;font-size:12px;color:var(--text-secondary)}.cancel-upload-btn{margin-top:16px;padding:8px 20px;background:transparent;border:1px solid var(--text-secondary);color:var(--text-secondary);border-radius:var(--radius-md);font-size:13px;cursor:pointer;transition:all .2s ease}.cancel-upload-btn:hover{border-color:var(--error);color:var(--error);background:#ff52521a}.skeleton-preview{padding:16px;opacity:.3;pointer-events:none}.skeleton-stat{background:linear-gradient(90deg,#ffffff08 25%,#ffffff14,#ffffff08 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-lg)}.skeleton-container .skeleton,.skeleton-preview .skeleton{background:linear-gradient(90deg,#ffffff08 25%,#ffffff14,#ffffff08 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{display:flex;flex:1;overflow:hidden}.content-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:200px;color:var(--text-secondary);text-align:center;padding:40px 20px}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state-text{font-size:14px;max-width:300px}.empty-state-hint{font-size:12px;color:var(--text-muted);margin-top:8px}.section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.section+.section{margin-top:var(--space-md)}.section-header{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg-tertiary);border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast)}.section-header:hover{background:#ffffff0d}.section-header.no-collapse{cursor:default}.section-header.no-collapse:hover{background:var(--bg-tertiary)}.section-arrow{font-size:10px;color:var(--text-secondary);transition:transform var(--transition-fast);width:16px;text-align:center}.section-arrow.open{transform:rotate(90deg)}.section-icon{font-size:16px}.section-title{font-weight:600;font-size:13px;color:var(--accent)}.section-subtitle{font-size:11px;color:var(--text-secondary);margin-left:4px}.section-count{margin-left:auto;font-size:12px;color:var(--text-secondary);padding:2px 8px;background:#6bc5d81a;border-radius:var(--radius-sm)}.section-content{padding:14px}.section-content.no-padding{padding:0}.badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 6px;border-radius:var(--radius-sm);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.02em;white-space:nowrap}.badge-primary,.badge-cyan{background:#6bc5d826;color:var(--accent)}.badge-secondary,.badge-purple{background:#204f6e26;color:var(--accent-secondary)}.badge-success,.badge-green{background:#4cd96426;color:var(--success)}.badge-warning,.badge-orange{background:#ff950026;color:var(--warning)}.badge-error,.badge-red{background:#ff3b3026;color:var(--error)}.badge-muted,.badge-gray{background:#ffffff1a;color:var(--text-secondary)}.badge-route{background:#6bc5d826;color:var(--accent)}.badge-mmtp{background:#4cd96426;color:var(--success)}.badge-sm{padding:1px 4px;font-size:9px}.badge-lg{padding:4px 10px;font-size:11px}.badge-dot{display:inline-flex;align-items:center;gap:6px}.badge-dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.card:hover{border-color:var(--border-accent)}.card.interactive:hover{box-shadow:0 2px 8px #6bc5d81a}.card-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--bg-tertiary);border-bottom:1px solid var(--border)}.card-title{font-weight:600;font-size:14px;color:var(--accent)}.card-subtitle{font-size:12px;color:var(--text-secondary)}.card-body{padding:12px 14px}.card-footer{padding:10px 14px;background:var(--bg-tertiary);border-top:1px solid var(--border)}.card.compact{background:var(--bg-tertiary)}.card.compact .card-body{padding:10px 12px}.card.highlighted{border-color:var(--border-accent);box-shadow:0 0 12px #6bc5d826}.card.warning{border-color:#ff950066}.card.warning .card-header{background:linear-gradient(135deg,#ff95001a,#ff3b301a)}.card.error{border-color:#ff3b3066}.card.purple{border-color:#204f6e66}.card.purple .card-header{background:linear-gradient(135deg,#204f6e1a,#5856d61a)}.data-row{display:flex;justify-content:space-between;align-items:baseline;padding:6px 0;font-size:12px}.data-row:not(:last-child){border-bottom:1px solid rgba(255,255,255,.05)}.data-label{color:var(--text-secondary);flex-shrink:0;margin-right:12px}.data-value{color:var(--text-primary);text-align:right}.data-value.mono{font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px}.data-value.accent{color:var(--accent)}.data-table{width:100%;border-collapse:collapse;font-size:12px}.data-table th{text-align:left;padding:10px 12px;background:#0003;color:var(--text-secondary);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--border)}.data-table td{padding:10px 12px;color:var(--text-primary);border-bottom:1px solid var(--border)}.data-table tr:hover{background:#6bc5d80d}.data-table tr:last-child td{border-bottom:none}.data-table .mono{font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px}.alert{display:flex;gap:12px;padding:12px 16px;border-radius:var(--radius-lg);border-left:4px solid;margin-bottom:var(--space-md)}.alert-icon{font-size:18px;flex-shrink:0}.alert-content{flex:1}.alert-title{font-weight:600;font-size:13px;margin-bottom:4px}.alert-message{font-size:12px;color:var(--text-secondary)}.alert-info{background:#6bc5d81a;border-left-color:var(--accent)}.alert-warning{background:#ff95001a;border-left-color:var(--warning)}.alert-error{background:#ff3b301a;border-left-color:var(--error)}.alert-success{background:#4cd9641a;border-left-color:var(--success)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-md)}.stat-card{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;transition:border-color var(--transition-fast)}.stat-card:hover{border-color:var(--border-accent)}.stat-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1.2}.stat-value.accent{color:var(--accent)}.stat-unit{font-size:14px;font-weight:400;color:var(--text-secondary);margin-left:4px}.stat-change{font-size:11px;margin-top:4px}.stat-change.positive{color:var(--success)}.stat-change.negative{color:var(--error)}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.mt-xs{margin-top:var(--space-xs)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-xs{margin-bottom:var(--space-xs)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.p-sm{padding:var(--space-sm)}.p-md{padding:var(--space-md)}.p-lg{padding:var(--space-lg)}@media (max-width: 768px){.empty-state{padding:32px 16px;min-height:150px}.empty-state-icon{font-size:40px}.empty-state-text{font-size:13px}.section-header{padding:12px;min-height:44px}.section-title{font-size:12px}.section-content{padding:12px}.card-header,.card-body{padding:10px 12px}.card-title{font-size:13px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:12px}.stat-value{font-size:22px}.stat-label{font-size:10px}.data-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -12px;padding:0 12px}.data-table{min-width:500px}.data-table th,.data-table td{padding:8px 10px;font-size:11px}.data-row{padding:8px 0;font-size:11px}.alert{padding:10px 12px;gap:10px}.alert-icon{font-size:16px}.alert-title{font-size:12px}.alert-message{font-size:11px}.badge{padding:2px 5px;font-size:9px}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr;gap:8px}.stat-card{padding:10px 12px;display:flex;justify-content:space-between;align-items:center}.stat-label{margin-bottom:0;font-size:11px}.stat-value{font-size:18px}.section-header{min-height:48px;padding:10px 12px}.section-arrow{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.card-header,.card-body{padding:10px}.data-row{flex-direction:column;align-items:flex-start;gap:2px}.data-value{text-align:left}.data-label{margin-right:0}}@media (hover: none) and (pointer: coarse){.section-header{min-height:48px}.card.interactive:active{transform:scale(.99);box-shadow:0 1px 4px #6bc5d81a}.data-table tr:active{background:#6bc5d81a}.card:hover,.stat-card:hover{border-color:var(--border)}.card:active,.stat-card:active{border-color:var(--border-accent)}}*{margin:0;padding:0;box-sizing:border-box}:root,[data-theme=obs-blue]{--bg-primary: #183a4d;--bg-secondary: #122d3d;--bg-tertiary: #153349;--bg-surface: #1a3f5c;--accent: #6BC5D8;--accent-secondary: #204F6E;--accent-bright: #00DFFF;--accent-gradient: linear-gradient(135deg, #6BC5D8 0%, #204F6E 100%);--title: #8DD8E8;--text-primary: #ffffff;--text-secondary: #a0c0d0;--text-muted: #668090;--success: #4CD964;--warning: #ff9500;--warning-light: #ffb340;--error: #FF3B30;--color-cyan: #6BC5D8;--color-cyan-bright: #00dfff;--color-blue: #204F6E;--color-green: #4cd964;--color-orange: #ff9500;--color-red: #ff3b30;--color-indigo: #5856d6;--border: rgba(255, 255, 255, .1);--border-accent: rgba(107, 197, 216, .3);--glow-accent: 0 0 20px rgba(107, 197, 216, .3);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--transition-fast: .15s ease-in-out;--transition-normal: .25s ease-in-out}[data-theme=high-contrast]{--bg-primary: #0a1a24;--bg-secondary: #061218;--bg-tertiary: #0d2633;--bg-surface: #122d3d;--accent: #00DFFF;--accent-secondary: #0077aa;--accent-bright: #00DFFF;--title: #00DFFF;--text-primary: #ffffff;--text-secondary: #b8d4e3;--text-muted: #8ab0c5;--border: rgba(255, 255, 255, .2);--border-accent: rgba(0, 223, 255, .5);--color-cyan: #00DFFF;--accent-gradient: linear-gradient(135deg, #00DFFF 0%, #0077aa 100%)}[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: #f1f5f9;--bg-tertiary: #e2e8f0;--bg-surface: #ffffff;--accent: #0891b2;--accent-secondary: #164e63;--accent-bright: #06b6d4;--title: #0891b2;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--border: rgba(15, 23, 42, .1);--border-accent: rgba(8, 145, 178, .3);--color-cyan: #0891b2;--accent-gradient: linear-gradient(135deg, #0891b2 0%, #164e63 100%)}[data-theme=classic-purple]{--bg-primary: #150027;--bg-secondary: #1a0d2e;--bg-tertiary: #27213D;--bg-surface: #1A1A2E;--accent: #00DFFF;--accent-secondary: #AC1CFF;--accent-bright: #00DFFF;--title: #00DFFF;--text-primary: #ffffff;--text-secondary: #a0a0b0;--text-muted: #666680;--border: rgba(255, 255, 255, .1);--border-accent: rgba(0, 223, 255, .3);--color-cyan: #00DFFF;--accent-gradient: linear-gradient(135deg, #00DFFF 0%, #AC1CFF 100%)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(180deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);background-attachment:fixed;color:var(--text-primary);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#8dd8e8}::selection{background:#6bc5d84d;color:#fff}*:focus{outline:none}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:focus-visible,.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;box-shadow:0 0 0 4px #6bc5d833}a:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.tab-item:focus-visible,.tree-item-header:focus-visible,.service-card:focus-visible,.section-header:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:0;border-color:var(--accent)}.skeleton{background:linear-gradient(90deg,#ffffff0d 25%,#ffffff1a,#ffffff0d 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.skeleton-text{height:14px;margin-bottom:8px}.skeleton-text.short{width:60%}.skeleton-text.medium{width:80%}.skeleton-title{height:20px;width:40%;margin-bottom:12px}.skeleton-card{height:120px;border-radius:var(--radius-lg)}.skeleton-stat{height:48px;border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.spinner.small{width:14px;height:14px;border-width:1.5px}.spinner.large{width:32px;height:32px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}:root{--touch-target-min: 44px}@supports (padding: env(safe-area-inset-bottom)){.app{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-bottom:env(safe-area-inset-bottom)}}@media (max-width: 1024px){.main-content{flex-direction:column}.sidebar{width:100%!important;min-width:100%!important;max-height:200px;border-right:none;border-bottom:1px solid var(--border)}.content-area{width:100%}.data-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}table{min-width:600px}}@media (max-width: 768px){body{font-size:15px}.header{padding:12px 16px;flex-wrap:wrap;gap:12px}.header-left{gap:10px}.header-title{font-size:16px}.header-company-name,.header-file-info{display:none}.services-grid,.stats-grid,.stltp-charts-grid,.overview-grid{grid-template-columns:1fr!important;gap:12px}.chart-container{max-width:100%}.tab-bar{padding:0 12px}.tab-item{padding:12px 14px;font-size:13px;min-height:var(--touch-target-min)}.tab-badge{display:none}.section-header,.section-content{padding:12px}.btn{min-height:var(--touch-target-min);padding:12px 16px}.sidebar{max-height:150px;overflow-y:auto}.stat-card{padding:14px}.stat-value{font-size:22px}.service-card{margin-bottom:12px}.detail-panel{padding:12px}.section-header{min-height:var(--touch-target-min);cursor:pointer}.xml-content{font-size:12px;overflow-x:auto}}@media (max-width: 480px){body{font-size:14px}.header{padding:10px 12px}.header-logo{width:28px;height:28px}.header-title{font-size:14px}.header-actions{gap:8px}.header-actions .btn{padding:10px 12px;font-size:13px;min-height:var(--touch-target-min)}.header-actions .btn span{display:none}.tab-bar{overflow-x:auto;-webkit-overflow-scrolling:touch;padding:0 8px;scrollbar-width:none}.tab-bar::-webkit-scrollbar{display:none}.tab-bar-inner{min-width:max-content;gap:2px}.tab-item{padding:12px;min-height:var(--touch-target-min);flex-shrink:0}.tab-label{display:none}.tab-icon{font-size:18px}.stat-card{padding:12px}.stat-value{font-size:20px}.stat-label{font-size:11px}.service-card-header,.service-card-body{padding:10px 12px}.sidebar{max-height:120px}.section-content{padding:10px}.data-table{font-size:12px}.data-table th,.data-table td{padding:8px 10px}.upload-zone{min-height:200px;padding:24px}.upload-zone-icon{font-size:48px}.tree-item-header{min-height:var(--touch-target-min);padding:10px 12px}.tree-item-toggle{width:32px;height:32px;display:flex;align-items:center;justify-content:center}}@media (max-width: 768px) and (orientation: landscape){.main-content{flex-direction:row}.sidebar{width:200px!important;min-width:200px!important;max-height:none;border-right:1px solid var(--border);border-bottom:none}.header{padding:8px 16px}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.header-logo{image-rendering:-webkit-optimize-contrast}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast: high){:root{--border: rgba(255, 255, 255, .3);--text-secondary: #c0c0d0}}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;top:-40px;left:0;background:var(--accent);color:#000;padding:8px 16px;z-index:1000;font-weight:600;text-decoration:none;border-radius:0 0 var(--radius-md) 0;transition:top var(--transition-fast)}.skip-link:focus{top:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mono{font-family:SF Mono,Monaco,Consolas,monospace}.text-gradient{background:linear-gradient(135deg,#6bc5d8,#204f6e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.glow{box-shadow:0 0 20px #6bc5d84d}.glow-secondary{box-shadow:0 0 20px #204f6e4d}.card-glow:hover{border-color:#6bc5d84d;box-shadow:0 0 12px #6bc5d826}.card-hover-lift{transition:transform .3s ease,box-shadow .3s ease}.card-hover-lift:hover{transform:translateY(-4px);box-shadow:0 20px 40px #0000004d,0 0 30px #6bc5d81a}.btn-gradient-border{position:relative;background:transparent;z-index:1}.btn-gradient-border:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;padding:2px;background:linear-gradient(135deg,#6bc5d8,#204f6e);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;z-index:-1}.btn-gradient-border:hover:before{background:linear-gradient(135deg,#204f6e,#6bc5d8)}.btn-shimmer{background:linear-gradient(90deg,#6bc5d8,#6bc5d8 40%,#fff,#6bc5d8 60%,#6bc5d8);background-size:200% auto;color:#153349;transition:all .3s ease}.btn-shimmer:hover{animation:shimmer-btn 1.5s linear infinite;box-shadow:0 0 30px #6bc5d880}@keyframes shimmer-btn{0%{background-position:-200% center}to{background-position:200% center}}@keyframes pulse-glow{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}.pulse-glow{animation:pulse-glow 4s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(5deg)}}.float-animation{animation:float 6s ease-in-out infinite}
