:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f5f7fa;--panel:#fff;--panel-soft:#fafbfc;--text:#1a1a2e;--muted:#6b7280;--line:#e5e7eb;--primary:#3b82f6;--primary-light:#eff6ff;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--shadow:0 4px 6px -1px #0000000d, 0 2px 4px -1px #00000008;--shadow-lg:0 10px 15px -3px #0000000d, 0 4px 6px -2px #00000008;--sidebar-bg:#1e293b;--sidebar-hover:#334155;--sidebar-active:#ffffff1a;--content-gap:12px;--content-pad:12px;--sidebar-width:240px;--header-height:64px;--border-radius:16px;--border-radius-btn:8px}*{box-sizing:border-box}html,body{background:var(--bg);height:100%;color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,PingFang SC,Microsoft YaHei,sans-serif}a{color:inherit;text-decoration:none}button,input{font:inherit}.shell{height:100vh;min-height:100vh;display:flex;overflow:hidden}.auth-shell{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);place-items:center;min-height:100vh;padding:32px;display:grid}.auth-card{border-radius:var(--border-radius);background:#fffffffa;border:none;width:min(420px,100%);padding:40px;box-shadow:0 25px 50px -12px #00000040}.page-grid{height:100vh;min-height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--sidebar-bg);color:#e2e8f0;flex-direction:column;flex-shrink:0;height:100vh;display:flex;overflow:hidden}.sidebar-logo{height:var(--header-height);border-bottom:1px solid #ffffff0f;align-items:center;padding:0 24px;display:flex}.brand{letter-spacing:-.02em;color:#fff;align-items:center;gap:10px;font-size:22px;font-weight:700;display:flex}.brand-icon{background:linear-gradient(135deg, var(--primary) 0%, #8b5cf6 100%);border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;font-weight:700;display:flex}.sidebar-nav{scrollbar-width:thin;scrollbar-color:#94a3b861 transparent;flex:1;padding:16px 12px;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background:#94a3b847;border-radius:999px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#cbd5e175}.sidebar-bottom{border-top:1px solid #ffffff0f;padding:12px}.nav-list{flex-direction:column;gap:4px;display:flex}.nav-item{border-radius:var(--border-radius-btn);color:#94a3b8;cursor:pointer;align-items:center;gap:12px;padding:12px 16px;font-size:14px;font-weight:500;transition:all .2s;display:flex;position:relative}.nav-item:hover{background:var(--sidebar-hover);color:#e2e8f0}.nav-item.active{background:var(--sidebar-active);color:#f8fafc}.nav-label{font-size:14px;font-weight:500}.nav-group{gap:4px;display:grid}.nav-group summary{padding-right:10px;list-style:none}.nav-group summary::-webkit-details-marker{display:none}.nav-group-caret{color:#cbd5e1;border-radius:6px;justify-content:center;align-items:center;width:24px;min-width:24px;height:24px;margin-left:auto;transition:transform .2s;display:inline-flex}.nav-group-summary:hover .nav-group-caret{color:#fff}.nav-group[open] .nav-group-caret{transform:rotate(90deg)}.nav-sub-list{gap:2px;padding-left:16px;display:grid}.nav-sub-item{min-height:38px;padding-block:9px;font-size:13px}.nav-sub-dot{flex-shrink:0;justify-content:center;align-items:center;width:8px;height:22px;display:inline-flex;position:relative}.nav-sub-dot:before{content:"";opacity:.65;transform-origin:50%;background:currentColor;border-radius:999px;width:6px;height:6px;transition:width .18s,height .18s,opacity .18s,background-color .18s}.nav-sub-item.active .nav-sub-dot:before{opacity:1;background:#93c5fde6;width:4px;height:22px}.main{background:var(--bg);flex-direction:column;flex:1;min-width:0;height:100vh;display:flex;overflow:hidden}.topbar{height:var(--header-height);min-height:var(--header-height);padding:0 var(--content-pad);background:var(--panel);border-bottom:1px solid var(--line);z-index:20;flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.topbar-left{align-items:center;gap:16px;display:flex}.topbar-title{color:var(--text);font-size:18px;font-weight:600}.topbar-actions{align-items:center;gap:12px;display:flex}.admin-name{color:var(--text);font-size:13px;font-weight:600}.topbar-button{border-radius:var(--border-radius-btn);border:1px solid var(--line);background:var(--panel);width:36px;height:36px;color:var(--muted);cursor:pointer;justify-content:center;align-items:center;padding:0;font-size:16px;transition:all .2s;display:inline-flex}.topbar-button:hover{background:var(--panel-soft);color:var(--text);border-color:#d1d5db}.content{height:0;min-height:0;padding:var(--content-pad);flex-direction:column;flex:1 1 0;display:flex;overflow-y:auto}.content>section,.content>article{flex-shrink:0}.content>section:only-child,.content>article:only-child{flex-direction:column;flex:1;display:flex}.content>section:only-child>.panel-body:not(.table-panel-body),.content>article:only-child>.panel-body:not(.table-panel-body){flex:1;overflow-y:auto}body.admin-sidebar-compact{--sidebar-width:76px}body.admin-sidebar-compact .brand{justify-content:center}body.admin-sidebar-compact .brand .brand-icon{margin-right:0}body.admin-sidebar-compact .brand{font-size:0}body.admin-sidebar-compact .nav-item{justify-content:center}body.admin-sidebar-compact .nav-label{display:none}.card-grid{gap:var(--content-gap);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.metrics-grid{gap:var(--content-gap);margin-top:var(--content-gap);grid-template-columns:repeat(auto-fit,minmax(260px,1fr));display:grid}.chart-grid{gap:var(--content-gap);margin-top:var(--content-gap);grid-template-columns:repeat(auto-fit,minmax(320px,1fr));display:grid}.dashboard-hero{gap:var(--content-gap);margin-bottom:var(--content-gap);box-shadow:var(--shadow);background:radial-gradient(circle at 100% 0,#3b82f62e,#0000 34%),linear-gradient(135deg,#f7fbff 0%,#edf5ff 45%,#f8fbff 100%);border:1px solid #d9e7fb;border-radius:24px;grid-template-columns:minmax(0,1.6fr) minmax(320px,1fr);padding:22px 24px;display:grid}.dashboard-hero-copy h1{margin:8px 0 10px;font-size:32px;line-height:1.2}.dashboard-hero-copy p{color:#4b5563;max-width:760px;margin:0;line-height:1.7}.dashboard-hero-eyebrow{height:30px;color:var(--primary);letter-spacing:.08em;background:#3b82f61a;border-radius:999px;align-items:center;padding:0 12px;font-size:12px;font-weight:700;display:inline-flex}.dashboard-health{align-content:start;gap:12px;display:grid}.dashboard-health-item{border-radius:var(--border-radius);background:#ffffffd9;border:1px solid #d9e7fbf2;padding:14px 16px}.dashboard-health-item span{color:var(--muted);margin-bottom:8px;font-size:13px;display:block}.dashboard-health-item strong{font-size:18px}.dashboard-summary-grid{gap:var(--content-gap);grid-template-columns:repeat(auto-fit,minmax(230px,1fr));align-items:stretch;display:grid}.dashboard-summary-card{border-radius:var(--border-radius);box-shadow:var(--shadow);background:linear-gradient(#fff 0%,#fbfdff 100%);border:1px solid #dbe4efe6;flex-direction:column;justify-content:space-between;padding:18px;display:flex}.dashboard-summary-label{color:var(--muted);font-size:13px}.dashboard-summary-value{letter-spacing:-.03em;margin-top:10px;margin-bottom:auto;font-size:32px;font-weight:800}.dashboard-summary-meta{color:#475569;margin-top:8px;font-size:13px}.dashboard-main-grid,.dashboard-secondary-grid,.dashboard-detail-grid{gap:var(--content-gap);margin-top:var(--content-gap);align-items:stretch;display:grid}.dashboard-main-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.dashboard-secondary-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.dashboard-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-secondary-grid>*,.dashboard-detail-grid>*,.chart-grid>*{height:100%}.dashboard-panel{flex-direction:column;display:flex}.dashboard-panel>.panel-body,.chart-panel>.panel-body{flex:1}.dashboard-panel>.panel-body{flex-direction:column;display:flex}.dashboard-panel-wide{grid-column:1/-1}.dashboard-metric-list{gap:12px;display:grid}.dashboard-simple-metrics{grid-auto-rows:minmax(0,1fr);gap:12px;display:grid}.dashboard-simple-metric{border-radius:var(--border-radius);background:linear-gradient(#fff 0%,#f8fbff 100%);border:1px solid #e6edf6;flex-direction:column;justify-content:center;padding:14px 16px;display:flex}.dashboard-simple-metric span{color:var(--muted);font-size:13px;display:block}.dashboard-simple-metric strong{margin-top:8px;font-size:24px;display:block}.dashboard-metric-item{border-radius:var(--border-radius);background:linear-gradient(#fff 0%,#f8fbff 100%);border:1px solid #e6edf6;gap:6px;padding:14px 16px;display:grid}.dashboard-metric-item span,.dashboard-metric-item em{color:var(--muted);font-size:13px;font-style:normal}.dashboard-metric-item strong{font-size:24px;line-height:1.2}.distribution-list,.funnel-list,.insight-list,.todo-list,.activity-list{flex:1;gap:12px;display:grid}.funnel-list,.insight-list,.activity-list{align-content:stretch}.funnel-list{grid-auto-rows:minmax(0,1fr)}.insight-list,.activity-list{grid-auto-rows:minmax(72px,1fr)}.distribution-list{align-content:space-between}.distribution-row{gap:8px;display:grid}.distribution-head,.activity-item{justify-content:space-between;align-items:center;gap:12px;display:flex}.distribution-head span{color:#334155;font-size:13px}.distribution-head strong{font-size:14px}.distribution-track{background:#edf4ff;border-radius:999px;width:100%;height:10px;overflow:hidden}.distribution-fill{border-radius:inherit;background:linear-gradient(90deg,#3b82f6 0%,#38bdf8 100%);height:100%}.distribution-foot{color:var(--muted);font-size:12px}.dashboard-bar-chart{flex:1;grid-template-columns:repeat(5,minmax(0,1fr));align-items:end;gap:12px;min-height:240px;display:grid}.dashboard-bar-item{text-align:center;grid-template-rows:1fr auto auto;gap:8px;min-width:0;display:grid}.dashboard-bar-track{background:#edf4ff;border-radius:8px;height:100%;min-height:160px;position:relative;overflow:hidden}.dashboard-bar-fill{background:linear-gradient(#2563eb 0%,#38bdf8 100%);border-radius:8px 8px 0 0;position:absolute;bottom:0;left:0;right:0}.dashboard-bar-item strong{font-size:16px}.dashboard-bar-item span{color:var(--muted);font-size:12px;line-height:1.3}.dashboard-donut-layout{grid-template-columns:150px minmax(0,1fr);align-items:center;gap:18px;min-height:240px;display:grid}.dashboard-donut{width:150px;height:150px}.dashboard-donut-value{fill:#0f172a;font-size:18px;font-weight:800}.dashboard-donut-label{fill:var(--muted);font-size:11px}.dashboard-donut-legend{align-content:center;gap:10px;display:grid}.dashboard-donut-legend-item,.dashboard-status-item{grid-template-columns:10px minmax(0,1fr) auto;align-items:center;gap:8px;display:grid}.dashboard-donut-legend-item i,.dashboard-status-item i{border-radius:999px;width:10px;height:10px}.dashboard-donut-legend-item span,.dashboard-status-item span{color:#334155;min-width:0;font-size:13px}.dashboard-donut-legend-item strong,.dashboard-status-item strong{font-size:13px}.dashboard-stacked-bar{background:#edf4ff;border-radius:999px;width:100%;height:28px;display:flex;overflow:hidden}.dashboard-stacked-bar div{min-width:0}.dashboard-status-grid{flex:1;align-content:space-between;gap:12px;margin-top:18px;display:grid}.dashboard-status-item{grid-template-columns:10px minmax(0,1fr) auto auto}.dashboard-status-item em{color:var(--muted);font-size:12px;font-style:normal}.funnel-item,.insight-item{border-radius:var(--border-radius);background:linear-gradient(#fff 0%,#f8fbff 100%);border:1px solid #e6edf6;padding:14px 16px}.funnel-top{justify-content:space-between;align-items:center;gap:12px;display:flex}.funnel-top span{color:var(--muted);font-size:13px}.funnel-top strong{font-size:22px}.funnel-track{background:#ecfdf5;border-radius:999px;width:100%;height:12px;margin-top:10px;overflow:hidden}.funnel-fill{border-radius:inherit;background:linear-gradient(90deg,#10b981 0%,#34d399 100%);height:100%}.funnel-foot{color:var(--muted);margin-top:8px;font-size:12px}.insight-item strong{font-size:14px;display:block}.insight-item p{color:#475569;margin:8px 0 0;font-size:13px;line-height:1.65}.insight-item.tone-success{background:#f0fdf4;border-color:#cdeed8}.insight-item.tone-warning{background:#fffbeb;border-color:#f8e2aa}.insight-item.tone-danger{background:#fef2f2;border-color:#f7caca}.todo-item{border-radius:var(--border-radius);border:1px solid #e5e7eb;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.todo-item span{color:#334155}.todo-item strong{font-size:22px}.todo-item.tone-success{background:#f0fdf4;border-color:#cdeed8}.todo-item.tone-warning{background:#fffbeb;border-color:#f8e2aa}.todo-item.tone-danger{background:#fef2f2;border-color:#f7caca}.activity-item{border-radius:var(--border-radius);background:#fff;border:1px solid #e6edf6;padding:14px 16px}.activity-main{gap:4px;display:grid}.activity-main strong{font-size:14px}.activity-main span{color:var(--muted);font-size:13px}.activity-side{justify-items:end;gap:6px;display:grid}.card,.panel{background:var(--panel);border-radius:var(--border-radius);box-shadow:var(--shadow);border:1px solid #dbe4efe6}.card{padding:var(--content-pad)}.card-label{color:var(--muted);font-size:14px}.card-value{margin-top:10px;font-size:30px;font-weight:700}.status-panel .panel-body{padding-top:18px}.status-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.status-item{border-radius:var(--border-radius-btn);background:linear-gradient(#f8fbff 0%,#f3f7fc 100%);border:1px solid #e6edf6;padding:14px}.status-item span{color:var(--muted);font-size:13px;display:block}.status-item strong{margin-top:8px;font-size:22px;display:block}.chart-panel{flex-direction:column;display:flex}.chart-panel .panel-body{flex-direction:column;padding-top:20px;display:flex}.trend-svg{flex:1;width:100%;height:clamp(180px,28vh,300px);display:block}.chart-grid-line{stroke:#e7eef7;stroke-width:1px}.chart-line{stroke:var(--primary);stroke-width:3px;stroke-linecap:round;stroke-linejoin:round}.chart-dot{fill:#fff;stroke:var(--primary);stroke-width:3px}.chart-axis{grid-template-columns:repeat(auto-fit,minmax(44px,1fr));gap:8px;margin-top:12px;display:grid}.chart-axis-item{text-align:center}.chart-axis-item strong{font-size:14px;display:block}.chart-axis-item span{color:var(--muted);margin-top:4px;font-size:12px;display:block}.panel{overflow:hidden}.panel:has(>.table-panel-body){flex-direction:column;flex:1;min-height:0;display:flex}.panel-header{padding:var(--content-pad) var(--content-pad) 10px;border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;display:flex}.panel-header-left,.panel-header-right{align-items:center;gap:8px;display:flex}.panel-title{font-size:18px;font-weight:700;line-height:42px}.panel-body{padding:10px var(--content-pad) var(--content-pad)}.dashboard-panel>.panel-body{flex-direction:column;flex:1;display:flex}.table-panel-body{flex-direction:column;flex:1;min-height:0;display:flex}.input,.button{border-radius:var(--border-radius-btn);border:1px solid var(--line);height:42px}.input{background:#fff;min-width:160px;padding:0 14px}select.input{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2.5 4.5l3.5 3.5 3.5-3.5' fill='none' stroke='%236b7280' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:12px;padding-right:36px}.input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #3b82f61a}textarea.input{resize:vertical;height:auto;min-height:80px;font-family:inherit;font-size:inherit;padding:12px 14px;line-height:1.5}.button{background:var(--primary);color:#fff;border-color:var(--primary);cursor:pointer;white-space:nowrap;justify-content:center;align-items:center;padding:0 16px;line-height:1;text-decoration:none;display:inline-flex}.button.secondary{background:var(--panel-soft);color:var(--text);border-color:var(--line)}.button.danger{color:var(--danger);background:#fff1f1;border-color:#f8caca}.button.warning{color:#b7791f;background:#fff7e8;border-color:#f2d39a}.button:disabled,.button[disabled]{color:#9ca3af;cursor:not-allowed;box-shadow:none;opacity:1;background:#f3f4f6;border-color:#e5e7eb}.button.secondary:disabled,.button.secondary[disabled],.button.danger:disabled,.button.danger[disabled],.button.warning:disabled,.button.warning[disabled]{color:#9ca3af;background:#f3f4f6;border-color:#e5e7eb}.input:disabled,.input[disabled]{color:#9ca3af;cursor:not-allowed;background:#f8fafc}.table{border-collapse:collapse;width:100%}.table th,.table td{text-align:center;vertical-align:middle;border-bottom:1px solid #edf2f7;max-width:280px;padding:14px 10px;font-size:14px;overflow:hidden}.table th{color:var(--muted);font-weight:600}.table-cell-main{color:var(--text);font-weight:600}.table-cell-sub{color:var(--muted);margin-top:4px;font-size:12px;line-height:1.5}.table-cell-sub.compact{margin-top:2px}.table-code{font-family:Consolas,Courier New,monospace}.table-wrap-cell{white-space:normal}.table-index-cell{width:72px;min-width:72px;text-align:center!important}.badge{border-radius:var(--border-radius-btn);align-items:center;padding:6px 10px;font-size:12px;font-weight:700;display:inline-flex}.badge.success,.badge.is-success{color:var(--success);background:#e9f8ef}.badge.warning,.badge.is-warning{color:var(--warning);background:#fff4dd}.badge.danger,.badge.is-danger{color:var(--danger);background:#feecec}.meta{color:var(--muted);font-size:13px}.backend-state{background:var(--panel);border-radius:var(--border-radius-btn);box-shadow:var(--shadow);border:1px solid #dbe4efe6;max-width:720px;padding:28px}.backend-state.compact{border-radius:var(--border-radius);background:#fffaf1;margin-top:20px;padding:18px 20px}.backend-badge{border-radius:var(--border-radius-btn);color:var(--warning);background:#fff4dd;align-items:center;padding:6px 10px;font-size:12px;font-weight:700;display:inline-flex}.backend-title{margin:16px 0 10px;font-size:28px}.backend-desc{color:var(--muted);margin:0;line-height:1.7}.backend-code{border-radius:var(--border-radius);color:#f5f8fc;background:#102038;margin-top:18px;padding:12px 14px;font-family:Consolas,Courier New,monospace;display:inline-block}.offline-banner{padding:var(--content-pad);margin-bottom:var(--content-gap);border-radius:var(--border-radius);background:#fffaf1;border:1px solid #fde7b3;align-items:flex-start;gap:14px;display:flex}.offline-title{margin-bottom:6px;font-weight:700}.customapp-config-banner{width:100%;margin-bottom:var(--content-gap);border-radius:var(--border-radius);box-shadow:var(--shadow);background:linear-gradient(90deg,#fffaf1 0%,#fffdf8 100%);border:1px solid #fde7b3;padding:22px 24px}.customapp-config-banner-badge{border-radius:var(--border-radius-btn);color:var(--warning);background:#fff4dd;align-items:center;padding:6px 10px;font-size:12px;font-weight:700;display:inline-flex}.customapp-config-banner-text{color:var(--muted);margin:12px 0 0;line-height:1.8}.empty-state{color:var(--muted);padding:18px 0 4px}.table-empty-state{min-height:280px;color:var(--muted);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:48px 16px;display:flex}.table-empty-icon{color:#7c8da5;background:#f3f7fc;border:1px solid #e3ebf6;border-radius:50%;justify-content:center;align-items:center;width:54px;height:54px;display:flex}.table-empty-text{color:var(--muted);font-size:14px;font-weight:600}.captcha-row{align-items:center;gap:12px;display:flex}.captcha-input{text-transform:uppercase;flex:1;min-width:100px}.captcha-image{border-radius:var(--border-radius);border:1px solid var(--line);cursor:pointer;background:#fff;justify-content:center;align-items:center;width:120px;height:42px;padding:0;display:flex;overflow:hidden}.captcha-image:hover{border-color:var(--primary)}.captcha-image:disabled{cursor:wait;opacity:.7}.captcha-image svg{width:100%;height:100%}.row-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;display:flex}.button.small{height:34px;padding:0 12px}.action-menu{display:inline-flex;position:relative}.action-menu-panel{z-index:70;border-radius:var(--border-radius-btn);width:160px;box-shadow:var(--shadow-lg);background:#fff;border:1px solid #dbe3ee;padding:6px;position:fixed}.action-menu-item{width:100%;min-height:34px;color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;padding:0 10px;font-size:13px;font-weight:600}.action-menu-item:hover:not(:disabled){background:#f4f7fb}.action-menu-item.warning{color:#b7791f}.action-menu-item.danger{color:var(--danger)}.action-menu-item:disabled{color:#a7b0bd;cursor:not-allowed}.modal-backdrop{z-index:50;background:#1020387a;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-card{background:var(--panel);border-radius:var(--border-radius);width:min(760px,100%);max-height:min(820px,100vh - 48px);box-shadow:var(--shadow-lg);border:1px solid #dbe4efe6;flex-direction:column;display:flex;overflow:hidden}.modal-card.chat-modal{width:min(960px,100%);height:calc(100vh - 48px);max-height:820px}.modal-card.chat-modal .modal-header{padding-bottom:var(--content-pad)}.modal-card.chat-modal .modal-body{flex-direction:column;flex:1;min-height:0;padding:0;display:flex;overflow:hidden}.modal-card.chat-modal .modal-footer{display:none}.modal-header{padding:var(--content-pad);border-bottom:1px solid var(--line);background:linear-gradient(#fff 0%,#fbfdff 100%);justify-content:space-between;align-items:center;gap:16px;display:flex}.modal-body{min-height:0;padding:var(--content-pad);flex:1;overflow-y:auto}.modal-card:has(.app-version-form) .modal-body{flex-direction:column;display:flex;overflow:hidden}:is(.modal-card:has(.app-version-form),.modal-card:has(.announcement-form)){width:min(860px,100%)}.modal-card:has(.announcement-form) .modal-body{flex-direction:column;display:flex;overflow:hidden}.modal-close{border-radius:var(--border-radius);background:var(--panel-soft);width:40px;height:40px;color:var(--muted);cursor:pointer;border:none;font-size:24px;line-height:1;transition:background .18s,border-color .18s,color .18s}.modal-close:hover{color:var(--text);background:#fff;border-color:#d3d9e3}.modal-footer{padding:var(--content-pad);border-top:1px solid var(--line);background:linear-gradient(#fbfdff 0%,#fff 100%);justify-content:space-between;align-items:center;gap:16px;display:flex}.modal-footer-actions{flex-shrink:0;justify-content:flex-end;gap:12px;display:flex}.chat-thread{flex-direction:column;flex:1;gap:14px;min-height:0;display:flex}.chat-thread-empty{flex:1}.chat-thread-list{flex:1;align-content:start;justify-items:stretch;gap:14px;min-height:0;padding:16px;display:grid;overflow-y:auto}.chat-thread-list-empty{place-items:center}.chat-row{align-self:start;display:flex}.chat-row.user{justify-content:flex-start}.chat-row.admin{justify-content:flex-end}.chat-row.system{justify-content:center}.chat-bubble-shell{justify-items:start;gap:6px;max-width:min(72%,640px);display:inline-grid}.chat-row.admin .chat-bubble-shell{justify-items:end;margin-left:auto}.chat-row.system .chat-bubble-shell{justify-items:center;max-width:100%}.chat-bubble-meta{color:var(--muted);gap:8px;font-size:12px;display:flex}.chat-row.admin .chat-bubble-meta{justify-content:flex-end}.chat-bubble{border-radius:var(--border-radius);white-space:pre-wrap;word-break:break-word;width:fit-content;max-width:100%;padding:12px 14px;line-height:1.7;display:inline-block;box-shadow:0 6px 12px #0f172a0a}.chat-bubble.user{color:var(--text);background:#fff;border:1px solid #dfe8f2;border-top-left-radius:6px}.chat-bubble.admin{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border-top-right-radius:6px}.chat-bubble.system{color:#475569;text-align:center;background:#eef2f7;border-radius:999px}.chat-compose-form{display:block}.chat-compose-input{resize:none;width:100%;min-width:0;min-height:112px}.chat-compose-panel{padding:var(--content-pad);flex-shrink:0;gap:12px;display:grid}.chat-compose-actions{justify-content:space-between;align-items:flex-end;gap:12px;display:flex}.chat-status-form{flex:none}.chat-status-select{min-width:150px;height:40px}.chat-send-button{align-self:flex-end;min-width:112px}.chat-compose-closed{gap:12px;display:grid}.chat-closed-note{border-radius:var(--border-radius);color:#8a5a12;background:#fff7e8;border:1px solid #f2d39a;padding:12px 14px;font-size:13px}.modal-feedback{color:#0000;flex:1;min-height:22px;font-size:13px;font-weight:600}.modal-feedback.success{color:var(--success)}.modal-feedback.error{color:var(--danger)}.modal-form{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;gap:14px;display:grid}.modal-form>*{min-width:0}.modal-form>.form-section,.modal-form>.form-info,.modal-form>.confirm-modal-actions{grid-column:1/-1}.modal-form>label:has(input[type=checkbox]){grid-column:1/-1}.modal-form>.form-field:has(textarea){grid-column:1/-1}.form-field{gap:8px;display:grid}.form-label-placeholder{visibility:hidden}.form-field-readonly{gap:8px;display:grid}.form-readonly-value{color:var(--muted);align-items:center;min-height:40px;font-size:13px;line-height:1.4;display:flex}.form-readonly-value-right{text-align:right;justify-content:flex-end}.form-label{color:var(--text);font-size:14px;font-weight:700}.form-required{color:var(--danger);margin-left:4px}.form-hint{color:var(--muted);font-size:12px}.form-section{border:1px solid var(--line);border-radius:var(--border-radius);background:#f9fbff;gap:10px;padding:14px;display:grid}.form-section-title{color:var(--text);font-size:14px;font-weight:700}.form-section-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.form-section-grid .form-field-full{grid-column:1/-1}.checkbox-row{min-height:36px;color:var(--text);align-items:center;gap:8px;font-size:14px;display:flex}.tag{color:#1d4ed8;background:#2563eb14;border-radius:999px;align-items:center;min-height:22px;margin:2px 4px 2px 0;padding:0 8px;font-size:12px;font-weight:600;display:inline-flex}.form-info{color:var(--muted);gap:6px;font-size:13px;display:grid}.form-info p{margin:0}.confirm-modal{gap:16px;display:grid}.confirm-modal-desc{color:var(--muted);margin:0;line-height:1.7}.confirm-modal-actions{justify-content:flex-end;gap:12px;display:flex}.section-stack{align-content:start;gap:16px;display:grid}.content-stack{gap:20px;display:grid}.settings-card{border:1px solid var(--line);border-radius:var(--border-radius);background:var(--panel);box-shadow:var(--shadow);padding:20px}.settings-card>.section-head{margin-bottom:0}.settings-card-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.settings-card-title{color:var(--text);font-size:15px;font-weight:700}.settings-card-desc{color:var(--muted);margin:-8px 0 12px;font-size:13px;line-height:1.6}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.field-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;display:grid}.summary-card{border-radius:var(--border-radius);background:#fff;border:1px solid #dfe8f2;padding:14px}.summary-label{color:var(--muted);font-size:13px}.summary-value{word-break:break-word;margin-top:8px;font-size:16px;font-weight:700}.action-bar{justify-content:space-between;align-items:center;gap:12px;margin-top:16px;display:flex}.section-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.section-title{font-size:18px;font-weight:700}.table-shell{border-radius:var(--border-radius);background:#fff;border:1px solid #dfe8f2;flex-direction:column;flex:1;min-height:360px;display:flex;overflow:auto}body.admin-table-compact .table th,body.admin-table-compact .table td{padding-top:8px;padding-bottom:8px}.table-shell .table{flex:none}.option-list{gap:12px;display:grid}.option-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.option-item{border-radius:var(--border-radius);background:#fff;border:1px solid #dfe8f2;align-items:center;gap:10px;min-height:44px;padding:12px 14px;display:flex}.option-item input{margin:0}.option-item span{color:var(--text);font-size:14px}.permission-group-list{gap:16px;display:grid}.permission-group{gap:10px;display:grid}.permission-group-title{border-bottom:1px solid var(--line);color:var(--muted);padding-bottom:8px;font-size:13px;font-weight:700}.permission-option-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;display:grid}.permission-option-item{align-items:flex-start;min-height:72px}.permission-option-item input{margin-top:3px}.permission-option-item span{gap:4px;line-height:1.35;display:grid}.permission-option-item strong{font-size:14px;font-weight:700}.permission-option-item small{color:var(--muted);font-size:12px;line-height:1.45}.permission-boundary{gap:12px;display:grid}.permission-boundary-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.permission-access-toggle{min-height:38px;color:var(--text);align-items:center;gap:8px;font-size:14px;font-weight:700;display:inline-flex}.permission-access-toggle input{margin:0}.permission-tab-list{scrollbar-width:thin;border-bottom:1px solid var(--line);gap:6px;padding-bottom:2px;display:flex;overflow-x:auto}.permission-tab{min-width:max-content;height:38px;color:var(--muted);cursor:pointer;background:0 0;border:1px solid #0000;border-bottom:none;border-radius:8px 8px 0 0;align-items:center;gap:8px;padding:0 12px;font-size:13px;font-weight:700;display:inline-flex}.permission-tab:hover{color:var(--text);background:#f8fbff}.permission-tab.active{color:var(--primary);border-color:var(--line);background:#fff;margin-bottom:-1px}.permission-tab em{color:#64748b;text-align:center;background:#eef2f7;border-radius:999px;min-width:28px;padding:2px 6px;font-size:11px;font-style:normal}.permission-tab.active em{background:var(--primary-light);color:var(--primary)}.permission-tab-panel{border:1px solid var(--line);border-radius:0 0 var(--border-radius-btn) var(--border-radius-btn);background:#fff;min-height:168px;padding:12px}.permission-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;display:grid}.permission-editor{flex-direction:column;flex:1;min-height:0;padding:0;display:flex}.permission-subject-controls{flex-wrap:wrap}.permission-subject-controls .input:first-child{width:140px}.permission-subject-controls .input:last-child{min-width:260px}.permission-subject-summary{justify-content:space-between;align-items:center;gap:12px;display:flex}.permission-subject-summary>div{gap:4px;display:grid}.permission-subject-summary .muted,.permission-product-row span{color:var(--muted);font-size:12px}.permission-panel-body{flex:1;min-height:0;overflow:auto}.permission-option{border-radius:var(--border-radius-btn);background:#fbfdff;border:1px solid #dfe8f2;align-items:flex-start;gap:10px;min-height:72px;padding:12px;display:flex}.permission-option input{margin-top:3px}.permission-option span{gap:4px;display:grid}.permission-option small{color:var(--muted);line-height:1.45}.permission-product-grid{gap:10px;display:grid}.permission-product-row{border-radius:var(--border-radius-btn);background:#fbfdff;border:1px solid #dfe8f2;justify-content:space-between;align-items:center;gap:16px;padding:12px;display:flex}.permission-product-row>div:first-child{gap:4px;display:grid}.permission-checks{flex-wrap:wrap;gap:10px;display:flex}.check-row{align-items:center;gap:8px;display:inline-flex}.check-row input{margin:0}.check-row.compact{border:1px solid var(--line);border-radius:var(--border-radius-btn);background:#fff;min-height:34px;padding:0 10px}.form-message{border-radius:var(--border-radius-btn);padding:10px 12px;font-size:14px}.form-message.success{color:#047857;background:#ecfdf5}.form-message.error{color:#b91c1c;background:#fef2f2}.permission-item{border-radius:var(--border-radius-btn);min-height:40px;color:var(--text);background:#fbfdff;border:1px solid #dfe8f2;align-items:center;gap:8px;padding:10px 12px;font-size:13px;font-weight:600;display:flex}.permission-item input{margin:0}.role-description-input{resize:none}.legal-panel-header,.legal-top-tabs{border-bottom:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:10px}.legal-top-tabs{flex-shrink:0;display:flex}.legal-top-tabs .row-actions{margin-bottom:8px}.legal-layout{flex-direction:column;flex:1;gap:8px;min-height:0;display:flex;overflow:hidden}.content>section:only-child>.legal-layout,.content>article:only-child>.legal-layout{overflow:hidden}.legal-layout>.content-stack{flex:1;min-height:0;padding-right:4px;overflow-y:auto}.tab-list{flex-wrap:wrap;flex-shrink:0;gap:2px;display:flex}.tab-button{cursor:pointer;height:40px;color:var(--muted);background:0 0;border:1px solid #0000;border-bottom:none;border-radius:10px 10px 0 0;align-items:center;gap:8px;margin-bottom:-1px;padding:0 18px;transition:color .18s,background .18s,border-color .18s;display:inline-flex;position:relative}.tab-button:hover{color:var(--text);background:#3b82f60a}.tab-button.active{color:var(--primary);border-color:var(--line);background:var(--panel);z-index:1}.tab-button.active:after{content:"";background:var(--panel);height:2px;position:absolute;bottom:-1px;left:0;right:0}.tab-title{font-size:14px;font-weight:600}.tab-meta{color:var(--muted);background:#0000000d;border-radius:6px;padding:2px 6px;font-size:11px}.tab-button.active .tab-meta{color:var(--primary);background:#3b82f61a}.legal-editor-shell{flex-direction:column;flex:1;gap:12px;min-height:0;display:flex}.legal-top-bar{gap:var(--content-gap);flex-shrink:0;grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:center;display:grid}.legal-history-panel{gap:12px;display:grid}.legal-workspace{gap:var(--content-gap);flex:1;grid-template-columns:minmax(0,1fr) minmax(0,1fr);min-height:0;display:grid}.legal-editor-panel,.legalpreview-panel{flex-direction:column;flex:1;gap:12px;min-height:0;display:flex}.legal-textarea{resize:none;width:100%;min-height:0;color:var(--text);background:#fbfdff;border:none;flex:1;padding:14px;font:13px/1.7 Consolas,Courier New,monospace}.legal-textarea:focus{outline:none}.legalpreview-frame{background:#fff;border:none;flex:1;width:100%;min-height:0}.legalpreview-title{color:var(--muted);font-size:13px;font-weight:700}.legalpreview-header{justify-content:flex-end;align-items:center;gap:12px;display:flex}.legal-title-input{min-width:0}.legal-history-list{gap:10px;display:grid}.app-version-form{flex-direction:column;flex:1;gap:12px;min-height:0;display:flex}.form-row{flex-shrink:0;gap:12px;width:100%;display:grid}.form-row-two{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.form-row-full{flex:1;grid-template-columns:minmax(0,1fr);min-height:0}.form-row-full .form-field{flex-direction:column;min-height:0;display:flex}.form-row-full .form-field textarea.input{resize:none;flex:1;min-height:120px;max-height:100%;overflow-y:auto}.form-inline-pair{grid-template-columns:minmax(0,1.6fr) minmax(120px,.8fr);gap:8px;display:grid}.copy-inline-field{grid-template-columns:minmax(0,1fr) 40px;align-items:center;gap:8px;display:grid}.copy-icon-button{color:#51657b;cursor:pointer;background:#f8fbff;border:1px solid #d6e1ee;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;transition:background .2s,color .2s,border-color .2s;display:inline-flex}.copy-icon-button:hover:not(:disabled){color:#114a9f;background:#edf4ff;border-color:#bfd3ef}.copy-icon-button:disabled{opacity:.45;cursor:not-allowed}.copy-icon-button.copied{color:#16703a;background:#edf9f0;border-color:#b7e0c1}.app-version-textarea{resize:none;width:100%}.announcement-form{flex:1;min-height:0}.announcement-pin-field{align-content:start}.modal-form>label.announcement-pin-field:has(input[type=checkbox]){grid-column:auto}.announcement-pin-option{min-height:40px;color:var(--text);justify-self:start;align-items:center;gap:8px;font-size:14px;font-weight:600;display:inline-flex}.announcement-form .markdown-editor-field{height:360px;min-height:300px}.markdown-editor-field{flex-direction:column;gap:8px;min-height:0;display:flex}.modal-form>.markdown-editor-field{grid-column:1/-1}.markdown-editor-shell{border:1px solid var(--line);border-radius:var(--border-radius-btn);background:#fff;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.markdown-editor-shell.is-fullscreen{z-index:80;min-height:0;position:fixed;inset:16px;box-shadow:0 24px 60px #0f172a38}.markdown-editor-toolbar{border-bottom:1px solid var(--line);height:42px;color:var(--muted);background:#f8fbff;flex-shrink:0;justify-content:space-between;align-items:center;gap:10px;padding:0 10px 0 14px;font-size:13px;font-weight:700;display:flex}.markdown-editor-actions{align-items:center;gap:8px;display:flex}.markdown-source-input{resize:none;border:none;border-radius:0;flex:1;width:100%;min-width:0;min-height:0;max-height:none;font:13px/1.7 Consolas,Courier New,monospace;overflow-y:auto}.markdown-editor-shell.is-fullscreen .markdown-source-input{font-size:14px}.markdown-source-input:focus{box-shadow:none}.markdown-preview-panel{scrollbar-gutter:stable;flex:1;min-height:0;padding:14px;overflow-y:scroll}.app-version-form .markdown-editor-field,.form-row-full .markdown-editor-shell{flex:1}.markdown-preview{color:#273449;word-break:break-word;font-size:14px;line-height:1.75}.markdown-preview>:first-child{margin-top:0}.markdown-preview>:last-child{margin-bottom:0}.markdown-preview h1,.markdown-preview h2,.markdown-preview h3{color:var(--text);margin:16px 0 8px;line-height:1.35}.markdown-preview h1{font-size:22px}.markdown-preview h2{font-size:18px}.markdown-preview h3{font-size:15px}.markdown-preview p{margin:0 0 10px}.markdown-preview ul,.markdown-preview ol{margin:0 0 10px;padding-left:22px}.markdown-preview li+li{margin-top:4px}.markdown-preview blockquote{color:#475569;background:#f7fbff;border-left:3px solid #bfd3ef;margin:0 0 10px;padding:8px 12px}.markdown-preview img{border-radius:var(--border-radius-btn);background:#fff;border:1px solid #dbe6f2;max-width:100%;height:auto;margin:10px 0;display:block}.markdown-table-shell{border-radius:var(--border-radius-btn);border:1px solid #dbe6f2;width:100%;margin:0 0 12px;overflow-x:auto}.markdown-preview table{border-collapse:collapse;background:#fff;width:100%;min-width:420px}.markdown-preview th,.markdown-preview td{text-align:left;vertical-align:top;border-bottom:1px solid #edf2f7;border-right:1px solid #edf2f7;padding:9px 10px}.markdown-preview th:last-child,.markdown-preview td:last-child{border-right:none}.markdown-preview tbody tr:last-child td{border-bottom:none}.markdown-preview th{color:var(--text);background:#f8fbff;font-weight:700}.markdown-preview pre,.markdown-source-preview{border-radius:var(--border-radius-btn);color:#d7e5f5;white-space:pre-wrap;word-break:break-word;background:#0f1720;margin:0 0 10px;padding:12px;font:12px/1.7 Consolas,Courier New,monospace;overflow:auto}.markdown-preview code{color:#1d4f91;background:#edf4ff;border-radius:6px;padding:2px 5px;font-family:Consolas,Courier New,monospace;font-size:.92em}.markdown-preview pre code{color:inherit;font-size:inherit;background:0 0;padding:0}.markdown-preview a{color:var(--primary);text-underline-offset:3px;text-decoration:underline}.markdown-source-preview{color:#334155;background:#fbfdff;border:1px solid #dbe6f2;min-height:100%;margin:0}.markdown-empty{height:100%;min-height:120px;color:var(--muted);justify-content:center;align-items:center;font-size:13px;display:flex}.panel-body-dividerless{border-bottom:1px solid var(--line)}.build-log-panel{flex-direction:column;gap:12px;min-height:0;display:flex}.build-log-meta{color:var(--muted);flex-wrap:wrap;gap:10px 14px;font-size:13px;display:flex}.build-log-pre{color:#d7e5f5;white-space:pre-wrap;word-break:break-word;background:#0f1720;border:1px solid #dbe6f2;border-radius:14px;min-height:280px;max-height:60vh;margin:0;padding:14px;font:12px/1.6 Consolas,Courier New,monospace;overflow:auto}.legal-history-row{justify-content:space-between;gap:var(--content-gap);padding:12px var(--content-pad);border-radius:var(--border-radius);background:#fff;border:1px solid #e6edf6;align-items:center;display:flex}.legal-history-row strong{margin-bottom:4px;display:block}.pagination{padding:16px var(--content-pad);border-top:1px solid var(--line);justify-content:center;align-items:center;gap:16px;display:flex}.page-info{color:var(--muted);font-size:14px}@media (max-width:960px){.shell,.page-grid,.sidebar,.main{height:auto}.page-grid{grid-template-columns:1fr;overflow:visible}.sidebar{border-right:none;position:static;overflow:visible}.main{padding:0 var(--content-pad) var(--content-pad);overflow:visible}.topbar{margin:0 calc(-1 * var(--content-pad)) var(--content-gap);padding:0 var(--content-pad);position:sticky}.status-grid,.dashboard-hero,.dashboard-detail-grid{grid-template-columns:1fr}.dashboard-hero-copy h1{font-size:26px}.activity-item,.distribution-head{flex-direction:column;align-items:flex-start}.activity-side{justify-items:start}.dashboard-donut-layout{grid-template-columns:1fr;justify-items:center}.dashboard-donut-legend{width:100%}.dashboard-bar-chart{gap:8px}.legal-workspace,.form-row-two,.form-inline-pair,.modal-form,.form-section-grid{grid-template-columns:1fr}.chat-compose-form{display:block}.chat-compose-actions{flex-direction:column;align-items:stretch}.chat-status-form,.chat-status-select,.chat-send-button{width:100%}.chat-bubble-shell{max-width:100%}.form-readonly-value-right{text-align:left;justify-content:flex-start}.modal-form>.form-section,.modal-form>.form-info,.modal-form>.confirm-modal-actions,.modal-form>.markdown-editor-field{grid-column:auto}.modal-form>label:has(input[type=checkbox]){grid-column:auto}.modal-form>.form-field:has(textarea){grid-column:auto}.markdown-editor-shell{min-height:260px}.markdown-editor-shell.is-fullscreen{inset:8px}.announcement-form .markdown-editor-field{height:320px}.action-bar,.section-head{flex-direction:column;align-items:stretch}.legal-textarea,.legalpreview-frame{min-height:320px}}
