*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{text-size-adjust:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.5}img,picture,video,canvas,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit;color:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}ul,ol{list-style:none}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none}table{border-collapse:collapse;border-spacing:0}:root{--color-background:#fff;--color-surface:#f5f5f7;--color-sidebar:#f0f0f2;--color-elevated:#fff;--color-super-elevated:#fff;--color-border:#e5e5e7;--color-separator:#f2f2f7;--color-text-primary:#1d1d1f;--color-text-secondary:#86868b;--color-text-tertiary:#aeaeb2;--color-allow:#34c759;--color-block:#ff3b30;--color-warning:#ff9500;--color-info:#007aff;--color-disabled:#c7c7cc;--color-log:#5856d6;--color-diff-added-bg:#34c7590a;--color-diff-added-field:#34c75914;--color-diff-removed-bg:#ff3b300a;--color-diff-removed-field:#ff3b3014;--color-selected:#007aff1a;--color-hover:#f5f5f7;--color-primary:#007aff;--color-primary-text:#fff;--font-family:-apple-system, BlinkMacSystemFont, "SF Pro", "Segoe UI", system-ui, sans-serif;--font-mono:"SF Mono", "Menlo", "Consolas", monospace;--font-size-page-title:22px;--font-size-section-header:12px;--font-size-rule-name:14px;--font-size-rule-protocol:12px;--font-size-rule-comment:12px;--font-size-status-label:11px;--font-size-caption:11px;--font-size-filter-count:12px;--font-size-mono:12px;--space-tight:4px;--space-compact:8px;--space-default:12px;--space-comfortable:16px;--space-section:20px;--space-spacious:24px;--space-generous:32px;--row-height:52px;--sidebar-width:220px;--side-panel-width:420px;--status-bar-width:3px;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--color-focus-ring:#007aff33;--shadow-segment:0 1px 3px #00000014;--color-primary-hover-bg:#007aff0f;--shadow-popover:0 8px 24px #00000026;--shadow-modal:0 24px 80px #00000040;--shadow-banner:0 8px 32px #00000040;--transition-fast:.1s ease;--transition-default:.15s ease;--transition-slow:.25s ease-out;--transition-banner:.3s ease}@media (prefers-color-scheme:dark){:root{--color-background:#000;--color-surface:#1c1c1e;--color-sidebar:#1c1c1e;--color-elevated:#2c2c2e;--color-super-elevated:#3a3a3c;--color-border:#38383a;--color-separator:#38383a;--color-text-primary:#fff;--color-text-secondary:#98989d;--color-text-tertiary:#636366;--color-allow:#30d158;--color-block:#ff453a;--color-warning:#ff9f0a;--color-info:#0a84ff;--color-disabled:#48484a;--color-log:#5e5ce6;--color-diff-added-bg:#32d74b33;--color-diff-added-field:#32d74b33;--color-diff-removed-bg:#ff453a33;--color-diff-removed-field:#ff453a33;--color-selected:#0a84ff33;--color-hover:#ffffff0f;--color-primary:#0a84ff;--color-primary-text:#fff;--color-focus-ring:#0a84ff4d;--shadow-segment:0 1px 3px #0003;--color-primary-hover-bg:#0a84ff1a;--shadow-banner:0 8px 32px #00000080}}html,body{height:100%;color:var(--color-text-primary);background:var(--color-background);-webkit-font-smoothing:antialiased;margin:0;font-family:-apple-system,BlinkMacSystemFont,SF Pro,Segoe UI,system-ui,sans-serif;font-size:13px}#app{flex-direction:column;height:100%;display:flex}.app-layout{flex:1;height:100%;display:flex;overflow:hidden}.app-layout>.sidebar{background:var(--color-sidebar);border-right:1px solid var(--color-border);flex-direction:column;width:220px;min-width:180px;max-width:320px;display:flex;overflow-y:auto}.app-layout>.main-content{flex-direction:column;flex:1;min-width:0;display:flex;position:relative;overflow-y:auto}.app-title-bar{background:var(--color-sidebar,#1a1a1a);border-bottom:1px solid var(--color-border,#333);flex-shrink:0;align-items:center;gap:8px;padding:6px 16px;display:flex}.app-title-bar__logo{color:var(--color-text-primary,#fff);letter-spacing:-.3px;font-size:14px;font-weight:700}.app-title-bar__subtitle{color:var(--color-text-tertiary,#666);font-size:11px;font-weight:400}.loading-screen{height:100%;color:var(--color-text-secondary);justify-content:center;align-items:center;font-size:15px;display:flex}.error-screen{height:100%;color:var(--color-text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}.error-screen h1{color:var(--color-text-primary);font-size:17px;font-weight:600}.error-screen button{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:6px 16px;font-size:13px;font-weight:500}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;height:100%;padding:32px;display:flex}.empty-state__icon{width:48px;height:48px;color:var(--color-primary);margin-bottom:8px}.empty-state__title{color:var(--color-text-primary);font-size:22px;font-weight:600}.empty-state__description{color:var(--color-text-secondary);max-width:320px;font-size:15px;line-height:22px}.empty-state__cta{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:6px;margin-top:12px;padding:6px 16px;font-size:13px;font-weight:500}.empty-state__cta:hover{background:var(--color-primary-hover,#0071e3)}.empty-state__hint{color:var(--color-text-tertiary);margin-top:4px;font-size:11px}:is(.rule-table__header-btn:focus-visible,.rule-table__add-rule-btn:focus-visible,.filter-bar__add-rule-btn:focus-visible,.rule-table__pending-bar-discard:focus-visible,.rule-table__pending-bar-show-changes:focus-visible,.rule-table__empty-btn:focus-visible,.sidebar__add-btn:focus-visible,.sidebar__all-hosts-row:focus-visible,.sidebar__status-filter-pill:focus-visible,.blocked-log__block-btn:focus-visible,.rule-builder__more-options-link:focus-visible,.rule-builder__add-condition-btn:focus-visible,.rule-table__terminal-sub-tab:focus-visible,.nat-builder__btn-primary:focus-visible,.nat-builder__btn-cancel:focus-visible,.side-panel__entry-remove-btn:focus-visible,.empty-state__cta:focus-visible){outline:2px solid var(--color-primary);outline-offset:-2px}input[type=checkbox]{-webkit-appearance:none;appearance:none;border:1.5px solid var(--color-text-tertiary);background:var(--color-background);cursor:pointer;width:16px;height:16px;transition:background var(--transition-fast), border-color var(--transition-fast);border-radius:4px;flex-shrink:0;position:relative}input[type=checkbox]:checked{background:var(--color-primary);border-color:var(--color-primary)}input[type=checkbox]:checked:after{content:"";border:solid var(--color-primary-text,#fff);border-width:0 2px 2px 0;width:4.5px;height:8px;position:absolute;top:1.5px;left:4.5px;transform:rotate(45deg)}input[type=checkbox]:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.rule-table__pending-bar-apply:active,.empty-state__cta:active,.rule-table__empty-btn:active,.blocked-log__block-btn:active{transform:scale(.97)}.sidebar{width:var(--sidebar-width);background:var(--color-sidebar);border-right:1px solid var(--color-border);min-width:180px;max-width:320px;height:100%;transition:width var(--transition-default);flex-direction:column;flex-shrink:0;display:flex;position:relative;overflow:hidden auto}.sidebar--collapsed{width:36px;min-width:36px;overflow:hidden}.sidebar--collapsed .sidebar__search,.sidebar--collapsed .sidebar__section-header,.sidebar--collapsed .sidebar__host-name,.sidebar--collapsed .sidebar__chevron,.sidebar--collapsed .sidebar__group-name,.sidebar--collapsed .sidebar__group-count,.sidebar--collapsed .sidebar__iplist-name,.sidebar--collapsed .sidebar__iplist-count,.sidebar--collapsed .sidebar__add-btn{display:none}.sidebar__search{padding:var(--space-compact) var(--space-default);flex-shrink:0}.sidebar__search-input{width:100%;height:28px;padding:0 var(--space-compact);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background);color:var(--color-text-primary);font-family:var(--font-family);box-sizing:border-box;transition:border-color var(--transition-fast);outline:none;font-size:12px}.sidebar__search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.sidebar__search-input::placeholder{color:var(--color-text-tertiary)}.sidebar__search{position:relative}.sidebar__search-clear{right:calc(var(--space-default) + 4px);background:var(--color-hover,#333);width:18px;height:18px;color:var(--color-text-secondary,#888);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:12px;line-height:1;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.sidebar__search-clear:hover{background:var(--color-text-tertiary,#555);color:var(--color-text-primary,#fff)}.sidebar__iplist-row--selected{background:var(--color-selected,#2a2a2a)}.sidebar__iplist-detail{background:var(--color-elevated,#1e1e1e);border:1px solid var(--color-border,#333);border-radius:var(--radius-md,6px);margin:4px var(--space-default,12px) 8px;padding:8px 12px;font-size:12px;position:relative}.sidebar__iplist-detail-title{color:var(--color-text-primary,#fff);margin-bottom:6px;padding-right:20px;font-weight:600}.sidebar__iplist-detail-close{width:18px;height:18px;color:var(--color-text-secondary,#888);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:14px;display:flex;position:absolute;top:4px;right:4px}.sidebar__iplist-detail-entry{align-items:center;gap:8px;padding:2px 0;display:flex}.sidebar__iplist-detail-addr{font-family:var(--font-mono,monospace);color:var(--color-text-primary,#fff);font-size:11px}.sidebar__iplist-detail-comment{color:var(--color-text-tertiary,#666);font-size:11px}.sidebar__iplist-detail-empty{color:var(--color-text-tertiary,#666);font-style:italic}.sidebar__section{flex-shrink:0}.sidebar__section--recent{border-bottom:1px solid var(--color-border);padding-bottom:var(--space-compact)}.sidebar__section--all-hosts{border-top:1px solid var(--color-border)}.sidebar__host-list,.sidebar__group-list,.sidebar__iplist-list{flex-direction:column;display:flex}.sidebar__host-list--recent{max-height:160px;overflow-y:auto}.sidebar__all-hosts-row{width:100%;height:32px;padding:0 var(--space-default);color:var(--color-primary);font-family:var(--font-family);cursor:pointer;transition:background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;font-size:13px;font-weight:500;display:flex}.sidebar__all-hosts-row:hover{background:var(--color-hover)}.sidebar__status-filter-pill{align-items:center;gap:var(--space-tight);height:24px;margin:var(--space-tight) var(--space-default);padding:0 var(--space-compact);border:1px solid var(--color-border);background:var(--color-background);color:var(--color-text-secondary);font-family:var(--font-family);cursor:pointer;transition:border-color var(--transition-fast), color var(--transition-fast);border-radius:12px;font-size:11px;display:inline-flex}.sidebar__status-filter-pill:hover{border-color:var(--color-primary);color:var(--color-primary)}.sidebar__status-filter-pill--active{background:var(--color-primary);color:var(--color-primary-text,#fff);border-color:var(--color-primary)}.sidebar__section-header{font-size:var(--font-size-caption);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-secondary);padding:var(--space-section) var(--space-default) var(--space-compact);-webkit-user-select:none;user-select:none;font-weight:600}.sidebar__host-row{height:32px;padding:0 var(--space-default);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast);align-items:center;gap:var(--space-compact);border-left:3px solid #0000;display:flex;position:relative}.sidebar__host-row:hover{background:var(--color-hover)}.sidebar__host-row--selected{background:var(--color-selected);border-left-color:var(--color-primary)}.sidebar__host-row:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.sidebar__status-icon{flex-shrink:0;width:10px;min-width:10px;height:10px}@keyframes sidebar-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sidebar__status-icon--spinning{animation:1s linear infinite sidebar-spin}.sidebar__host-name{color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:400;overflow:hidden}.sidebar__persistence-badge{text-transform:uppercase;letter-spacing:.5px;color:var(--color-warning,#ff9500);cursor:default;background:#ff950026;border-radius:3px;flex-shrink:0;padding:1px 4px;font-size:9px;font-weight:700;line-height:1.2}.sidebar__chevron{opacity:0;transition:opacity var(--transition-fast);flex-shrink:0}.sidebar__host-row:hover .sidebar__chevron{opacity:1}.sidebar__mixed-backend-warn{color:var(--color-warning);flex-shrink:0;margin-left:auto;margin-right:2px;font-size:11px}.sidebar__group-row{height:32px;padding:0 var(--space-default);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:var(--space-compact);transition:background var(--transition-fast);display:flex}.sidebar__group-row:hover{background:var(--color-hover)}.sidebar__group-row:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.sidebar__disclosure{width:8px;height:8px;transition:transform var(--transition-fast);flex-shrink:0}.sidebar__disclosure--expanded{transform:rotate(90deg)}.sidebar__group-name{color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:400;overflow:hidden}.sidebar__group-count{font-size:var(--font-size-caption);color:var(--color-text-tertiary);flex-shrink:0}.sidebar__iplist-row{height:32px;padding:0 var(--space-default) 0 calc(var(--space-default) + 16px);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:var(--space-compact);transition:background var(--transition-fast);display:flex}.sidebar__iplist-row:hover{background:var(--color-hover)}.sidebar__iplist-row:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.sidebar__iplist-name{color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:400;overflow:hidden}.sidebar__iplist-count{font-size:var(--font-size-caption);color:var(--color-text-tertiary);flex-shrink:0}.sidebar__add-btn{height:36px;margin:var(--space-compact) var(--space-default);border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-family:var(--font-family);cursor:pointer;transition:border-color var(--transition-fast), color var(--transition-fast);background:0 0;justify-content:center;align-items:center;font-size:13px;display:flex}.sidebar__add-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.sidebar__add-btn:active{transform:scale(.97)}.sidebar__bottom-actions{padding:0 var(--space-default);margin-bottom:var(--space-compact);gap:6px;display:flex}.sidebar__bottom-actions .sidebar__add-btn{flex:1;margin:0}.sidebar__compare-btn{border:1px solid var(--color-border);border-radius:var(--radius-md);height:36px;color:var(--color-text-secondary);font-family:var(--font-family);cursor:pointer;transition:border-color var(--transition-fast), color var(--transition-fast);white-space:nowrap;background:0 0;justify-content:center;align-items:center;padding:0 12px;font-size:12px;display:flex}.sidebar__compare-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.sidebar__compare-btn:active{transform:scale(.97)}.sidebar--collapsed .sidebar__bottom-actions{display:none}.sidebar:after{content:"";cursor:col-resize;width:3px;height:100%;transition:background var(--transition-fast);position:absolute;top:0;right:-1px}.sidebar:hover:after{background:var(--color-primary)}.sidebar__resize-handle{cursor:col-resize;z-index:10;width:4px;height:100%;position:absolute;top:0;right:0}.sidebar__host-delete-btn,.sidebar__group-delete-btn,.sidebar__iplist-delete-btn{width:18px;height:18px;color:var(--color-text-tertiary);cursor:pointer;opacity:0;transition:opacity var(--transition-fast), color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:14px;display:flex}.sidebar__host-row:hover .sidebar__host-delete-btn,.sidebar__group-row:hover .sidebar__group-delete-btn,.sidebar__iplist-row:hover .sidebar__iplist-delete-btn{opacity:1}.sidebar__host-delete-btn:hover,.sidebar__group-delete-btn:hover,.sidebar__iplist-delete-btn:hover{color:var(--color-block,#ff453a);background:var(--color-hover)}.rule-table{flex-direction:column;flex:1;min-width:0;height:100%;display:flex;position:relative}.rule-table__sections{flex:1;padding-bottom:60px;overflow-y:auto}.rule-table__section{margin-bottom:var(--space-compact)}.rule-table__section-header{cursor:pointer;-webkit-user-select:none;user-select:none;z-index:1;background:0 0;border-radius:0;align-items:center;gap:8px;margin:8px 0;padding:8px 16px;display:flex;position:sticky;top:0}.rule-table__section-header:before,.rule-table__section-header:after{content:"";background:var(--color-border);flex:1;height:1px}.rule-table__section-icon{display:none}.rule-table__section-title{text-transform:uppercase;letter-spacing:1px;color:var(--color-text-tertiary);white-space:nowrap;font-size:10px;font-weight:600}.rule-table__section-count{color:var(--color-text-tertiary);white-space:nowrap;font-size:10px;font-weight:400}.rule-table__section-disclosure{font-size:var(--font-size-section-header);color:var(--color-disabled);margin-left:var(--space-tight)}.rule-table__section-header--sub{padding:var(--space-compact) var(--space-spacious)}.rule-table__section-header--sub .rule-table__section-title{font-size:11px;font-weight:500}.rule-table__drag-handle{cursor:grab;color:#0000;-webkit-user-select:none;user-select:none;flex-shrink:0;justify-content:center;align-items:center;width:20px;font-size:14px;transition:color .1s;display:flex}.rule-table__row:hover .rule-table__drag-handle{color:var(--color-text-tertiary)}.rule-table__drag-handle:active{cursor:grabbing}.rule-table__row--ghost{opacity:.3;background:var(--color-primary-hover-bg)}.rule-table__rows{flex-direction:column;gap:4px;padding-top:8px;display:flex}.rule-table__row{min-height:var(--row-height);padding:0 var(--space-spacious) 0 calc(var(--status-bar-width) + var(--space-default));cursor:pointer;transition:background var(--transition-fast), box-shadow var(--transition-fast);border-bottom:1px solid var(--color-separator);box-sizing:border-box;border-radius:6px;align-items:center;display:flex;position:relative}.rule-table__row:hover{background:var(--color-hover);box-shadow:0 1px 4px #0000001a}.rule-table__row:hover .rule-table__overflow-btn{opacity:1}.rule-table__row:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.rule-table__row--selected{background:var(--color-selected)}.rule-table__row--selected .rule-table__row-bar{background:var(--color-primary)!important}.rule-table__row--disabled{opacity:.4}.rule-table__row--disabled .rule-table__rule-name{text-decoration:line-through}.rule-table__row-bar{width:var(--status-bar-width);z-index:1;border-radius:0 2px 2px 0;position:absolute;top:4px;bottom:4px;left:0}.rule-table__row--selected .rule-table__row-bar{width:4px}.rule-table__row-bar--allow{background:linear-gradient(to bottom, var(--color-allow), color-mix(in srgb, var(--color-allow) 60%, transparent))}.rule-table__row-bar--block{background:linear-gradient(to bottom, var(--color-block), color-mix(in srgb, var(--color-block) 60%, transparent))}.rule-table__row-bar--log{background:linear-gradient(to bottom, var(--color-log), color-mix(in srgb, var(--color-log) 60%, transparent))}.rule-table__row-bar--fwd{background:linear-gradient(to bottom, var(--color-info), color-mix(in srgb, var(--color-info) 60%, transparent))}.rule-table__row-content{min-width:0;padding-left:var(--space-default);flex-direction:column;flex:1;justify-content:center;gap:2px;display:flex}.rule-table__row-first-line{align-items:center;gap:var(--space-compact);display:flex}.rule-table__status-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.5px;border-radius:4px;flex-shrink:0;align-items:center;padding:2px 6px;font-size:9px;font-weight:700;display:inline-flex}.rule-table__status-label--allow{color:#30d158;background:#30d15814}.rule-table__status-label--block{color:#ff453a;background:#ff453a14}.rule-table__status-label--log{color:#5e5ce6;background:#5e5ce614}.rule-table__status-label--fwd{color:#ff9f0a;background:#ff9f0a14}.rule-table__rule-name{color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:500;overflow:hidden}.rule-table__rule-name--group{font-weight:400}.rule-table__pending-dot{background:var(--color-warning);border-radius:50%;flex-shrink:0;width:6px;height:6px}@keyframes pending-dot-appear{0%{transform:scale(0)}70%{transform:scale(1.2)}to{transform:scale(1)}}.rule-table__pending-dot--animate{animation:.3s pending-dot-appear}.rule-table__row-second-line{align-items:center;padding-left:52px;display:flex}.rule-table__protocol{font-size:var(--font-size-rule-protocol);color:var(--color-text-secondary);font-weight:400}.rule-table__comment{font-size:var(--font-size-rule-comment);color:var(--color-text-tertiary);text-overflow:ellipsis;white-space:nowrap;font-weight:400;overflow:hidden}.rule-table__row-right{align-items:center;gap:var(--space-compact);flex-shrink:0;margin-left:auto;display:flex}.rule-table__source{color:var(--color-text-primary);text-align:right;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;width:120px;font-size:13px;overflow:hidden}.rule-table__source--mono{font-family:var(--font-mono);font-size:var(--font-size-mono);color:var(--color-text-secondary)}.rule-table__origin-tag{font-size:var(--font-size-caption);color:var(--color-text-tertiary);white-space:nowrap;text-align:right;text-overflow:ellipsis;flex-shrink:0;width:50px;overflow:hidden}.rule-table__origin-tag--pill{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);padding:2px 6px}.rule-table__hit-count{color:var(--color-text-secondary);text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0;width:50px;font-size:13px;font-weight:400;transition:color .3s}.rule-table__hit-count--updating{color:var(--color-allow)}.rule-table__overflow-btn{color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-sm);opacity:0;transition:opacity var(--transition-fast);background:0 0;border:none;flex-shrink:0;padding:4px 8px;font-size:16px}.rule-table__overflow-btn:hover{background:var(--color-surface)}.rule-table__overflow-btn:focus-visible{opacity:1;outline:2px solid var(--color-primary)}.rule-table__loading-overlay{justify-content:center;align-items:center;gap:var(--space-default,12px);padding:var(--space-spacious,24px) * 2;min-height:200px;color:var(--color-text-secondary,#86868b);flex-direction:column;font-size:14px;display:flex}.rule-table__loading-spinner{border:2.5px solid var(--color-border,#e5e5e7);border-top-color:var(--color-primary,#007aff);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite rule-table-spin}@keyframes rule-table-spin{to{transform:rotate(360deg)}}.rule-table__error-banner{align-items:center;gap:var(--space-compact,8px);padding:var(--space-default,12px) var(--space-spacious,24px);margin:var(--space-default,12px) var(--space-spacious,24px) 0;background:var(--color-diff-removed-bg,#ff3b3014);color:var(--color-block,#ff3b30);border-radius:var(--radius-md,6px);font-size:13px;font-weight:500;display:flex}.rule-table__error-banner:before{content:"⚠";flex-shrink:0;font-size:16px}.rule-table__empty{padding:var(--space-generous) var(--space-spacious);text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:200px;display:flex}.rule-table__empty-title{font-size:var(--font-size-rule-name);color:var(--color-text-primary);margin:0 0 var(--space-compact);font-weight:500}.rule-table__empty-subtitle{font-size:var(--font-size-rule-protocol);color:var(--color-text-secondary);margin:0 0 var(--space-comfortable)}.rule-table__empty-actions{gap:var(--space-compact);display:flex}.rule-table__empty-btn{font-family:var(--font-family);color:var(--color-primary);border:1px solid var(--color-primary);border-radius:var(--radius-md);cursor:pointer;height:28px;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;padding:6px 16px;font-size:13px}.rule-table__empty-btn:hover{background:var(--color-primary-hover-bg)}.rule-table__empty-btn--primary{background:var(--color-primary);color:var(--color-primary-text);border-color:var(--color-primary)}.rule-table__empty-btn--primary:hover{opacity:.9;background:var(--color-primary)}.rule-table__row--added{background:var(--color-diff-added-bg)}.rule-table__row--modified .rule-table__rule-name--old{color:var(--color-block);opacity:.6;text-decoration:line-through}.rule-table__row--deleted{opacity:.4;background:var(--color-diff-removed-bg)}.rule-table__row--deleted .rule-table__rule-name{text-decoration:line-through}.rule-table__row--default-policy{opacity:1;background:#ff453a0f;border:1px dashed #ff453a4d;border-radius:8px;margin:8px 0;padding:12px 16px}.rule-table__row--default-policy .rule-table__status-label{font-size:11px}.rule-table__row--default-policy-accept{background:#30d1580f;border-color:#30d1584d}.rule-table__nat-actions{padding:var(--space-compact) var(--space-comfortable)}.rule-table__nat-link{color:var(--color-primary);cursor:pointer;font-size:13px;font-family:var(--font-family);transition:opacity var(--transition-fast);background:0 0;border:none;padding:4px 0;display:block}.rule-table__nat-link:hover{opacity:.8}.rule-table__nat-hint{margin:var(--space-compact) 0 0;color:var(--color-text-secondary);font-size:12px}.rule-table__section-empty{padding:var(--space-compact) var(--space-spacious);color:var(--color-text-tertiary);font-size:13px;font-style:italic}.rule-table__route-map{padding:6px var(--space-spacious);font-family:var(--font-mono);color:var(--color-text-tertiary);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:4px;font-size:11px;line-height:1.6;display:flex}.rule-table__route-map-node{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);white-space:nowrap;border-radius:3px;padding:1px 6px}.rule-table__route-map-node:hover{background:var(--color-hover);color:var(--color-text-primary)}.rule-table__route-map-node--active{background:var(--color-primary-hover-bg);border-color:var(--color-primary);color:var(--color-primary);font-weight:600}.rule-table__route-map-arrow{color:var(--color-text-tertiary);font-size:10px}.rule-table__route-map-label{color:var(--color-text-tertiary);white-space:nowrap;font-size:10px}.rule-table__activity-dot{background:var(--color-disabled);border-radius:50%;flex-shrink:0;width:5px;height:5px}.rule-table__activity-dot--active{background:var(--color-allow);animation:2s ease-in-out infinite activity-dot-pulse}@keyframes activity-dot-pulse{0%,to{opacity:1}50%{opacity:.4}}.rule-table__row-third-line{align-items:center;gap:6px;padding-left:60px;display:flex}.rule-table__micro-tag{font-family:var(--font-mono);color:var(--color-text-tertiary);background:var(--color-surface);border-radius:3px;padding:0 4px;font-size:11px}.rule-table__micro-separator{color:var(--color-text-tertiary);font-size:11px}.rule-table__header{align-items:center;gap:var(--space-default);padding:var(--space-spacious) var(--space-spacious) var(--space-compact);flex-shrink:0;display:flex}.rule-table__host-name{font-size:var(--font-size-page-title);color:var(--color-text-primary);font-weight:600}.rule-table__host-status{font-size:var(--font-size-caption);border-radius:var(--radius-sm);padding:2px 8px;font-weight:500}.rule-table__host-status--connected{color:var(--color-allow)}.rule-table__host-status--connecting{color:var(--color-info)}.rule-table__host-status--disconnected{color:var(--color-block)}.rule-table__host-status--unreachable{color:var(--color-disabled)}.rule-table__host-status--drifted{color:var(--color-warning)}.rule-table__host-status--pending{color:var(--color-info)}.rule-table__tabs{padding:0 var(--space-spacious);border-bottom:1px solid var(--color-border);flex-shrink:0;gap:0;display:flex}.rule-table__tab{padding:var(--space-compact) var(--space-comfortable);font-family:var(--font-family);color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;font-size:13px;font-weight:500}.rule-table__tab:hover{color:var(--color-text-primary)}.rule-table__tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.rule-table__header-actions{align-items:center;gap:6px;margin-left:auto;display:flex}.rule-table__header-btn{cursor:pointer;border-radius:var(--radius-md);border:1px solid var(--color-border);height:28px;color:var(--color-text-secondary);font-size:13px;font-weight:400;font-family:var(--font-family);transition:background var(--transition-fast), color var(--transition-fast);background:0 0;padding:0 12px}.rule-table__header-btn:hover{background:var(--color-hover)}.rule-table__header-btn:active{transform:scale(.97)}.rule-table__header-btn--disconnect{color:var(--color-block);border-color:var(--color-border)}.rule-table__header-btn--disconnect:hover{background:var(--color-diff-removed-bg)}.rule-table__header-btn--reconnect{background:var(--color-primary);color:var(--color-primary-text);border:none}.rule-table__header-btn--reconnect:hover{opacity:.9;background:var(--color-primary)}.rule-table__add-rule-container{padding:var(--space-compact) var(--space-spacious);flex-shrink:0}.rule-table__add-rule-btn{height:28px;font-size:13px;font-weight:400;font-family:var(--font-family);color:var(--color-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);background:0 0;padding:0 12px}.rule-table__add-rule-btn:hover{background:var(--color-primary-hover-bg)}.rule-table__add-rule-btn:active{transform:scale(.97)}.rule-table__filter-bar-container{flex-shrink:0;margin-bottom:12px}.rule-table__filter-bar{align-items:center;gap:var(--space-default);padding:var(--space-default) var(--space-spacious);display:flex}.filter-bar__segmented{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);gap:1px;padding:2px;display:inline-flex}.filter-bar__segment{font-family:var(--font-family);color:var(--color-text-secondary);border-radius:calc(var(--radius-lg) - 2px);cursor:pointer;transition:all var(--transition-default);white-space:nowrap;background:0 0;border:none;padding:4px 14px;font-size:12px;font-weight:500}.filter-bar__segment:hover{color:var(--color-text-primary)}.filter-bar__segment--active{background:var(--color-elevated);color:var(--color-text-primary);box-shadow:var(--shadow-segment), 0 0 0 .5px #00000014;font-weight:600}.filter-bar__search-wrap{align-items:center;gap:var(--space-compact);flex:1;display:flex;position:relative}.filter-bar__search-clear{background:var(--color-hover,#333);width:18px;height:18px;color:var(--color-text-secondary,#888);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:12px;line-height:1;display:flex;position:absolute;left:178px}.filter-bar__search-clear:hover{background:var(--color-text-tertiary,#555);color:var(--color-text-primary,#fff)}.filter-bar__search-input{height:28px;padding:0 var(--space-compact);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background);color:var(--color-text-primary);font-family:var(--font-family);box-sizing:border-box;max-width:200px;transition:border-color var(--transition-fast);outline:none;flex:1;font-size:12px}.filter-bar__search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.filter-bar__search-input::placeholder{color:var(--color-text-tertiary)}.filter-bar__count{font-size:var(--font-size-filter-count);color:var(--color-text-secondary);white-space:nowrap}.filter-bar__advanced{align-items:center;gap:var(--space-compact,8px);flex-shrink:0;display:flex}.filter-bar__select{height:28px;padding:0 var(--space-compact,8px);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background);color:var(--color-text-primary);font-family:var(--font-family);cursor:pointer;transition:border-color var(--transition-fast);-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%2386868B'/%3E%3C/svg%3E");background-position:right 6px center;background-repeat:no-repeat;outline:none;padding-right:20px;font-size:12px}.filter-bar__select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.filter-bar__port-input{width:60px;height:28px;padding:0 var(--space-compact,8px);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background);color:var(--color-text-primary);font-family:var(--font-family);box-sizing:border-box;transition:border-color var(--transition-fast);outline:none;font-size:12px}.filter-bar__port-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.filter-bar__port-input::placeholder{color:var(--color-text-tertiary)}.filter-bar__address-input{width:110px;height:28px;padding:0 var(--space-compact,8px);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background);color:var(--color-text-primary);font-family:var(--font-family);box-sizing:border-box;transition:border-color var(--transition-fast);outline:none;font-size:12px}.filter-bar__address-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.filter-bar__address-input::placeholder{color:var(--color-text-tertiary)}.filter-bar__add-rule-btn{height:28px;font-size:13px;font-family:var(--font-family);color:var(--color-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);white-space:nowrap;background:0 0;flex-shrink:0;padding:0 12px;font-weight:400}.filter-bar__add-rule-btn:hover{background:var(--color-primary-hover-bg)}.filter-bar__add-rule-btn:active{transform:scale(.97)}.rule-table__pending-bar-container{position:relative}.rule-table__pending-bar{height:var(--row-height);padding:0 var(--space-spacious);background:var(--color-elevated);border-top:2px solid var(--color-warning);z-index:10;transition:transform var(--transition-default);align-items:center;gap:var(--space-compact);display:flex;position:sticky;bottom:0;transform:translateY(100%)}.rule-table__pending-bar--visible{transform:translateY(0)}.rule-table__pending-bar-dot{background:var(--color-warning);border-radius:50%;flex-shrink:0;width:8px;height:8px}.rule-table__pending-bar-count{color:var(--color-text-primary);font-size:13px;font-weight:500}.rule-table__pending-bar-spacer{flex:1}.rule-table__pending-bar-discard{font-family:var(--font-family);color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:color var(--transition-fast);background:0 0;border:none;padding:4px 12px;font-size:13px}.rule-table__pending-bar-discard:hover{color:var(--color-block)}.rule-table__pending-bar-apply{font-family:var(--font-family);color:var(--color-primary-text);background:var(--color-primary);cursor:pointer;border-radius:var(--radius-md);align-items:center;gap:var(--space-tight);height:28px;transition:opacity var(--transition-fast);border:none;padding:6px 16px;font-size:13px;font-weight:500;display:flex}.rule-table__pending-bar-apply:hover{opacity:.9}.rule-table__pending-bar-apply:disabled{opacity:.5;cursor:not-allowed}.rule-table__pending-bar-apply kbd{font-family:var(--font-family);opacity:.7;font-size:11px;font-weight:400}.rule-table__pending-bar-group-apply{font-family:var(--font-family);color:var(--color-primary);border:1px solid var(--color-primary);cursor:pointer;border-radius:var(--radius-md);height:28px;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;align-items:center;padding:5px 12px;font-size:13px;font-weight:500;display:flex}.rule-table__pending-bar-group-apply:hover{background:var(--color-primary);color:var(--color-primary-text)}.rule-table__pending-bar-show-changes{color:var(--color-primary);cursor:pointer;font-size:12px;font-family:var(--font-family);padding:0 var(--space-compact);transition:opacity var(--transition-fast);background:0 0;border:none}.rule-table__pending-bar-show-changes:hover{opacity:.8}.rule-table__pending-bar-apply-wrap{display:inline-block;position:relative}.rule-table__pending-bar-changes-list{padding:var(--space-compact) var(--space-comfortable);border-top:1px solid var(--color-border);font-size:12px}.rule-table__pending-bar-change-row{justify-content:space-between;align-items:center;padding:2px 0;display:flex}.rule-table__pending-bar-undo-btn{color:var(--color-primary);cursor:pointer;font-size:11px;font-family:var(--font-family);transition:opacity var(--transition-fast);background:0 0;border:none;padding:0 4px}.rule-table__pending-bar-undo-btn:hover{opacity:.8}.rule-table__pending-bar-empty{color:var(--color-text-secondary)}.rule-table__pending-bar-error{color:var(--color-block);margin-left:var(--space-compact);font-size:12px}.rule-table__lock-error{align-items:center;gap:var(--space-compact);padding:var(--space-compact) var(--space-spacious);background:color-mix(in srgb, var(--color-block) 10%, var(--color-elevated));border-top:1px solid var(--color-block);color:var(--color-text-primary);flex-wrap:wrap;font-size:12px;display:flex}.rule-table__lock-error-msg{color:var(--color-block);font-weight:600}.rule-table__lock-error-tip{color:var(--color-text-secondary)}.rule-table__lock-error-retry{font-family:var(--font-family);color:var(--color-primary-text);background:var(--color-primary);cursor:pointer;border-radius:var(--radius-md);transition:opacity var(--transition-fast);border:none;margin-left:auto;padding:3px 12px;font-size:12px;font-weight:500}.rule-table__lock-error-retry:hover{opacity:.9}.rule-table__lock-error-dismiss{color:var(--color-text-tertiary);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;padding:0 4px;font-size:16px;line-height:1}.rule-table__lock-error-dismiss:hover{color:var(--color-text-primary)}.rule-table__pending-bar-tooltip{background:var(--color-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-compact) var(--space-default);white-space:nowrap;z-index:100;box-shadow:var(--shadow-popover);color:var(--color-text-primary);margin-bottom:6px;font-size:12px;position:absolute;bottom:100%;right:0}.rule-table__pending-bar-tooltip-item{padding:1px 0}.rule-table__pending-bar-preview{font-family:var(--font-family);color:var(--color-text-secondary);background:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;border-radius:var(--radius-md);height:28px;transition:background var(--transition-fast), border-color var(--transition-fast);align-items:center;padding:5px 14px;font-size:13px;font-weight:500;display:flex}.rule-table__pending-bar-preview:hover{background:var(--color-hover);border-color:var(--color-border-strong)}.rule-table__pending-bar-preview:disabled{opacity:.5;cursor:not-allowed}.preview-modal__backdrop{z-index:9999;background:#00000073;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.preview-modal{background:var(--color-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg,10px);flex-direction:column;width:640px;max-width:90vw;max-height:80vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #0000004d}.preview-modal__header{border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px 12px;display:flex}.preview-modal__title{font-family:var(--font-family);color:var(--color-text-primary);margin:0;font-size:15px;font-weight:600}.preview-modal__close{color:var(--color-text-tertiary);cursor:pointer;border-radius:var(--radius-sm,4px);transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;padding:2px 6px;font-size:20px;line-height:1}.preview-modal__close:hover{background:var(--color-hover);color:var(--color-text-primary)}.preview-modal__section{padding:12px 20px;overflow:auto}.preview-modal__section-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.preview-modal__label{font-family:var(--font-family);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:11px;font-weight:600;display:block}.preview-modal__section-header .preview-modal__label{margin-bottom:0}.preview-modal__code{font-family:var(--font-mono);color:var(--color-text-primary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);white-space:pre;word-break:break-all;tab-size:4;max-height:400px;margin:0;padding:12px 14px;font-size:12px;line-height:1.5;overflow:auto}.preview-modal__code--cmd{max-height:none;color:var(--color-text-secondary);background:var(--color-hover)}.preview-modal__copy{font-family:var(--font-family);color:var(--color-primary);border:1px solid var(--color-primary);cursor:pointer;border-radius:var(--radius-md);transition:background var(--transition-fast), color var(--transition-fast);background:0 0;padding:3px 10px;font-size:12px}.preview-modal__copy:hover{background:var(--color-primary);color:var(--color-primary-text)}@media (prefers-color-scheme:dark){.preview-modal{background:var(--color-elevated);box-shadow:0 20px 60px #0009}.preview-modal__backdrop{background:#0009}}.rule-table__conflicts-banner{margin:var(--space-default,12px) var(--space-spacious,24px) 0;background:color-mix(in srgb, var(--color-warning) 8%, transparent);border:1px solid color-mix(in srgb, var(--color-warning) 25%, transparent);border-radius:var(--radius-md,6px);overflow:hidden}.rule-table__conflicts-summary{align-items:center;gap:var(--space-compact,8px);width:100%;padding:var(--space-default,12px) var(--space-spacious,24px);font-size:13px;font-weight:500;font-family:var(--font-family);color:var(--color-warning,#ff9500);cursor:pointer;text-align:left;background:0 0;border:none;display:flex}.rule-table__conflicts-summary:hover{background:color-mix(in srgb, var(--color-warning) 5%, transparent)}.rule-table__conflicts-chevron{transition:transform var(--transition-fast,.15s);flex-shrink:0;font-size:10px}.rule-table__conflicts-chevron--open{transform:rotate(90deg)}.rule-table__conflicts-list{padding:0 var(--space-spacious,24px) var(--space-default,12px);gap:var(--space-compact,8px);flex-direction:column;display:flex}.rule-table__conflicts-item{align-items:baseline;gap:var(--space-compact,8px);padding:var(--space-compact,8px) var(--space-default,12px);background:var(--color-elevated,#fff);border-radius:var(--radius-sm,4px);flex-wrap:wrap;font-size:12px;line-height:1.4;display:flex}.rule-table__conflicts-badge{text-transform:uppercase;letter-spacing:.02em;border-radius:3px;flex-shrink:0;padding:1px 6px;font-size:11px;font-weight:600;display:inline-block}.rule-table__conflicts-badge--shadow{background:color-mix(in srgb, var(--color-warning) 15%, transparent);color:var(--color-warning)}.rule-table__conflicts-badge--contradiction{background:color-mix(in srgb, var(--color-block) 12%, transparent);color:var(--color-block)}.rule-table__conflicts-badge--redundant{background:color-mix(in srgb, var(--color-info) 12%, transparent);color:var(--color-info)}.rule-table__conflicts-rules{font-family:var(--font-mono);color:var(--color-text-secondary);flex-shrink:0}.rule-table__conflicts-desc{color:var(--color-text-primary)}@media (prefers-color-scheme:dark){.rule-table__conflicts-item{background:var(--color-elevated)}}.rule-table__import-banner{background:color-mix(in srgb, var(--color-primary) 8%, transparent);border:1px solid color-mix(in srgb, var(--color-primary) 20%, transparent);border-radius:var(--radius-md,8px);align-items:center;gap:12px;margin:8px 0;padding:10px 16px;display:flex}.rule-table__import-text{font-size:var(--font-size-base,14px);color:var(--color-text-primary,#1d1d1f);flex:1}.rule-table__import-btn{font-size:var(--font-size-rule-protocol,12px);color:var(--color-primary-text);background:var(--color-primary);border-radius:var(--radius-sm,4px);cursor:pointer;white-space:nowrap;transition:opacity var(--transition-fast);border:none;padding:5px 14px;font-weight:600}.rule-table__import-btn:hover{opacity:.85}.rule-table__import-dismiss{color:var(--color-text-secondary,#86868b);cursor:pointer;border-radius:var(--radius-sm,4px);background:0 0;border:none;padding:2px 6px;font-size:16px;line-height:1}.rule-table__import-dismiss:hover{background:var(--color-surface,#f5f5f7);color:var(--color-text-primary,#1d1d1f)}@media (prefers-color-scheme:dark){.rule-table__import-dismiss:hover{background:var(--color-surface)}}.side-panel{width:var(--side-panel-width,420px);background:var(--color-surface);border-left:1px solid var(--color-border);z-index:100;flex-direction:column;transition:transform .25s ease-out;display:flex;position:fixed;top:0;bottom:0;right:0;overflow-y:auto;transform:translate(100%);box-shadow:-2px 0 8px #0000000d}.side-panel--open{transform:translate(0)}.side-panel__header{padding:var(--space-default) var(--space-spacious);flex-shrink:0;justify-content:flex-end;display:flex}.side-panel__close-btn{width:32px;height:32px;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;font-size:18px;display:flex}.side-panel__close-btn:hover{background:var(--color-hover)}.side-panel__close-btn:focus-visible{outline:2px solid var(--color-info);outline-offset:-2px}.side-panel__content{padding:0 var(--space-spacious) var(--space-spacious);opacity:1;flex:1;transition:opacity .15s}.side-panel__content--fading{opacity:0}.side-panel__section-title{font-size:var(--font-size-section-header);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-primary);margin:var(--space-section) 0 var(--space-compact);font-weight:600}.side-panel__empty-text{font-size:var(--font-size-rule-protocol);color:var(--color-text-tertiary)}.side-panel__label{font-size:var(--font-size-rule-name,14px);color:var(--color-text-primary,#1d1d1f);margin-bottom:var(--space-comfortable,16px);font-weight:500;display:block}.side-panel__input{width:100%;padding:var(--space-compact,8px) var(--space-default,12px);border:1px solid var(--color-border,#e5e5e7);border-radius:var(--radius-md,6px);font-size:var(--font-size-rule-name,14px);font-family:var(--font-family);color:var(--color-text-primary,#1d1d1f);background:var(--color-background,#fff);box-sizing:border-box;margin-top:var(--space-tight,4px);transition:border-color var(--transition-fast,.1s ease);display:block}.side-panel__input:focus{border-color:var(--color-primary,#007aff);box-shadow:0 0 0 3px var(--color-focus-ring,#007aff33);outline:none}.side-panel__subtitle{font-size:var(--font-size-section-header,12px);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-secondary,#86868b);margin:var(--space-section,20px) 0 var(--space-compact,8px);font-weight:600}.side-panel__empty{font-size:var(--font-size-rule-protocol,12px);color:var(--color-text-tertiary,#aeaeb2);padding:var(--space-compact,8px) 0}.side-panel__add-entry-row{gap:var(--space-compact,8px);margin-bottom:var(--space-default,12px);display:flex}.side-panel__add-entry-row .side-panel__input{flex:1;margin-top:0}.side-panel__entries-list{border:1px solid var(--color-border,#e5e5e7);border-radius:var(--radius-md,6px);min-height:40px;max-height:240px;margin-bottom:var(--space-comfortable,16px);overflow-y:auto}.side-panel__entries-list:empty{display:none}.side-panel__entry-row{align-items:center;gap:var(--space-compact,8px);padding:var(--space-compact,8px) var(--space-default,12px);display:flex}.side-panel__entry-row:not(:last-child){border-bottom:1px solid var(--color-separator,#f2f2f7)}.side-panel__entry-addr{font-family:var(--font-mono,monospace);font-size:var(--font-size-mono,12px);color:var(--color-text-primary,#1d1d1f);flex:1;min-width:0}.side-panel__entry-comment{font-size:var(--font-size-rule-protocol,12px);color:var(--color-text-secondary,#86868b);flex-shrink:0}.side-panel__entry-remove-btn{color:var(--color-text-tertiary,#aeaeb2);cursor:pointer;transition:color var(--transition-fast,.1s ease);background:0 0;border:none;flex-shrink:0;padding:0 4px;font-size:16px;line-height:1}.side-panel__entry-remove-btn:hover{color:var(--color-block,#ff3b30)}.side-panel__member-list{border:1px solid var(--color-border,#e5e5e7);border-radius:var(--radius-md,6px);padding:var(--space-compact,8px) var(--space-default,12px);max-height:200px;overflow-y:auto}.side-panel__member-row{align-items:center;gap:var(--space-compact,8px);padding:var(--space-tight,4px) 0;font-size:var(--font-size-rule-name,14px);color:var(--color-text-primary,#1d1d1f);cursor:pointer;display:flex}.side-panel__member-row:hover{color:var(--color-primary,#007aff)}.side-panel__group-rules-list{margin-bottom:var(--space-default,12px)}.side-panel__group-rule-row{padding:var(--space-compact,8px) var(--space-default,12px);border:1px solid var(--color-border,#e5e5e7);border-radius:var(--radius-md,6px);margin-bottom:var(--space-compact,8px);font-size:var(--font-size-rule-name,14px);justify-content:space-between;align-items:center;display:flex}.side-panel__group-rule-builder{margin:var(--space-comfortable,16px) 0}.side-panel__group-rule-builder-actions{gap:var(--space-compact,8px);margin-top:var(--space-default,12px);justify-content:flex-end;display:flex}.side-panel__btn-row{gap:var(--space-compact,8px);margin-top:var(--space-spacious,24px);padding-top:var(--space-comfortable,16px);border-top:1px solid var(--color-separator,#f2f2f7);display:flex}.side-panel__snapshot-history{flex-direction:column;display:flex}.side-panel__snapshot-list{gap:var(--space-compact,8px);flex-direction:column;display:flex}.side-panel__snapshot-item{padding:var(--space-default,12px);border:1px solid var(--color-border,#e5e5e7);border-radius:var(--radius-md,6px)}.side-panel__snapshot-item-header{justify-content:space-between;align-items:center;gap:var(--space-compact,8px);display:flex}.side-panel__snapshot-item-time{font-size:var(--font-size-rule-name,14px);color:var(--color-text-primary,#1d1d1f);font-weight:500}.side-panel__snapshot-restore-btn{flex-shrink:0}.side-panel__snapshot-item-desc{font-size:var(--font-size-rule-protocol,12px);color:var(--color-text-secondary,#86868b);margin:var(--space-tight,4px) 0 0}.side-panel__snapshot-item-meta{font-size:var(--font-size-caption,11px);color:var(--color-text-tertiary,#aeaeb2);margin-top:var(--space-tight,4px);display:block}.rule-detail{font-family:var(--font-family)}.rule-detail__title{font-size:var(--font-size-page-title);color:var(--color-text-primary);margin:0 0 var(--space-default);font-weight:600}.rule-detail__divider{border:none;border-top:1px solid var(--color-separator);margin:0 0 var(--space-comfortable)}.rule-detail__fields{gap:var(--space-default);flex-direction:column;display:flex}.rule-detail__field{align-items:baseline;gap:var(--space-compact);flex-direction:row;display:flex}.rule-detail__label{color:var(--color-text-secondary);flex-shrink:0;width:100px;font-size:13px}.rule-detail__value{color:var(--color-text-primary);font-size:13px;font-weight:500}.rule-detail__expanded-ips{margin-top:var(--space-tight);flex-direction:column;gap:2px;display:flex}.rule-detail__ip-entry{font-family:var(--font-mono);font-size:var(--font-size-mono);color:var(--color-text-secondary)}.rule-detail__empty{color:var(--color-text-tertiary);padding:var(--space-spacious);text-align:center;font-size:13px}.rule-detail__section{margin-top:var(--space-spacious)}.rule-detail__section-header{align-items:center;gap:var(--space-compact);font-size:var(--font-size-section-header);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-primary);padding-bottom:var(--space-compact);margin-bottom:var(--space-default);font-weight:600;display:flex}.rule-detail__section-header:before,.rule-detail__section-header:after{content:"";background:var(--color-border);flex:1;height:1px}.rule-detail__section-header:before{max-width:16px}.rule-detail__disclosure{margin-top:var(--space-comfortable)}.rule-detail__disclosure-summary{color:var(--color-info);cursor:pointer;-webkit-user-select:none;user-select:none;padding:var(--space-compact) 0;font-size:13px;list-style:none}.rule-detail__disclosure-summary::-webkit-details-marker{display:none}.rule-detail__disclosure-summary:before{content:"▸";margin-right:var(--space-compact);transition:transform var(--transition-fast);display:inline-block}.rule-detail__disclosure[open] .rule-detail__disclosure-summary:before{transform:rotate(90deg)}.rule-detail__code{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-default);font-family:var(--font-mono);font-size:var(--font-size-mono);color:var(--color-text-primary);margin-top:var(--space-compact);white-space:pre-wrap;word-break:break-all;overflow-x:auto}.rule-detail__actions{gap:var(--space-compact);margin-top:var(--space-spacious);padding-top:var(--space-comfortable);border-top:1px solid var(--color-separator);display:flex}.rule-detail__action-btn{border-radius:var(--radius-md);cursor:pointer;height:28px;transition:background var(--transition-fast);border:none;flex:1;font-size:13px;font-weight:500}.rule-detail__action-btn--edit{background:var(--color-primary);color:var(--color-primary-text)}.rule-detail__action-btn--edit:hover{opacity:.9}.rule-detail__action-btn--disable{color:var(--color-primary);border:1px solid var(--color-border);background:0 0}.rule-detail__action-btn--disable:hover{background:var(--color-primary-hover-bg)}.rule-detail__action-btn--delete{color:var(--color-block);border:1px solid var(--color-border);background:0 0}.rule-detail__action-btn--delete:hover{background:var(--color-diff-removed-bg)}.rule-edit{height:100%;font-family:var(--font-family);flex-direction:column;display:flex}.rule-edit__title{font-size:var(--font-size-page-title);color:var(--color-text-primary);margin:0 0 var(--space-default);font-weight:600}.rule-edit__divider{border:none;border-top:1px solid var(--color-separator);margin:0 0 var(--space-comfortable)}.rule-edit__builder{flex:1;overflow-y:auto}.rule-edit__footer{gap:var(--space-compact);padding:var(--space-comfortable) 0 0;border-top:1px solid var(--color-separator);margin-top:var(--space-comfortable);flex-shrink:0;justify-content:flex-end;display:flex}.rule-edit__cancel-btn{height:28px;padding:0 var(--space-comfortable);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);cursor:pointer;transition:background var(--transition-fast);background:0 0;font-size:13px}.rule-edit__cancel-btn:hover{background:var(--color-hover)}.rule-edit__save-btn{height:28px;padding:0 var(--space-comfortable);border-radius:var(--radius-md);background:var(--color-primary);color:var(--color-primary-text);cursor:pointer;transition:opacity var(--transition-fast);border:none;font-size:13px;font-weight:500}.rule-edit__save-btn:hover{opacity:.9}.side-panel--bottom-sheet{border-left:none;border-top:1px solid var(--color-border);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-height:70vh;top:auto;left:0;right:0;transform:translateY(100%)}.side-panel--bottom-sheet.side-panel--open{transform:translateY(0)}@media (prefers-color-scheme:dark){.side-panel{background:var(--color-elevated)}.rule-detail__code{background:var(--color-surface)}}.side-panel__btn--danger{color:var(--color-block);border-color:var(--color-block)}.side-panel__btn--danger:hover{background:var(--color-block);color:var(--color-primary-text)}.side-panel__feedback{margin-top:var(--space-compact,8px);padding:var(--space-compact,8px) var(--space-default,12px);border-radius:var(--radius-md,6px);font-size:var(--font-size-rule-protocol,12px);color:var(--color-allow);background:#34c7591f}.side-panel__feedback--error{color:var(--color-block);background:#ff3b301f}.rule-builder{gap:var(--space-comfortable);font-family:var(--font-family);flex-direction:column;display:flex}.rule-builder__field-group{gap:var(--space-tight);flex-direction:column;display:flex}.rule-builder__field-label{font-size:var(--font-size-rule-protocol);color:var(--color-text-primary);font-weight:500}.rule-builder__segment-control{background:var(--color-surface);border-radius:var(--radius-lg);gap:0;padding:2px;display:flex;position:relative}.rule-builder__segment-indicator{background:var(--color-background);border-radius:var(--radius-md);height:calc(100% - 4px);box-shadow:var(--shadow-segment);z-index:0;transition:left .15s,width .15s;position:absolute;top:2px}.rule-builder__segment-btn{height:28px;color:var(--color-text-secondary);cursor:pointer;z-index:1;border-radius:var(--radius-md);transition:color var(--transition-default);background:0 0;border:none;flex:1;font-size:13px;font-weight:500;position:relative}.rule-builder__segment-btn--active{color:var(--color-text-primary)}.rule-builder__segment-btn:focus-visible{outline:2px solid var(--color-info);outline-offset:-2px}.rule-builder__input{width:100%;height:32px;padding:0 var(--space-default);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-background);color:var(--color-text-primary);font-size:13px;font-family:var(--font-family);box-sizing:border-box;transition:border-color var(--transition-fast)}.rule-builder__input:focus{border-color:var(--color-info);box-shadow:0 0 0 2px var(--color-focus-ring);outline:none}.rule-builder__input::placeholder{color:var(--color-text-tertiary)}.rule-builder__select{width:100%;height:32px;padding:0 var(--space-default);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-background);color:var(--color-text-primary);font-size:13px;font-family:var(--font-family);box-sizing:border-box;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' fill='none' stroke='%2386868B' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:28px}.rule-builder__select:focus{border-color:var(--color-info);box-shadow:0 0 0 2px var(--color-focus-ring);outline:none}.rule-builder__more-options-link{color:var(--color-info);cursor:pointer;padding:var(--space-compact) 0;text-align:left;font-size:13px;font-family:var(--font-family);background:0 0;border:none}.rule-builder__more-options-link:hover{text-decoration:underline}.rule-builder__more-options{gap:var(--space-comfortable);flex-direction:column;animation:.2s ease-out rule-builder-expand;display:flex;overflow:hidden}@keyframes rule-builder-expand{0%{opacity:0;max-height:0}to{opacity:1;max-height:800px}}.rule-builder__section-header{font-size:var(--font-size-section-header);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-secondary);padding-bottom:var(--space-compact);border-bottom:1px solid var(--color-separator);margin-top:var(--space-compact);font-weight:600}.rule-builder__static-value{color:var(--color-text-primary);padding:var(--space-tight) 0;font-size:13px;font-weight:500}.rule-builder__checkbox-group{gap:var(--space-comfortable);display:flex}.rule-builder__checkbox-label{color:var(--color-text-primary);align-items:center;gap:var(--space-tight);cursor:pointer;font-size:13px;display:flex}.rule-builder__checkbox{margin:0}.rule-builder__disclosure{margin-top:var(--space-compact)}.rule-builder__disclosure-summary{color:var(--color-info);cursor:pointer;-webkit-user-select:none;user-select:none;padding:var(--space-compact) 0;font-size:13px;list-style:none}.rule-builder__disclosure-summary::-webkit-details-marker{display:none}.rule-builder__disclosure-summary:before{content:"▸";margin-right:var(--space-compact);transition:transform var(--transition-fast);display:inline-block}.rule-builder__disclosure[open] .rule-builder__disclosure-summary:before{transform:rotate(90deg)}.rule-builder__code{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-default);font-family:var(--font-mono);font-size:var(--font-size-mono);color:var(--color-text-primary);margin-top:var(--space-compact);white-space:pre-wrap;word-break:break-all;overflow-x:auto}.service-picker,.address-picker{position:relative}.service-picker__input-wrapper,.address-picker__input-wrapper{align-items:center;display:flex;position:relative}.service-picker__input,.address-picker__input{width:100%;height:32px;padding:0 var(--space-default);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-background);color:var(--color-text-primary);font-size:13px;font-family:var(--font-family);box-sizing:border-box;transition:border-color var(--transition-fast);padding-right:28px}.service-picker__input:focus,.address-picker__input:focus{border-color:var(--color-info);box-shadow:0 0 0 2px var(--color-focus-ring);outline:none}.service-picker__trigger,.address-picker__trigger{color:var(--color-text-tertiary);cursor:pointer;pointer-events:all;-webkit-user-select:none;user-select:none;font-size:12px;position:absolute;right:8px}.service-picker__dropdown,.address-picker__dropdown{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:320px;max-height:300px;box-shadow:var(--shadow-popover);z-index:200;animation:.2s combobox-appear;position:absolute;top:calc(100% + 4px);left:0;overflow-y:auto}@keyframes combobox-appear{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.service-picker__category,.address-picker__category{font-size:var(--font-size-section-header);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-secondary);padding:var(--space-compact) var(--space-default);margin-top:var(--space-compact);font-weight:600}.service-picker__category:first-child,.address-picker__category:first-child{margin-top:var(--space-tight)}.service-picker__item,.address-picker__item{padding:var(--space-compact) var(--space-default);color:var(--color-text-primary);cursor:pointer;transition:background var(--transition-fast);justify-content:space-between;align-items:center;font-size:13px;display:flex}.service-picker__item:hover,.address-picker__item:hover{background:var(--color-hover)}.service-picker__item-label,.address-picker__item-label{flex:1}.service-picker__item-protocol{font-size:var(--font-size-rule-protocol);color:var(--color-text-secondary);font-family:var(--font-mono)}.address-picker__item-detail{font-size:var(--font-size-rule-protocol);color:var(--color-text-tertiary);margin-left:var(--space-compact)}.service-picker__custom-fields{gap:var(--space-default);flex-direction:column;display:flex}.service-picker__custom-group{gap:var(--space-tight);flex-direction:column;display:flex}.service-picker__custom-label{font-size:var(--font-size-rule-protocol);color:var(--color-text-primary);font-weight:500}.service-picker__custom-input,.service-picker__custom-select{width:100%;height:32px;padding:0 var(--space-default);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-background);color:var(--color-text-primary);font-size:13px;font-family:var(--font-family);box-sizing:border-box}.service-picker__custom-input:focus,.service-picker__custom-select:focus{border-color:var(--color-info);box-shadow:0 0 0 2px var(--color-focus-ring);outline:none}.service-picker__custom-input--error{border-color:var(--color-block)}.service-picker__custom-input:disabled{opacity:.5;cursor:not-allowed}.service-picker__hint{font-size:var(--font-size-caption);color:var(--color-text-tertiary);margin:0}.address-picker__manual{gap:var(--space-compact);flex-direction:column;display:flex}.address-picker__manual-label{font-size:var(--font-size-rule-protocol);color:var(--color-text-secondary)}.address-picker__manual-input{width:100%;height:32px;padding:0 var(--space-default);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-background);color:var(--color-text-primary);font-family:var(--font-mono);font-size:var(--font-size-mono);box-sizing:border-box}.address-picker__manual-input:focus{border-color:var(--color-info);box-shadow:0 0 0 2px var(--color-focus-ring);outline:none}.address-picker__manual-input--error{border-color:var(--color-block)}.address-picker__validation{font-size:var(--font-size-caption);color:var(--color-block);margin:0}.rule-builder__condition-row{align-items:center;gap:var(--space-compact);margin-bottom:var(--space-compact);display:flex}.rule-builder__condition-field,.rule-builder__condition-operator{flex-shrink:0;width:auto}.rule-builder__condition-value{flex:1}.rule-builder__condition-remove{width:24px;height:24px;color:var(--color-text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:16px;display:flex}.rule-builder__condition-remove:hover{color:var(--color-block)}.rule-builder__add-condition-btn{color:var(--color-primary);font-size:13px;font-family:var(--font-family);cursor:pointer;padding:var(--space-compact) 0;transition:opacity var(--transition-fast);background:0 0;border:none}.rule-builder__add-condition-btn:hover{opacity:.8}.rule-builder__rate-limit-fields{margin-top:var(--space-compact);align-items:center;gap:var(--space-compact);color:var(--color-text-primary);flex-wrap:wrap;font-size:13px;display:flex}.rule-builder__rate-limit-fields .rule-builder__input{width:60px;display:inline-block}.rule-builder__rate-limit-fields .rule-builder__select{width:auto;display:inline-block}.nat-builder{flex-direction:column;display:flex}.nat-builder__description{color:var(--color-text-secondary);margin-bottom:var(--space-comfortable);font-size:13px;line-height:1.5}.nat-builder__field-group{margin-bottom:var(--space-default)}.nat-builder__target-row{gap:var(--space-compact);margin-bottom:var(--space-default);align-items:center;display:flex}.nat-builder__target-row .rule-builder__input:first-child{flex:2}.nat-builder__target-row .rule-builder__input:last-of-type{flex:1}.nat-builder__port-label{color:var(--color-text-secondary);flex-shrink:0;align-self:center;font-size:13px}.nat-builder__checkbox-label{align-items:center;gap:var(--space-compact);margin:var(--space-default) 0;cursor:pointer;color:var(--color-text-primary);font-size:13px;display:flex}.nat-builder__radio-label{align-items:flex-start;gap:var(--space-compact);margin-bottom:var(--space-compact);cursor:pointer;color:var(--color-text-primary);font-size:13px;display:flex}.nat-builder__radio-label input[type=radio]{margin-top:2px}.nat-builder__snat-ip-input{margin-top:var(--space-compact)}.nat-builder__error{color:var(--color-block);min-height:20px;margin-top:var(--space-tight);font-size:12px}.nat-builder__btn-row{justify-content:flex-end;gap:var(--space-compact);margin-top:var(--space-comfortable);display:flex}.nat-builder__btn-cancel{border-radius:var(--radius-md);border:1px solid var(--color-border);color:var(--color-text-primary);cursor:pointer;font-size:13px;font-family:var(--font-family);transition:background var(--transition-fast);background:0 0;padding:6px 16px}.nat-builder__btn-cancel:hover{background:var(--color-hover)}.nat-builder__btn-primary{border-radius:var(--radius-md);background:var(--color-primary);color:var(--color-primary-text);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-family);transition:opacity var(--transition-fast);border:none;padding:6px 16px}.nat-builder__btn-primary:hover{opacity:.9}.side-panel__title{font-size:var(--font-size-page-title);color:var(--color-text-primary);margin:0 0 var(--space-default);font-weight:600}@media (prefers-color-scheme:dark){.rule-builder__segment-control{background:var(--color-surface)}.rule-builder__segment-indicator{background:var(--color-super-elevated)}.service-picker__dropdown,.address-picker__dropdown{background:var(--color-elevated);border-color:var(--color-border)}}.safety-banner{border-radius:var(--radius-xl);width:400px;box-shadow:var(--shadow-banner);z-index:1100;padding:var(--space-comfortable) var(--space-spacious);background:#1c1c1e;transition:transform .3s cubic-bezier(.16,1.36,.3,1);position:fixed;top:20px;left:50%;transform:translate(-50%)translateY(-120%)}.safety-banner--visible{transform:translate(-50%)translateY(0)}.safety-banner--hiding{transform:translate(-50%)translateY(-120%)}.safety-banner__progress-track{width:100%;height:4px;margin-bottom:var(--space-default);background:#ffffff1a;border-radius:2px;overflow:hidden}.safety-banner__progress{background:var(--color-allow);border-radius:2px;width:0%;height:100%;transition:width 1s linear}.safety-banner__content{text-align:center}.safety-banner__text{color:#fff;margin:0 0 var(--space-compact);font-size:14px;line-height:1.4}.safety-banner__revert-btn{color:#fffc;cursor:pointer;padding:var(--space-compact) var(--space-comfortable);font-size:13px;font-family:var(--font-family);transition:color var(--transition-fast);background:0 0;border:none}.safety-banner__revert-btn:hover{color:#fff;text-decoration:underline}.safety-banner--compact{padding:var(--space-compact) var(--space-comfortable)}.safety-banner--compact .safety-banner__progress-track{margin-bottom:var(--space-compact)}.safety-banner__compact-line{justify-content:center;align-items:center;gap:var(--space-default);color:#fff;height:28px;font-size:13px;display:flex}.safety-banner__revert-btn--compact{padding:var(--space-tight) var(--space-compact);font-size:12px}@media (prefers-color-scheme:dark){.safety-banner{background:var(--color-super-elevated);box-shadow:var(--shadow-banner)}}.command-palette__overlay{-webkit-backdrop-filter:blur(20px)saturate(180%);z-index:2000;background:#0000004d;justify-content:center;padding-top:20vh;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.command-palette__dialog{background:var(--color-background);border-radius:var(--radius-xl);width:680px;max-width:calc(100vw - 48px);max-height:60vh;box-shadow:var(--shadow-modal);opacity:0;flex-direction:column;align-self:flex-start;transition:transform .2s,opacity .2s;display:flex;overflow:hidden;transform:scale(.95)}.command-palette__dialog--open{opacity:1;transform:scale(1)}.command-palette__search{border:none;border-bottom:1px solid var(--color-separator);width:100%;height:48px;color:var(--color-text-primary);font-size:17px;font-family:var(--font-family);padding:0 var(--space-spacious);box-sizing:border-box;background:0 0;outline:none}.command-palette__search::placeholder{color:var(--color-text-tertiary)}.command-palette__results{padding:var(--space-compact) 0;flex:1;overflow-y:auto}.command-palette__category{font-size:var(--font-size-caption);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-secondary);padding:var(--space-default) var(--space-spacious) var(--space-tight);font-weight:600}.command-palette__result{height:44px;padding:0 var(--space-spacious);cursor:pointer;transition:background var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.command-palette__result:hover{background:var(--color-hover)}.command-palette__result--selected{background:var(--color-selected)}.command-palette__result-label{color:var(--color-text-primary);font-size:14px;font-weight:500}.command-palette__result-detail{font-size:var(--font-size-rule-protocol);color:var(--color-text-tertiary);margin-left:var(--space-compact);font-family:var(--font-mono)}.command-palette__empty{text-align:center;padding:var(--space-spacious);color:var(--color-text-tertiary);font-size:13px}@media (prefers-color-scheme:dark){.command-palette__dialog{background:var(--color-elevated)}}.dialog-overlay{z-index:1000;-webkit-backdrop-filter:blur(20px)saturate(180%);background:#0000004d;justify-content:center;align-items:center;animation:.2s ease-out dialog-fade-in;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}@keyframes dialog-fade-in{0%{opacity:0}to{opacity:1}}.dialog-card{background:var(--color-elevated,#fff);border-radius:var(--radius-xl,12px);box-shadow:var(--shadow-modal,0 24px 80px #00000040);width:520px;max-width:90vw;max-height:85vh;animation:.2s ease-out dialog-scale-in;overflow-y:auto}@keyframes dialog-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.dialog-card--quick-block{width:380px}.dialog-card--first-setup{width:560px}.dialog-card--create-group,.dialog-card--create-iplist{width:480px}.dialog-header{padding:var(--space-spacious,24px) var(--space-spacious,24px) var(--space-comfortable,16px);justify-content:space-between;align-items:center;display:flex}.dialog-header--compact{padding-bottom:var(--space-compact,8px)}.dialog-title{font-size:var(--font-size-page-title,22px);color:var(--color-text-primary,#1d1d1f);font-weight:600}.dialog-close{color:var(--color-text-secondary,#86868b);cursor:pointer;border-radius:var(--radius-sm,4px);width:32px;height:32px;transition:background var(--transition-fast,.1s ease);background:0 0;border:none;justify-content:center;align-items:center;font-size:18px;display:flex}.dialog-close:hover{background:var(--color-hover,#f5f5f7)}.dialog-body{padding:0 var(--space-spacious,24px) var(--space-comfortable,16px)}.dialog-field{margin-bottom:var(--space-comfortable,16px)}.dialog-field--inline{align-items:center;gap:var(--space-compact,8px);display:flex}.dialog-label{font-size:var(--font-size-rule-name,14px);color:var(--color-text-primary,#1d1d1f);margin-bottom:var(--space-tight,4px);font-weight:500;display:block}.dialog-input{width:100%;padding:var(--space-compact,8px) var(--space-default,12px);border:1px solid var(--color-border,#e5e5e7);border-radius:var(--radius-md,6px);font-size:var(--font-size-rule-name,14px);font-family:var(--font-family);color:var(--color-text-primary,#1d1d1f);background:var(--color-background,#fff);box-sizing:border-box;transition:border-color var(--transition-fast,.1s ease)}.dialog-input:focus{border-color:var(--color-primary,#007aff);box-shadow:0 0 0 3px var(--color-focus-ring,#007aff33);outline:none}.dialog-input--error{border-color:var(--color-block,#ff3b30)}.dialog-input--quick{padding:var(--space-default,12px) var(--space-comfortable,16px);font-size:16px;font-family:var(--font-mono,monospace)}.dialog-input--ip{font-family:var(--font-mono,monospace);font-size:var(--font-size-mono,12px)}.dialog-input--entry{flex:1}.dialog-select{padding:var(--space-compact,8px) var(--space-default,12px);border:1px solid var(--color-border,#e5e5e7);border-radius:var(--radius-md,6px);font-size:var(--font-size-rule-name,14px);font-family:var(--font-family);color:var(--color-text-primary,#1d1d1f);background:var(--color-background,#fff);box-sizing:border-box;cursor:pointer;width:100%}.dialog-select:focus{border-color:var(--color-primary,#007aff);box-shadow:0 0 0 3px var(--color-focus-ring,#007aff33);outline:none}.dialog-parsed-info{font-size:var(--font-size-caption,11px);color:var(--color-text-secondary,#86868b);margin-top:var(--space-compact,8px);font-family:var(--font-mono,monospace);min-height:16px}.dialog-parsed-info--error{color:var(--color-block,#ff3b30)}.dialog-error{font-size:var(--font-size-caption,11px);color:var(--color-block,#ff3b30);margin-top:var(--space-tight,4px)}.dialog-radio-group{gap:var(--space-comfortable,16px);align-items:center;display:flex}.dialog-radio-group input[type=radio]{margin-right:var(--space-tight,4px)}.dialog-radio-group label{font-size:var(--font-size-rule-name,14px);color:var(--color-text-primary,#1d1d1f);cursor:pointer}.dialog-help-text{color:var(--color-text-secondary,#6e6e73);margin-top:var(--space-tight,4px);font-size:12px;line-height:1.4}.dialog-expanded-form{padding:0 var(--space-spacious,24px);animation:.2s ease-out expand-in}@keyframes expand-in{0%{opacity:0;max-height:0}to{opacity:1;max-height:800px}}.dialog-test-status{padding:0 var(--space-spacious,24px)}.dialog-test-item{font-size:var(--font-size-rule-protocol,12px);padding:var(--space-tight,4px) 0}.dialog-test-item--ok{color:var(--color-allow,#34c759)}.dialog-test-item--error{color:var(--color-block,#ff3b30)}.dialog-footer{align-items:center;gap:var(--space-compact,8px);padding:var(--space-comfortable,16px) var(--space-spacious,24px) var(--space-spacious,24px);border-top:1px solid var(--color-separator,#f2f2f7);display:flex}.dialog-footer--setup{flex-wrap:wrap}.dialog-footer-spacer{flex:1}.dialog-btn{border-radius:var(--radius-md,6px);font-size:var(--font-size-rule-name,14px);font-family:var(--font-family);cursor:pointer;height:28px;transition:background var(--transition-fast,.1s ease), opacity var(--transition-fast,.1s ease);white-space:nowrap;border:none;justify-content:center;align-items:center;padding:6px 16px;display:inline-flex}.dialog-btn--primary{background:var(--color-primary,#007aff);color:var(--color-primary-text,#fff)}.dialog-btn--primary:hover{opacity:.9}.dialog-btn--primary:active{transform:scale(.97)}.dialog-btn--primary:disabled{background:var(--color-disabled,#c7c7cc);color:var(--color-text-tertiary,#aeaeb2);cursor:not-allowed}.dialog-btn--secondary{color:var(--color-primary,#007aff);border:1px solid var(--color-border,#e5e5e7);background:0 0}.dialog-btn--secondary:hover{background:var(--color-primary-hover-bg,#007aff0f)}.dialog-btn--secondary:active{transform:scale(.97)}.dialog-btn--text{color:var(--color-primary,#007aff);background:0 0;padding:6px 8px}.dialog-btn--text:hover{background:var(--color-primary-hover-bg,#007aff0f)}.dialog-btn--small{height:24px;font-size:var(--font-size-rule-protocol,12px);padding:4px 12px}.dialog-btn--remove{color:var(--color-text-tertiary,#aeaeb2);padding:0 4px;font-size:16px}.dialog-btn--remove:hover{color:var(--color-block,#ff3b30)}.dialog-empty-text{font-size:var(--font-size-rule-protocol,12px);color:var(--color-text-secondary,#86868b);padding:var(--space-compact,8px) 0}.dialog-members-list{border:1px solid var(--color-border,#e5e5e7);border-radius:var(--radius-md,6px);max-height:240px;padding:var(--space-compact,8px);overflow-y:auto}.dialog-member-row{align-items:center;gap:var(--space-compact,8px);padding:var(--space-tight,4px) 0;display:flex}.dialog-member-label{font-size:var(--font-size-rule-name,14px);color:var(--color-text-primary,#1d1d1f);cursor:pointer}.dialog-entries-list{border:1px solid var(--color-border,#e5e5e7);border-radius:var(--radius-md,6px);padding:var(--space-compact,8px);min-height:40px;max-height:200px;margin-bottom:var(--space-compact,8px);overflow-y:auto}.dialog-entry-row{padding:var(--space-tight,4px) var(--space-compact,8px);justify-content:space-between;align-items:center;display:flex}.dialog-entry-row:not(:last-child){border-bottom:1px solid var(--color-separator,#f2f2f7)}.dialog-entry-address{font-family:var(--font-mono,monospace);font-size:var(--font-size-mono,12px);color:var(--color-text-primary,#1d1d1f)}.dialog-add-entry-row{gap:var(--space-compact,8px);display:flex}.setup-notice{font-size:var(--font-size-rule-name,14px);color:var(--color-text-secondary,#86868b);margin-bottom:var(--space-comfortable,16px)}.setup-notice--info{padding:var(--space-default,12px);background:var(--color-surface,#f5f5f7);border-radius:var(--radius-md,6px)}.setup-section-title{font-size:var(--font-size-section-header,12px);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-secondary,#86868b);margin:var(--space-section,20px) 0 var(--space-compact,8px);font-weight:600}.setup-services{margin-bottom:var(--space-comfortable,16px)}.setup-service-row{align-items:center;gap:var(--space-default,12px);padding:var(--space-compact,8px) 0;border-bottom:1px solid var(--color-separator,#f2f2f7);display:flex}.setup-service-name{font-weight:500;font-size:var(--font-size-rule-name,14px);min-width:120px}.setup-service-ports{font-family:var(--font-mono,monospace);font-size:var(--font-size-mono,12px);color:var(--color-text-secondary,#86868b)}.setup-show-more{margin-top:var(--space-compact,8px)}.setup-footnote{font-size:var(--font-size-caption,11px);color:var(--color-text-tertiary,#aeaeb2);margin-top:var(--space-compact,8px)}.setup-rules-list{border:1px solid var(--color-border,#e5e5e7);border-radius:var(--radius-md,6px);overflow:hidden}.setup-rule-item{align-items:center;gap:var(--space-compact,8px);padding:var(--space-default,12px) var(--space-comfortable,16px);border-bottom:1px solid var(--color-separator,#f2f2f7);display:flex}.setup-rule-item:last-child{border-bottom:none}.setup-rule-checkbox{flex-shrink:0}.setup-rule-indicator{flex-shrink:0;font-size:14px}.setup-rule-indicator--allow{color:var(--color-allow,#34c759)}.setup-rule-indicator--block{color:var(--color-block,#ff3b30)}.setup-rule-label{font-size:var(--font-size-rule-name,14px);color:var(--color-text-primary,#1d1d1f);cursor:pointer;font-weight:500}.setup-rule-desc{font-size:var(--font-size-rule-protocol,12px);color:var(--color-text-secondary,#86868b);margin-left:auto}.setup-health{margin-bottom:var(--space-comfortable,16px)}.setup-health-item{font-size:var(--font-size-rule-name,14px);padding:var(--space-tight,4px) 0}.setup-health-item--good{color:var(--color-allow,#34c759)}.setup-health-item--warning{color:var(--color-warning,#ff9500)}.setup-health-item--suggestion{color:var(--color-text-secondary,#86868b)}.setup-tool{margin-bottom:var(--space-comfortable,16px);padding:var(--space-default,12px);background:var(--color-surface,#f5f5f7);border-radius:var(--radius-md,6px)}.setup-tool-header{align-items:center;gap:var(--space-compact,8px);margin-bottom:var(--space-tight,4px);display:flex}.setup-tool-icon{font-size:18px}.setup-tool-name{font-weight:600;font-size:var(--font-size-rule-name,14px)}.setup-tool-detail{font-size:var(--font-size-rule-protocol,12px);color:var(--color-text-secondary,#86868b);margin:0}.dialog-card--compare{width:680px;max-height:85vh}.compare-selector-row{align-items:flex-end;gap:12px;margin-bottom:16px;display:flex}.compare-selector-row .dialog-field{flex:1}.compare-vs-label{font-size:var(--font-size-base,14px);color:var(--color-text-secondary,#86868b);padding-bottom:10px;font-weight:600}.compare-results{max-height:400px;margin-top:8px;overflow-y:auto}.compare-summary{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.compare-stat{border-radius:var(--radius-md,8px);font-size:var(--font-size-rule-protocol,12px);align-items:center;padding:4px 10px;font-weight:500;display:inline-flex}.compare-stat--identical{background:var(--color-surface,#f5f5f7);color:var(--color-text-secondary,#86868b)}.compare-stat--only-a{color:var(--color-allow,#34c759);background:#34c7591f}.compare-stat--only-b{color:var(--color-block,#ff3b30);background:#ff3b301f}.compare-stat--different{color:var(--color-warning,#ff9f0a);background:#ff9f0a1f}.compare-section{margin-bottom:12px}.compare-section-title{font-size:var(--font-size-rule-name,14px);margin:0 0 6px;font-weight:600}.compare-list{margin:0;padding:0;list-style:none}.compare-item{font-family:var(--font-mono,"SF Mono", "Menlo", monospace);border-radius:var(--radius-sm,4px);word-break:break-all;margin-bottom:2px;padding:4px 8px;font-size:11px;line-height:1.6}.compare-item--only-a{border-left:3px solid var(--color-allow,#34c759);background:#34c75914}.compare-item--only-b{border-left:3px solid var(--color-block,#ff3b30);background:#ff3b3014}.compare-item--different{border-left:3px solid var(--color-warning,#ff9f0a);background:#ff9f0a14}.compare-note,.compare-loading{font-size:var(--font-size-base,14px);color:var(--color-text-secondary,#86868b);text-align:center;padding:20px 0}.compare-error{font-size:var(--font-size-base,14px);color:var(--color-block,#ff3b30);text-align:center;padding:20px 0}.dialog-card--persistence-setup{width:460px}.persistence-status-row{align-items:center;gap:var(--space-compact,8px);padding:var(--space-tight,4px) 0;font-size:var(--font-size-rule-name,14px);display:flex}.persistence-status-label{color:var(--color-text-primary,#1d1d1f);min-width:110px;font-weight:500}.persistence-status-value{font-size:var(--font-size-rule-name,14px)}.persistence-status-value--ok{color:var(--color-allow,#34c759)}.persistence-status-value--warn{color:var(--color-warning,#ff9500)}.persistence-warning{font-size:var(--font-size-rule-protocol,12px);color:var(--color-warning,#ff9500);margin-top:var(--space-default,12px);padding:var(--space-compact,8px) var(--space-default,12px);border-radius:var(--radius-md,6px);background:#ff950014;line-height:1.4}.activity-view{padding:var(--space-spacious,24px);overflow-y:auto}.activity-view__controls{gap:var(--space-compact,8px);margin-bottom:var(--space-comfortable,16px);justify-content:flex-end;display:flex}.activity-view__section-title{align-items:center;gap:var(--space-compact,8px);font-size:var(--font-size-section-header,12px);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-primary,#1d1d1f);margin:var(--space-section,20px) 0 var(--space-compact,8px);padding-bottom:var(--space-compact,8px);font-weight:600;display:flex}.activity-view__section-title:before,.activity-view__section-title:after{content:"";background:var(--color-border,#e5e5e7);flex:1;height:1px}.activity-view__section-title:before{max-width:16px}.activity-view__section-title:first-of-type{margin-top:0}.hit-counters{margin-bottom:var(--space-comfortable,16px)}.hit-counters__empty{font-size:var(--font-size-rule-name,14px);color:var(--color-text-secondary,#86868b);padding:var(--space-comfortable,16px) 0}.hit-counters__header{padding:var(--space-compact,8px) 0;border-bottom:1px solid var(--color-border,#e5e5e7);align-items:center;display:flex}.hit-counters__header .hit-counters__col{font-size:var(--font-size-caption,11px);text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-tertiary,#aeaeb2);font-weight:600}.hit-counters__row{height:var(--row-height,52px);border-bottom:1px solid var(--color-separator,#f2f2f7);transition:background var(--transition-fast,.1s ease);align-items:center;padding:0;display:flex;position:relative}.hit-counters__row:hover{background:var(--color-hover,#f5f5f7)}.hit-counters__status-bar{width:var(--status-bar-width,3px);border-radius:0 1.5px 1.5px 0;flex-shrink:0;height:100%}.hit-counters__col{padding:0 var(--space-compact,8px)}.hit-counters__col--rule{font-size:var(--font-size-rule-name,14px);color:var(--color-text-primary,#1d1d1f);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:500;overflow:hidden}.hit-counters__col--hits{text-align:right;width:80px;font-weight:600;font-size:var(--font-size-rule-name,14px);font-family:var(--font-mono,monospace);color:var(--color-text-primary,#1d1d1f)}.hit-counters__col--sparkline{justify-content:center;align-items:center;width:80px;display:flex}.hit-counters__col--rate{text-align:right;width:60px;font-size:var(--font-size-rule-protocol,12px);color:var(--color-text-secondary,#86868b);font-family:var(--font-mono,monospace)}.hit-counters__col--last{text-align:right;width:80px;font-size:var(--font-size-rule-protocol,12px);color:var(--color-text-secondary,#86868b)}.sparkline-canvas{image-rendering:auto;display:block}.blocked-log{margin-bottom:var(--space-comfortable,16px)}.blocked-log__empty{padding:var(--space-comfortable,16px) 0;color:var(--color-text-secondary,#86868b);font-size:var(--font-size-rule-name,14px)}.blocked-log__hint{font-size:var(--font-size-rule-protocol,12px);color:var(--color-text-tertiary,#aeaeb2);margin-top:var(--space-tight,4px)}.blocked-log__row{align-items:center;gap:var(--space-compact,8px);padding:var(--space-compact,8px) 0;border-bottom:1px solid var(--color-separator,#f2f2f7);font-size:var(--font-size-rule-protocol,12px);display:flex}.blocked-log__indicator{background:var(--color-block,#ff3b30);border-radius:50%;flex-shrink:0;width:8px;height:8px}.blocked-log__time{color:var(--color-text-secondary,#86868b);min-width:60px}.blocked-log__ip{font-family:var(--font-mono,monospace);font-size:var(--font-size-mono,12px);color:var(--color-text-primary,#1d1d1f);min-width:110px}.blocked-log__arrow{color:var(--color-text-tertiary,#aeaeb2)}.blocked-log__port{font-family:var(--font-mono,monospace);font-size:var(--font-size-mono,12px);color:var(--color-text-primary,#1d1d1f);min-width:48px}.blocked-log__service{color:var(--color-text-secondary,#86868b);text-transform:uppercase;font-size:var(--font-size-caption,11px);letter-spacing:.5px;font-weight:600}.blocked-log__block-btn{border:1px solid var(--color-border,#e5e5e7);border-radius:var(--radius-sm,4px);color:var(--color-primary,#007aff);font-size:var(--font-size-caption,11px);cursor:pointer;transition:background var(--transition-fast,.1s ease);white-space:nowrap;background:0 0;margin-left:auto;padding:2px 8px}.blocked-log__block-btn:hover{background:var(--color-primary-hover-bg,#007aff0f)}.blocked-log__offender-alert{justify-content:space-between;align-items:center;gap:var(--space-default,12px);padding:var(--space-default,12px) var(--space-comfortable,16px);margin-bottom:var(--space-default,12px);border:1px solid var(--color-warning,#ff9500);border-radius:var(--radius-md,6px);background:#ff950014;display:flex}.blocked-log__offender-text{color:var(--color-text-primary,#1d1d1f);font-size:13px;font-weight:500}.blocked-log__offender-actions{gap:var(--space-compact,8px);flex-shrink:0;display:flex}.activity-view__bans-section{margin-bottom:var(--space-comfortable,16px)}.activity-view__bans-list{flex-direction:column;display:flex}.activity-view__bans-empty{font-size:var(--font-size-rule-protocol,12px);color:var(--color-text-secondary,#86868b);padding:var(--space-compact,8px) 0}.activity-view__bans-empty--error{color:var(--color-block,#ff3b30)}.activity-view__error{align-items:center;gap:var(--space-compact,8px);padding:var(--space-default,12px);background:var(--color-diff-removed-bg,#ff3b3014);color:var(--color-block,#ff3b30);border-radius:var(--radius-md,6px);font-size:13px;display:flex}.activity-view__ban-row{align-items:center;gap:var(--space-compact,8px);padding:var(--space-compact,8px) 0;border-bottom:1px solid var(--color-separator,#f2f2f7);height:40px;font-size:var(--font-size-rule-protocol,12px);display:flex}.activity-view__ban-icon{flex-shrink:0;font-size:14px}.activity-view__ban-ip{font-family:var(--font-mono,monospace);font-size:var(--font-size-mono,12px);color:var(--color-text-primary,#1d1d1f);min-width:110px}.activity-view__ban-time{color:var(--color-text-secondary,#86868b)}.activity-view__ban-jail{font-family:var(--font-mono,monospace);font-size:var(--font-size-mono,12px);color:var(--color-text-tertiary,#aeaeb2);margin-left:auto}.activity-view__saturation-banner{align-items:center;gap:var(--space-compact,8px);padding:var(--space-default,12px) var(--space-comfortable,16px);margin-bottom:var(--space-default,12px);border:1px solid var(--color-warning,#ff9500);border-radius:var(--radius-md,6px);color:var(--color-text-primary,#1d1d1f);background:#ff950014;font-size:13px;font-weight:500;display:flex}.activity-view__saturation-banner:before{content:"⚠️";flex-shrink:0}.conntrack{margin-bottom:var(--space-comfortable,16px)}.conntrack__header{margin-bottom:var(--space-compact,8px);justify-content:space-between;align-items:center;display:flex}.conntrack__title{font-size:var(--font-size-rule-name,14px);color:var(--color-text-primary,#1d1d1f);font-weight:500}.conntrack__label{font-family:var(--font-mono,monospace);font-size:var(--font-size-mono,12px);color:var(--color-text-secondary,#86868b)}.conntrack__bar-track{background:var(--color-surface,#f5f5f7);border-radius:2px;width:100%;height:4px;overflow:hidden}.conntrack__bar-fill{background-color:var(--color-allow,#34c759);border-radius:2px;height:100%;transition:width .3s ease-out,background-color .3s}.audit-log__list{flex-direction:column;gap:2px;max-height:400px;display:flex;overflow-y:auto}.audit-log__empty{padding:var(--space-comfortable,16px);text-align:center;color:var(--color-text-tertiary,#aeaeb2);font-size:var(--font-size-body,13px)}.audit-log__row{align-items:center;gap:var(--space-compact,8px);padding:var(--space-compact,8px) var(--space-default,12px);border-radius:var(--radius-sm,4px);background:var(--color-surface,#f5f5f7);font-size:var(--font-size-body,13px);transition:background var(--transition-fast,.1s ease);display:flex}.audit-log__row:hover{background:var(--color-hover,#f5f5f7)}.audit-log__time{color:var(--color-text-secondary,#86868b);font-size:var(--font-size-caption,11px);font-variant-numeric:tabular-nums;flex-shrink:0;min-width:100px}.audit-log__badge{border-radius:var(--radius-sm,4px);font-size:var(--font-size-caption,11px);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;flex-shrink:0;align-items:center;padding:1px 6px;font-weight:600;display:inline-flex}.audit-log__badge--apply{color:var(--color-primary,#007aff);background:#007aff1a}.audit-log__badge--revert{color:var(--color-block,#ff3b30);background:#ff3b301a}.audit-log__badge--confirm{color:var(--color-allow,#34c759);background:#34c7591a}.audit-log__badge--restore{color:var(--color-warning,#ff9500);background:#ff95001a}.audit-log__badge--group-apply{color:var(--color-log,#5856d6);background:#5856d61a}.audit-log__host{color:var(--color-text-primary,#1d1d1f);text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;max-width:120px;font-weight:500;overflow:hidden}.audit-log__details{color:var(--color-text-secondary,#86868b);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.audit-log__ago{color:var(--color-text-tertiary,#aeaeb2);font-size:var(--font-size-caption,11px);flex-shrink:0;margin-left:auto}@media (prefers-color-scheme:dark){.audit-log__row{background:var(--color-surface,#1c1c1e)}.audit-log__row:hover{background:var(--color-hover,#2c2c2e)}.activity-view__saturation-banner,.blocked-log__offender-alert{border-color:var(--color-warning);background:#ff9f0a1f}.activity-view__error{background:#ff453a1f}}.rule-table__terminal-placeholder{flex-direction:column;flex:1;display:flex}.rule-table__terminal-sub-tabs{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);margin:var(--space-comfortable) var(--space-spacious) 0;gap:1px;padding:2px;display:inline-flex}.rule-table__terminal-sub-tab{border-radius:calc(var(--radius-lg) - 2px);color:var(--color-text-secondary);font-size:12px;font-weight:500;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-default);white-space:nowrap;background:0 0;border:none;padding:4px 14px}.rule-table__terminal-sub-tab:hover:not(:disabled){color:var(--color-text-primary)}.rule-table__terminal-sub-tab:disabled{opacity:.5;cursor:not-allowed}.rule-table__terminal-sub-tab--active{background:var(--color-elevated);color:var(--color-text-primary);box-shadow:var(--shadow-segment), 0 0 0 .5px #00000014;font-weight:600}.rule-table__terminal-sub-tab--active:hover{color:var(--color-text-primary)}.rule-table__terminal-message{padding:48px var(--space-spacious);text-align:center;color:var(--color-text-secondary)}.rule-table__terminal-message p{max-width:400px;margin:0 auto;font-size:14px;line-height:1.6}.terminal__content{padding:var(--space-comfortable) var(--space-spacious);flex:1}.rule-table__split-container{flex-direction:column;flex:1;display:flex;overflow:hidden}.rule-table__split-divider{cursor:row-resize;background:var(--color-border);height:4px;transition:background var(--transition-fast);flex-shrink:0}.rule-table__split-divider:hover{background:var(--color-primary)}.rule-table__split-bottom{overflow:auto}.rule-table__split-terminal-placeholder{padding:var(--space-spacious);color:var(--color-text-secondary);text-align:center}.terminal__editor{width:100%;min-height:400px;padding:var(--space-default);font-family:var(--font-mono);font-size:var(--font-size-mono);color:var(--color-text-primary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);resize:vertical;box-sizing:border-box;tab-size:4;line-height:1.5}.terminal__editor:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring);outline:none}.terminal__tracer-form{gap:var(--space-default);margin-bottom:var(--space-comfortable);flex-wrap:wrap;display:flex}.terminal__tracer-field{flex:1;min-width:150px}.terminal__tracer-result{padding:var(--space-default);font-family:var(--font-mono);font-size:var(--font-size-mono);min-height:40px}.terminal__tracer-verdict{margin-bottom:var(--space-compact);font-size:14px;font-weight:600}.terminal__tracer-chain{color:var(--color-text-secondary);margin-bottom:var(--space-compact)}.terminal__tracer-explanation{color:var(--color-text-secondary)}.terminal__live-trace-method{color:var(--color-text-secondary);margin-bottom:var(--space-compact);font-size:12px}.terminal__live-trace-status{color:var(--color-text-tertiary);margin-bottom:var(--space-default);font-size:12px}.terminal__live-trace-empty{padding:var(--space-comfortable);text-align:center;color:var(--color-text-secondary);font-style:italic}.terminal__live-trace-table{border-collapse:collapse;width:100%;font-family:var(--font-mono);font-size:var(--font-size-mono);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.terminal__live-trace-table thead{background:var(--color-elevated)}.terminal__live-trace-table th{text-align:left;text-transform:uppercase;letter-spacing:.03em;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:6px 10px;font-size:11px;font-weight:600}.terminal__live-trace-table td{border-bottom:1px solid var(--color-separator);color:var(--color-text-primary);white-space:nowrap;padding:5px 10px}.terminal__live-trace-table td:last-child{white-space:normal;word-break:break-all}.terminal__live-trace-table tbody tr:last-child td{border-bottom:none}.terminal__live-trace-table tbody tr:hover{background:var(--color-hover)}.terminal__ssh-log{font-family:var(--font-mono);font-size:var(--font-size-mono);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-default);max-height:500px;overflow-y:auto}.terminal__ssh-log-entry{gap:var(--space-default);border-bottom:1px solid var(--color-separator);padding:3px 0;display:flex}.terminal__ssh-log-entry:last-child{border-bottom:none}.terminal__ssh-log-time{color:var(--color-text-tertiary);flex-shrink:0;min-width:80px}.terminal__ssh-log-cmd{color:var(--color-text-primary)}.rule-table__export-dropdown{background:var(--color-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-popover);z-index:100;min-width:160px;margin-top:4px;position:absolute;top:100%;right:0;overflow:hidden}.rule-table__export-option{width:100%;font-size:13px;font-family:var(--font-family);color:var(--color-text-primary);cursor:pointer;text-align:left;transition:background var(--transition-fast);background:0 0;border:none;padding:8px 16px;display:block}.rule-table__export-option:hover{background:var(--color-hover)}.rule-table__export-option:not(:last-child){border-bottom:1px solid var(--color-separator)}.settings-panel{padding:var(--space-generous,32px);max-width:640px;overflow-y:auto}.settings-panel__header{margin-bottom:var(--space-spacious,24px)}.settings-panel__title{font-size:var(--font-size-page-title,22px);color:var(--color-text-primary,#1d1d1f);margin:0;font-weight:600}.settings-panel__section-header{font-size:var(--font-size-section-header,12px);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-secondary,#86868b);margin-top:var(--space-spacious,24px);margin-bottom:var(--space-comfortable,16px);padding-top:var(--space-comfortable,16px);border-top:1px solid var(--color-separator,#f2f2f7);font-weight:600}.settings-panel__section-header:first-child{border-top:none;margin-top:0;padding-top:0}.settings-panel__field{margin-bottom:var(--space-comfortable,16px);justify-content:space-between;align-items:center;gap:var(--space-comfortable,16px);display:flex}.settings-panel__field--checkbox{justify-content:flex-start;gap:var(--space-compact,8px)}.settings-panel__field--checkbox label{cursor:pointer;flex-direction:column;display:flex}.settings-panel__label{font-size:var(--font-size-rule-name,14px);color:var(--color-text-primary,#1d1d1f);white-space:nowrap;font-weight:500}.settings-panel__select{max-width:280px}.settings-panel__radio-group{gap:var(--space-compact,8px);flex-direction:column;display:flex}.settings-panel__radio-group input[type=radio]{margin-right:var(--space-tight,4px)}.settings-panel__radio-group label{font-size:var(--font-size-rule-name,14px);color:var(--color-text-primary,#1d1d1f);cursor:pointer}.settings-panel__checkbox-desc{font-size:var(--font-size-rule-protocol,12px);color:var(--color-text-secondary,#86868b);font-weight:400;display:block}.settings-panel__number-wrap{align-items:center;gap:var(--space-compact,8px);display:flex}.settings-panel__number-input{text-align:center;width:80px}.settings-panel__number-suffix{font-size:var(--font-size-rule-protocol,12px);color:var(--color-text-secondary,#86868b)}.settings-panel__data-row{gap:var(--space-default,12px);flex-direction:column;display:flex}.settings-panel__data-item{justify-content:space-between;align-items:center;gap:var(--space-comfortable,16px);font-size:var(--font-size-rule-name,14px);color:var(--color-text-primary,#1d1d1f);display:flex}.settings-panel__hint{font-size:var(--font-size-rule-protocol,12px);color:var(--color-text-tertiary,#aeaeb2);margin-top:var(--space-comfortable,16px)}.settings-panel__separator{background:var(--color-separator,#f2f2f7);height:1px;margin:var(--space-spacious,24px) 0}.settings-panel__about{margin-top:var(--space-comfortable,16px)}.settings-panel__about-title{font-size:var(--font-size-section-header,12px);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-secondary,#86868b);margin:0 0 var(--space-compact,8px);font-weight:600}.settings-panel__about-version{font-size:var(--font-size-rule-name,14px);color:var(--color-text-primary,#1d1d1f);margin:0 0 var(--space-tight,4px)}.settings-panel__about-link{font-size:var(--font-size-rule-protocol,12px);color:var(--color-text-secondary,#86868b);margin:0}.settings-panel__import-error{color:var(--color-block);padding:var(--space-compact) 0;font-size:13px}.update-banner{background:color-mix(in srgb, var(--color-info) 85%, #000);border-radius:var(--radius-xl);width:460px;max-width:calc(100vw - 40px);box-shadow:var(--shadow-banner);z-index:1100;padding:var(--space-comfortable) var(--space-spacious);transition:transform .3s cubic-bezier(.16,1.36,.3,1);position:fixed;bottom:20px;left:50%;transform:translate(-50%)translateY(120%)}.update-banner--visible{transform:translate(-50%)translateY(0)}.update-banner--hiding{transform:translate(-50%)translateY(120%)}.update-banner__content{align-items:center;gap:var(--space-compact);display:flex}.update-banner__icon{flex-shrink:0;font-size:16px}.update-banner__text{color:#fff;flex:1;font-size:13px;line-height:1.4}.update-banner__download-btn{color:#fff;cursor:pointer;padding:var(--space-tight) var(--space-comfortable);border-radius:var(--radius-md);font-size:12px;font-weight:500;font-family:var(--font-family);transition:background var(--transition-fast), border-color var(--transition-fast);white-space:nowrap;background:#ffffff26;border:1px solid #ffffff4d;flex-shrink:0}.update-banner__download-btn:hover{background:#ffffff40;border-color:#ffffff80}.update-banner__progress{background:#ffffff26;border-radius:2px;flex:1;min-width:60px;height:4px;overflow:hidden}.update-banner__progress-bar{background:#fff;border-radius:2px;width:0%;height:100%;transition:width .2s}.update-banner__download-btn:disabled{opacity:.7;cursor:not-allowed}.update-banner__dismiss-btn{color:#fff9;cursor:pointer;padding:0 var(--space-tight);font-size:18px;line-height:1;font-family:var(--font-family);transition:color var(--transition-fast);background:0 0;border:none;flex-shrink:0}.update-banner__dismiss-btn:hover{color:#fff}@media (prefers-color-scheme:dark){.update-banner{background:color-mix(in srgb, var(--color-info) 70%, #000);box-shadow:var(--shadow-banner)}}
