:root{--layout-header-height: 4.25rem;--layout-sidebar-width: 220px;--layout-sidebar-width-collapsed: 56px}.layout{min-height:100vh}.layout-overlay{display:none}.layout-header{position:fixed;top:0;left:0;right:0;z-index:102;height:var(--layout-header-height);box-sizing:border-box;display:flex;align-items:center;gap:.75rem;padding:max(.75rem,env(safe-area-inset-top)) 1rem .75rem;padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));background:#1e293b;color:#f8fafc;border-bottom:1px solid #334155}.layout-sidebar-toggle{display:flex;align-items:center;justify-content:center;min-width:2.75rem;min-height:2.75rem;padding:0;background:transparent;border:1px solid #475569;color:#cbd5e1;border-radius:6px;transition:background .15s,color .15s;flex-shrink:0}.layout-sidebar-toggle:hover{background:#334155;color:#f8fafc}.layout-sidebar-toggle-icon{font-size:1.25rem;line-height:1;transition:transform .2s}.layout-header-title{flex:1;min-width:0;font-weight:600;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.layout-logout{padding:.5rem .75rem;min-height:2.75rem;background:transparent;border:1px solid #64748b;color:#cbd5e1;border-radius:6px;font-size:.875rem;transition:background .15s,color .15s;flex-shrink:0}.layout-logout:hover{background:#475569;color:#f8fafc}.layout-sidebar{position:fixed;top:var(--layout-header-height);left:0;bottom:0;z-index:101;width:var(--layout-sidebar-width);background:#1e293b;border-right:1px solid #334155;transition:width .2s ease;overflow-x:hidden;overflow-y:auto}.layout-sidebar--collapsed{width:var(--layout-sidebar-width-collapsed)}.layout-sidebar--collapsed .layout-nav-label{opacity:0;width:0;overflow:hidden;white-space:nowrap}.layout-nav{display:flex;flex-direction:column;padding:.75rem 0;gap:.25rem}.layout-nav-link{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;color:#94a3b8;text-decoration:none;font-size:.9375rem;transition:background .15s,color .15s;white-space:nowrap}.layout-nav-link:hover{background:#334155;color:#e2e8f0}.layout-nav-link--active{background:#334155;color:#93c5fd;font-weight:500}.layout-sidebar--collapsed .layout-nav-link{padding:.6rem;justify-content:center}.layout-nav-icon{flex-shrink:0;font-size:1.125rem;width:1.5rem;text-align:center}.layout-nav-label{transition:opacity .2s,width .2s}.layout-main{margin-top:var(--layout-header-height);margin-left:var(--layout-sidebar-width);padding:1rem 1.5rem;padding-left:max(1.5rem,env(safe-area-inset-left));padding-right:max(1.5rem,env(safe-area-inset-right));padding-bottom:max(1.5rem,env(safe-area-inset-bottom));background:#f1f5f9;overflow:auto;min-width:0;min-height:calc(100vh - var(--layout-header-height));transition:margin-left .2s ease}.layout--sidebar-collapsed .layout-main{margin-left:var(--layout-sidebar-width-collapsed)}@media(max-width:640px){.layout-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:99;background:transparent;pointer-events:none;transition:background .2s,pointer-events 0s .2s}.layout-overlay--visible{background:#00000059;pointer-events:auto;transition:background .2s}.layout-header{padding:max(.625rem,env(safe-area-inset-top)) .75rem .625rem;padding-left:max(.75rem,env(safe-area-inset-left));padding-right:max(.75rem,env(safe-area-inset-right));gap:.5rem}.layout-header-title{font-size:.9375rem}.layout-logout{padding:.5rem .6rem;font-size:.8125rem}.layout-sidebar{position:fixed;left:0;top:var(--layout-header-height);bottom:0;z-index:100;box-shadow:4px 0 12px #00000026;padding-top:.75rem;padding-left:env(safe-area-inset-left);padding-bottom:env(safe-area-inset-bottom)}.layout-sidebar--collapsed{width:0;min-width:0;border-right:none}.layout-sidebar--collapsed .layout-nav-link{padding:.6rem 1rem}.layout-sidebar--collapsed .layout-nav-label{display:none}.layout-main{margin-left:0!important;padding:1rem;padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));padding-bottom:max(1rem,env(safe-area-inset-bottom))}}.login-page{padding:max(1.5rem,env(safe-area-inset-top)) 1.5rem max(1.5rem,env(safe-area-inset-bottom));padding-left:max(1.5rem,env(safe-area-inset-left));padding-right:max(1.5rem,env(safe-area-inset-right));min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center}.login-form{max-width:360px;width:100%;margin:0 auto;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.login-title{margin:0 0 1.5rem;font-size:1.375rem}.login-description{color:#64748b;margin:0 0 1.5rem;font-size:.9375rem;line-height:1.5}.login-field{margin-bottom:1rem}.login-input{width:100%;min-height:2.75rem;padding:.6rem .75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:1rem}.login-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.login-error{color:#dc2626;font-size:.9375rem;margin:0 0 1rem}.login-submit{width:100%;min-height:2.75rem;padding:.6rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-weight:600;font-size:.9375rem}.login-submit:hover:not(:disabled){background:#1d4ed8}.login-submit:disabled{opacity:.6;cursor:not-allowed}.login-submit--secondary{margin-top:.5rem;background:#64748b}.login-submit--secondary:hover:not(:disabled){background:#475569}.login-link{display:block;width:100%;margin-top:1rem;padding:.5rem;background:none;border:none;color:#2563eb;font-size:.875rem;cursor:pointer}.login-link:hover{text-decoration:underline}.login-secret-block{margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.login-form-wrapper{max-width:360px;width:100%}.login-input--code{font-size:1.5rem;letter-spacing:.5rem;text-align:center}@media(max-width:640px){.login-page{padding:max(2rem,env(safe-area-inset-top)) 1rem max(1rem,env(safe-area-inset-bottom));padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));align-items:flex-start}.login-form{padding:1.25rem}.login-title{font-size:1.25rem}}.dashboard-page{width:100%;min-width:0}.dashboard-title{margin:0 0 1rem;font-size:1.5rem}.dashboard-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #00000014;margin-bottom:1rem}.dashboard-card-title{margin:0 0 .5rem;font-size:1.1rem}.dashboard-card-title--small{font-size:1rem}.dashboard-card-text{color:#64748b;margin:0;font-size:.9375rem;line-height:1.5}.dashboard-list{margin:0;padding-left:1.25rem;font-size:.9375rem;line-height:1.6}.dashboard-list li{margin-bottom:.25rem}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;margin-top:.5rem}.dashboard-stat{display:flex;flex-direction:column;gap:.25rem}.dashboard-stat-value{font-size:1.5rem;font-weight:700;color:#1e293b}.dashboard-stat-label{font-size:.8125rem;color:#64748b}@media(max-width:640px){.dashboard-title{font-size:1.25rem}.dashboard-card{padding:1.25rem}.dashboard-card-title{font-size:1rem}.dashboard-card-title--small{font-size:.9375rem}}.keys-page{width:100%;min-width:0}.keys-title{margin:0 0 1rem;font-size:1.5rem}.keys-error{padding:.75rem 1rem;margin-bottom:1rem;background:#fef2f2;color:#dc2626;border-radius:8px;font-size:.9375rem}.keys-create{margin-bottom:1.5rem}.keys-form{display:flex;gap:.5rem;flex-wrap:wrap}.keys-form-input{flex:1;min-width:0;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9375rem}.keys-form-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.keys-form-btn{padding:.5rem 1rem;min-height:2.5rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-weight:500;font-size:.9375rem}.keys-form-btn:hover:not(:disabled){background:#1d4ed8}.keys-form-btn:disabled{opacity:.6;cursor:not-allowed}.keys-form-select{min-width:140px;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9375rem;background:#fff}.keys-form-select:focus{outline:none;border-color:#2563eb}.keys-table-wrap{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;overflow:auto;-webkit-overflow-scrolling:touch}.keys-loading,.keys-empty{padding:2rem;text-align:center;color:#64748b;margin:0}.keys-table{width:100%;min-width:520px;border-collapse:collapse;font-size:.875rem}.keys-table th,.keys-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #f1f5f9}.keys-table th{background:#f8fafc;font-weight:600;color:#475569}.keys-table tr:last-child td{border-bottom:none}.keys-table-select{min-width:120px;padding:.25rem .5rem;border:1px solid #e2e8f0;border-radius:4px;font-size:.8125rem;background:#fff}.keys-table-input{min-width:100px;width:100%;padding:.25rem .5rem;border:1px solid #e2e8f0;border-radius:4px;font-size:.8125rem}.keys-form-input--sender{min-width:140px}.keys-id{font-size:.8125rem;background:#f1f5f9;padding:.2rem .4rem;border-radius:4px}.keys-badge{display:inline-block;padding:.2rem .5rem;border-radius:6px;font-size:.75rem;font-weight:500}.keys-badge--active{background:#dcfce7;color:#166534}.keys-badge--revoked{background:#fee2e2;color:#991b1b}.keys-btn{padding:.35rem .65rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;font-size:.8125rem;color:#475569}.keys-btn:hover:not(:disabled){background:#e2e8f0;color:#1e293b}.keys-btn:disabled{opacity:.6;cursor:not-allowed}.keys-btn--small{padding:.25rem .5rem}.keys-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.75rem 1rem;padding:.75rem 1rem;border-top:1px solid #f1f5f9}.keys-pagination-info{font-size:.8125rem;color:#64748b}.keys-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:200;padding:max(1rem,env(safe-area-inset-top)) max(1rem,env(safe-area-inset-right)) max(1rem,env(safe-area-inset-bottom)) max(1rem,env(safe-area-inset-left));overflow-y:auto}.keys-modal{background:#fff;border-radius:12px;padding:1.25rem;max-width:480px;width:100%;max-height:min(90vh,400px);overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a;margin:auto}.keys-modal-title{margin:0 0 .5rem;font-size:1.25rem}.keys-modal-warning{margin:0 0 1rem;color:#b45309;font-size:.875rem;background:#fffbeb;padding:.5rem .75rem;border-radius:6px}.keys-modal-key-wrap{display:flex;flex-wrap:wrap;gap:.5rem;align-items:flex-start;margin-bottom:1rem}.keys-modal-key{flex:1;min-width:0;font-size:.8125rem;word-break:break-all;background:#f8fafc;padding:.75rem;border-radius:6px;border:1px solid #e2e8f0}.keys-modal-copy{flex-shrink:0;min-height:2.5rem}.keys-modal-close{width:100%;padding:.5rem}@media(max-width:900px){.keys-table-wrap{border-radius:10px}.keys-table{min-width:520px}.keys-table th,.keys-table td{padding:.6rem .75rem;font-size:.8125rem}.keys-table-select{min-width:100px}.keys-table-input{min-width:80px}}@media(max-width:640px){.keys-title{font-size:1.25rem}.keys-form-input,.keys-form-btn{width:100%}.keys-table-wrap{overflow:visible;padding:0 .25rem}.keys-table{min-width:0;display:block}.keys-table thead{display:none}.keys-table tbody tr{display:block;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:.75rem;padding:.75rem 1rem;background:#fff;box-shadow:0 1px 2px #0000000a}.keys-table tbody tr:last-child{margin-bottom:0}.keys-table tbody td{display:block;padding:.5rem 0;border-bottom:1px solid #f1f5f9;text-align:left}.keys-table tbody td:last-child{border-bottom:none;padding-top:.75rem;margin-top:.25rem;border-top:1px solid #f1f5f9}.keys-table tbody td:before{content:attr(data-label);font-weight:600;font-size:.75rem;color:#64748b;display:block;margin-bottom:.2rem}.keys-table-select,.keys-table-input{width:100%;min-width:0;max-width:100%}.keys-btn{min-height:2.25rem;padding:.4rem .75rem}.keys-pagination-info{width:100%;text-align:center}}@media(max-width:380px){.keys-table tbody tr{padding:.6rem .75rem}.keys-table tbody td{font-size:.8125rem}}.users-page{width:100%;min-width:0}.users-title{margin:0 0 1rem;font-size:1.5rem}.users-error{padding:.75rem 1rem;margin-bottom:1rem;background:#fef2f2;color:#dc2626;border-radius:8px;font-size:.9375rem}.users-success{padding:.75rem 1rem;margin-bottom:1rem;background:#f0fdf4;color:#166534;border-radius:8px;font-size:.9375rem}.users-create{margin-bottom:1.5rem}.users-form{display:flex;gap:.5rem;flex-wrap:wrap}.users-form-input{flex:1;min-width:200px;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9375rem}.users-form-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.users-form-select{min-width:140px;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9375rem;background:#fff}.users-form-btn{padding:.5rem 1rem;min-height:2.5rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-weight:500;font-size:.9375rem}.users-form-btn:hover:not(:disabled){background:#1d4ed8}.users-form-btn:disabled{opacity:.6;cursor:not-allowed}.users-table-wrap{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;overflow:auto;-webkit-overflow-scrolling:touch}.users-loading,.users-empty{padding:2rem;text-align:center;color:#64748b;margin:0}.users-table{width:100%;min-width:480px;border-collapse:collapse;font-size:.875rem}.users-table th,.users-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #f1f5f9}.users-table th{background:#f8fafc;font-weight:600;color:#475569}.users-table tr:last-child td{border-bottom:none}.users-table-select{min-width:120px;padding:.25rem .5rem;border:1px solid #e2e8f0;border-radius:4px;font-size:.8125rem;background:#fff}.users-badge{display:inline-block;padding:.2rem .5rem;border-radius:6px;font-size:.75rem;font-weight:500}.users-badge--active{background:#dcfce7;color:#166534}.users-badge--inactive{background:#fee2e2;color:#991b1b}.users-btn{padding:.35rem .65rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;font-size:.8125rem;color:#475569}.users-btn:hover:not(:disabled){background:#e2e8f0;color:#1e293b}.users-btn:disabled{opacity:.6;cursor:not-allowed}.users-btn--danger{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.users-btn--danger:hover:not(:disabled){background:#fee2e2;color:#991b1b}.users-row--self{background:#f8fafc}.users-self-label{color:#64748b;font-size:.8125rem}.users-table-role{font-size:.875rem;color:#475569}.users-no-action{font-size:.8125rem;color:#64748b;font-style:italic}.users-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:200;padding:max(1rem,env(safe-area-inset-top)) max(1rem,env(safe-area-inset-right)) max(1rem,env(safe-area-inset-bottom)) max(1rem,env(safe-area-inset-left));overflow-y:auto}.users-modal{background:#fff;border-radius:12px;padding:1.25rem;max-width:420px;width:100%;box-shadow:0 20px 25px -5px #0000001a;margin:auto}.users-modal-title{margin:0 0 .5rem;font-size:1.25rem}.users-modal-warning{margin:0 0 1rem;color:#92400e;font-size:.875rem;background:#fffbeb;padding:.5rem .75rem;border-radius:6px}.users-modal-actions{display:flex;gap:.5rem;justify-content:flex-end}@media(max-width:640px){.users-title{font-size:1.25rem}.users-form-input,.users-form-btn{width:100%}.users-table th,.users-table td{padding:.5rem .75rem;font-size:.8125rem}}.config-page{width:100%;min-width:0}.config-title{margin:0 0 .5rem;font-size:1.5rem}.config-intro{margin:0 0 1.5rem;color:#64748b;font-size:.9375rem;line-height:1.5}.config-loading{margin:0;color:#64748b}.config-error{padding:.75rem 1rem;margin-bottom:1rem;background:#fef2f2;color:#dc2626;border-radius:8px;font-size:.9375rem}.config-success{padding:.75rem 1rem;margin-bottom:1rem;background:#f0fdf4;color:#166534;border-radius:8px;font-size:.9375rem}.config-form{display:flex;flex-direction:column;gap:1.5rem}.config-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;overflow:hidden}.config-section-title{margin:0;padding:1rem 1.25rem;font-size:1.125rem;font-weight:600;background:#f8fafc;border-bottom:1px solid #f1f5f9;color:#1e293b}.config-fields{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:1rem}.config-field{display:flex;flex-direction:column;gap:.25rem}.config-label{font-weight:500;font-size:.9375rem;color:#334155}.config-description{margin:0;font-size:.8125rem;color:#64748b}.config-input-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.config-input{flex:1;min-width:0;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9375rem}.config-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.config-reset-btn{flex-shrink:0;padding:.5rem .75rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;font-size:.8125rem;color:#475569}.config-reset-btn:hover{background:#e2e8f0;color:#1e293b}.config-actions{padding-top:.5rem}.config-save-btn{padding:.625rem 1.25rem;background:#2563eb;color:#fff;border:none;border-radius:8px;font-weight:500;font-size:.9375rem}.config-save-btn:hover:not(:disabled){background:#1d4ed8}.config-save-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:640px){.config-title{font-size:1.25rem}.config-intro{font-size:.875rem}.config-section-title{padding:.875rem 1rem;font-size:1rem}.config-fields{padding:1rem}.config-input-row{flex-direction:column;align-items:stretch}.config-reset-btn{align-self:flex-start;min-height:2.5rem}.config-save-btn{width:100%;min-height:2.75rem}}.queue-page{width:100%;min-width:0}.queue-title{margin:0 0 .5rem;font-size:1.5rem}.queue-intro{margin:0 0 1.5rem;color:#64748b;font-size:.9375rem;line-height:1.5}.queue-loading{margin:0;color:#64748b}.queue-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;padding:1.25rem;margin-bottom:1.5rem}.queue-card--error{background:#fef2f2;border:1px solid #fecaca}.queue-unavailable{margin:0;color:#dc2626;font-size:.9375rem}.queue-card-title{margin:0 0 1rem;font-size:1.125rem;font-weight:600;color:#1e293b}.queue-card-hint{margin:0 0 .75rem;font-size:.875rem;color:#64748b}.queue-card-hint code{padding:.15em .4em;background:#f1f5f9;border-radius:4px;font-size:.8125rem}.queue-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem;margin-bottom:1.25rem}.queue-stat{text-align:center;padding:.75rem;background:#f8fafc;border-radius:8px}.queue-stat--paused .queue-stat-value{color:#b45309}.queue-stat-value{display:block;font-size:1.5rem;font-weight:600;color:#1e293b}.queue-stat-label{display:block;margin-top:.25rem;font-size:.8125rem;color:#64748b}.queue-actions{display:flex;flex-wrap:wrap;gap:.5rem}.queue-btn{padding:.5rem 1rem;min-height:2.5rem;border:none;border-radius:6px;font-weight:500;font-size:.9375rem;cursor:pointer}.queue-btn:disabled{opacity:.6;cursor:not-allowed}.queue-btn--primary{background:#2563eb;color:#fff}.queue-btn--primary:hover:not(:disabled){background:#1d4ed8}.queue-btn--secondary{background:#dc2626;color:#fff}.queue-btn--secondary:hover:not(:disabled){background:#b91c1c}.queue-btn--outline{background:#fff;color:#475569;border:1px solid #e2e8f0}.queue-btn--outline:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.queue-form{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.queue-input{flex:1;min-width:200px;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9375rem}.queue-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.queue-error{margin:0 0 .75rem;padding:.5rem .75rem;background:#fef2f2;color:#dc2626;border-radius:6px;font-size:.875rem}.queue-job-result{margin-top:1rem;padding:1rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.queue-job-dl{margin:0 0 1rem;display:grid;grid-template-columns:auto 1fr;gap:.5rem 1rem;font-size:.9375rem}.queue-job-dl dt{color:#64748b;font-weight:500}.queue-job-dl dd{margin:0}.queue-job-dl code{padding:.15em .4em;background:#e2e8f0;border-radius:4px;font-size:.8125rem}.queue-job-status{display:inline-block;padding:.2em .5em;border-radius:4px;font-size:.8125rem;font-weight:500}.queue-job-status--completed{background:#dcfce7;color:#166534}.queue-job-status--failed{background:#fef2f2;color:#dc2626}.queue-job-status--waiting,.queue-job-status--delayed{background:#fef9c3;color:#854d0e}.queue-job-status--active{background:#dbeafe;color:#1d4ed8}.queue-job-error{color:#dc2626;font-size:.875rem}.queue-job-pre{margin:0;padding:.75rem;background:#1e293b;color:#e2e8f0;border-radius:6px;font-size:.8125rem;overflow-x:auto;white-space:pre-wrap;word-break:break-word}@media(max-width:640px){.queue-stats{grid-template-columns:repeat(2,1fr)}.queue-form{flex-direction:column}.queue-input{min-width:0}.queue-btn{width:100%}}.servers-page{width:100%;min-width:0}.servers-title{margin:0 0 .5rem;font-size:1.5rem}.servers-intro{margin:0 0 1.5rem;color:#64748b;font-size:.9375rem;line-height:1.5}.servers-error{padding:.75rem 1rem;margin-bottom:1rem;background:#fef2f2;color:#dc2626;border-radius:8px;font-size:.9375rem}.servers-actions{margin-bottom:1.5rem}.servers-btn{padding:.5rem 1rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;font-size:.9375rem;color:#475569}.servers-btn:hover:not(:disabled){background:#e2e8f0;color:#1e293b}.servers-btn--primary{background:#2563eb;border-color:#2563eb;color:#fff}.servers-btn--primary:hover:not(:disabled){background:#1d4ed8;border-color:#1d4ed8;color:#fff}.servers-btn--danger{background:#fef2f2;border-color:#fecaca;color:#dc2626}.servers-btn--danger:hover:not(:disabled){background:#fee2e2;color:#b91c1c}.servers-btn--small{padding:.35rem .65rem;font-size:.8125rem;margin-right:.5rem;margin-bottom:.25rem}.servers-test-ok,.servers-test-fail{display:inline-block;margin-left:.5rem;font-size:.8125rem;white-space:nowrap}.servers-test-ok{color:#166534}.servers-test-fail{color:#dc2626}.servers-btn:disabled{opacity:.6;cursor:not-allowed}.servers-table-wrap{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;overflow:hidden}.servers-table-scroll{overflow:auto;-webkit-overflow-scrolling:touch}.servers-loading,.servers-empty{padding:2rem;text-align:center;color:#64748b;margin:0}.servers-table{width:100%;min-width:640px;border-collapse:collapse;font-size:.875rem}.servers-table th,.servers-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #f1f5f9}.servers-table th{background:#f8fafc;font-weight:600;color:#475569}.servers-table tr:last-child td{border-bottom:none}.servers-host{font-size:.8125rem;background:#f1f5f9;padding:.2rem .4rem;border-radius:4px}.servers-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:200;padding:max(1rem,env(safe-area-inset-top)) max(1rem,env(safe-area-inset-right)) max(1rem,env(safe-area-inset-bottom)) max(1rem,env(safe-area-inset-left));overflow-y:auto}.servers-modal{background:#fff;border-radius:12px;padding:1.5rem;max-width:480px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a;margin:auto}.servers-modal--small{max-width:400px}.servers-modal-title{margin:0 0 1rem;font-size:1.25rem}.servers-form{display:flex;flex-direction:column;gap:1rem}.servers-field{display:flex;flex-direction:column;gap:.25rem}.servers-field-row{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end}.servers-field-row .servers-field{flex:1;min-width:100px}.servers-field--checkbox{flex:0 0 auto;align-self:flex-end;padding-bottom:.25rem}.servers-label{font-weight:500;font-size:.9375rem;color:#334155}.servers-label--checkbox{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:400}.servers-hint{display:block;margin-top:.25rem;font-size:.8125rem;color:#64748b}.servers-label--checkbox input{width:auto}.servers-input{padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9375rem}.servers-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.servers-form-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:.5rem}.servers-delete-text{margin:0 0 1rem;color:#64748b;font-size:.9375rem}@media(max-width:900px){.servers-table{min-width:560px}.servers-table th,.servers-table td{padding:.6rem .75rem;font-size:.8125rem}}@media(max-width:640px){.servers-title{font-size:1.25rem}.servers-table-scroll{overflow:visible}.servers-table-wrap{padding:0 .25rem}.servers-table{min-width:0;display:block}.servers-table thead{display:none}.servers-table tbody tr{display:block;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:.75rem;padding:.75rem 1rem;background:#fff;box-shadow:0 1px 2px #0000000a}.servers-table tbody tr:last-child{margin-bottom:0}.servers-table tbody td{display:block;padding:.5rem 0;border-bottom:1px solid #f1f5f9;text-align:left}.servers-table tbody td:last-child{border-bottom:none;padding-top:.75rem;margin-top:.25rem;border-top:1px solid #f1f5f9}.servers-table tbody td:before{content:attr(data-label);font-weight:600;font-size:.75rem;color:#64748b;display:block;margin-bottom:.2rem}.servers-btn--small{display:inline-block;margin-right:.5rem;margin-bottom:.35rem}.servers-test-ok,.servers-test-fail{display:block;margin-left:0;margin-top:.35rem}.servers-field-row{flex-direction:column;align-items:stretch}.servers-form-actions{flex-direction:column}.servers-form-actions .servers-btn{width:100%}}@media(max-width:380px){.servers-table tbody tr{padding:.6rem .75rem}.servers-table tbody td{font-size:.8125rem}}.templates-page{width:100%;min-width:0}.templates-title{margin:0 0 .5rem;font-size:1.5rem}.templates-intro{margin:0 0 1.5rem;color:#64748b;font-size:.9375rem;line-height:1.5}.templates-error{padding:.75rem 1rem;margin-bottom:1rem;background:#fef2f2;color:#dc2626;border-radius:8px;font-size:.9375rem}.templates-actions{margin-bottom:1.5rem}.templates-btn{padding:.5rem 1rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;font-size:.9375rem;color:#475569;text-decoration:none;display:inline-block;cursor:pointer}.templates-btn:hover:not(:disabled){background:#e2e8f0;color:#1e293b}.templates-btn--primary{background:#2563eb;border-color:#2563eb;color:#fff}.templates-btn--primary:hover{background:#1d4ed8;border-color:#1d4ed8;color:#fff}.templates-btn--danger{background:#fef2f2;border-color:#fecaca;color:#dc2626;margin-left:.5rem}.templates-btn--danger:hover:not(:disabled){background:#fee2e2;color:#b91c1c}.templates-btn--small{padding:.35rem .65rem;font-size:.8125rem}.templates-btn:disabled{opacity:.6;cursor:not-allowed}.templates-table-wrap{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;overflow:hidden}.templates-table-scroll{overflow:auto;-webkit-overflow-scrolling:touch}.templates-loading,.templates-empty{padding:2rem;text-align:center;color:#64748b;margin:0}.templates-table{width:100%;min-width:480px;border-collapse:collapse;font-size:.875rem}.templates-table th,.templates-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #f1f5f9}.templates-table th{background:#f8fafc;font-weight:600;color:#475569}.templates-table tr:last-child td{border-bottom:none}.templates-slug{font-size:.8125rem;background:#f1f5f9;padding:.2rem .4rem;border-radius:4px}.templates-badge{display:inline-block;padding:.2rem .5rem;border-radius:6px;font-size:.75rem;font-weight:500}.templates-badge--active{background:#dcfce7;color:#166534}.templates-badge--inactive{background:#f1f5f9;color:#64748b}.templates-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.templates-modal{background:#fff;border-radius:12px;padding:1.5rem;max-width:400px;width:100%;box-shadow:0 20px 25px -5px #0000001a}.templates-modal-title{margin:0 0 .75rem;font-size:1.25rem}.templates-modal-text{margin:0 0 1rem;color:#475569;font-size:.9375rem}.templates-modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.block-editor{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1rem;flex-wrap:wrap}.block-palette{flex:0 0 180px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:.75rem}.block-palette-title{font-weight:600;font-size:.875rem;color:#475569;margin-bottom:.5rem}.block-palette-list{display:flex;flex-direction:column;gap:.35rem}.block-palette-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:.8125rem;cursor:grab;text-align:left;width:100%}.block-palette-item:hover{background:#f1f5f9;border-color:#cbd5e1}.block-palette-item:active{cursor:grabbing}.block-palette-item--dragging{opacity:.6}.block-palette-item-icon{font-weight:700;color:#64748b;min-width:1.5em}.block-canvas{flex:1;min-width:280px;min-height:200px;background:#fff;border:2px dashed #e2e8f0;border-radius:8px;padding:.75rem;transition:border-color .15s,background .15s}.block-canvas--over{border-color:#2563eb;background:#eff6ff}.block-canvas-empty{color:#94a3b8;font-size:.875rem;text-align:center;padding:2rem 1rem}.block-canvas-item{display:flex;gap:.5rem;align-items:flex-start;margin-bottom:.5rem;padding:.5rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px}.block-canvas-item--dragging{opacity:.8;box-shadow:0 4px 12px #0000001a}.block-canvas-item-handle{flex-shrink:0;padding:.25rem .35rem;cursor:grab;color:#94a3b8;font-size:.75rem;border-radius:4px;background:transparent;border:none}.block-canvas-item-handle:active{cursor:grabbing}.block-canvas-item-handle:hover{color:#64748b;background:#e2e8f0}.block-canvas-item-body{flex:1;min-width:0}.block-canvas-item-type{display:inline-block;font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;margin-bottom:.35rem}.block-item-fields{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:flex-start;position:relative}.block-item--column{padding:.25rem 0}.block-item-label{font-size:.8125rem;color:#64748b}.block-item-field{display:flex;flex-direction:column;gap:.2rem;font-size:.75rem;color:#475569}.block-item-field--wide{flex:1;min-width:160px}.block-item-field--row{flex-direction:row;align-items:center}.block-item-input{padding:.35rem .5rem;border:1px solid #e2e8f0;border-radius:4px;font-size:.8125rem;min-width:0}.block-item-input:focus{outline:none;border-color:#2563eb}.block-item-textarea{resize:vertical;font-family:inherit}.block-item-textarea--code{font-family:ui-monospace,monospace;font-size:.75rem}.block-item-remove{position:absolute;top:0;right:0;padding:.2rem .4rem;background:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:4px;font-size:.75rem;cursor:pointer;line-height:1}.block-item-remove:hover{background:#fee2e2}.block-columns-editor{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:.5rem}.block-column-slot{min-height:80px;padding:.5rem;background:#fff;border:1px dashed #cbd5e1;border-radius:6px}.block-column-slot-title{font-size:.75rem;font-weight:600;color:#64748b;margin-bottom:.5rem;text-transform:uppercase}.block-column-item{margin-bottom:.5rem;padding:.4rem;background:#f8fafc;border-radius:4px;border:1px solid #e2e8f0}.block-column-item .block-item-remove{position:relative;top:0;right:0}.block-column-add{margin-top:.5rem}.block-column-add-select{width:100%;padding:.35rem .5rem;font-size:.8125rem;border:1px solid #e2e8f0;border-radius:4px;background:#fff;color:#475569}.block-column-add-select:focus{outline:none;border-color:#2563eb}@media(max-width:640px){.block-editor{flex-direction:column}.block-palette{flex:0 0 auto;width:100%}.block-palette-list{flex-direction:row;flex-wrap:wrap}.block-palette-item{flex:1 1 120px}.block-columns-editor{grid-template-columns:1fr}}.template-form-page{width:100%;min-width:0}.template-form-title{margin:0 0 .5rem;font-size:1.5rem}.template-form-back{margin:0 0 1.5rem;font-size:.9375rem}.template-form-back a{color:#2563eb;text-decoration:none}.template-form-back a:hover{text-decoration:underline}.template-form-loading{color:#64748b}.template-form-error{padding:.75rem 1rem;margin-bottom:1rem;background:#fef2f2;color:#dc2626;border-radius:8px;font-size:.9375rem}.template-form-success{padding:.75rem 1rem;margin-bottom:1rem;background:#dcfce7;color:#166534;border-radius:8px;font-size:.9375rem}.template-form{width:100%;margin-bottom:2rem}.template-form-field{margin-bottom:1.25rem}.template-form-field--row{margin-bottom:1rem}.template-form-label{display:block;font-weight:500;font-size:.9375rem;color:#334155;margin-bottom:.35rem}.template-form-label--checkbox{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:400}.template-form-label--checkbox input{width:auto}.template-form-input{width:100%;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9375rem}.template-form-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.template-form-input:disabled{background:#f8fafc;color:#64748b}.template-form-textarea{width:100%;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9375rem;font-family:inherit;resize:vertical}.template-form-textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.template-form-textarea--code{font-family:ui-monospace,monospace;font-size:.8125rem}.template-form-hint{display:block;margin-top:.25rem;font-size:.8125rem;color:#64748b}.template-form-hint code{background:#f1f5f9;padding:.1rem .3rem;border-radius:4px;font-size:.75rem}.template-form-tabs{display:flex;gap:.25rem;margin-bottom:.75rem}.template-form-tab{padding:.4rem .75rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem;color:#475569;cursor:pointer}.template-form-tab:hover{background:#e2e8f0}.template-form-tab--active{background:#2563eb;border-color:#2563eb;color:#fff}.template-form-actions{margin-top:1.5rem;display:flex;flex-wrap:wrap;gap:.75rem}.template-form-btn{padding:.5rem 1rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;font-size:.9375rem;color:#475569;cursor:pointer}.template-form-btn:hover:not(:disabled){background:#e2e8f0;color:#1e293b}.template-form-btn--primary{background:#2563eb;border-color:#2563eb;color:#fff}.template-form-btn--primary:hover:not(:disabled){background:#1d4ed8;border-color:#1d4ed8;color:#fff}.template-form-btn:disabled{opacity:.6;cursor:not-allowed}.template-form-preview{border-top:1px solid #e2e8f0;padding-top:1.5rem;width:100%}.template-form-preview-title{margin:0 0 .5rem;font-size:1.25rem}.template-form-preview-hint{margin:0 0 .75rem;font-size:.875rem;color:#64748b}.template-form-preview textarea{margin-bottom:.75rem}.template-form-preview .template-form-btn{margin-bottom:1rem}.template-form-preview-result{margin-top:1rem;padding:1rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.template-form-preview-result p{margin:0 0 .75rem;font-size:.9375rem}.template-form-preview-iframe-wrap{border:1px solid #e2e8f0;border-radius:6px;overflow:hidden;background:#fff}.template-form-preview-iframe{display:block;width:100%;min-height:300px;height:400px;border:none}.analytics-page{width:100%;min-width:0}.analytics-title{margin:0 0 .5rem;font-size:1.5rem}.analytics-intro{margin:0 0 1.5rem;color:#64748b;font-size:.9375rem;line-height:1.5}.analytics-filters{display:flex;flex-wrap:wrap;align-items:flex-end;gap:1rem;margin-bottom:1.5rem}.analytics-label{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem;font-weight:500;color:#334155}.analytics-input{padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9375rem}.analytics-btn{padding:.5rem 1rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;font-size:.9375rem;color:#475569}.analytics-btn:hover:not(:disabled){background:#e2e8f0;color:#1e293b}.analytics-btn:disabled{opacity:.6;cursor:not-allowed}.analytics-error{padding:.75rem 1rem;margin-bottom:1rem;background:#fef2f2;color:#dc2626;border-radius:8px;font-size:.9375rem}.analytics-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;margin-bottom:1.5rem}.analytics-card{background:#fff;border-radius:12px;padding:1rem;box-shadow:0 1px 3px #00000014;display:flex;flex-direction:column;gap:.25rem}.analytics-card-value{font-size:1.5rem;font-weight:700;color:#1e293b}.analytics-card-label{font-size:.8125rem;color:#64748b}.analytics-tables{display:flex;flex-direction:column;gap:1.5rem}.analytics-table-wrap{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;overflow:hidden}.analytics-section-title{margin:0;padding:1rem 1.25rem;font-size:1.125rem;font-weight:600;background:#f8fafc;border-bottom:1px solid #f1f5f9;color:#1e293b}.analytics-scroll{overflow:auto;-webkit-overflow-scrolling:touch}.analytics-empty{padding:2rem;text-align:center;color:#64748b;margin:0;font-size:.9375rem}.analytics-table{width:100%;min-width:400px;border-collapse:collapse;font-size:.875rem}.analytics-table th,.analytics-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #f1f5f9}.analytics-table th{background:#f8fafc;font-weight:600;color:#475569}.analytics-table tr:last-child td{border-bottom:none}.analytics-code{font-size:.8125rem;background:#f1f5f9;padding:.2rem .4rem;border-radius:4px}.analytics-status--ok{color:#166534}.analytics-status--error{color:#dc2626}.analytics-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.75rem 1rem;padding:.75rem 1rem;border-top:1px solid #f1f5f9}.analytics-pagination-info{font-size:.8125rem;color:#64748b}@media(max-width:640px){.analytics-title{font-size:1.25rem}.analytics-table th,.analytics-table td{padding:.5rem .75rem;font-size:.8125rem}}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5;color:#1a1a1a;background:#f5f5f5;overflow-x:hidden}#root{min-height:100vh;min-height:100dvh}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}a{color:#2563eb;text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;cursor:pointer}input{font:inherit}
