:root{--md-sys-color-primary: #006e2b;--md-sys-color-on-primary: #ffffff;--md-sys-color-surface: #f6fbf1;--md-sys-color-on-surface: #181d18;--shape-xs: 4px;--shape-sm: 8px;--shape-md: 12px;--shape-lg: 16px;--shape-xl: 28px;--shape-full: 999px;--elev-1: 0 1px 2px rgba(0, 0, 0, .3), 0 1px 3px 1px rgba(0, 0, 0, .15);--elev-2: 0 1px 2px rgba(0, 0, 0, .3), 0 2px 6px 2px rgba(0, 0, 0, .15);--elev-3: 0 1px 3px rgba(0, 0, 0, .3), 0 4px 8px 3px rgba(0, 0, 0, .15)}*{box-sizing:border-box}body{margin:0;font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--md-sys-color-surface);color:var(--md-sys-color-on-surface);font-size:14px;line-height:1.5}h1{font-size:28px;line-height:36px;font-weight:400;margin:0}h2{font-size:24px;line-height:32px;font-weight:400;margin:0 0 4px}h3{font-size:20px;line-height:28px;font-weight:500;margin:0 0 12px}a{color:var(--md-sys-color-primary);text-decoration:none}a:hover{text-decoration:underline}.muted{color:var(--md-sys-color-on-surface-variant)}.small{font-size:12px}*:focus-visible{outline:2px solid var(--md-sys-color-primary);outline-offset:2px}.layout{display:flex;min-height:100vh}.sidebar{width:244px;flex-shrink:0;background:var(--md-sys-color-surface-container);color:var(--md-sys-color-on-surface);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:12px;font-size:16px;font-weight:500;letter-spacing:.15px;padding:22px 20px 18px}.brand.big{font-size:20px;justify-content:center;padding:0 0 20px}.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--shape-md);background:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);font-weight:700}.sidebar nav{display:flex;flex-direction:column;padding:0 12px;gap:4px;flex:1}.sidebar nav a{display:flex;align-items:center;gap:12px;height:52px;padding:0 18px;border-radius:var(--shape-full);color:var(--md-sys-color-on-surface-variant);font-size:14px;font-weight:500;letter-spacing:.1px}.sidebar nav a:hover{background:color-mix(in srgb,var(--md-sys-color-on-surface) 8%,transparent);text-decoration:none}.sidebar nav a.active{background:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container)}.sidebar-foot{padding:14px 16px;border-top:1px solid var(--md-sys-color-outline-variant);display:flex;flex-direction:column;gap:12px}.foot-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.lang-switch{display:inline-flex;border:1px solid var(--md-sys-color-outline);border-radius:var(--shape-full);overflow:hidden}.lang-switch button{background:transparent;border:none;color:var(--md-sys-color-on-surface);padding:5px 14px;cursor:pointer;font-size:12px;font-weight:500;font-family:inherit}.lang-switch button+button{border-left:1px solid var(--md-sys-color-outline)}.lang-switch button.active{background:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container)}.lang-switch.big button{padding:10px 18px;font-size:14px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:var(--shape-full);background:transparent;color:var(--md-sys-color-on-surface-variant);cursor:pointer}.icon-btn:hover{background:color-mix(in srgb,var(--md-sys-color-on-surface) 8%,transparent)}.user-row{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:13px}.user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}button.link{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--md-sys-color-on-surface-variant);cursor:pointer;padding:6px 10px;border-radius:var(--shape-full);font-size:13px;font-weight:500;font-family:inherit}button.link:hover{background:color-mix(in srgb,var(--md-sys-color-on-surface) 8%,transparent);color:var(--md-sys-color-on-surface)}.content{flex:1;padding:28px 36px;min-width:0}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:12px}.page-loading{display:flex;justify-content:center;padding:60px}.page-loading.full{min-height:100vh;align-items:center}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 22px;border-radius:var(--shape-full);border:1px solid var(--md-sys-color-outline);background:transparent;color:var(--md-sys-color-primary);font-size:14px;font-weight:500;letter-spacing:.1px;font-family:inherit;cursor:pointer;text-decoration:none;transition:background .15s}.btn:hover{background:color-mix(in srgb,var(--md-sys-color-primary) 8%,transparent);text-decoration:none}.btn.primary{background:var(--md-sys-color-primary);border-color:transparent;color:var(--md-sys-color-on-primary);box-shadow:none}.btn.primary:hover{background:color-mix(in srgb,var(--md-sys-color-on-primary) 8%,var(--md-sys-color-primary));box-shadow:var(--elev-1)}.btn.danger{color:var(--md-sys-color-error);border-color:var(--md-sys-color-outline)}.btn.danger:hover{background:color-mix(in srgb,var(--md-sys-color-error) 8%,transparent)}.btn.small{height:32px;padding:0 14px;font-size:13px}.btn:disabled{cursor:not-allowed;border-color:transparent;background:color-mix(in srgb,var(--md-sys-color-on-surface) 12%,transparent);color:color-mix(in srgb,var(--md-sys-color-on-surface) 38%,transparent);box-shadow:none}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.card{background:var(--md-sys-color-surface-container-low);border-radius:var(--shape-md);padding:20px;box-shadow:var(--elev-1)}.card-title{font-size:12px;line-height:16px;font-weight:500;letter-spacing:.5px;text-transform:uppercase;color:var(--md-sys-color-on-surface-variant);margin-bottom:12px}.big-number{font-size:36px;line-height:44px;font-weight:400}.status-dot-row{display:flex;align-items:center;gap:10px;font-weight:500}.status-dot-row .dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-dot-row.ok{color:var(--md-sys-color-primary)}.status-dot-row.ok .dot{background:var(--md-sys-color-primary);box-shadow:0 0 0 4px color-mix(in srgb,var(--md-sys-color-primary) 18%,transparent)}.status-dot-row.bad{color:var(--md-sys-color-error)}.status-dot-row.bad .dot{background:var(--md-sys-color-error);box-shadow:0 0 0 4px color-mix(in srgb,var(--md-sys-color-error) 18%,transparent)}.warn-list{margin:0;padding-left:18px}.warn-list li{margin-bottom:4px}.table-card{background:var(--md-sys-color-surface-container-low);border-radius:var(--shape-md);box-shadow:var(--elev-1);overflow-x:auto}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase;color:var(--md-sys-color-on-surface-variant);padding:14px 18px;border-bottom:1px solid var(--md-sys-color-outline-variant)}td{padding:13px 18px;border-bottom:1px solid var(--md-sys-color-outline-variant);vertical-align:middle}tr:last-child td{border-bottom:none}.row-disabled td{opacity:.5}.row-disabled td:nth-last-child(-n+2){opacity:1}.site-domain{font-weight:500;font-size:15px}.site-detail{margin-top:2px}.row-actions{text-align:right;white-space:nowrap}.row-actions .btn{margin-left:8px}.badge{display:inline-block;padding:4px 12px;border-radius:var(--shape-sm);font-size:12px;font-weight:500;letter-spacing:.3px;white-space:nowrap}.badge.gray{background:var(--md-sys-color-surface-container-highest);color:var(--md-sys-color-on-surface-variant)}.badge.green{background:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container)}.badge.yellow{background:var(--md-sys-color-tertiary-container);color:var(--md-sys-color-on-tertiary-container)}.badge.red{background:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container)}.badge.blue{background:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container)}.empty-state{background:var(--md-sys-color-surface-container-lowest);border:1px solid var(--md-sys-color-outline-variant);border-radius:var(--shape-md);padding:48px;text-align:center;color:var(--md-sys-color-on-surface-variant)}.empty-state .btn{margin-top:10px}.toggle{width:52px;height:32px;border-radius:var(--shape-full);background:var(--md-sys-color-surface-container-highest);border:2px solid var(--md-sys-color-outline);position:relative;cursor:pointer;transition:background .15s,border-color .15s;flex-shrink:0;padding:0}.toggle .knob{position:absolute;top:50%;left:6px;width:16px;height:16px;border-radius:50%;background:var(--md-sys-color-outline);transform:translateY(-50%);transition:left .15s,width .15s,height .15s,background .15s}.toggle.on{background:var(--md-sys-color-primary);border-color:var(--md-sys-color-primary)}.toggle.on .knob{left:22px;width:24px;height:24px;background:var(--md-sys-color-on-primary);box-shadow:var(--elev-1)}.toggle:disabled{opacity:.38;cursor:not-allowed}input,textarea,select{width:100%;padding:12px 16px;border:1px solid var(--md-sys-color-outline);border-radius:var(--shape-xs);font-size:14px;font-family:inherit;background:transparent;color:var(--md-sys-color-on-surface)}select{cursor:pointer}select option{background:var(--md-sys-color-surface-container-high);color:var(--md-sys-color-on-surface)}input::placeholder,textarea::placeholder{color:color-mix(in srgb,var(--md-sys-color-on-surface-variant) 75%,transparent)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--md-sys-color-primary);box-shadow:inset 0 0 0 1px var(--md-sys-color-primary)}textarea{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;resize:vertical}.field{display:block;margin-bottom:20px}.field-label{display:block;font-weight:500;margin-bottom:8px;font-size:14px;letter-spacing:.1px}.field-hint{display:block;font-size:12px;color:var(--md-sys-color-on-surface-variant);margin-top:6px;font-weight:400}.check-row{display:flex;gap:12px;align-items:flex-start;margin-bottom:16px;cursor:pointer}.check-row input{width:18px;height:18px;margin-top:2px;accent-color:var(--md-sys-color-primary);flex-shrink:0}.stack>div{margin-bottom:0}.site-form{background:var(--md-sys-color-surface-container-low);border-radius:var(--shape-lg);padding:28px;box-shadow:var(--elev-1)}.type-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}.type-card{background:transparent;border:1px solid var(--md-sys-color-outline-variant);border-radius:var(--shape-md);padding:16px;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:4px;font-family:inherit;color:var(--md-sys-color-on-surface);transition:background .15s,border-color .15s}.type-card:hover{background:color-mix(in srgb,var(--md-sys-color-on-surface) 8%,transparent)}.type-card.selected{background:var(--md-sys-color-secondary-container);border-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container)}.type-icon{font-size:22px}.type-name{font-weight:500;font-size:14px;letter-spacing:.1px}.type-desc{font-size:12px;color:var(--md-sys-color-on-surface-variant)}.type-card.selected .type-desc{color:color-mix(in srgb,var(--md-sys-color-on-secondary-container) 80%,transparent)}.chips-input{display:flex;flex-wrap:wrap;gap:8px;padding:8px 10px;border:1px solid var(--md-sys-color-outline);border-radius:var(--shape-xs);background:transparent;cursor:text}.chips-input:focus-within{border-color:var(--md-sys-color-primary);box-shadow:inset 0 0 0 1px var(--md-sys-color-primary)}.chips-input input{border:none;flex:1;min-width:140px;padding:6px 4px}.chips-input input:focus{border:none;box-shadow:none}.chip{display:inline-flex;align-items:center;gap:4px;height:32px;background:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container);border-radius:var(--shape-sm);padding:0 6px 0 12px;font-size:13px;font-weight:500}.chip button{background:none;border:none;color:inherit;cursor:pointer;font-size:16px;padding:0 6px;border-radius:50%}.chip button:hover{color:var(--md-sys-color-error)}.ssl-section{margin:24px 0}.ssl-options{display:grid;gap:10px;margin:10px 0 16px}.ssl-option{display:grid;grid-template-columns:auto auto 1fr;align-items:baseline;gap:4px 12px;border:1px solid var(--md-sys-color-outline-variant);border-radius:var(--shape-md);padding:14px 16px;cursor:pointer;transition:background .15s,border-color .15s}.ssl-option:hover{background:color-mix(in srgb,var(--md-sys-color-on-surface) 5%,transparent)}.ssl-option.selected{background:var(--md-sys-color-secondary-container);border-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container)}.ssl-option input{width:18px;height:18px;accent-color:var(--md-sys-color-primary)}.ssl-name{font-weight:500;font-size:14px}.ssl-desc{grid-column:3;font-size:12px;color:var(--md-sys-color-on-surface-variant)}.ssl-option.selected .ssl-desc{color:color-mix(in srgb,var(--md-sys-color-on-secondary-container) 80%,transparent)}.advanced{margin:20px 0;border-top:1px solid var(--md-sys-color-outline-variant);padding-top:16px}.advanced summary{cursor:pointer;font-weight:500;font-size:14px;color:var(--md-sys-color-on-surface-variant);margin-bottom:14px}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.error-box{background:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container);border-radius:var(--shape-md);padding:12px 16px;margin:14px 0;font-size:13px;word-break:break-word}.info-box{background:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container);border-radius:var(--shape-md);padding:12px 16px;margin:14px 0;font-size:13px;display:flex;align-items:center;gap:12px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--md-sys-color-surface)}.auth-card{background:var(--md-sys-color-surface-container-low);border-radius:var(--shape-xl);box-shadow:var(--elev-2);padding:36px;width:100%;max-width:392px;display:flex;flex-direction:column;gap:14px}.auth-card h2{text-align:center}.auth-card p{margin:0;text-align:center;font-size:13px}.auth-card .btn{margin-top:8px;height:44px}.logs-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.logs-toolbar .check-row{margin:0}.tabs{display:inline-flex;border:1px solid var(--md-sys-color-outline);border-radius:var(--shape-full);overflow:hidden}.tabs button{border:none;background:transparent;padding:9px 24px;font-size:14px;font-weight:500;cursor:pointer;color:var(--md-sys-color-on-surface);font-family:inherit}.tabs button+button{border-left:1px solid var(--md-sys-color-outline)}.tabs button.active{background:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container)}.live-pill{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--md-sys-color-primary)}.live-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--md-sys-color-primary);animation:pulse 1.6s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.log-box,.conf-preview{background:var(--md-sys-color-inverse-surface);color:var(--md-sys-color-inverse-on-surface);border-radius:var(--shape-md);padding:16px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;line-height:1.6;overflow:auto;margin:0;white-space:pre-wrap;word-break:break-all}[data-theme=dark] .log-box,[data-theme=dark] .conf-preview{background:var(--md-sys-color-surface-container-lowest);color:var(--md-sys-color-on-surface)}.log-box{height:calc(100vh - 220px)}.conf-preview{margin-top:14px}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}.page-tabs{display:flex;gap:4px;border-bottom:1px solid var(--md-sys-color-outline-variant);margin-bottom:20px;overflow-x:auto}.page-tabs button{position:relative;background:none;border:none;cursor:pointer;padding:12px 18px;font-size:14px;font-weight:500;font-family:inherit;letter-spacing:.1px;color:var(--md-sys-color-on-surface-variant);white-space:nowrap}.page-tabs button:hover{color:var(--md-sys-color-on-surface);background:color-mix(in srgb,var(--md-sys-color-on-surface) 6%,transparent);border-radius:var(--shape-xs) var(--shape-xs) 0 0}.page-tabs button.active{color:var(--md-sys-color-primary)}.page-tabs button.active:after{content:"";position:absolute;left:16px;right:16px;bottom:0;height:3px;border-radius:3px 3px 0 0;background:var(--md-sys-color-primary)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,var(--md-sys-color-scrim, #000) 38%,transparent);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}.modal{background:var(--md-sys-color-surface-container-high);border-radius:var(--shape-xl);padding:24px;width:100%;max-width:440px;box-shadow:var(--elev-3)}.modal h3{font-size:24px;line-height:32px;font-weight:400;margin:0 0 14px}.modal p{margin:0 0 22px;color:var(--md-sys-color-on-surface-variant)}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.modal-actions .btn:not(.primary){border-color:transparent}.toasts{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:100;max-width:440px}.toast{padding:14px 16px;border-radius:var(--shape-xs);font-size:14px;box-shadow:var(--elev-3);cursor:pointer;animation:slide-in .2s ease-out;word-break:break-word}.toast.ok{background:var(--md-sys-color-inverse-surface);color:var(--md-sys-color-inverse-on-surface)}.toast.err{background:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container)}@keyframes slide-in{0%{transform:translateY(8px);opacity:0}to{transform:none;opacity:1}}.spinner{display:inline-block;width:22px;height:22px;border:3px solid color-mix(in srgb,var(--md-sys-color-primary) 25%,transparent);border-top-color:var(--md-sys-color-primary);border-radius:50%;animation:spin .7s linear infinite}.spinner.small{width:14px;height:14px;border-width:2px}@keyframes spin{to{transform:rotate(360deg)}}.btn.primary .spinner{border-color:color-mix(in srgb,var(--md-sys-color-on-primary) 30%,transparent);border-top-color:var(--md-sys-color-on-primary)}.health-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:7px;vertical-align:middle}.health-dot.ok{background:var(--md-sys-color-primary)}.health-dot.bad{background:var(--md-sys-color-error);box-shadow:0 0 0 3px color-mix(in srgb,var(--md-sys-color-error) 20%,transparent)}.health-dot.na{background:var(--md-sys-color-outline-variant)}.traffic-card{margin-top:16px}.traffic-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}.traffic-stats{display:flex;gap:14px;font-size:13px}.stat-err{color:var(--md-sys-color-error);font-weight:500}.traffic-chart{width:100%;height:auto;display:block}.traffic-chart .bar-ok{fill:var(--md-sys-color-primary);opacity:.75}.traffic-chart .bar-err{fill:var(--md-sys-color-error)}.chart-label{font-size:10px;fill:var(--md-sys-color-on-surface-variant)}.top-hosts{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:12px}.tuning-section,.protect-section{margin:24px 0;border-top:1px solid var(--md-sys-color-outline-variant);padding-top:18px}.cert-upload{border:1px dashed var(--md-sys-color-outline-variant);border-radius:var(--shape-md);padding:16px;margin-top:8px}.auth-users{margin:0 0 18px 30px}.auth-user-row{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;margin-bottom:8px}.row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.stack-list{display:flex;flex-direction:column;gap:8px;align-items:flex-start}.stack-list .url-row{display:flex;gap:8px;width:100%}.url-row input{flex:1;min-width:0}.url-row select{flex:0 0 150px;width:150px}.url-row .btn{align-self:center}.target-row{display:flex;flex-direction:column;gap:6px;width:100%}.stack-list .target-row+.target-row{border-top:1px solid var(--md-sys-color-outline-variant);padding-top:10px}.url-events{display:flex;flex-wrap:wrap;gap:16px;padding-left:2px}.url-events label{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--md-sys-color-on-surface-variant);cursor:pointer}.url-events input{width:16px;height:16px;accent-color:var(--md-sys-color-primary)}.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}.user-line{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 0;border-bottom:1px solid var(--md-sys-color-outline-variant);font-weight:500}.user-add{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;margin-top:14px}.audit-card{grid-column:1 / -1}.audit-list{display:flex;flex-direction:column;max-height:360px;overflow-y:auto}.audit-row{display:grid;grid-template-columns:110px 90px auto 1fr;gap:10px;align-items:baseline;padding:7px 0;border-bottom:1px solid var(--md-sys-color-outline-variant);font-size:13px}.audit-row:last-child{border-bottom:none}.audit-user{font-weight:500;overflow:hidden;text-overflow:ellipsis}@media(max-width:760px){.layout{flex-direction:column}.sidebar{width:100%;height:auto;position:static}.sidebar nav{flex-direction:row;overflow-x:auto;padding-bottom:8px}.sidebar nav a{height:44px;padding:0 16px}.content{padding:18px}.type-cards,.row-2,.user-add,.auth-user-row{grid-template-columns:1fr}.audit-row{grid-template-columns:1fr;gap:2px}.url-row{flex-wrap:wrap}.url-row input{flex-basis:100%;order:1}}
