:root{--bg: oklch(.985 .005 80);--surface: #ffffff;--surface-2: oklch(.972 .006 80);--surface-3: oklch(.955 .008 75);--border: oklch(.91 .008 75);--border-strong: oklch(.84 .01 70);--hairline: oklch(.94 .006 75);--ink: oklch(.2 .012 60);--ink-2: oklch(.34 .012 60);--muted: oklch(.52 .01 70);--subtle: oklch(.68 .008 70);--accent: oklch(.58 .14 45);--accent-soft: oklch(.94 .05 50);--accent-ink: oklch(.4 .13 45);--sent: oklch(.6 .13 145);--sent-soft: oklch(.94 .05 145);--pending: oklch(.68 .14 75);--pending-soft: oklch(.95 .06 80);--locked: oklch(.58 .18 25);--locked-soft: oklch(.94 .06 25);--locked-bg: oklch(.97 .025 25);--info: oklch(.55 .1 240);--info-soft: oklch(.94 .04 240);--shadow-1: 0 1px 0 rgba(0,0,0,.02), 0 1px 2px rgba(15,12,8,.04);--shadow-2: 0 1px 0 rgba(0,0,0,.02), 0 6px 16px rgba(15,12,8,.08);--shadow-3: 0 1px 0 rgba(0,0,0,.03), 0 24px 60px rgba(15,12,8,.16);--radius-1: 4px;--radius-2: 6px;--radius-3: 10px;--radius-4: 14px;--sans: "Geist", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;--serif: "Instrument Serif", "GT Sectra", Georgia, serif;--mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--row-h: 44px}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;background:var(--bg);color:var(--ink)}body{font-family:var(--sans);font-size:13.5px;line-height:1.45;-webkit-font-smoothing:antialiased;font-feature-settings:"ss01","cv11"}#root{height:100%}button{font-family:inherit}a{color:inherit}.app{display:grid;grid-template-columns:232px 1fr;height:100%}.sidebar{background:var(--surface-2);border-right:1px solid var(--border);padding:14px 12px;display:flex;flex-direction:column;gap:4px;height:100vh;position:sticky;top:0;overflow:hidden}.sidebar-scroll{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:4px;margin:0 -4px;padding:0 4px}.sidebar-scroll::-webkit-scrollbar{width:6px}.sidebar-scroll::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.brand{display:flex;align-items:center;gap:10px;padding:8px 8px 16px}.brand-mark{width:26px;height:26px;border-radius:6px;background:var(--ink);color:var(--bg);display:grid;place-items:center;font-family:var(--serif);font-style:italic;font-size:18px;line-height:1;padding-bottom:2px;flex-shrink:0}.brand-name{font-family:var(--serif);font-size:20px;letter-spacing:.005em}.brand-name em{font-style:italic;color:var(--accent)}.nav-group{display:flex;flex-direction:column;gap:1px;margin-top:4px}.nav-label{font-size:10.5px;letter-spacing:.09em;text-transform:uppercase;color:var(--subtle);padding:12px 10px 6px;font-weight:500}.nav-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--radius-2);font-size:13px;color:var(--ink-2);cursor:default;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-weight:450;line-height:1}.nav-item:hover{background:var(--surface-3);color:var(--ink)}.nav-item.active{background:var(--surface);color:var(--ink);font-weight:500;box-shadow:var(--shadow-1)}.nav-item .nav-icon{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;color:var(--muted);flex-shrink:0}.nav-item .nav-icon>svg{display:block}.nav-item.active .nav-icon{color:var(--accent)}.nav-item .count{margin-left:auto;font-size:11px;color:var(--subtle);font-variant-numeric:tabular-nums}.sidebar-foot{padding-top:12px;margin-top:8px;border-top:1px solid var(--hairline);flex-shrink:0}.user-chip{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:var(--radius-2)}.user-chip:hover{background:var(--surface-3)}.avatar{width:28px;height:28px;border-radius:50%;background:var(--ink);color:var(--bg);display:grid;place-items:center;font-size:11px;font-weight:600;letter-spacing:.03em;flex-shrink:0}.avatar.lg{width:36px;height:36px;font-size:13px}.user-chip .meta{min-width:0;flex:1}.user-chip .nm{font-size:12.5px;color:var(--ink);font-weight:500;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-chip .rl{font-size:11px;color:var(--muted);line-height:1.2}.main{display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-bottom:1px solid var(--border);background:var(--bg);gap:16px;flex-shrink:0}.topbar-l{display:flex;align-items:baseline;gap:16px;min-width:0}.title{font-family:var(--serif);font-size:26px;letter-spacing:-.005em}.title em{font-style:italic;color:var(--accent)}.title-sub{color:var(--muted);font-size:12.5px}.topbar-r{display:flex;align-items:center;gap:8px}.search-input{display:flex;align-items:center;gap:8px;height:32px;padding:0 10px;border:1px solid var(--border);border-radius:var(--radius-2);background:var(--surface);color:var(--ink);min-width:240px}.search-input input{all:unset;flex:1;font-size:13px}.search-input input::-moz-placeholder{color:var(--subtle)}.search-input input::placeholder{color:var(--subtle)}.search-input .kbd{font-family:var(--mono);font-size:10.5px;color:var(--subtle);border:1px solid var(--border);padding:1px 5px;border-radius:3px}.view{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;background:var(--bg)}.btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border:1px solid var(--border);background:var(--surface);color:var(--ink);border-radius:var(--radius-2);font-size:13px;font-weight:500;cursor:default;white-space:nowrap}.btn:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn.primary{background:var(--ink);color:var(--bg);border-color:var(--ink)}.btn.primary:hover{background:#2b2521}.btn.accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.accent:hover{background:#a84811}.btn.ghost{background:transparent;border-color:transparent;color:var(--ink-2)}.btn.ghost:hover{background:var(--surface-3);color:var(--ink);border-color:transparent}.btn.danger{color:var(--locked)}.btn.danger:hover{background:var(--locked-soft);border-color:var(--locked)}.btn.sm{height:26px;padding:0 8px;font-size:12px;gap:4px}.btn.icon{width:32px;height:32px;padding:0;justify-content:center}.btn.icon.sm{width:24px;height:24px}.btn:disabled{opacity:.55;pointer-events:none}.toolbar{display:flex;align-items:center;gap:8px;padding:10px 24px;border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0;flex-wrap:wrap}.toolbar .sep{width:1px;height:18px;background:var(--border);margin:0 2px}.toolbar .spacer{flex:1}.chip{display:inline-flex;align-items:center;gap:6px;height:26px;padding:0 8px;border:1px solid var(--border);border-radius:13px;background:var(--surface);font-size:12px;color:var(--ink-2)}.chip .x{color:var(--subtle);cursor:default;padding-left:2px}.chip .x:hover{color:var(--locked)}.chip .k{color:var(--muted)}.chip .v{color:var(--ink);font-weight:500}.chip.add{border-style:dashed;color:var(--muted);cursor:default}.chip.add:hover{border-color:var(--accent);color:var(--accent)}.table-wrap{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:16px 0 80px}.table-outer{overflow-x:auto;margin:0 24px}.table{width:100%;border-collapse:separate;border-spacing:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-3);clip-path:inset(0 round var(--radius-3));table-layout:auto}.table th,.table td{padding:0 12px;vertical-align:middle;font-weight:400;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table th.sticky,.table td.sticky{position:sticky;left:0;z-index:2;background:inherit}.table thead th.sticky{z-index:3;background:var(--surface-2)}.table tbody tr td.sticky{background:var(--surface)}.table tbody tr.locked td.sticky{background:var(--locked-bg)}.table tbody tr.selected td.sticky{background:#ffe1d1}.table th{height:36px;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-weight:500;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:sticky;top:0;z-index:2}.table th.sortable{cursor:default}.table th.sortable:hover{color:var(--ink)}.table th .sort-ind{color:var(--accent);margin-left:4px}.table tbody tr{height:var(--row-h)}.table tbody tr:not(:last-child) td{border-bottom:1px solid var(--hairline)}.table tbody tr:hover td{background:var(--surface-2)}.table tbody tr.selected td{background:var(--accent-soft)}.table tbody tr.locked td{background:var(--locked-bg)}.table tbody tr.locked:hover td{background:#ffe8e6;background:oklch(.95 .035 25)}.table tbody tr.locked td:first-child{box-shadow:inset 3px 0 0 var(--locked)}.table tbody tr.deleted td{background:var(--surface-2);opacity:.65}.table tbody tr.deleted:hover td{background:var(--surface-3);opacity:.8}.table tbody tr.deleted td.sticky{background:var(--surface-2)}.ag-row.ag-locked-row{background:var(--locked-bg)!important}.ag-row.ag-locked-row:hover{background:#ffe8e6!important;background:oklch(.95 .035 25)!important}.ag-row.ag-locked-row{box-shadow:inset 3px 0 0 var(--locked)}.ag-row.ag-deleted-row{opacity:.65}.ag-row.ag-deleted-row:hover{opacity:.8}.ag-header-cell{padding:0!important}.ag-header-cell:not(.ag-floating-filter){padding-inline:10px!important}.ag-floating-filter-button{display:none!important}.ag-floating-filter .ag-input-wrapper{height:30px!important}.ag-floating-filter input{margin-inline:5px!important;height:30px!important}.ag-floating-filter-body{display:flex!important;align-items:center}.ag-cell{display:flex!important;align-items:center;justify-content:center}.app-col-header{display:flex;align-items:center;height:100%;gap:2px;width:100%;overflow:hidden}.app-col-header-label{flex:1;min-width:0;display:flex;align-items:center;justify-content:center;gap:5px;overflow:hidden;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-weight:500;-webkit-user-select:none;-moz-user-select:none;user-select:none}.app-col-header-label.sortable{cursor:default}.app-col-header-label.sortable:hover{color:var(--ink)}.app-col-header-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-col-header-sort{flex-shrink:0;color:var(--accent);font-size:10px;line-height:1}.app-col-header-filter-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:0;height:18px;padding:0;background:transparent;border:none;border-radius:3px;color:var(--subtle);cursor:default;opacity:0;overflow:hidden;transition:opacity .1s,color .1s,width .1s}.app-col-header:hover .app-col-header-filter-btn,.app-col-header-filter-btn.active{opacity:1;width:18px}.app-col-header-filter-btn.active{color:var(--accent)}.app-col-header-filter-btn:hover{color:var(--ink)}.app-col-header-menu-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:0;height:20px;padding:0;background:transparent;border:none;border-radius:3px;color:var(--subtle);cursor:default;opacity:0;overflow:hidden;transition:opacity .1s,background .1s,color .1s,width .1s}.app-col-header:hover .app-col-header-menu-btn,.app-col-header-menu-btn.active{opacity:1;width:20px}.app-col-header-menu-btn:hover{background:var(--surface-3);color:var(--ink)}.app-col-header-grip{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:0;height:20px;cursor:grab;color:var(--subtle);opacity:0;overflow:hidden;transition:opacity .1s,color .1s,width .1s}.app-col-header:hover .app-col-header-grip{opacity:1;width:14px}.app-col-header-grip:hover{color:var(--ink)}.app-col-header-grip:active{cursor:grabbing}.group-panel{display:flex;align-items:center;height:32px;padding:0 14px;border-bottom:1px solid var(--border);background:var(--surface-2);gap:6px;flex-shrink:0;transition:background .12s,border-color .12s}.group-panel.drag-over{background:var(--accent-soft);border-color:var(--accent);outline:1.5px dashed var(--accent);outline-offset:-2px}.group-panel-hint{font-size:11.5px;color:var(--subtle);display:flex;align-items:center;gap:5px;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none}.group-panel-chip{display:inline-flex;align-items:center;gap:5px;background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:2px 4px 2px 6px;font-size:12px;color:var(--ink);-webkit-user-select:none;-moz-user-select:none;user-select:none}.group-panel-chip-remove{display:flex;align-items:center;background:none;border:none;padding:1px;cursor:pointer;color:var(--muted);border-radius:3px}.group-panel-chip-remove:hover{background:var(--surface-3);color:var(--ink)}.group-header-cell{display:flex;align-items:center;gap:7px;height:100%;padding:0 14px;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:11.5px}.group-header-chevron{display:flex;align-items:center;flex-shrink:0;color:var(--subtle)}.group-header-field{font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:10.5px;color:var(--muted)}.group-header-sep{color:var(--subtle)}.group-header-value{font-weight:500;color:var(--ink)}.group-header-count{margin-left:auto;font-size:11px;color:var(--muted);background:var(--surface-3);border:1px solid var(--border);border-radius:10px;padding:1px 7px;font-variant-numeric:tabular-nums}.table tbody tr.group-row td{height:30px;padding:0 12px;background:var(--surface-3);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-weight:600;border-bottom:1px solid var(--border)!important}.table tbody tr.group-row .count{margin-left:6px;color:var(--subtle);font-weight:400;letter-spacing:0}td.col-id{font-family:var(--mono);font-size:12px;color:var(--ink-2)}td.col-id .num{color:var(--ink)}td.col-hotel{line-height:1.25}td.col-hotel .name{color:var(--ink);font-weight:500;font-size:13px}td.col-delivery .time{color:var(--muted);font-size:11.5px;font-family:var(--mono)}td.col-delivery .date{color:var(--ink);font-size:13px}td.col-delivery{line-height:1.25}td.col-money{font-variant-numeric:tabular-nums;font-family:var(--mono);font-size:12.5px}td.col-money .ccy{color:var(--muted);font-size:11px;margin-right:2px}td.col-money .rest.due{color:var(--locked)}td.col-money .rest.clear{color:var(--sent)}td.col-actions{width:130px}td.col-actions .actions{display:flex;gap:2px;opacity:0;justify-content:flex-end}tr:hover td.col-actions .actions,tr.selected td.col-actions .actions{opacity:1}td.col-cb{width:36px}td.col-lock{width:28px;padding:0 4px;text-align:center;color:var(--locked)}tr:not(.locked) td.col-lock{color:transparent}.svc-pills{display:flex;gap:3px;flex-wrap:nowrap}.svc{display:inline-flex;align-items:center;height:18px;padding:0 6px;border-radius:4px;font-size:10.5px;font-weight:500;letter-spacing:.02em;background:var(--surface-3);color:var(--ink-2);border:1px solid var(--hairline)}.svc.usb{background:#d9efff;background:oklch(.94 .04 240);color:#005b88;color:oklch(.45 .11 240);border-color:#aed7f5}.svc.dvd{background:#ebedff;background:oklch(.95 .04 280);color:#49499b;border-color:#cfd4ff}.svc.album_medium{background:#ffeade;background:oklch(.95 .05 50);color:#873d00;color:oklch(.45 .13 50);border-color:#fecbaf}.svc.album_large{background:#ffe3de;background:oklch(.94 .06 30);color:#942318;border-color:#ffbfb4;border-color:oklch(.86 .08 30)}.badge{display:inline-flex;align-items:center;gap:6px;height:22px;padding:0 8px 0 6px;border-radius:11px;font-size:11.5px;font-weight:500;border:1px solid transparent}.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.badge.sent{background:var(--sent-soft);color:var(--sent);border-color:#c0e3c0}.badge.pending{background:var(--pending-soft);color:#865900;color:oklch(.5 .13 75);border-color:#f7d19c}.badge.locked{background:var(--locked-soft);color:var(--locked);border-color:#ffc8c2;border-color:oklch(.88 .08 25)}.badge.draft{background:var(--surface-3);color:var(--muted);border-color:var(--border)}.badge.info{background:var(--info-soft);color:var(--info);border-color:#b4defc}.badge.active{background:var(--sent-soft);color:var(--sent);border-color:#c0e3c0}.badge.inactive{background:var(--surface-3);color:var(--muted);border-color:var(--border)}.role{font-size:10.5px;padding:1px 7px;border-radius:4px;letter-spacing:.04em;text-transform:uppercase;font-weight:600;background:var(--surface-3);color:var(--muted);border:1px solid var(--hairline)}.role.superadmin{background:#ebedff;background:oklch(.95 .04 280);color:#42428c;border-color:#cfd4ff}.role.admin{background:var(--accent-soft);color:var(--accent-ink);border-color:#faccb7}.role.manager{background:var(--surface-3);color:var(--ink-2)}.checkbox{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:16px;height:16px;border:1px solid var(--border-strong);border-radius:3px;background:var(--surface);display:grid;place-items:center;cursor:default;flex-shrink:0;position:relative}.checkbox:hover{border-color:var(--ink-2)}.checkbox:checked{background:var(--ink);border-color:var(--ink)}.checkbox:checked:after{content:"";width:4px;height:7px;border:solid var(--bg);border-width:0 1.5px 1.5px 0;transform:rotate(45deg) translate(-.5px,-1px)}.checkbox.indeterminate{background:var(--ink);border-color:var(--ink)}.checkbox.indeterminate:after{content:"";width:7px;height:1.5px;background:var(--bg);border:none;transform:none}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0c0852;z-index:100;animation:fade-in .15s ease-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes scale-in{0%{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}.drawer{position:fixed;top:0;right:0;bottom:0;width:560px;max-width:92vw;background:var(--surface);border-left:1px solid var(--border);box-shadow:var(--shadow-3);z-index:101;display:flex;flex-direction:column;animation:slide-in .22s cubic-bezier(.32,.72,.2,1)}.drawer.wide{width:760px}.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.drawer-title{font-family:var(--serif);font-size:22px;letter-spacing:-.005em}.drawer-body{flex:1;overflow:auto;padding:20px}.drawer-foot{padding:12px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--surface-2);flex-shrink:0}.drawer-tabs{display:flex;gap:0;padding:0 20px;border-bottom:1px solid var(--border);flex-shrink:0}.drawer-tab{background:none;border:none;border-radius:0;border-bottom:2px solid transparent;padding:0;margin-right:18px;height:40px;font-size:13px;font-weight:500;color:var(--muted);cursor:default}.drawer-tab.active{border-bottom-color:var(--ink);color:var(--ink);font-weight:600}.drawer-tab:hover{color:var(--ink-2)}.form-section{margin-bottom:22px}.form-section-h{display:flex;align-items:baseline;gap:10px;margin-bottom:12px}.form-section-h .n{font-family:var(--mono);font-size:10.5px;color:var(--subtle);width:22px}.form-section-h .lb{font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2)}.form-section-h .sb{font-size:12px;color:var(--muted);margin-left:auto}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.grid-4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:12px}.field{display:flex;flex-direction:column;gap:5px}.field .lbl{font-size:11.5px;color:var(--muted);letter-spacing:.01em}.field .lbl .req{color:var(--locked)}.field .lbl .hint{color:var(--subtle);margin-left:4px;font-size:11px}.input,.select,.textarea{height:34px;border:1px solid var(--border);border-radius:var(--radius-2);background:var(--surface);padding:0 10px;font:inherit;font-size:13px;color:var(--ink);font-family:inherit;width:100%}.input:focus,.select:focus,.textarea:focus{outline:2px solid oklch(.85 .08 45);outline-offset:0;border-color:var(--accent)}.input.mono{font-family:var(--mono);font-size:12.5px}.input[readonly]{background:var(--surface-2);color:var(--ink-2);cursor:default}.input.input-err{border-color:#c53637;outline:none}.input.input-err:focus{outline:2px solid oklch(.8 .1 25);border-color:#c53637}.field-err{font-size:11.5px;color:#c53637;margin-top:4px}.input.hint-prefix{padding-left:32px}.input-wrap{position:relative}.input-prefix{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:12px;font-family:var(--mono);pointer-events:none}.input-suffix{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:11.5px}.textarea{height:auto;padding:8px 10px;resize:vertical;min-height:64px}.select{-moz-appearance:none;appearance:none;-webkit-appearance:none}.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.svc-check{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-2);cursor:default;background:var(--surface)}.svc-check:hover{border-color:var(--border-strong)}.svc-check.on{border-color:var(--ink);background:var(--surface-2)}.svc-check .nm{font-size:13px;font-weight:500}.svc-check .sub{font-size:11px;color:var(--muted);margin-left:auto;font-family:var(--mono)}.switch{position:relative;width:30px;height:18px;background:var(--border-strong);border-radius:9px;transition:background .15s ease;flex-shrink:0;cursor:default}.switch:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:transform .15s ease;box-shadow:0 1px 2px #0003}.switch.on{background:var(--ink)}.switch.on.accent{background:var(--accent)}.switch.on:after{transform:translate(12px)}.toggle-row{display:flex;align-items:center;gap:10px;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-2);background:var(--surface)}.toggle-row .nm{font-size:13px;font-weight:500}.toggle-row .sub{font-size:11.5px;color:var(--muted)}.toggle-row .body{flex:1;min-width:0}.field.computed .input{background:var(--accent-soft);color:var(--accent-ink);font-weight:600}.field.computed .lbl{color:var(--accent-ink)}.kv-grid{display:grid;grid-template-columns:130px 1fr;row-gap:9px;-moz-column-gap:12px;column-gap:12px;font-size:13px}.kv-grid dt{color:var(--muted);font-size:12px}.kv-grid dd{margin:0;color:var(--ink);font-weight:500}.detail-id-row{display:flex;align-items:baseline;gap:12px;margin-bottom:4px}.id-chip{font-family:var(--mono);font-size:11px;padding:2px 7px;border-radius:4px;background:var(--surface-3);color:var(--ink-2);border:1px solid var(--hairline)}.id-chip.lg{font-size:14px;padding:4px 10px}.price-card{padding:10px 12px;background:var(--surface-2);border-radius:8px}.price-card .lbl{font-size:11px;color:var(--muted);margin-bottom:2px}.price-card .val{font-family:var(--mono);font-size:18px;font-weight:600}.timeline{display:flex;flex-direction:column;gap:0}.tl-item{display:grid;grid-template-columns:28px 1fr;gap:10px;padding:10px 0;border-bottom:1px solid var(--hairline)}.tl-item:last-child{border-bottom:0}.tl-dot{width:22px;height:22px;border-radius:50%;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center;color:var(--muted);font-size:11px}.tl-dot.out{background:var(--sent-soft);border-color:#b9dcb9;color:var(--sent)}.tl-dot.in{background:var(--info-soft);border-color:#aed7f5;color:var(--info)}.tl-meta{display:flex;align-items:baseline;gap:8px}.tl-from{font-weight:500;font-size:13px}.tl-time{color:var(--subtle);font-size:11.5px;font-family:var(--mono);margin-left:auto}.tl-body{color:var(--ink-2);font-size:12.5px;margin-top:2px;line-height:1.5;white-space:pre-wrap}.tl-channel{font-size:10px;padding:1px 5px;border-radius:3px;letter-spacing:.05em;text-transform:uppercase;font-weight:600}.tl-channel.whatsapp{background:#d3f7d3;color:#135d1d}.tl-channel.telegram{background:#d9efff;background:oklch(.94 .05 240);color:#00537c;color:oklch(.42 .12 240)}.bulk-bar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--ink);color:var(--bg);padding:8px 8px 8px 16px;border-radius:999px;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-3);font-size:13px;z-index:50;animation:scale-in .18s ease-out}.bulk-bar .count{font-weight:600}.bulk-bar .sep{width:1px;height:18px;background:#4d4641;margin:0 4px}.bulk-bar .btn.ghost{color:var(--bg)}.bulk-bar .btn.ghost:hover{background:#322c28}.login-shell{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:var(--bg);z-index:200}.login-shell:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(60% 50% at 20% 30%,oklch(.94 .04 45 / .6),transparent 60%),radial-gradient(50% 40% at 90% 80%,oklch(.94 .04 240 / .4),transparent 60%);pointer-events:none}.login-card{position:relative;width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-4);padding:32px;box-shadow:var(--shadow-3)}.login-card h1{font-family:var(--serif);font-size:32px;margin:14px 0 4px;letter-spacing:-.005em}.login-card h1 em{font-style:italic;color:var(--accent)}.login-card .sub{color:var(--muted);font-size:13px;margin-bottom:24px}.login-card .field{margin-bottom:12px}.login-card .btn{width:100%;justify-content:center;height:38px}.login-error{color:var(--locked);font-size:12px;margin-top:8px;text-align:center}.cal{padding:16px 24px 60px}.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.cal-head .month{font-family:var(--serif);font-size:28px;letter-spacing:-.005em}.cal-head .month em{font-style:italic;color:var(--accent)}.cal-head .nav{display:flex;gap:6px;align-items:center}.viewtoggle{display:inline-flex;padding:2px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-2);gap:0}.viewtoggle .seg{padding:4px 10px;font-size:12px;font-weight:500;border-radius:4px;color:var(--muted);cursor:default}.viewtoggle .seg.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-1)}.month-grid{display:grid;grid-template-columns:repeat(7,1fr);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-3);overflow:hidden}.month-dow{padding:8px 10px;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:500;background:var(--surface-2);border-bottom:1px solid var(--border);border-right:1px solid var(--hairline)}.month-dow:last-child{border-right:0}.day-cell{min-height:120px;padding:6px 6px 8px;border-bottom:1px solid var(--hairline);border-right:1px solid var(--hairline);background:var(--surface);display:flex;flex-direction:column;gap:3px;position:relative}.day-cell.muted-cell{background:var(--surface-2)}.day-cell.today .day-num{background:var(--accent);color:#fff}.day-cell:nth-child(7n+7){border-right:0}.day-num{font-family:var(--mono);font-size:11.5px;width:22px;height:22px;display:grid;place-items:center;border-radius:50%;color:var(--ink-2);margin:2px 2px 0}.day-cell.muted-cell .day-num{color:var(--subtle)}.cal-chip{display:flex;align-items:center;gap:5px;padding:2px 6px 2px 5px;border-radius:4px;font-size:11px;font-weight:500;background:var(--surface-3);color:var(--ink-2);border-left:2px solid var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4;cursor:pointer}.cal-chip:hover{filter:brightness(.97)}.cal-chip .t{font-family:var(--mono);font-size:10.5px;color:var(--muted)}.cal-chip.sent{background:var(--sent-soft);border-left-color:var(--sent);color:#004b0f;color:oklch(.36 .13 145)}.cal-chip.sent .t{color:#3b723e}.cal-chip.pending{background:var(--pending-soft);border-left-color:var(--pending);color:#694500;color:oklch(.42 .13 75)}.cal-chip.pending .t{color:#986600;color:oklch(.55 .12 75)}.cal-chip.locked{background:var(--locked-soft);border-left-color:var(--locked);color:var(--locked)}.cal-chip.locked .t{color:#b54a46}.cal-overflow{font-size:10.5px;color:var(--muted);padding-left:6px}.week-grid{display:grid;grid-template-columns:56px repeat(7,1fr);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-3);overflow:hidden}.week-dow{padding:10px;text-align:center;border-bottom:1px solid var(--border);border-right:1px solid var(--hairline);background:var(--surface-2)}.week-dow:last-child{border-right:0}.week-dow .dn{font-size:10.5px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}.week-dow .dd{font-family:var(--serif);font-size:22px}.week-dow.today .dd{color:var(--accent)}.week-hour{font-family:var(--mono);font-size:10.5px;color:var(--subtle);text-align:right;padding:4px 8px 0 0;border-right:1px solid var(--hairline);border-bottom:1px solid var(--hairline);height:56px}.week-cell{border-right:1px solid var(--hairline);border-bottom:1px solid var(--hairline);height:56px;position:relative}.week-cell:nth-last-child(-n+7){border-bottom:0}.week-cell:nth-child(8n){border-right:0}.week-event{position:absolute;left:4px;right:4px;z-index:1;background:var(--surface-3);border:1px solid var(--hairline);border-left:3px solid var(--muted);border-radius:4px;padding:4px 6px;font-size:11px;line-height:1.25;overflow:hidden;cursor:pointer}.week-event:hover{filter:brightness(.97)}.week-event.sent{background:var(--sent-soft);border-color:#b5deb5;border-left-color:var(--sent)}.week-event.pending{background:var(--pending-soft);border-color:#f0ca96;border-left-color:var(--pending)}.week-event.locked{background:var(--locked-soft);border-color:#ffbeb8;border-color:oklch(.86 .08 25);border-left-color:var(--locked)}.week-event .ttl{font-weight:600;color:var(--ink)}.week-event .meta{color:var(--muted);font-size:10.5px;font-family:var(--mono)}.day-col{display:grid;grid-template-columns:64px 1fr;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-3);overflow:hidden}.day-hour-label{font-family:var(--mono);font-size:11px;color:var(--muted);text-align:right;padding:6px 10px 0 0;border-right:1px solid var(--hairline);border-bottom:1px solid var(--hairline);height:68px}.day-hour-track{border-bottom:1px solid var(--hairline);height:68px;position:relative;padding:4px 12px}.day-event{position:absolute;left:12px;right:12px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--muted);border-radius:6px;padding:8px 10px;display:flex;flex-direction:column;gap:2px;box-shadow:var(--shadow-1);cursor:pointer}.day-event:hover{background:var(--surface-2)}.day-event.sent{border-left-color:var(--sent)}.day-event.pending{border-left-color:var(--pending)}.day-event.locked{background:var(--locked-soft);border-color:#ffbeb8;border-color:oklch(.86 .08 25);border-left-color:var(--locked)}.day-event .top{display:flex;align-items:center;gap:8px}.day-event .h{font-weight:600;font-size:13px}.day-event .s{color:var(--muted);font-size:11.5px}.day-event .m{font-family:var(--mono);font-size:11px;color:var(--muted);margin-left:auto}.users-table .col-name .nm{font-weight:500}.users-table .col-name .un{color:var(--muted);font-family:var(--mono);font-size:12px}.popover{position:fixed;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-3);box-shadow:var(--shadow-3);padding:6px;min-width:200px;z-index:200;animation:scale-in .12s ease-out}.popover-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:var(--radius-2);font-size:13px;color:var(--ink-2);cursor:default}.popover-item:hover{background:var(--surface-2);color:var(--ink)}.popover-item.danger{color:var(--locked)}.popover-item.danger:hover{background:var(--locked-soft)}.popover-divider{height:1px;background:var(--hairline);margin:4px 0}.popover-label{font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--subtle);padding:8px 10px 4px;font-weight:500}.checkrow{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:var(--radius-2);font-size:13px;cursor:default}.checkrow:hover{background:var(--surface-2)}@keyframes spin{to{transform:rotate(360deg)}}.loading-state{display:flex;align-items:center;justify-content:center;padding:60px 20px;color:var(--muted)}.empty-state{padding:60px 20px;text-align:center;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:12px}.empty-state .e-ttl{font-family:var(--serif);font-size:22px;color:var(--ink)}.msg-bubble{background:#eaf6ea;border:1px solid oklch(.86 .05 145);border-radius:12px;padding:14px;font-size:13px;line-height:1.6;white-space:pre-wrap;position:relative}.msg-bubble-label{position:absolute;top:-10px;left:14px;background:#38853e;color:#fff;font-size:10px;padding:2px 8px;border-radius:10px;letter-spacing:.05em;text-transform:uppercase;font-weight:600}.info-banner{display:flex;gap:16px;padding:12px 16px;background:var(--info-soft);border:1px solid oklch(.86 .06 240);border-radius:10px;font-size:12.5px;color:#003f60;color:oklch(.35 .1 240)}[data-sonner-toaster]{font-family:var(--sans)!important}.app{transition:grid-template-columns .22s ease}.app.sidebar-collapsed{grid-template-columns:52px 1fr}.sidebar{transition:padding .22s ease}.sidebar.collapsed{padding:14px 6px}.sidebar.collapsed .brand{padding:8px 4px 16px;justify-content:center}.sidebar.collapsed .nav-group{align-items:center}.sidebar.collapsed .nav-item{justify-content:center;padding:8px;gap:0}.sidebar.collapsed .nav-item .nav-icon{width:18px;height:18px}.new-ticket-btn{width:100%;height:32px;margin-bottom:8px}.sidebar.collapsed .new-ticket-btn{width:32px;height:32px;padding:0;justify-content:center;margin-bottom:8px}.sidebar.collapsed .user-chip{padding:6px}.collapse-btn{display:flex;align-items:center;gap:6px;width:100%;padding:6px 8px;margin-top:6px;border:none;background:none;border-radius:var(--radius-2);font-family:inherit;font-size:12px;color:var(--subtle);cursor:default}.collapse-btn:hover{background:var(--surface-3);color:var(--ink-2)}.sidebar.collapsed .collapse-btn{justify-content:center;padding:6px}.mobile-menu-btn{display:none;position:fixed;top:11px;left:12px;z-index:50}.sidebar-scrim{display:none}@media(max-width:768px){.app,.app.sidebar-collapsed{grid-template-columns:1fr;height:100dvh}.sidebar,.sidebar.collapsed{position:fixed;top:0;left:0;bottom:0;height:100%;width:240px;padding:14px 12px;transform:translate(-100%);transition:transform .25s cubic-bezier(.32,.72,.2,1);z-index:150}.sidebar.open{transform:translate(0)}.sidebar.collapsed .brand{justify-content:flex-start;padding:8px 8px 16px}.sidebar.collapsed .brand-name,.sidebar.collapsed .nav-label{display:block}.sidebar.collapsed .nav-item{justify-content:flex-start;padding:7px 10px;gap:10px}.sidebar.collapsed .nav-item span,.sidebar.collapsed .nav-item .count{display:inline}.sidebar.collapsed .new-ticket-btn{width:100%;padding:0 12px;gap:6px}.sidebar.collapsed .user-chip{justify-content:flex-start}.sidebar.collapsed .user-chip .meta{display:block}.sidebar.collapsed .logout-btn{display:inline-flex}.collapse-btn{display:none}.sidebar-scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0c0866;z-index:149;animation:fade-in .15s ease-out}.mobile-menu-btn{display:inline-flex}.topbar{padding:12px 16px 12px 52px}.toolbar{padding:8px 12px;gap:6px}.search-input{min-width:100px!important;flex:1}.table-outer{margin:0 8px}.login-card{width:calc(100% - 32px);max-width:380px;padding:24px}.grid-2,.grid-3{grid-template-columns:1fr}.grid-4{grid-template-columns:1fr 1fr}.cal{padding:12px 12px 60px}.cal-head{flex-wrap:wrap;gap:8px}.cal-head .month{font-size:22px}.drawer,.drawer.wide{width:100vw;max-width:100vw}.drawer-body{padding:16px}.day-cell{min-height:80px;padding:4px 3px}td.col-actions .actions{opacity:1}.bulk-bar{width:calc(100% - 32px)}.kv-grid{grid-template-columns:110px 1fr}.title{font-size:22px}}
