body{color:#222;background:#f4f6f8;margin:0;font-family:Arial,sans-serif}#root{min-height:100vh}.app-navbar{z-index:100;background:#1f2d3d;padding:4px 10px;position:relative}.app-navbar__inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.app-menu{flex-wrap:wrap;align-items:center;gap:4px;margin:0;padding:0;list-style:none;display:flex}.app-menu--main{flex:1;min-width:0}.app-menu a{color:#fff;border-radius:4px;padding:3px 8px;font-size:13px;line-height:1.2;text-decoration:none;display:inline-block}.app-menu a:hover,.app-menu a.active{background:#2e4358}.app-user-menu{flex-shrink:0;margin-left:auto;position:relative}.app-user-menu__trigger{cursor:pointer;-webkit-user-select:none;user-select:none;color:#e2e8f0;border-radius:4px;padding:3px 8px;font-size:13px;line-height:1.2;list-style:none}.app-user-menu__trigger::-webkit-details-marker{display:none}.app-user-menu__trigger:after{content:" ▾";opacity:.85;font-size:10px}.app-user-menu[open] .app-user-menu__trigger,.app-user-menu__trigger:hover{color:#fff;background:#2e4358}.app-user-menu__panel{z-index:102;background:#2e4358;border-radius:6px;min-width:10rem;padding:4px;position:absolute;top:calc(100% + 4px);right:0;box-shadow:0 4px 12px #00000040}.app-user-menu__logout{box-sizing:border-box;text-align:left;color:#fff;cursor:pointer;width:100%;font:inherit;background:0 0;border:none;border-radius:4px;padding:4px 10px;font-size:13px;line-height:1.2;display:block}.app-user-menu__logout:hover{background:#3d566e}.app-menu details{position:relative}.app-menu summary{color:#fff;cursor:pointer;border-radius:4px;padding:6px 10px;list-style:none}.app-menu summary:hover{background:#2e4358}.app-submenu{z-index:101;background:#2e4358;border-radius:6px;min-width:180px;margin:0;padding:6px;list-style:none;position:absolute;top:32px;left:0;box-shadow:0 4px 12px #00000040}.app-submenu a{box-sizing:border-box;width:100%}.app-submenu a:hover{background:#3d566e}.app-main{box-sizing:border-box;width:100%;max-width:none;margin:16px auto;padding:0 10px}.app-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;max-width:52rem;padding:16px}.app-card--wide{box-sizing:border-box;width:100%;max-width:min(100%,100vw - 20px);padding-bottom:12px}.app-card h1{color:#222;margin:0 0 12px;font-size:1.75rem;font-weight:600}.app-card p{color:#222;margin:0 0 12px;line-height:1.5}.app-card p:last-child{margin-bottom:0}.app-card a{color:#2c7be5}.app-card a:hover{text-decoration:underline}.app-card code{background:#f1f5f9;border-radius:4px;padding:2px 6px;font-family:ui-monospace,Consolas,monospace;font-size:.9em}.app-intro{color:#475569;max-width:52rem;font-size:14px;line-height:1.45}.page-title{margin-top:0}.list-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:6px;margin-bottom:8px;display:flex}.list-toolbar__right{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.tb{cursor:pointer;color:#fff;border:none;border-radius:3px;align-items:center;gap:3px;height:22px;padding:0 7px;font-size:11px;line-height:1;text-decoration:none;display:inline-flex}.tb--create{background:#27ae60}.tb--create:hover{background:#229954}.tb--excel{background:#2e7d32}.tb--excel:hover{background:#276b2b}.tb--view{background:#7e57c2}.tb--view:hover{background:#6d49ac}.tb--reset{background:#95a5a6}.tb--reset:hover{background:#7f8c8d}.list-msg{margin:0 0 10px;font-size:14px}.list-msg--warn{color:#92400e}.list-msg--err{color:#b91c1c}.list-selection-msg{color:#64748b;background:0 0;border:1px solid #0000;border-radius:4px;min-height:20px;margin:0 0 6px;padding:2px 6px;font-size:11px}.list-selection-msg.is-active{background:0 0;border-color:#0000}.list-table-footer{align-items:center;margin-top:6px;padding-top:8px;display:flex}.list-table-count{color:#334155;font-size:13px;font-weight:700}.list-page-shell{flex-direction:column;display:flex}.list-table-area{margin-top:2px}.table-wrap{background:#fff;border:1px solid #ddd;border-radius:6px;overflow-x:auto}.list-table{border-collapse:collapse;background:#fff;width:100%;font-size:11px;line-height:1.1}.list-table th,.list-table td{text-align:left;vertical-align:middle;border:1px solid #ddd;padding:1px 4px}.list-table thead tr.list-table__head-row th{color:#fff;z-index:2;background:#2c3e50;font-size:11px;font-weight:500;line-height:1.1;position:sticky;top:0;box-shadow:0 1px #0000001f}.list-table thead tr.list-table__head-row th:has(.list-table__sort-btn){vertical-align:middle;padding:0}.list-table__sort-btn{box-sizing:border-box;width:100%;min-height:100%;color:inherit;font:inherit;font-weight:inherit;font-size:inherit;line-height:inherit;cursor:pointer;text-align:left;background:0 0;border:none;justify-content:flex-start;align-items:center;gap:2px;margin:0;padding:1px 4px;display:flex}.list-table__sort-btn:hover{background:#ffffff14}.list-table__sort-btn:focus-visible{outline-offset:-2px;outline:2px solid #f0af89}.list-table__sort-arrow{opacity:.95;flex-shrink:0;font-size:8px}.list-table thead tr.list-filter-row{--list-filter-focus:#f0af89}.list-table thead tr.list-filter-row th{color:#fff;vertical-align:middle;background:#34495e;padding:1px 3px;font-weight:400}.list-table thead .list-table__cb input{accent-color:#3498db;width:12px;height:12px}.list-table tbody tr{transition:background-color .15s}.list-table tbody td{color:#222;background:#fff;font-size:11px}.list-table tbody tr:hover td{background:#e8f4f8}.list-table__cb{text-align:center;width:26px;min-width:26px;padding-left:1px;padding-right:1px}.list-table tbody .list-table__cb input{accent-color:#3498db;vertical-align:middle;width:12px;height:12px}.list-filter-cell{width:100%;min-width:5.5rem;max-width:12rem;position:relative}.list-filter-cell__field{box-sizing:border-box;color:#1e293b;background:#fff;border:1px solid #cbd5e1;border-radius:2px;width:100%;min-height:18px;padding:0 3px;font-size:10px;line-height:1.15}.list-filter-cell--dirty .list-filter-cell__field{padding-right:18px}.list-filter-cell__field:focus,.list-filter-cell__field:focus-visible{border-color:var(--list-filter-focus,#f0af89);box-shadow:0 0 0 1px var(--list-filter-focus,#f0af89);outline:none}.list-table thead tr.list-filter-row .list-filter-cell--dirty .list-filter-cell__field{border-color:var(--list-filter-focus,#f0af89);box-shadow:0 0 0 1px var(--list-filter-focus,#f0af89)}.list-filter-cell__field--select{cursor:pointer;appearance:auto}.list-table thead tr.list-filter-row .list-filter-cell__field--select:hover{background-color:#f8fafc}.list-filter-cell__clear{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:2px;justify-content:center;align-items:center;width:16px;height:16px;margin:0;padding:0;font-size:12px;line-height:1;display:flex;position:absolute;top:50%;right:0;transform:translateY(-50%)}.list-filter-cell__clear:hover{color:#1e293b;background:#e2e8f0}.list-table thead tr.list-filter-row .list-filter-cell__clear{color:#94a3b8}.list-table thead tr.list-filter-row .list-filter-cell__clear:hover{color:#fff;background:#ffffff1f}.row-context-menu__backdrop{z-index:299;position:fixed;inset:0}.row-context-menu{z-index:300;background:#2e4358;border:1px solid #1f2d3d;border-radius:6px;min-width:14rem;margin:0;padding:4px 0;position:fixed;box-shadow:0 8px 24px #00000059}.row-context-menu__item{box-sizing:border-box;color:#fff;width:100%;font:inherit;text-align:left;cursor:pointer;background:0 0;border:none;margin:0;padding:6px 12px;font-size:12px;line-height:1.25;display:block}.row-context-menu__item:hover{background:#3d566e}.row-context-menu__item:focus-visible{outline-offset:-2px;outline:2px solid #f0af89}.row-context-menu__item:disabled{opacity:.45;cursor:default}.row-context-menu__divider{border:0;border-top:1px solid #94a3b899;margin:4px 0}.list-filter-exclude-hint{color:#fda4af;text-overflow:ellipsis;white-space:nowrap;max-width:12rem;margin-top:2px;font-size:9px;line-height:1.2;display:block;overflow:hidden}.dialog-backdrop{z-index:200;background:#0f172a73;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.dialog{background:#fff;border-radius:8px;width:100%;max-width:28rem;padding:16px;box-shadow:0 8px 24px #0003}.dialog__hint{color:#64748b;margin:0 0 12px;font-size:13px}.dialog-cols{margin:0 0 12px;padding:0;list-style:none}.dialog-cols__row{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;gap:8px;padding:4px 0;display:flex}.dialog-cols__move{gap:4px;display:flex}.dialog-cols__move button{cursor:pointer;min-width:28px;height:24px}.dialog__actions{flex-wrap:wrap;gap:8px;display:flex}.wh-form{flex-direction:column;gap:12px;max-width:24rem;display:flex}.wh-form label{flex-direction:column;gap:4px;font-size:14px;display:flex}.wh-form input[type=text]{padding:6px 8px;font-size:14px}.wh-form__check{flex-direction:row;align-items:center;gap:8px}.wh-form__err{color:#b91c1c;margin:0;font-size:14px}.wh-form__actions{align-items:center;gap:12px;display:flex}.wh-form__actions button{cursor:pointer;padding:8px 14px}.wh-form__actions a{color:#2c7be5;text-decoration:none}
