:root{--blue: #2b6cb0;--card: #2f2f2f;--text: #e9e9e9;--muted: #cfd8e3;--btn: #2b6cb0;--btn-hover: #245a93}.login-page{min-height:100%;display:grid;place-items:center;background:var(--blue);padding:24px}.login-card{width:360px;background:var(--card);border-radius:6px;padding:28px 28px 32px;box-shadow:0 10px 30px #00000059;display:flex;flex-direction:column;align-items:center}.login-logo{width:220px;height:auto;margin-bottom:18px;-webkit-user-select:none;user-select:none}.login-form{width:100%;display:grid;grid-template-columns:1fr;gap:10px}.login-label{color:var(--text);font-size:15px;margin-top:4px}.login-input{width:100%;height:42px;border:1px solid #3e3e3e;background:#fff;border-radius:3px;padding:0 10px;font-size:15px;outline:none}.login-input:focus{border-color:#5a9bf6;box-shadow:0 0 0 3px #5a9bf640}.login-error{margin-top:6px;padding:8px 10px;background:#ffebee;color:#b71c1c;border:1px solid #ffcdd2;border-radius:4px;font-size:14px}.login-button{margin-top:6px;height:44px;border:none;border-radius:4px;font-size:16px;font-weight:600;color:#fff;background:var(--btn);cursor:pointer}.login-button:hover{background:var(--btn-hover)}.login-button:disabled{opacity:.6;cursor:not-allowed}.disp-page{padding:16px}.disp-header{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:12px 16px;margin-bottom:8px}.disp-header h1{margin:0;font-size:22px;font-weight:600;color:#1f2937}.disp-header .primary{background:#2563eb;color:#fff;border:none;border-radius:6px;padding:10px 14px;font-weight:600;cursor:pointer}.disp-header .primary:hover{background:#1d4ed8}.disp-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.disp-table{width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed;font-size:14px}.disp-table thead th{background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:0;text-align:left}.th-filter{display:flex;gap:6px;width:100%;padding:10px 12px;background:transparent;border:0;cursor:pointer;color:#111827}.th-filter.active{color:#2563eb}.disp-table tbody td{border-bottom:1px solid #e5e7eb;padding:10px 12px;color:#111827;vertical-align:top}.disp-table tbody tr:hover{background:#fafafa}.disp-table th,.disp-table td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.disp-table th:nth-child(1),.disp-table td:nth-child(1){width:14%}.disp-table th:nth-child(2),.disp-table td:nth-child(2){width:36%}.disp-table th:nth-child(3),.disp-table td:nth-child(3){width:8%;text-align:center}.disp-table th:nth-child(4),.disp-table td:nth-child(4){width:16%}.disp-table th:nth-child(5),.disp-table td:nth-child(5){width:16%}.disp-table th:nth-child(6),.disp-table td:nth-child(6){width:10%}.td-actions{display:flex;gap:8px;justify-content:flex-start}.disp-pager{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 16px}.disp-pager button{width:36px;height:36px;border:1px solid #e5e7eb;background:#fff;border-radius:6px;cursor:pointer}.disp-pager button:disabled{opacity:.6;cursor:not-allowed}.empty-cell{text-align:center;color:#6b7280;padding:24px 12px}.emoji-anchor{position:relative;display:inline-block}.emoji-btn{border:1px solid var(--stroke);background:#fff;border-radius:8px;padding:6px 10px;cursor:pointer;margin-right:8px}.emoji-popover{position:absolute;top:42px;left:0;z-index:1200;background:#fff;border:1px solid var(--stroke);border-radius:8px;box-shadow:0 8px 28px #10182833;overflow:hidden}.emoji-popover-fixed{position:fixed;z-index:10000;background:#fff;border:1px solid var(--stroke);border-radius:8px;box-shadow:0 8px 28px #10182833;overflow:hidden;pointer-events:auto}.modal-card{display:flex;flex-direction:column}.modal-card.xl{width:980px;max-width:96vw;height:88vh;max-height:88vh}.modal-header,.modal-footer{flex:0 0 auto}.modal-body{flex:1 1 auto;overflow:auto;min-height:0}.msg-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:16px;min-height:0}.msg-textarea{min-height:200px;height:40vh;resize:vertical}.attach-preview img{max-width:100%;max-height:32vh;border-radius:8px}.emoji-popover{z-index:1200}.th-actions{padding:10px 12px;width:120px}.disp-table th:nth-child(6),.disp-table td:nth-child(6){width:120px}.td-actions{display:flex;gap:8px;align-items:center;justify-content:flex-start;white-space:nowrap}.icon-btn{border:1px solid #e5e7eb;background:#fff;border-radius:6px;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.icon-btn.danger{border-color:#fecaca}.disp-header button{background:var(--btn);color:#fff;border:none;border-radius:6px;padding:10px 14px;font-weight:600;cursor:pointer}.modal-backdrop{position:fixed;inset:0;background:#00000059;display:grid;place-items:center;z-index:50}.modal-card{width:520px;max-width:94vw;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 20px 50px #00000040;animation:pop .15s ease-out}@keyframes pop{0%{transform:translateY(8px);opacity:.8}to{transform:none;opacity:1}}.modal-header{padding:14px 16px;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:18px}.modal-body{padding:12px 16px;max-height:60vh;overflow:auto}.modal-footer{padding:12px 16px;border-top:1px solid #e5e7eb;display:flex;gap:10px;justify-content:flex-end}.modal-footer .primary{background:#2563eb;color:#fff;border:0;padding:8px 14px;border-radius:8px;font-weight:600;cursor:pointer}.modal-footer .primary:hover{background:#1d4ed8}.modal-footer .link{background:transparent;border:0;color:#374151;cursor:pointer}.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.form-row label{font-size:12px;color:#374151}.search{width:100%;height:36px;border:1px solid #e5e7eb;border-radius:8px;padding:0 10px}.options-list{display:grid;grid-template-columns:1fr;gap:6px}.opt{display:flex;align-items:center;gap:10px;padding:6px;border-radius:6px}.opt:hover{background:#f9fafb}.muted{color:#6b7280;font-size:13px}.hist-pills{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 12px}.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid #e5e7eb;border-radius:999px;background:#fff;font-size:12px}.pill button{border:0;background:transparent;cursor:pointer;font-size:14px;line-height:1}.modal-backdrop{position:fixed;inset:0;background:#11182773;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:saturate(120%) blur(2px);backdrop-filter:saturate(120%) blur(2px)}.modal-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 20px 40px #0000001f;max-height:calc(100vh - 80px);overflow:auto}.modal-sm{width:min(420px,calc(100vw - 32px))}.modal-lg,.modal-xl{width:min(720px,calc(100vw - 32px))}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid #eef2f7}.modal-header h2{margin:0;font-size:18px;font-weight:700;color:#111827}.modal-close{background:transparent;border:0;font-size:22px;line-height:1;cursor:pointer;color:#6b7280}.modal-close:hover{color:#111827}.modal-body{padding:16px 18px}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:12px 18px;border-top:1px solid #eef2f7}.btn{border:1px solid #e5e7eb;background:#fff;color:#111827;padding:9px 14px;border-radius:8px;font-weight:600;cursor:pointer}.btn.primary{background:#2563eb;border-color:#2563eb;color:#fff}.btn.primary:hover{background:#1d4ed8;border-color:#1d4ed8}.btn.link{background:transparent;border-color:transparent;color:#2563eb}.btn[disabled]{opacity:.65;cursor:not-allowed}.form-grid{display:grid;grid-template-columns:1fr;gap:14px 16px}@media (min-width: 720px){.form-grid{grid-template-columns:1fr 1fr}}.field{display:flex;flex-direction:column;gap:8px}.col-2{grid-column:1 / -1}.label{font-weight:600;color:#111827}.input{border:1px solid #e5e7eb;border-radius:10px;padding:10px 12px;outline:0;background:#fff;width:100%}.input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.radio-group{display:flex;gap:16px;flex-wrap:wrap}.radio{display:flex;align-items:center;gap:8px}.catpicker .chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid #c7d2fe;background:#eef2ff;color:#3730a3;border-radius:999px;font-size:12px}.chip button{border:0;background:transparent;cursor:pointer;color:inherit;font-weight:700;line-height:1}.options-list{display:flex;flex-direction:column;gap:8px;max-height:34vh;overflow:auto;border:1px solid #e5e7eb;border-radius:10px;padding:8px}.form-error{color:#b91c1c;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;padding:10px 12px;font-weight:600}.muted{color:#6b7280}.hist-page{min-height:100vh;background:var(--bg);padding:16px}.hist-header{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid var(--stroke);border-radius:8px;padding:12px 16px;margin-bottom:12px}.hist-header h1{margin:0;font-size:22px;font-weight:600;color:var(--title)}.hist-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.hist-header button{background:var(--btn);color:#fff;border:none;border-radius:6px;padding:10px 14px;font-weight:600;cursor:pointer}.hist-header button:hover{background:var(--btn-hover)}.hist-header .link{background:transparent;color:var(--btn);border:1px solid transparent;padding:10px 8px}.hist-header .link:hover{text-decoration:underline}.hist-pills{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:8px 0 12px}.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#eef2ff;border:1px solid #c7d2fe;color:#1e3a8a;font-size:12px}.pill button{border:0;background:transparent;cursor:pointer;font-weight:700;color:inherit}.hist-empty{background:#fff;border:1px solid var(--stroke);border-radius:8px;padding:24px;text-align:center;color:var(--muted);font-size:15px}.hist-card{background:var(--card);border:1px solid var(--stroke);border-radius:8px;overflow:hidden}.hist-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;table-layout:fixed}.hist-table thead th{background:#f9fafb;color:#111827;font-weight:600;border-bottom:1px solid var(--stroke);padding:0;text-align:left}.th-filter{display:flex;align-items:center;gap:6px;width:100%;padding:10px 12px;background:transparent;border:0;color:inherit;font:inherit;text-align:left;cursor:pointer}.hist-table tbody td{border-bottom:1px solid var(--stroke);padding:10px 12px;color:var(--text);vertical-align:top}.hist-table tbody tr:hover{background:#fafafa}.hist-table th:nth-child(1),.hist-table td:nth-child(1){width:180px}.hist-table th:nth-child(2),.hist-table td:nth-child(2){width:160px}.hist-table th:nth-child(3),.hist-table td:nth-child(3){width:140px}.hist-table th:nth-child(4),.hist-table td:nth-child(4){width:35%;min-width:240px}.hist-table th:nth-child(5),.hist-table td:nth-child(5){width:35%;min-width:240px}.hist-pager{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 16px}.hist-pager button{width:36px;height:36px;border:1px solid var(--stroke);background:#fff;border-radius:6px;cursor:pointer}.hist-pager button:disabled{opacity:.6;cursor:not-allowed}.hist-pager span{color:#374151}.hist-badge{display:inline-block;padding:2px 8px;font-size:12px;background:#eef2ff;border:1px solid #c7d2fe;color:#3730a3;border-radius:999px}.confirm-row{display:flex;align-items:flex-start;gap:10px}.confirm-row .confirm-ic{font-size:22px;margin-top:2px}.confirm-row.danger .confirm-ic{color:var(--danger)}.primary.danger{background:var(--danger)}.primary.danger:hover{background:var(--danger-h)}.toast-backdrop{position:fixed;inset:0;display:flex;align-items:flex-start;justify-content:center;padding-top:32px;pointer-events:none;z-index:60}.toast{background:#10b981;color:#fff;padding:12px 16px;border-radius:10px;box-shadow:0 10px 24px #00000040}.toast-title{font-weight:700}.toast-msg{opacity:.95;margin-top:4px}.msg-grid{display:grid;grid-template-columns:1fr 320px;gap:16px}.msg-editor{display:flex;flex-direction:column}.label{font-weight:600;margin-bottom:6px}.msg-textarea{min-height:240px;border:1px solid #e5e7eb;border-radius:8px;padding:12px;resize:vertical}.msg-toolbar{display:flex;gap:8px;margin-top:8px}.emoji-btn{position:relative;border:1px solid #e5e7eb;background:#fff;border-radius:6px;padding:6px 10px;cursor:pointer}.emoji-btn .emoji-pop{display:none;position:absolute;top:40px;left:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:6px;gap:6px}.emoji-btn:hover .emoji-pop{display:flex;flex-wrap:wrap;max-width:260px}.emoji-pop button{background:transparent;border:0;font-size:18px;padding:4px;cursor:pointer}.img-btn{border:1px solid #e5e7eb;background:#fff;border-radius:6px;padding:6px 10px;cursor:pointer}.attach-preview{margin-top:10px}.attach-preview img{max-width:240px;border:1px solid #e5e7eb;border-radius:8px}.msg-meta .field{margin-bottom:12px}.msg-preview-card{border:1px solid #e5e7eb;background:#fff;border-radius:8px;padding:10px;margin-bottom:12px}.msg-preview-title{font-weight:600;margin-bottom:6px;color:#1f2937}.msg-preview-body{white-space:pre-wrap;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;margin:0}.msg-preview-image{display:block;margin-top:8px;max-width:100%;border:1px solid #e5e7eb;border-radius:6px}.select select{width:100%;border:1px solid #e5e7eb;border-radius:6px;padding:8px}.form-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;padding:8px 10px;border-radius:6px}.muted.small{color:#6b7280;font-size:12px}.primary{background:#2563eb;color:#fff;border:none;border-radius:6px;padding:10px 14px;font-weight:600;cursor:pointer}.primary:hover{background:#1d4ed8}.form-actions{display:flex;gap:8px;justify-content:flex-end}.secondary{background:#e5e7eb;color:#1f2937;border:none;border-radius:6px;padding:10px 14px;font-weight:600;cursor:pointer}.secondary:hover{background:#d1d5db}:root{--sb: #2b6cb0;--bg: #f3f4f6;--link: #e5e7eb;--active: #ffffff;--stroke: #e5e7eb;--sb-w: 72px}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;overflow:hidden}.app-shell{height:100vh;display:grid;grid-template-columns:var(--sb-w) 1fr;overflow:hidden}.app-sidebar{width:var(--sb-w);height:100%;background:var(--sb);color:#fff;display:flex;flex-direction:column;align-items:stretch;padding:10px 8px;gap:8px;border-right:1px solid rgba(255,255,255,.15);transition:width .2s ease;overflow-y:auto;-webkit-overflow-scrolling:touch;min-height:0}.sb-toggle{height:36px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.4);background:transparent;color:#fff;border-radius:8px;cursor:pointer;transition:background .15s ease,transform .15s ease}.sb-toggle:hover{background:#ffffff26;transform:scale(1.02)}.sb-nav{display:flex;flex-direction:column;gap:6px;margin-top:6px;flex:1}.sb-link{display:flex;align-items:center;gap:10px;height:36px;padding:0 10px;border-radius:8px;color:var(--link);text-decoration:none;transition:background .15s ease,color .15s ease;white-space:nowrap;overflow:hidden}.sb-link:hover{background:#ffffff1f;color:#fff}.sb-link.active{background:#ffffff2e;color:var(--active);font-weight:600}.sb-link.disabled{opacity:.5;pointer-events:none}.sb-icon{min-width:18px;display:grid;place-items:center}.sb-text{opacity:0;transform:translate(6px);transition:opacity .18s ease,transform .18s ease}.sb-text.show{opacity:1;transform:translate(0)}.sb-logout{height:36px;display:flex;align-items:center;gap:10px;border:1px solid rgba(255,255,255,.4);background:transparent;color:#fff;border-radius:8px;cursor:pointer;padding:0 10px;transition:background .15s ease}.sb-logout:hover{background:#ffffff26}.app-main{height:100%;background:var(--bg);padding:16px;overflow:auto;-webkit-overflow-scrolling:touch;min-width:0;min-height:0}.app-container{min-height:100%}.header,.hist-header{position:sticky;top:0;z-index:1;background:#fff}@media (prefers-reduced-motion: reduce){.app-sidebar,.sb-text{transition:none}}:root{--bg: #f3f4f6;--card: #fff;--stroke: #e5e7eb;--title: #1f2937;--text: #111827;--btn: #2563eb;--btn-h: #1d4ed8;--muted: #6b7280}.cli-page{min-height:100vh;background:var(--bg);padding:16px}.cli-header{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid var(--stroke);border-radius:8px;padding:12px 16px;margin-bottom:8px}.cli-header h1{margin:0;font-size:22px;font-weight:600;color:var(--title)}.cli-actions{display:flex;gap:8px;flex-wrap:wrap}.cli-header button{background:var(--btn);color:#fff;border:none;border-radius:6px;padding:10px 14px;font-weight:600;cursor:pointer}.cli-header button:hover{background:var(--btn-h)}.cli-header .secondary{background:#475569}.cli-header .secondary:hover{background:#334155}.cli-header .link{background:transparent;color:var(--btn);border:1px solid var(--btn)}.cli-pills{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 12px}.cli-card{background:var(--card);border:1px solid var(--stroke);border-radius:8px;overflow:hidden}.cli-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;table-layout:fixed}.cli-table thead th{background:#f9fafb;color:#111827;font-weight:600;border-bottom:1px solid var(--stroke);padding:0;text-align:left}.cli-table tbody td{border-bottom:1px solid var(--stroke);padding:10px 12px;color:var(--text);vertical-align:top}.cli-table tbody tr:hover{background:#fafafa}.cli-table th:nth-child(1),.cli-table td:nth-child(1){width:40px}.cli-table th:nth-child(2),.cli-table td:nth-child(2){width:22%}.cli-table th:nth-child(3),.cli-table td:nth-child(3){width:14%}.cli-table th:nth-child(4),.cli-table td:nth-child(4){width:14%}.cli-table th:nth-child(5),.cli-table td:nth-child(5){width:26%}.cli-table th:nth-child(6),.cli-table td:nth-child(6){width:15%}.cli-table th:nth-child(7),.cli-table td:nth-child(7){width:25%}.cli-table th:nth-child(8),.cli-table td:nth-child(8){width:110px;white-space:nowrap}.cli-table th,.cli-table td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.icon-btn{border:1px solid var(--stroke);background:#fff;border-radius:6px;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.cli-pager{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 16px}.cli-pager button{width:36px;height:36px;border:1px solid var(--stroke);background:#fff;border-radius:6px;cursor:pointer}.cli-pager button:disabled{opacity:.6;cursor:not-allowed}.form-row .search{border:1px solid var(--stroke);border-radius:6px;padding:8px 10px;background:#fff;width:100%}.options-list{display:flex;flex-direction:column;gap:8px;max-height:40vh;overflow:auto;border:1px solid var(--stroke);border-radius:8px;padding:8px}.form-label .muted{font-weight:400;margin-left:4px}.userdb{border:1px solid var(--stroke);border-radius:8px;padding:10px;background:#fff}.userdb.disabled{opacity:.6;pointer-events:none}.userdb-list{display:flex;flex-direction:column;gap:6px;max-height:220px;overflow:auto;margin-top:6px}.userdb-item{display:flex;align-items:center;gap:8px;padding:6px;border:1px solid #f1f5f9;border-radius:6px}.userdb-item.selected{background:#f0f9ff;border-color:#bae6fd}.userdb-name{font-weight:600}.userdb-sep{opacity:.6}.userdb-actions{margin-top:8px;display:flex;justify-content:space-between;align-items:center;gap:8px}.userdb-actions .pager{display:flex;align-items:center;gap:8px}.summary{margin-top:8px}.chip-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;max-height:200px;overflow:auto}.chip{display:inline-flex;align-items:center;gap:6px;background:#eef2ff;border:1px solid #c7d2fe;color:#3730a3;border-radius:999px;padding:4px 10px;font-size:12px}.chip button{border:0;background:transparent;cursor:pointer;font-weight:700;color:inherit}.drop{border:1px dashed var(--stroke);border-radius:8px;padding:12px;text-align:center;background:#fff;margin:10px 0}.drop.drag{background:#f8fafc;border-color:#cbd5e1}.drop.disabled{opacity:.6;pointer-events:none}.file-btn input{display:none}.file-btn span{color:var(--btn);cursor:pointer}.paste-box{margin-top:8px}.paste-area{border:1px solid var(--stroke);border-radius:8px;width:100%;min-height:100px;padding:8px;background:#fff;resize:vertical}.paste-actions{display:flex;justify-content:flex-end;margin-top:6px}.paste-actions button{background:var(--btn);color:#fff;border:none;border-radius:6px;padding:8px 12px;font-weight:600;cursor:pointer}.paste-actions button:hover{background:var(--btn-h)}.modal-card.xl{width:min(1200px,96vw);max-width:1200px}.grp-form-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:18px}.grp-users h3{margin:0 0 6px}.divider{height:1px;background:var(--stroke);margin:12px 0}.form-label{width:140px;color:var(--text);font-weight:600}.search,.select select{border:1px solid var(--stroke);border-radius:6px;padding:8px 10px;background:#fff;width:100%}.tip{margin-top:6px}.tabs{display:flex;gap:8px;margin:6px 0}.tab{background:#fff;border:1px solid var(--stroke);border-radius:999px;padding:6px 10px;font-weight:600;color:#111827;display:inline-flex;align-items:center;font-size:13px}.tab.active{border-color:#cbd5e1}:root{--bg: #f3f4f6;--card: #fff;--stroke: #e5e7eb;--title: #1f2937;--text: #111827;--btn: #2563eb;--btn-h: #1d4ed8;--muted: #6b7280;--danger: #ef4444;--danger-h: #dc2626}.grp-page{min-height:100vh;background:var(--bg);padding:16px}.grp-header{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid var(--stroke);border-radius:8px;padding:12px 16px;margin-bottom:8px}.grp-header h1{margin:0;font-size:22px;font-weight:600;color:var(--title)}.grp-actions{display:flex;gap:8px;flex-wrap:wrap}.grp-actions button{background:var(--btn);color:#fff;border:none;border-radius:6px;padding:10px 14px;font-weight:600;cursor:pointer}.grp-actions button:hover{background:var(--btn-h)}.grp-actions .link{background:transparent;color:var(--btn);border:1px solid var(--btn)}.grp-pills{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 12px}.pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--stroke);color:#111827;border-radius:999px;padding:6px 10px;font-size:13px}.grp-card{background:var(--card);border:1px solid var(--stroke);border-radius:8px;overflow:hidden}.grp-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;table-layout:fixed}.grp-table thead th{background:#f9fafb;color:#111827;font-weight:600;border-bottom:1px solid var(--stroke);padding:0;text-align:left}.th-filter .caret{font-size:12px;opacity:.6}.th-filter.active{color:var(--btn)}.th-actions{padding:10px 12px}.grp-table tbody td{border-bottom:1px solid var(--stroke);padding:10px 12px;color:var(--text);vertical-align:top}.grp-table tbody tr:hover{background:#fafafa}.grp-table th:nth-child(1),.grp-table td:nth-child(1){width:28%}.grp-table th:nth-child(2),.grp-table td:nth-child(2){width:18%}.grp-table th:nth-child(3),.grp-table td:nth-child(3){width:26%}.grp-table th:nth-child(4),.grp-table td:nth-child(4){width:12%}.grp-table th:nth-child(5),.grp-table td:nth-child(5){width:10%}.grp-table th:nth-child(6),.grp-table td:nth-child(6){width:6%}.td-actions{display:flex;align-items:center;gap:10px;justify-content:center}.icon-btn{border:1px solid var(--stroke);background:#fff;border-radius:8px;width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px}.icon-btn.lg{width:44px;height:44px;font-size:22px}.icon-btn.danger{border-color:var(--danger);color:var(--danger)}.icon-btn.danger:hover{background:#fff0f0}.grp-pager{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 16px}.grp-pager button{width:36px;height:36px;border:1px solid var(--stroke);background:#fff;border-radius:6px;cursor:pointer}.grp-pager button:disabled{opacity:.6;cursor:not-allowed}.grp-empty{background:#fff;border:1px solid var(--stroke);border-radius:8px;padding:24px;text-align:center;color:var(--muted);font-size:15px}.modal-card.sm{max-width:460px}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.x-btn{border:1px solid var(--stroke);background:#fff;border-radius:8px;width:44px;height:44px;cursor:pointer;font-size:22px}.x-btn:hover{background:#f8fafc}:root{--tpl-bg: #f3f4f6;--tpl-card: #fff;--tpl-stroke: #e5e7eb;--tpl-title: #1f2937;--tpl-text: #111827;--tpl-btn: #2563eb;--tpl-btn-h: #1d4ed8;--tpl-muted: #6b7280}.tpl-page{min-height:100vh;background:var(--tpl-bg);padding:16px}.tpl-header{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid var(--tpl-stroke);border-radius:8px;padding:12px 16px;margin-bottom:8px}.tpl-header h1{margin:0;font-size:22px;font-weight:600;color:var(--tpl-title)}.tpl-actions{display:flex;gap:8px;flex-wrap:wrap}.btn{background:#475569;color:#fff;border:none;border-radius:6px;padding:10px 14px;font-weight:600;cursor:pointer}.btn:hover{filter:brightness(.95)}.btn.primary{background:var(--tpl-btn)}.btn.primary:hover{background:var(--tpl-btn-h)}.btn.link{background:transparent;color:var(--tpl-btn);border:1px solid var(--tpl-btn)}.tpl-pills{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 12px}.pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--tpl-stroke);color:#111827;border-radius:999px;padding:6px 10px;font-size:13px}.pill button{border:none;background:transparent;color:#6b7280;cursor:pointer;font-size:16px;line-height:1}.tpl-card{background:var(--tpl-card);border:1px solid var(--tpl-stroke);border-radius:8px;overflow:hidden}.tpl-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;table-layout:fixed}.tpl-table thead th{background:#f9fafb;color:#111827;font-weight:600;border-bottom:1px solid var(--tpl-stroke);padding:0;text-align:left}.th-filter{display:flex;align-items:center;gap:6px;width:100%;padding:10px 12px;background:transparent;border:0;color:inherit;font:inherit;text-align:left;cursor:pointer;white-space:nowrap;min-width:0}.th-filter .caret{font-size:12px;opacity:.6;transition:transform .15s ease,opacity .15s ease}.th-filter:hover{background:#f3f4f6}.th-filter.active{color:var(--tpl-btn)}.th-filter.active .caret{opacity:1}.th-actions{padding:10px 12px;white-space:nowrap}.tpl-table tbody td{border-bottom:1px solid var(--tpl-stroke);padding:10px 12px;color:var(--tpl-text);vertical-align:top}.tpl-table tbody tr:hover{background:#fafafa}.td-actions{display:flex;align-items:center;gap:8px}.icon-btn{border:1px solid var(--tpl-stroke);background:#fff;border-radius:6px;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.icon-btn svg{fill:#111827}.tag{display:inline-block;margin:2px 6px 2px 0;padding:2px 8px;font-size:12px;background:#eef2ff;border:1px solid #c7d2fe;color:#3730a3;border-radius:999px;white-space:nowrap}.tpl-pager{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 16px}.form-row{display:flex;gap:8px;margin-bottom:10px;align-items:center}.form-row .search{border:1px solid var(--tpl-stroke);border-radius:6px;padding:8px 10px;background:#fff;width:100%}.opt-col{display:flex;flex-direction:column;gap:10px}.opt{display:flex;align-items:center;gap:10px}.tpl-empty{color:var(--tpl-muted);padding:24px 12px}:root{--bg: #f3f4f6;--card: #fff;--stroke: #e5e7eb;--title: #1f2937;--text: #111827;--muted: #6b7280}.tmpl-grid{display:grid;grid-template-columns:1.75fr 1fr;gap:20px}.tmpl-col{display:flex;flex-direction:column;gap:14px}.tmpl-col.side{border-left:1px solid var(--stroke);padding-left:16px}.form-row{display:flex;gap:8px;align-items:flex-start}.form-row .form-label{width:140px;color:var(--text);font-weight:600;line-height:34px}.form-row input[type=text],.form-row input[type=file],.form-row select,.form-row textarea,.form-row input:not([type]),.msg-textarea{border:1px solid var(--stroke);background:#fff;border-radius:6px;padding:8px 10px;width:100%;color:var(--text)}.msg-textarea{min-height:160px;resize:vertical}.switch input{width:18px;height:18px}.btn-row{display:flex;flex-wrap:wrap;gap:6px}.var-toolbar{display:flex;align-items:center;gap:10px}.chip{border:1px solid #d1d5db;background:#f8fafc;border-radius:6px;padding:4px 8px;font-size:12px;cursor:pointer}.examples-card{border:1px solid var(--stroke);background:#fafafa;border-radius:8px;padding:10px}.examples-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr)) auto;gap:8px;align-items:start}.examples-th{font-size:12px;font-weight:600;color:var(--muted);text-align:center}.examples-td{border:1px solid var(--stroke);background:#fff;border-radius:6px;padding:6px 8px;font-size:13px}.icon-btn{border:1px solid var(--stroke);background:#fff;border-radius:6px;width:32px;height:32px;cursor:pointer}.icon-btn:hover{background:#f3f4f6}.secondary{border:1px solid var(--stroke);background:#fff;color:var(--text);border-radius:6px;padding:6px 10px;cursor:pointer}.secondary:hover{background:#f9fafb}.preview-card{border:1px solid var(--stroke);background:#fff;border-radius:8px;padding:12px}.preview-title{font-weight:600;margin-bottom:6px;color:var(--title)}.preview-body{white-space:pre-wrap;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;margin:0 0 8px}@media (max-width: 980px){.tmpl-grid{grid-template-columns:1fr}.tmpl-col.side{border-left:0;padding-left:0;border-top:1px solid var(--stroke);padding-top:14px}}@media (max-width: 560px){.form-row{flex-direction:column;align-items:stretch}.form-row .form-label{width:auto;line-height:1.2}}:root{--bg: #f3f4f6;--card: #ffffff;--stroke: #e5e7eb;--title: #1f2937;--text: #111827;--muted: #6b7280;--btn: #2563eb;--btn-hover: #1d4ed8}.hist-envios-page{min-height:100vh;background:var(--bg);padding:16px;display:flex;flex-direction:column;gap:12px}.he-header{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid var(--stroke);border-radius:8px;padding:12px 16px}.he-header h1{margin:0;font-size:22px;font-weight:600;color:var(--title)}.he-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.he-search{width:320px;padding:10px 12px;border:1px solid var(--stroke);border-radius:6px;background:#fff}.he-select{padding:10px 12px;border:1px solid var(--stroke);border-radius:6px;background:#fff}.he-actions button{padding:10px 14px;border-radius:6px;border:none;background:var(--btn);color:#fff;font-weight:600;cursor:pointer}.he-actions button:hover{background:var(--btn-hover)}.he-actions .link{background:transparent;color:var(--btn);border:1px solid transparent;padding:10px 8px}.he-actions .link:hover{text-decoration:underline}.he-card{background:var(--card);border:1px solid var(--stroke);border-radius:8px;box-shadow:0 1px 2px #0000000a;padding:0}.he-table-wrap{overflow:auto}.he-table{width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed;font-size:14px}.he-table thead th{background:#f9fafb;color:#111827;font-weight:600;border-bottom:1px solid var(--stroke);padding:0;text-align:left}.th-sort,.th-filter{width:100%;display:flex;align-items:center;gap:6px;padding:10px 12px;background:transparent;border:0;color:inherit;font:inherit;text-align:left;cursor:pointer}.th-sort .caret,.th-filter .caret{font-size:12px;opacity:.6}.he-table tbody td{border-bottom:1px solid var(--stroke);padding:10px 12px;color:var(--text);vertical-align:top}.he-table tbody tr:hover{background:#fafafa}.cell-clamp{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.cell-clamp:hover{-webkit-line-clamp:unset;overflow:visible}.he-pager,.he-pager-sticky{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 16px}.he-pager button,.he-pager-sticky button{width:36px;height:36px;border:1px solid var(--stroke);background:#fff;border-radius:6px;cursor:pointer}.he-pager button:disabled,.he-pager-sticky button:disabled{opacity:.6;cursor:not-allowed}.he-badge{display:inline-block;font-size:12px;padding:2px 8px;border-radius:999px;border:1px solid}.he-badge.queued{color:#8b5cf6;border-color:#8b5cf6;background:#faf5ff}.he-badge.sending{color:#d97706;border-color:#d97706;background:#fffbeb}.he-badge.done{color:#16a34a;border-color:#16a34a;background:#ecfdf5}.he-badge.failed{color:#dc2626;border-color:#dc2626;background:#fef2f2}.he-badge.unknown{color:#374151;border-color:#9ca3af;background:#f9fafb}.he-progress{height:8px;background:#f3f4f6;border-radius:999px;overflow:hidden}.he-progress-inner{height:100%;background:#3b82f6;width:0%;transition:width .25s ease}.muted{color:var(--muted)}.small{font-size:12px}.he-drawer{position:fixed;inset:0;background:#11182759;display:flex;align-items:stretch;justify-content:flex-end;z-index:60}.he-drawer-card{width:min(880px,92vw);background:#fff;height:100%;border-left:1px solid var(--stroke);display:flex;flex-direction:column}.he-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid #f3f4f6}.x-btn{border:none;background:none;font-size:18px;cursor:pointer}.he-drawer-filters{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid #f3f4f6}.he-drawer-filters input,.he-drawer-filters select{padding:8px 10px;border:1px solid var(--stroke);border-radius:6px;background:#fff}.he-drawer-filters .link{background:transparent;color:var(--btn);border:1px solid transparent;padding:8px 6px}.he-drawer-filters .link:hover{text-decoration:underline}.he-items{padding:10px 14px;max-height:62vh;overflow:auto;border-top:1px solid #eee}.he-items-table{width:100%;border-collapse:collapse;table-layout:fixed}.he-items-table th,.he-items-table td{padding:8px 10px;text-align:left;border-bottom:1px solid var(--stroke)}.he-items-table th:nth-child(1),.he-items-table td:nth-child(1){width:25%}.he-items-table th:nth-child(2),.he-items-table td:nth-child(2){width:15%}.he-items-table th:nth-child(4),.he-items-table td:nth-child(4){width:20%}.he-items-table th:nth-child(5),.he-items-table td:nth-child(5){width:15%}.he-items-table thead th{position:sticky;top:0;background:#fff;z-index:1;box-shadow:0 1px #eee}.td-error{max-width:420px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.he-tag{display:inline-block;font-size:12px;padding:1px 6px;border-radius:6px;border:1px solid}.he-tag.sent{color:#16a34a;border-color:#16a34a;background:#ecfdf5}.he-tag.fail{color:#dc2626;border-color:#dc2626;background:#fef2f2}.he-tag.skipped{color:#6b7280;border-color:#9ca3af;background:#f3f4f6}.empty-cell{padding:24px;text-align:center;color:var(--muted)}:root{--promo-bg: #f3f4f6;--promo-card: #ffffff;--promo-stroke: #e5e7eb;--promo-text: #111827;--promo-muted: #6b7280}.promo-page{min-height:100vh;background:var(--promo-bg);padding:16px}.promo-header{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid var(--promo-stroke);border-radius:8px;padding:12px 16px;margin-bottom:12px}.promo-header h1{margin:0;font-size:22px;font-weight:600;color:var(--promo-text)}.promo-subtitle{margin:4px 0 0;color:var(--promo-muted);font-size:13px}.promo-actions{display:flex;gap:8px;flex-wrap:wrap}.promo-alert{border:1px solid var(--promo-stroke);background:#fff;border-radius:8px;padding:10px 12px;margin-bottom:12px}.promo-alert.ok{border-color:#bbf7d0;color:#166534;background:#f0fdf4}.promo-alert.err{border-color:#fecaca;color:#991b1b;background:#fef2f2}.promo-grid{display:grid;grid-template-columns:1fr 340px;gap:16px}@media (max-width: 960px){.promo-grid{grid-template-columns:1fr}}.promo-card{background:var(--promo-card);border:1px solid var(--promo-stroke);border-radius:8px;padding:16px}.promo-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px;font-size:14px;color:var(--promo-text)}.promo-badge{font-size:12px;padding:3px 8px;border-radius:999px;border:1px solid var(--promo-stroke);background:#fff}.promo-badge.ok{color:#166534;border-color:#bbf7d0;background:#f0fdf4}.promo-badge.warn{color:#92400e;border-color:#fde68a;background:#fffbeb}.promo-card input[type=text],.promo-card textarea{width:100%;border:1px solid var(--promo-stroke);border-radius:8px;padding:8px 10px;font-size:14px;font-family:inherit}.promo-card textarea{min-height:70px;resize:vertical}.promo-image-actions{margin-top:6px}.promo-preview-image{width:100%;max-height:260px;object-fit:cover;border-radius:8px;border:1px solid var(--promo-stroke);margin-bottom:10px}.promo-empty{color:var(--promo-muted);font-size:13px;padding:6px 0}.promo-meta{margin-top:12px;color:var(--promo-muted);font-size:12px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}.tmpl-grid{display:grid;grid-template-columns:1fr 340px;gap:16px}.tmpl-col.side{align-self:start}.stack{display:flex;flex-direction:column;gap:8px}.btn-row{display:flex;gap:6px;flex-wrap:wrap}.chip{border:1px solid var(--stroke);background:#fff;border-radius:999px;padding:4px 8px;cursor:pointer;font-weight:600}.chip:hover{background:#f3f4f6}.switch{display:inline-flex;align-items:center;gap:8px}.examples-card{border:1px solid var(--stroke);border-radius:8px;padding:10px;background:#fff}.examples-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.examples-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:6px}.examples-th{font-size:12px;color:#6b7280;padding:4px}.examples-row{display:contents}.examples-td{border:1px solid var(--stroke);border-radius:6px;padding:8px;width:100%}.preview-card{border:1px solid var(--stroke);border-radius:8px;padding:10px;background:#fff}.preview-title{font-weight:600;margin-bottom:6px}.preview-body{white-space:pre-wrap;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:12px;border:1px dashed var(--stroke);border-radius:6px;padding:8px;background:#fafafa;margin:0 0 6px}.secondary{background:#475569;color:#fff;border:none;border-radius:6px;padding:6px 10px;cursor:pointer}.secondary:hover{background:#334155}
