html,body{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}@-ms-viewport{width:device-width}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[title],abbr[data-original-title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=text],input[type=password],input[type=number],textarea{-webkit-appearance:none}ol,ul,dl{margin-top:0;margin-bottom:1em}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}pre,code,kbd,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}a,area,button,[role=button],input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}input,button,select,optgroup,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{padding:0;border-style:none}input[type=radio],input[type=checkbox]{box-sizing:border-box;padding:0}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}mark{padding:.2em;background-color:#feffe6}.app-layout{display:flex;flex-direction:column;min-height:100vh;background-color:#f5f5f5}.header{display:flex;justify-content:space-between;align-items:center;padding:0 20px;height:60px;background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;box-shadow:0 2px 8px #0000004d}.header-left{display:flex;align-items:center}.header-center{flex:1;display:flex;justify-content:center}.header-right{display:flex;align-items:center;gap:20px}.logo{display:flex;align-items:center;gap:10px}.logo-icon{font-size:24px}.logo-text{font-size:18px;font-weight:600}.search-input{width:400px;border-radius:20px;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2)}.search-input::placeholder{color:#fff9}.header-actions{display:flex;align-items:center;gap:15px}.action-btn{font-size:14px;color:#fffc;cursor:pointer;padding:8px 12px;border-radius:4px;transition:all .2s}.action-btn:hover{background-color:#ffffff1a;color:#fff}.action-btn.notification{position:relative}.action-btn .badge{position:absolute;top:-5px;right:-8px;background-color:#ff4d4f;color:#fff;font-size:10px;padding:1px 4px;border-radius:10px}.user-info{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:4px;cursor:pointer;transition:background-color .2s}.user-info:hover{background-color:#ffffff1a}.user-info .user-name{font-size:14px}.user-info .user-icon{font-size:18px}.main-content{display:flex;flex:1;overflow:hidden}.sidebar{width:220px;background-color:#2d3436;color:#fff;display:flex;flex-direction:column;flex-shrink:0}.sidebar-nav{flex:1;padding:10px 0}.sidebar-footer{padding:15px;border-top:1px solid rgba(255,255,255,.1)}.project-selector{padding:15px;background:linear-gradient(180deg,#27ae60,#2ecc71);text-align:center}.project-selector .project-name{font-size:14px;font-weight:600}.project-selector .project-env{font-size:12px;color:#fffc;margin-top:4px}.nav-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 20px;background:none;border:none;color:#ffffffb3;cursor:pointer;font-size:14px;transition:all .2s}.nav-item:hover{background-color:#ffffff1a;color:#fff}.nav-item.active{background-color:#ffffff26;color:#fff;border-left:3px solid #27ae60}.nav-item .nav-icon{font-size:16px}.nav-item .nav-label{flex:1;text-align:left}.footer-info{font-size:12px;color:#fff9;margin-bottom:10px}.footer-qrcode .qrcode-placeholder{width:80px;height:80px;background-color:#ffffff1a;border-radius:8px;margin:0 auto;display:flex;align-items:center;justify-content:center}.footer-qrcode .qrcode-placeholder .qrcode-pattern{width:60px;height:60px;background-image:linear-gradient(45deg,rgba(255,255,255,.1) 25%,transparent 25%),linear-gradient(-45deg,rgba(255,255,255,.1) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,rgba(255,255,255,.1) 75%),linear-gradient(-45deg,transparent 75%,rgba(255,255,255,.1) 75%);background-size:10px 10px;background-position:0 0,0 5px,5px -5px,-5px 0px}.footer-qrcode .qrcode-tip{font-size:10px;color:#ffffff80;text-align:center;margin-top:8px}.content-area{flex:1;overflow-y:auto;padding:20px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-header .header-left{display:flex;flex-direction:column;gap:10px}.page-header .header-right{display:flex;gap:10px}.page-title{font-size:20px;font-weight:600;color:#333;display:flex;align-items:center;gap:8px}.header-filters{display:flex;gap:15px;align-items:center}.empty-state{text-align:center;padding:60px 0;color:#999}.warning-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;background-color:#fff7e6;border-left:4px solid #faad14;margin-bottom:20px;border-radius:0 4px 4px 0}.warning-banner.small{padding:8px 12px;margin:10px 0}.warning-banner .warning-icon{color:#faad14;font-size:16px}.flag-list .list-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.flag-list .list-header .header-left{display:flex;flex-direction:column;gap:10px}.flag-list .list-title{font-size:20px;font-weight:600;color:#333}.flag-detail .detail-header{display:flex;gap:20px;padding:20px;background-color:#fff;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 8px #0000000f}.flag-detail .detail-header .back-btn{flex-shrink:0}.flag-detail .detail-header .header-info{flex:1}.flag-detail .detail-header .header-actions{display:flex;flex-direction:column;gap:10px}.flag-detail .breadcrumbs{display:flex;align-items:center;gap:8px;font-size:14px;color:#666;margin-bottom:12px}.flag-detail .breadcrumbs .separator{color:#ddd}.flag-detail .breadcrumbs .current{color:#333;font-weight:500}.flag-detail .flag-title-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.flag-detail .flag-title-row .flag-name{font-size:24px;font-weight:600;color:#333}.flag-detail .flag-title-row .status-tag{font-size:12px}.flag-detail .flag-meta{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:12px}.flag-detail .flag-meta .meta-item{display:flex;align-items:center;gap:6px}.flag-detail .flag-meta .meta-item .meta-label{font-size:14px;color:#999}.flag-detail .flag-meta .meta-item .meta-value{font-size:14px;color:#333}.flag-detail .flag-meta .meta-item .meta-value.type-tag{background-color:#e6f7ff;color:#1890ff;padding:2px 8px;border-radius:4px;font-size:12px}.flag-detail .flag-description{font-size:14px;color:#666;line-height:1.6;margin:0}.flag-detail .detail-tabs{background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000f}.flag-detail .sub-tabs{border-bottom:1px solid #f0f0f0}.rules-section{padding:20px}.rules-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.rules-section .section-header h3{font-size:16px;font-weight:600;color:#333;margin:0}.rules-section .section-icon{color:#27ae60;margin-right:8px}.rules-section .section-desc{font-size:13px;color:#999;margin-bottom:16px}.rules-section .config-group{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;padding:16px;background-color:#fafafa;border-radius:8px;margin-bottom:24px}.rules-section .config-group .config-item{display:flex;flex-direction:column;gap:8px}.rules-section .config-group .config-item .config-label{font-size:14px;color:#666;font-weight:500}.rules-section .config-group .config-item .config-value{display:flex;align-items:center;gap:10px}.rules-section .config-group .config-item .config-value span{font-size:14px;color:#333}.rules-section .config-group .config-item .config-select{width:200px}.whitelist-section{margin-bottom:24px}.whitelist-section .whitelist-list{display:flex;flex-direction:column;gap:16px}.whitelist-section .whitelist-item{padding:16px;background-color:#fafafa;border-radius:8px}.whitelist-section .whitelist-item .whitelist-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.whitelist-section .whitelist-item .whitelist-content{display:flex;gap:40px}.whitelist-section .whitelist-item .whitelist-content .whitelist-field{display:flex;flex-direction:column;gap:8px}.whitelist-section .whitelist-item .whitelist-content .whitelist-field label{font-size:13px;color:#999}.whitelist-section .whitelist-item .whitelist-content .whitelist-field .tag-list{display:flex;flex-wrap:wrap;gap:6px}.whitelist-section .whitelist-item .whitelist-content .whitelist-field .empty-hint{color:#999;font-size:13px}.rules-config-section .rules-collapse{margin-bottom:16px}.rules-config-section .rule-header{display:flex;align-items:center;gap:12px}.rules-config-section .rule-header .rule-priority{width:28px;height:28px;background-color:#27ae60;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center}.rules-config-section .rule-header .rule-priority .priority-number{font-size:14px;font-weight:600}.rules-config-section .rule-header .rule-info{flex:1;display:flex;flex-direction:column;gap:4px}.rules-config-section .rule-header .rule-info .rule-preview{font-size:14px;color:#333}.rules-config-section .rule-header .rule-info .rule-return{font-size:12px;color:#999}.rules-config-section .rule-header .rule-actions{display:flex;gap:8px}.rules-config-section .rule-content{padding-left:40px;border-left:2px solid #e8e8e8;margin-left:20px;padding-top:16px}.rules-config-section .condition-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}.rules-config-section .condition-row .condition-operator{color:#27ae60;font-weight:600;font-size:14px}.rules-config-section .condition-row .condition-if{display:flex;align-items:center;gap:10px}.rules-config-section .condition-row .condition-if .if-label{color:#27ae60;font-weight:600;font-size:14px}.rules-config-section .condition-row .condition-if .condition-select{width:180px}.rules-config-section .condition-row .condition-if .condition-select.values{width:350px}.rules-config-section .condition-row .condition-if .condition-input{width:180px}.rules-config-section .add-condition-btn{margin-left:40px;margin-bottom:16px}.rules-config-section .return-section{padding:16px;background-color:#fafafa;border-radius:8px;margin-left:40px}.rules-config-section .return-section .return-label{display:flex;align-items:center;gap:10px;margin-bottom:16px}.rules-config-section .return-section .return-label .return-keyword{color:#e74c3c;font-weight:600;font-size:14px}.rules-config-section .return-section .return-label .return-select{width:150px}.rules-config-section .percentage-config .branch-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.rules-config-section .percentage-config .branch-row .branch-color{width:12px;height:12px;border-radius:50%}.rules-config-section .percentage-config .branch-row .branch-name{width:80px;font-size:14px;color:#333}.rules-config-section .percentage-config .branch-row .percentage-bar-container{flex:1;height:8px;background-color:#e8e8e8;border-radius:4px;overflow:hidden}.rules-config-section .percentage-config .branch-row .percentage-bar-container .percentage-bar{height:100%;border-radius:4px;transition:width .3s ease}.rules-config-section .percentage-config .branch-row .percentage-input{width:60px}.rules-config-section .percentage-config .branch-row .percentage-unit{font-size:14px;color:#666}.rules-config-section .percentage-config .total-percentage{font-size:13px;color:#999;text-align:right;margin-bottom:12px}.rules-config-section .percentage-config .by-label{display:flex;align-items:center;gap:8px;font-size:13px;color:#666;margin-bottom:12px}.rules-config-section .percentage-config .by-label .by-select{width:120px}.rules-config-section .percentage-config .gradient-buttons{display:flex;gap:8px}.rules-config-section .add-rule-btn{margin-left:40px}.rules-config-section .default-rule,.rules-config-section .close-rule{margin-top:24px;padding:16px;background-color:#fafafa;border-radius:8px}.rules-config-section .default-rule h4,.rules-config-section .close-rule h4{font-size:14px;font-weight:600;color:#333;margin:0 0 8px}.rules-config-section .default-rule .rule-desc,.rules-config-section .close-rule .rule-desc{font-size:13px;color:#999;margin:0 0 12px}.rules-config-section .default-rule .warning-text,.rules-config-section .close-rule .warning-text{font-size:12px;color:#ff4d4f;margin-top:8px}.variations-section{padding:20px}.variations-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.variations-section .section-header h3{font-size:16px;font-weight:600;color:#333;margin:0}.variations-section .section-header .section-actions{display:flex;gap:10px}.variations-section .section-desc{font-size:13px;color:#999;margin-bottom:16px}.variations-section .branches-list{display:flex;flex-direction:column;gap:16px;margin-bottom:16px}.variations-section .branch-card{padding:16px;background-color:#fafafa;border-radius:8px}.variations-section .branch-card .branch-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.variations-section .branch-card .branch-header .branch-color-indicator{width:12px;height:12px;border-radius:50%}.variations-section .branch-card .branch-header .branch-name{font-size:14px;font-weight:500;color:#333}.variations-section .branch-card .branch-header .branch-percentage{margin-left:auto}.variations-section .branch-card .branch-header .branch-percentage .percentage-value{font-size:14px;font-weight:600;color:#666}.variations-section .branch-card .branch-form .form-select,.variations-section .branch-card .branch-form .form-input{width:100%}.variations-section .branch-card .branch-form .json-input{width:100%;font-family:monospace}.variations-section .add-branch-btn{width:100%}.settings-section{padding:20px}.settings-section .setting-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #f0f0f0}.settings-section .setting-item label{width:100px;font-size:14px;color:#666}.settings-section .setting-item .unit{margin-left:8px;font-size:14px;color:#666}.history-section,.traffic-section{padding:20px}.traffic-section .traffic-summary{display:flex;gap:20px;margin-bottom:24px}.traffic-section .traffic-summary .summary-card{flex:1;padding:20px;background-color:#fafafa;border-radius:8px;text-align:center}.traffic-section .traffic-summary .summary-card .card-value{font-size:28px;font-weight:600;color:#333}.traffic-section .traffic-summary .summary-card .card-label{font-size:13px;color:#999;margin-top:8px}.traffic-section .traffic-chart{margin-bottom:24px}.traffic-section .traffic-chart .chart-placeholder{padding:40px;background-color:#fafafa;border-radius:8px}.traffic-section .traffic-chart .chart-placeholder .chart-bars{display:flex;justify-content:space-between;align-items:flex-end;height:150px;gap:10px}.traffic-section .traffic-chart .chart-placeholder .chart-bars .chart-bar{flex:1;background-color:#27ae60;border-radius:4px 4px 0 0;transition:height .3s ease}.traffic-section .traffic-chart .chart-placeholder .chart-labels{display:flex;justify-content:space-between;margin-top:16px}.traffic-section .traffic-chart .chart-placeholder .chart-labels span{font-size:12px;color:#999}.traffic-section .branch-traffic h4{font-size:14px;font-weight:600;color:#333;margin:0 0 12px}.traffic-section .branch-traffic .branch-bars{display:flex;flex-direction:column;gap:12px}.traffic-section .branch-traffic .branch-traffic-item{display:flex;align-items:center;gap:12px}.traffic-section .branch-traffic .branch-traffic-item .branch-name{width:80px;font-size:14px;color:#333}.traffic-section .branch-traffic .branch-traffic-item .traffic-bar-container{flex:1;height:20px;background-color:#e8e8e8;border-radius:4px;overflow:hidden}.traffic-section .branch-traffic .branch-traffic-item .traffic-bar-container .traffic-bar{height:100%;border-radius:4px}.traffic-section .branch-traffic .branch-traffic-item .traffic-percentage{width:50px;text-align:right;font-size:14px;color:#666}.user-groups .groups-summary{display:flex;gap:20px;margin-bottom:20px}.user-groups .groups-summary .summary-item{padding:16px 24px;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;align-items:center}.user-groups .groups-summary .summary-item .summary-value{font-size:24px;font-weight:600;color:#333}.user-groups .groups-summary .summary-item .summary-label{font-size:13px;color:#999;margin-top:4px}.history-page .operator,.history-page .version,.history-page .project-name,.history-page .dependency-name,.history-page .role-name,.history-page .group-name,.project-management .operator,.project-management .version,.project-management .project-name,.project-management .dependency-name,.project-management .role-name,.project-management .group-name,.config-query .operator,.config-query .version,.config-query .project-name,.config-query .dependency-name,.config-query .role-name,.config-query .group-name,.external-dependencies .operator,.external-dependencies .version,.external-dependencies .project-name,.external-dependencies .dependency-name,.external-dependencies .role-name,.external-dependencies .group-name,.log-analysis .operator,.log-analysis .version,.log-analysis .project-name,.log-analysis .dependency-name,.log-analysis .role-name,.log-analysis .group-name,.mock-page .operator,.mock-page .version,.mock-page .project-name,.mock-page .dependency-name,.mock-page .role-name,.mock-page .group-name,.permission-page .operator,.permission-page .version,.permission-page .project-name,.permission-page .dependency-name,.permission-page .role-name,.permission-page .group-name{display:flex;align-items:center;gap:6px;font-size:14px;color:#333}.history-page .diff-content,.history-page .log-content,.project-management .diff-content,.project-management .log-content,.config-query .diff-content,.config-query .log-content,.external-dependencies .diff-content,.external-dependencies .log-content,.log-analysis .diff-content,.log-analysis .log-content,.mock-page .diff-content,.mock-page .log-content,.permission-page .diff-content,.permission-page .log-content{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;color:#666}.history-page .value-text,.history-page .mock-value,.project-management .value-text,.project-management .mock-value,.config-query .value-text,.config-query .mock-value,.external-dependencies .value-text,.external-dependencies .mock-value,.log-analysis .value-text,.log-analysis .mock-value,.mock-page .value-text,.mock-page .mock-value,.permission-page .value-text,.permission-page .mock-value{font-family:monospace;font-size:14px;color:#333}.config-query .query-section{background-color:#fff;padding:20px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 8px #0000000f}.config-query .query-section .query-form{display:flex;gap:20px;align-items:flex-end}.config-query .query-section .form-group{display:flex;flex-direction:column;gap:8px}.config-query .query-section .form-group label{font-size:14px;color:#666;font-weight:500}.config-query .query-section .form-group .query-input{width:250px}.config-query .query-section .form-group .query-select{width:150px}.config-query .results-section{background-color:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 8px #0000000f}.config-query .results-section h3{font-size:16px;font-weight:600;color:#333;margin:0 0 16px}.log-analysis .log-content{max-width:300px}.mock-page .mock-section{margin-bottom:20px}.mock-page .mock-section .mock-form{display:flex;gap:15px;align-items:center}.more-actions{position:relative;display:inline-block}.more-actions .dropdown-menu{position:absolute;top:100%;right:0;margin-top:4px;padding:8px 0;background-color:#fff;border:1px solid #e8e8e8;border-radius:4px;box-shadow:0 2px 8px #0000001a;min-width:120px;z-index:100}.more-actions .dropdown-menu .dropdown-item{display:block;width:100%;padding:8px 16px;text-align:left;background:none;border:none;font-size:14px;color:#333;cursor:pointer;transition:background-color .2s}.more-actions .dropdown-menu .dropdown-item:hover{background-color:#f5f5f5}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}body{margin:0;padding:0}#root{min-height:100vh}
