:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--font-ui:Inter, "GenSenRounded TW", "GenSenRounded2 TW", "jf open 粉圓 2.1", "PingFang TC", "Noto Sans TC", "Microsoft JhengHei", Arial, sans-serif;--background:#f5f6f8;--surface:#fff;--surface-muted:#f8fafc;--border:#d6dce6;--text:#101828;--muted:#667085;--accent:#1683e8;--accent-strong:#0b66c3;--accent-soft:#eaf4ff;--accent-border:#9ccfff;--focus-ring:#1683e833;--danger:#b42318;--danger-bg:#fff1f0}*{box-sizing:border-box}::selection{color:#0b2f5f;background:#bfdbfe}html,body{min-height:100%;margin:0}body{background:var(--background);color:var(--text);font-family:var(--font-ui);-moz-text-size-adjust:100%;text-size-adjust:100%;-webkit-font-smoothing:antialiased;font-synthesis:none;font-size:14px;line-height:1.45}button,input,select,textarea{font:inherit;line-height:1.2}button{background:var(--accent);color:#fff;cursor:pointer;border:0;border-radius:6px;font-weight:700}button:disabled{cursor:not-allowed;opacity:.55}button:not(:disabled):hover{background:var(--accent-strong);color:#fff}input,select,textarea{border:1px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:6px}input,select{height:38px;padding:0 10px}textarea{resize:vertical;min-height:86px;padding:10px;line-height:1.45}label{min-width:0;color:var(--muted);grid-template-rows:18px auto;gap:7px;font-size:13px;font-weight:700;line-height:18px;display:grid}.field-label{color:var(--muted);font-size:13px;font-weight:700;line-height:18px}code{overflow-wrap:anywhere;border:1px solid var(--border);background:var(--surface);color:var(--muted);border-radius:6px;padding:8px 10px}.site-footer{color:var(--muted);text-align:center;padding:22px 0 4px;font-size:12px;line-height:18px}.center-shell,.login-shell{place-items:center;min-height:100vh;padding:24px;display:grid}.loading-indicator{color:var(--muted);justify-items:center;gap:10px;font-size:13px;font-weight:700;display:inline-grid}.loading-indicator img{width:80px;height:8px}.loading-panel{place-items:center;min-height:180px;display:grid}.loading-scope{position:relative}.loading-overlay{z-index:1000;background:var(--background);place-items:center;display:grid;position:fixed;inset:0}.loading-overlay-panel{z-index:20;border-radius:inherit;background:#ffffffdb;position:absolute}.login-panel{border:1px solid var(--border);background:var(--surface);border-radius:8px;gap:16px;width:min(420px,100%);padding:22px;display:grid}.login-panel h1,.topbar h1,.panel h2{margin:0}.login-panel h1{margin-top:4px;font-size:28px}.login-logo-panel{justify-content:center;align-items:center;margin-bottom:14px;display:flex}.login-logo-panel img{width:min(376px,100%);height:auto;display:block}.form-error{color:#b42318;margin:0;font-size:13px;line-height:1.4}.language-switch{border:1px solid var(--border);background:#fff;border-radius:6px;width:max-content;display:inline-flex;overflow:hidden}.language-switch button{height:32px;min-height:32px;color:var(--muted);white-space:nowrap;background:0 0;border:0;border-radius:0;justify-content:center;align-items:center;padding:0 10px;font-size:12px;font-weight:700;line-height:1;display:inline-flex}.language-switch button.active{background:var(--accent);color:#fff}.language-switch button:not(:disabled):hover{background:var(--accent-soft);color:var(--accent-strong)}.language-switch button.active:not(:disabled):hover{background:var(--accent-strong);color:#fff}.app-shell{grid-template-columns:230px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--border);background:var(--surface);grid-template-rows:auto 1fr auto;gap:18px;height:100vh;padding:22px 14px;display:grid;position:sticky;top:0}.sidebar-brand{border-bottom:1px solid var(--border);gap:10px;padding:0 0 14px;display:grid}.sidebar-logo-panel{justify-content:center;align-items:center;display:flex}.sidebar-logo-panel img{width:100%;height:auto;display:block}.sidebar-brand strong{text-align:center;font-size:16px;line-height:1.25}.sidebar-nav{align-content:start;gap:6px;display:grid}.sidebar-link{height:38px;min-height:38px;color:var(--muted);border-radius:7px;align-items:center;padding:0 10px;font-size:13px;font-weight:800;line-height:1;text-decoration:none;display:flex}.sidebar-link:hover{background:var(--surface-muted);color:var(--text)}.sidebar-link.active{background:var(--accent-soft);color:var(--accent-strong)}.sidebar-footer{border-top:1px solid var(--border);gap:10px;padding-top:14px;display:grid}.sidebar-footer .language-switch{width:100%}.sidebar-footer .language-switch button{flex:1}.sidebar-email{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:700;line-height:18px;overflow:hidden}.sidebar-signout{width:100%}.shell-content{width:min(1280px,100vw - 262px);margin:0 auto;padding:28px 0}.topbar{justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:20px;display:flex}.topbar h1{margin-top:4px;font-size:30px;line-height:1.2}.topbar-actions{align-items:center;gap:10px;display:flex}.eyebrow{color:var(--accent);text-transform:uppercase;margin:0;font-size:12px;font-weight:800}.layout{grid-template-columns:300px 1fr;align-items:start;gap:18px;display:grid}.panel{border:1px solid var(--border);background:var(--surface);border-radius:8px;padding:16px}.page-stack{gap:18px;display:grid}.admin-split{grid-template-columns:320px minmax(0,1fr);align-items:start;gap:18px;display:grid}.assign-panel{gap:14px;display:grid}.assign-summary{border:1px solid var(--border);background:var(--surface-muted);border-radius:6px;gap:2px;padding:12px;display:grid}.assign-summary strong{font-size:26px}.assign-summary span{color:var(--muted);font-size:13px}.combo-box{position:relative}.combo-menu{z-index:20;border:1px solid var(--border);background:#fff;border-radius:6px;max-height:240px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:auto;box-shadow:0 12px 28px #10182824}.combo-option{width:100%;min-height:44px;color:var(--text);text-align:left;background:#fff;border-radius:0;justify-items:start;gap:2px;padding:9px 10px;display:grid}button.combo-option:not(:disabled):hover{background:var(--surface-muted);color:var(--text)}.combo-option small{color:var(--muted);font-weight:400}.combo-empty{color:var(--muted);padding:10px;font-size:13px;font-weight:400}.compact-panel{padding-block:12px}.side-panel,.content-stack{gap:14px;display:grid}.inventory-panel{gap:14px;max-height:calc(100vh - 128px);display:grid;overflow:auto}.stack-form{gap:10px;display:grid}.cidr-form{grid-template-columns:minmax(220px,1.2fr) minmax(180px,1fr) 120px 140px auto;align-items:end;gap:10px;display:grid}.user-form{grid-template-columns:minmax(240px,1fr) minmax(180px,.8fr) auto;align-items:end;gap:10px;display:grid}.event-filter{grid-template-columns:150px 150px 150px minmax(180px,1fr) 96px;align-items:end;gap:10px;display:grid}.event-target-field{position:relative}.event-target-combobox{scrollbar-width:none;flex-wrap:nowrap;height:38px;min-height:38px;padding:0;overflow:auto hidden}.event-target-combobox::-webkit-scrollbar{display:none}.event-target-combobox .token-chip{flex:none}.event-target-combobox input{background:0 0;border:0;border-radius:0;outline:0;flex:1 0 96px;width:auto;height:36px;min-height:36px;padding:0 10px;line-height:36px}.event-target-menu button{grid-template-columns:minmax(0,1fr)}.event-target-menu strong{font-size:13px}.cidr-form>*,.user-form>*,.event-filter>*,.form-actions>*,.button-row>*,.topbar-actions>*{min-width:0}.two-col{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.section-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.section-head h3{margin:0}.section-title-row{align-items:center;gap:8px;display:inline-flex}.acl-status-badge{border:1px solid var(--border);background:var(--surface-muted);height:24px;color:var(--text);border-radius:999px;justify-content:center;align-items:center;padding:0 10px;font-size:12px;font-weight:700;line-height:1;display:inline-flex}.acl-status-badge>span,.rule-status-badge>span{color:inherit;font:inherit;line-height:inherit;align-items:center;display:inline-flex;overflow:visible}.acl-status-active{color:#067647;background:#ecfdf3;border-color:#a6d8bd}.acl-status-pending{color:#b54708;background:#fffaeb;border-color:#fedf89}.acl-status-error{background:var(--danger-bg);color:var(--danger);border-color:#f4b8b1}.acl-status-unknown{border-color:var(--border);background:var(--surface-muted);color:var(--muted)}.rule-status-badge{border:1px solid var(--border);background:#fff;border-radius:999px;flex:none;justify-content:center;place-items:center;height:22px;padding:0 8px;font-size:11px;font-weight:700;line-height:1;display:inline-grid}.rule-status-active{color:#067647;background:#ecfdf3;border-color:#a6d8bd}.rule-status-edited{color:#b54708;background:#fffaeb;border-color:#fedf89}.rule-status-new{color:#175cd3;background:#eff8ff;border-color:#b2ddff}.button-row,.inline-add{align-items:center;gap:8px;display:flex}.inline-add{width:min(300px,100%)}.wide-add{width:min(680px,100%)}.secondary-button,.link-button,.small-button,.icon-button{color:#344054;background:#fff;border:1px solid #cfd6e1;transition:border-color .14s,background .14s,box-shadow .14s,color .14s;box-shadow:0 1px 2px #1018280a}button.secondary-button:not(:disabled):hover,button.link-button:not(:disabled):hover,button.small-button:not(:disabled):hover,button.icon-button:not(:disabled):hover{border-color:var(--accent-border);background:var(--accent-soft);color:var(--accent-strong);box-shadow:0 1px 3px #10182814}.secondary-button,.link-button{border-radius:6px;justify-content:center;align-items:center;height:38px;min-height:38px;padding:0 14px;font-size:13px;font-weight:700;text-decoration:none;display:inline-flex}.small-button,.danger-button,.login-panel>button,.user-form>button,.event-filter>button,.form-actions>button{border-radius:6px;justify-content:center;align-items:center;height:38px;min-height:38px;padding:0 14px;font-size:13px;font-weight:700;display:inline-flex}.secondary-button>span,.link-button>span,.small-button>span,.danger-button>span,.language-switch button>span,.login-panel>button>span,.user-form>button>span,.event-filter>button>span,.form-actions>button>span{white-space:nowrap;justify-content:center;align-items:center;height:1em;line-height:1;display:inline-flex}.small-button,.danger-button{height:30px;min-height:30px;padding:0 10px;font-size:12px;line-height:1}.danger-button{background:var(--danger-bg);color:var(--danger);border:1px solid #f4b8b1}button.danger-button:not(:disabled):hover{color:var(--danger);background:#ffe4e0}.side-panel>button{height:40px}.rate-section{gap:14px;margin-bottom:16px;display:grid}.rate-section h3{margin:0 0 4px}.rate-block{gap:8px;display:grid}.rollback-section{border-top:1px solid var(--border);gap:8px;margin-bottom:16px;padding-top:14px;display:grid}.rollback-select{width:min(360px,100%)}.rollback-empty{margin:0}.rate-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.geoip-field{gap:7px;width:100%;display:grid;position:relative}.geoip-combobox{border:1px solid var(--border);background:#fff;border-radius:6px;flex-wrap:wrap;align-items:center;gap:3px;min-height:30px;padding:2px 6px;display:flex}.geoip-combobox:focus-within{outline:2px solid var(--focus-ring);border-color:var(--accent)}.geoip-combobox input{border:0;outline:0;flex:96px;min-width:92px;min-height:24px;padding:0;line-height:24px}.geoip-chip{border:1px solid var(--border);background:var(--surface-muted);max-width:min(100%,260px);min-height:24px;color:var(--text);border-radius:6px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:3px;padding:0 4px 0 8px;font-size:13px;font-weight:700;display:inline-grid}.geoip-chip strong,.geoip-chip span{align-items:center;min-height:20px;line-height:1.2;display:flex}.geoip-chip strong{font-size:12px}.geoip-chip span{min-width:0;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.geoip-chip button{width:22px;height:20px;color:var(--muted);background:0 0;border:0;border-radius:50%;padding:0;display:block;position:relative}.geoip-chip button:not(:disabled):hover{color:var(--text);background:#eef2f6}.geoip-chip button:focus-visible{outline:2px solid var(--focus-ring);outline-offset:1px}.geoip-menu{z-index:20;border:1px solid var(--border);background:#fff;border-radius:6px;width:100%;max-height:260px;position:absolute;top:calc(100% + 6px);left:0;overflow:auto;box-shadow:0 12px 28px #141c261f}.geoip-menu button{width:100%;min-height:38px;color:var(--text);text-align:left;background:#fff;border:0;border-radius:0;grid-template-columns:48px 1fr;align-items:center;gap:8px;padding:0 10px;font-size:13px;line-height:1.2;display:grid}.geoip-menu strong,.geoip-menu span{align-items:center;min-height:20px;display:flex}.geoip-menu strong{color:var(--text);font-size:12px;line-height:1.2}button.geoip-option:not(:disabled):hover,.geoip-menu button:not(:disabled):hover{background:var(--surface-muted);color:var(--text)}.geoip-menu span{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-weight:600;line-height:1.2;overflow:hidden}.geoip-menu p{color:var(--muted);margin:0;padding:10px;font-size:13px}.check-row{align-items:center;gap:8px;display:flex}.check-row input{width:16px;height:16px}.rule-list{gap:12px;display:grid}.nav-list,.ip-list{gap:8px;display:grid}.ip-list{max-height:calc(100vh - 190px);overflow:auto}.nav-row,.ip-row{border:1px solid var(--border);min-height:44px;color:var(--text);text-align:left;background:#fff;border-radius:6px;justify-content:space-between;align-items:center;gap:10px;padding:9px 10px;display:flex}.nav-row span{gap:2px;display:grid}.nav-row small,.ip-row small{color:var(--muted);font-weight:400}.nav-row.selected,.ip-row.selected{border-color:var(--accent);background:var(--accent-soft)}button.nav-row:not(:disabled):hover,button.ip-row:not(:disabled):hover{border-color:var(--accent);background:var(--accent-soft);color:var(--text)}.resource-list,.ip-page-list,.allocation-list{gap:8px;display:grid}.allocation-row{border:1px solid var(--border);background:var(--surface-muted);border-radius:6px;grid-template-columns:minmax(320px,1.6fr) 150px minmax(140px,.8fr) 18px;align-items:center;gap:12px;min-height:52px;padding:10px;display:grid}.allocation-item{gap:8px;display:grid}.allocation-row-public{grid-template-columns:minmax(0,1fr) 18px}.allocation-row>span:first-child{gap:4px;display:grid}.allocation-row .check-row{color:var(--text)}.allocation-row .check-row span{gap:2px;display:grid}.allocation-row small{color:var(--muted);font-weight:400}.route-map-toggle{-webkit-user-select:none;user-select:none;transition:border-color .14s,background .14s,box-shadow .14s;cursor:pointer!important}.route-map-toggle *,[data-clickable-route-map=true],[data-clickable-route-map=true] *{cursor:pointer!important}.route-map-toggle:hover,.route-map-toggle:focus-visible{border-color:var(--accent-border);background:var(--accent-soft);outline:none;box-shadow:0 1px 3px #10182814}.route-map-chevron{border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);justify-self:center;width:9px;height:9px;transition:border-color .14s,transform .14s;transform:rotate(45deg)}.route-map-toggle:hover .route-map-chevron,.route-map-toggle:focus-visible .route-map-chevron{border-color:var(--accent-strong)}.route-map-chevron.is-expanded{transform:translateY(3px)rotate(225deg)}.route-map-panel{border:1px solid var(--border);background:#fff;border-radius:6px;min-height:82px;padding:8px;overflow:auto}.route-map-panel .loading-indicator{gap:6px;font-size:11px}.route-map-panel .loading-indicator img{width:48px;height:5px}.route-map-link{width:min(360px,100%);max-width:100%;margin:0 auto;display:block;cursor:pointer!important}.route-map-link img{width:100%;max-width:100%;height:auto;display:block}.route-map-link img.is-loading{opacity:0}.admin-user-list{gap:8px;display:grid}.admin-user-row{border:1px solid var(--border);background:var(--surface-muted);border-radius:6px;grid-template-columns:minmax(260px,1fr) 110px 260px;align-items:center;gap:12px;min-height:52px;padding:10px;display:grid}.admin-user-row>span:first-child{gap:2px;display:grid}.admin-user-row small{color:var(--muted)}.permission-toggle{border:0;border-bottom:1px solid var(--border);background:0 0;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:18px;min-height:42px;padding:9px 0;display:grid}.permission-toggle>span:first-child{align-content:center;gap:3px;min-width:0;min-height:24px;line-height:1.25;display:grid}.permission-toggle small{color:var(--muted);font-size:12px;font-weight:500}.switch-control{flex:none;align-self:center;width:42px;height:24px;display:inline-flex;position:relative}.switch-control input{z-index:1;cursor:pointer;opacity:0;width:100%;height:100%;margin:0;position:absolute;inset:0}.switch-control>span{background:#d7dee8;border-radius:999px;transition:background .14s,box-shadow .14s;position:absolute;inset:0}.switch-control>span:after{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .14s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0f172a33}.switch-control input:checked+span{background:var(--accent)}.switch-control input:checked+span:after{transform:translate(18px)}.switch-control input:focus-visible+span{box-shadow:0 0 0 3px var(--focus-ring)}.permission-cidr-panel{gap:10px;display:grid}.permission-cidr-panel>div:first-child{gap:2px;display:grid}.permission-cidr-panel small{color:var(--muted)}.permission-cidr-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.permission-cidr-option{border:1px solid var(--border);background:#fff;border-radius:6px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px;min-height:38px;padding:7px 10px;display:grid}.permission-cidr-option input{accent-color:var(--accent)}.permission-cidr-option span{gap:2px;min-width:0;display:grid}.permission-dialog{width:min(900px,100vw - 40px);max-height:min(760px,100vh - 40px);padding:0;overflow:hidden}.permission-dialog-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:14px;padding:18px 20px;display:flex}.permission-dialog-head>div{gap:3px;min-width:0;display:grid}.permission-dialog-body{gap:0;max-height:calc(100vh - 150px);padding:16px 20px 20px;display:grid;overflow:auto}.permission-section{border-bottom:1px solid var(--border);gap:8px;padding:0 0 14px;display:grid}.permission-section+.permission-section{padding-top:12px}.permission-section:last-child{border-bottom:0}.permission-section-nested{border-left:2px solid var(--accent-soft);margin-left:18px;padding-left:14px}.permission-inline-nested{border-left:2px solid var(--accent-soft);border-bottom:1px solid var(--border);gap:8px;margin:0 0 0 18px;padding:2px 0 10px 14px;display:grid}.permission-inline-nested .permission-toggle:last-child{border-bottom:0}.permission-inline-nested>div:first-child:not(.permission-list){gap:2px;display:grid}.permission-inline-nested p{color:var(--muted);margin:0;font-size:13px}.permission-section>div:first-child{gap:2px;display:grid}.permission-section p{color:var(--muted);margin:0;font-size:13px}.permission-list,.permission-cidr-list{gap:0;display:grid}.permission-cidr-field{position:relative}.permission-cidr-combobox{min-height:34px}.permission-cidr-menu button{grid-template-columns:minmax(150px,.8fr) minmax(0,1fr)}.permission-cidr-menu strong{font-size:13px}.permission-number-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding-top:8px;display:grid}.resource-row{border:1px solid var(--border);background:var(--surface-muted);border-radius:6px;grid-template-columns:minmax(240px,1.4fr) 90px 130px auto;align-items:center;gap:12px;min-height:52px;padding:10px;display:grid}.resource-row a{color:var(--text);gap:3px;text-decoration:none;display:grid}.resource-row a:hover strong{color:var(--accent)}.resource-row span,.resource-row a span{color:var(--muted);font-size:13px}.ip-page-list{grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}.ip-page-row{border:1px solid var(--border);background:var(--surface-muted);min-height:44px;color:var(--text);border-radius:6px;justify-content:space-between;align-items:center;gap:10px;padding:10px;text-decoration:none;display:flex}.ip-page-row:hover{border-color:var(--accent);background:var(--accent-soft)}.ip-page-row small{color:var(--muted)}.rule-item{border:1px solid var(--border);background:var(--surface-muted);border-radius:8px;gap:12px;padding:12px;display:grid}.rule-item-collapsed{gap:0;padding-block:10px}.rule-head{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;display:grid}.rule-title{white-space:nowrap;align-items:center;gap:8px;min-width:0;min-height:32px;display:flex}.rule-summary-text,.rule-owner-text{min-width:0;height:28px;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;align-items:center;font-size:12px;font-weight:400;line-height:normal;display:inline-flex;overflow:hidden}.rule-owner-text{flex:0 auto}.rule-title .rule-status-badge{align-self:center;min-width:auto;height:24px;font-size:11px;font-weight:700;line-height:1;overflow:visible}.rule-title .rule-status-badge>span{height:14px;color:inherit;font:inherit;text-overflow:clip;justify-content:center;align-items:center;min-width:auto;line-height:14px;display:inline-flex;overflow:visible;transform:translateY(1px)}.rule-order-control{height:28px;color:var(--text);flex:none;align-self:center;align-items:center;gap:6px;margin:0;font-size:14px;font-weight:700;line-height:normal;display:inline-flex}.rule-order-label{min-width:auto;height:28px;color:var(--text);align-items:center;font-size:14px;font-weight:700;line-height:normal;display:inline-flex;overflow:visible}.rule-order-input{box-sizing:border-box;appearance:none;text-align:center;align-self:center;width:38px;height:28px;padding:0 4px;font-size:13px;font-weight:700;line-height:26px;display:block}.rule-order-input::-webkit-inner-spin-button{appearance:none;margin:0}.rule-order-input::-webkit-outer-spin-button{appearance:none;margin:0}.icon-button{border-radius:6px;width:34px;height:34px;padding:0;font-size:17px;line-height:1}.rule-grid{gap:8px;display:grid}.rule-policy-field{grid-column:1/-1;grid-template-rows:none}.compact-rule-field{grid-template-columns:104px minmax(0,1fr);align-items:center;gap:8px;display:grid}.compact-rule-field>span{color:var(--muted);font-size:13px;font-weight:700}.token-combobox{border:1px solid var(--border);background:#fff;border-radius:6px;flex-wrap:wrap;align-items:center;gap:3px;min-height:30px;padding:2px 6px;display:flex}.token-combobox:focus-within{outline:2px solid var(--focus-ring);border-color:var(--accent)}.token-combobox input{border:0;outline:0;flex:96px;min-width:92px;min-height:24px;padding:0;line-height:24px}.token-chip{border:1px solid var(--border);background:var(--surface-muted);max-width:min(100%,220px);min-height:24px;color:var(--text);border-radius:6px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:3px;padding:0 4px 0 8px;font-size:13px;font-weight:700;display:inline-grid}.token-chip span{text-overflow:ellipsis;white-space:nowrap;min-width:0;line-height:1.2;overflow:hidden}.token-chip button{width:22px;height:20px;color:var(--muted);background:0 0;border:0;border-radius:50%;padding:0;display:block;position:relative}.chip-remove:before,.chip-remove:after{content:"";transform-origin:50%;background:currentColor;border-radius:999px;width:9px;height:1.5px;position:absolute;top:50%;left:50%}.chip-remove:before{transform:translate(-50%,-50%)rotate(45deg)}.chip-remove:after{transform:translate(-50%,-50%)rotate(-45deg)}.token-chip button:not(:disabled):hover{color:var(--text);background:#eef2f6}.token-error{color:var(--danger);grid-column:2;margin-top:-2px;font-size:12px;font-weight:600}.protocol-box{color:var(--muted);gap:10px;padding-top:4px;font-size:13px;font-weight:700;display:grid}.subsection{border-top:1px solid var(--border);margin-top:14px;padding-top:14px}.protocol-list{flex-wrap:wrap;gap:10px 16px;display:flex}.form-actions{justify-content:flex-end;gap:8px;margin-top:14px;display:flex}.user-table{gap:8px;display:grid}.user-row{border:1px solid var(--border);background:var(--surface-muted);border-radius:6px;grid-template-columns:minmax(180px,1.3fr) minmax(120px,.8fr) 90px 170px;align-items:center;gap:10px;min-height:38px;padding:8px 10px;font-size:13px;display:grid}.user-row-head{min-height:auto;color:var(--muted);background:0 0;border:0;font-weight:700}.response-box{min-height:260px;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:13px}.response-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.error-box{background:var(--danger-bg);color:var(--danger);white-space:pre-wrap;border:1px solid #f4b8b1;border-radius:6px;margin:0;padding:10px}.warning-text{color:#93370d;background:#fffaeb;border:1px solid #fedf89;border-radius:6px;margin:0 0 14px;padding:10px;font-size:13px;line-height:1.5}.event-list{gap:3px;display:grid}.event-pagination{color:var(--muted);justify-content:space-between;align-items:center;gap:12px;margin:0 0 12px;font-size:13px;display:flex}.event-pagination-bottom{margin:12px 0 0}.event-page-number{min-height:32px;color:var(--text);align-items:center;font-size:13px;font-weight:700;display:inline-flex}.event-item{display:grid}.event-detail-shell{opacity:0;max-height:0;transition:max-height .18s,opacity .16s,transform .18s;overflow:hidden;transform:translateY(-4px)}.event-detail-shell.expanded{opacity:1;max-height:900px;transform:translateY(0)}.event-detail-shell>.event-detail{min-height:0;overflow:hidden}.event-row{border:1px solid var(--border);width:100%;min-height:38px;color:var(--text);text-align:left;background:#fff;border-radius:6px;grid-template-columns:minmax(160px,1.05fr) minmax(100px,.65fr) minmax(82px,.45fr) minmax(116px,.62fr) minmax(116px,.62fr) minmax(150px,1fr);align-items:center;gap:10px;padding:0 10px;font-size:13px;font-weight:700;display:grid}.event-row:not(.event-row-head):hover{border-color:var(--accent);background:var(--accent-soft);color:var(--text)}.event-row span{text-overflow:ellipsis;white-space:nowrap;align-items:center;min-width:0;min-height:20px;line-height:1;display:inline-flex;overflow:hidden}.event-row-head{min-height:auto;color:var(--muted);background:0 0;border:0;font-size:12px}.event-empty-state{border:1px solid var(--border);background:var(--surface-muted);min-height:104px;color:var(--muted);text-align:center;border-radius:6px;place-items:center;padding:18px;font-size:13px;font-weight:700;display:grid}.event-status-pill{border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;height:28px;min-height:28px;padding:0 10px;font-size:12px;font-weight:800;line-height:1;display:inline-flex}.event-status-ongoing{color:#b42318;background:#fef2f2;border-color:#fecaca}.event-status-ended{color:#175cd3;background:#eff6ff;border-color:#bfdbfe}.event-detail{border:1px solid var(--border);background:var(--surface-muted);border-radius:0 0 8px 8px;gap:12px;margin-top:-1px;padding:12px;display:grid}.event-tabs{flex-wrap:wrap;gap:8px;display:flex}.event-tabs button,.chart-toggle button{border:1px solid var(--border);height:30px;min-height:30px;color:var(--text);background:#fff;justify-content:center;align-items:center;padding:0 10px;font-size:12px;display:inline-flex}button.event-tab:not(:disabled):hover,.event-tabs button:not(:disabled):hover,.chart-toggle button:not(:disabled):hover{border-color:var(--accent-border);background:var(--accent-soft);color:var(--accent-strong)}.event-tabs button.active,.chart-toggle button.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.event-tabs button>span,.chart-toggle button>span{align-items:center;height:1em;line-height:1;display:inline-flex}.event-chart,.event-map{border:1px solid var(--border);background:#fff;border-radius:8px;width:100%;min-height:280px}.event-map{cursor:grab;background:#fff;min-height:420px}.event-map path{shape-rendering:optimizespeed}.map-chart-wrap{position:relative}.country-map-section{gap:12px;display:grid}.country-rank-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.country-rank-table{border:1px solid var(--border);background:#fff;border-radius:8px;gap:6px;padding:12px;display:grid}.country-rank-table h4{margin:0 0 4px;font-size:13px}.country-rank-row{border-bottom:1px solid #eef2f6;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;min-height:28px;padding:0 2px;font-size:12px;display:grid}.country-rank-row:last-child{border-bottom:0}.country-rank-row span{min-width:0;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.country-rank-row strong{color:var(--text);font-weight:700}.chart-toggle{z-index:3;gap:6px;display:flex;position:absolute;top:10px;right:10px}.event-chart-tooltip{z-index:2000;pointer-events:none;opacity:0;border:1px solid var(--border);color:var(--text);background:#fff;border-radius:6px;padding:8px 9px;font-size:12px;position:absolute;box-shadow:0 12px 28px #141c261f}.modal-backdrop{z-index:3000;background:#0f172a47;place-items:center;padding:20px;animation:.14s ease-out modal-backdrop-in;display:grid;position:fixed;inset:0}.app-dialog{border:1px solid var(--border);background:#fff;border-radius:8px;gap:14px;width:min(360px,100%);padding:20px;animation:.18s ease-out submit-dialog-in;display:grid;box-shadow:0 18px 48px #0f172a38}.app-dialog.permission-dialog{width:min(900px,100vw - 40px);max-height:min(760px,100vh - 40px);padding:0;overflow:hidden}.app-dialog h2,.app-dialog p{margin:0}.app-dialog p{color:var(--muted);font-size:14px;line-height:1.5}.app-dialog button{justify-self:end}@keyframes modal-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes submit-dialog-in{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.pie-pair{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.pie-chart{border:1px solid var(--border);background:#fff;border-radius:8px;width:100%;min-height:270px}.muted{color:var(--muted);margin:0;font-size:13px;font-weight:400}@media (max-width:980px){.app-shell{display:block}.sidebar{border-right:0;border-bottom:1px solid var(--border);height:auto;position:static}.sidebar-nav{grid-template-columns:repeat(2,minmax(0,1fr))}.shell-content{width:min(1280px,100vw - 32px);padding:22px 0}.topbar,.layout,.admin-split,.cidr-form,.user-form,.event-filter,.event-row,.resource-row,.allocation-row,.admin-user-row,.user-row,.pie-pair,.permission-grid,.permission-subgrid,.permission-number-grid,.permission-cidr-grid,.country-rank-grid{grid-template-columns:1fr}.topbar{align-items:stretch;display:grid}.topbar-actions,.section-head,.rule-head{flex-direction:column;align-items:stretch}.inline-add{width:100%}.compact-rule-field{grid-template-columns:1fr;gap:7px}}
