:root{--accent: #ff8fb3;--accent-strong: #f06595;--accent-soft: #ffd9e6;--on-accent: #3a1020;--success: #3fae8c;--warning: #e0a83d;--danger: #e35d77;--radius: 14px;--radius-sm: 10px;--shadow: 0 6px 24px rgba(120, 60, 90, .08);--shadow-sm: 0 2px 8px rgba(120, 60, 90, .06);--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--space: 16px;--maxw: 1100px;--control-h: 42px;--ring: color-mix(in srgb, var(--accent) 45%, transparent)}:root,:root[data-theme=light]{color-scheme:light;--bg: #fff7fa;--surface: #ffffff;--surface-2: #fdeff4;--text: #2a2230;--muted: #8a7f88;--border: #f0d9e3;--select-arrow: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238a7f88' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>")}:root[data-theme=dark]{color-scheme:dark;--bg: #131119;--surface: #1c1a24;--surface-2: #262330;--text: #f4f1f8;--muted: #a096ac;--border: #332f3e;--shadow: 0 10px 34px rgba(0, 0, 0, .5);--shadow-sm: 0 2px 10px rgba(0, 0, 0, .38);--select-arrow: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a096ac' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>")}@media (prefers-color-scheme: dark){:root:not([data-theme]){color-scheme:dark;--bg: #131119;--surface: #1c1a24;--surface-2: #262330;--text: #f4f1f8;--muted: #a096ac;--border: #332f3e;--shadow: 0 10px 34px rgba(0, 0, 0, .5);--shadow-sm: 0 2px 10px rgba(0, 0, 0, .38);--select-arrow: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a096ac' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>")}}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:var(--accent-strong);text-decoration:none}a:hover{text-decoration:underline}:focus-visible{outline:2px solid var(--accent-strong);outline-offset:2px}.app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.content{flex:1;width:100%;max-width:var(--maxw);margin:0 auto;padding:var(--space)}.topbar{position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--surface) 88%,transparent);-webkit-backdrop-filter:saturate(1.4) blur(10px);backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--border)}.topbar-inner{max-width:var(--maxw);margin:0 auto;padding:8px var(--space);display:flex;align-items:center;gap:10px}.brand{display:inline-flex;align-items:center;gap:8px;color:var(--text);font-weight:600;white-space:nowrap}.brand:hover{text-decoration:none}.brand-mark{font-size:22px}.brand-name b{color:var(--accent-strong)}.spacer{flex:1}.user-chip{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;max-width:280px}.chip-name{color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis}.chip-sep{opacity:.4;flex:none}.chip-tariff,.chip-expiry{flex:none}.chip-expired{color:var(--danger)}.nav{background:var(--surface-2);border-top:1px solid var(--border)}.nav-inner{max-width:var(--maxw);margin:0 auto;padding:4px var(--space) 5px;display:flex;gap:2px}.nav a{color:var(--muted);font-weight:500;font-size:14px;padding:5px 10px;border-radius:var(--radius-sm);white-space:nowrap;letter-spacing:.01em;transition:color .12s,background .12s}.nav a:hover{color:var(--text);text-decoration:none;background:color-mix(in srgb,var(--border) 60%,transparent)}.nav a.router-link-exact-active{color:var(--accent-strong);background:color-mix(in srgb,var(--accent) 14%,transparent)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;font:inherit;font-size:18px;line-height:1;min-width:var(--control-h);height:var(--control-h);padding:0 9px;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .15s,background .15s}.icon-btn:hover{border-color:var(--accent)}.icon-btn.nav-toggle{display:none}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:var(--control-h);padding:0 18px;font:inherit;font-weight:600;line-height:1.1;text-align:center;text-decoration:none;border-radius:var(--radius-sm);border:1px solid transparent;background:var(--accent);color:var(--on-accent);cursor:pointer;transition:background .15s,border-color .15s,color .15s,transform .05s}.btn:hover{background:var(--accent-strong);text-decoration:none}.btn:disabled{opacity:.55;cursor:default;transform:none}.btn-ghost{background:var(--surface);color:var(--text);border-color:var(--border)}.btn-ghost:hover{background:var(--surface-2);border-color:var(--accent)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:color-mix(in srgb,var(--danger) 85%,#000)}.btn-sm{min-height:34px;padding:0 12px;font-size:13px}.input{font:inherit;width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);transition:border-color .15s,box-shadow .15s}input.input,select.input{height:var(--control-h)}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}.input:disabled{opacity:.6;cursor:not-allowed}.input::placeholder{color:var(--muted)}textarea.input{height:auto;min-height:92px;line-height:1.5;resize:vertical}select.input{-moz-appearance:none;appearance:none;-webkit-appearance:none;padding-right:38px;background-image:var(--select-arrow);background-repeat:no-repeat;background-position:right 12px center;background-size:16px;cursor:pointer}select.input:disabled{cursor:not-allowed}input[type=date].input,input[type=datetime-local].input,input[type=time].input,input[type=month].input{-moz-appearance:none;appearance:none;-webkit-appearance:none}input[type=date].input::-webkit-date-and-time-value,input[type=datetime-local].input::-webkit-date-and-time-value,input[type=time].input::-webkit-date-and-time-value,input[type=month].input::-webkit-date-and-time-value{margin:0;text-align:left}.err{display:flex;gap:8px;align-items:flex-start;margin:12px 0;padding:10px 14px;font-size:14px;color:var(--danger);background:color-mix(in srgb,var(--danger) 12%,var(--surface));border:1px solid color-mix(in srgb,var(--danger) 38%,var(--border));border-radius:var(--radius-sm)}.err:before{content:"⚠";flex:none;font-size:15px;line-height:1.45}.notice{display:flex;gap:8px;align-items:flex-start;margin:12px 0;padding:10px 14px;font-size:14px;color:var(--warning);background:color-mix(in srgb,var(--warning) 10%,var(--surface));border:1px solid color-mix(in srgb,var(--warning) 35%,var(--border));border-radius:var(--radius-sm)}.notice:before{content:"ℹ";flex:none;font-size:15px;line-height:1.45}.badge{display:inline-block;font-size:12px;font-weight:600;padding:2px 8px;border-radius:999px;border:1px solid var(--border);color:var(--muted);background:var(--surface-2)}.badge.ok{color:var(--success);background:color-mix(in srgb,var(--success) 14%,transparent);border-color:color-mix(in srgb,var(--success) 40%,var(--border))}.badge.off{color:var(--danger);background:color-mix(in srgb,var(--danger) 14%,transparent);border-color:color-mix(in srgb,var(--danger) 40%,var(--border))}.badge.warn{color:var(--warning);background:color-mix(in srgb,var(--warning) 16%,transparent);border-color:color-mix(in srgb,var(--warning) 40%,var(--border))}.badge.info{color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,transparent);border-color:color-mix(in srgb,var(--accent) 40%,var(--border))}.table{width:100%;border-collapse:collapse;font-size:14px}.table th,.table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border);white-space:nowrap}.table th{color:var(--muted);font-weight:600;font-size:13px}.table tr:last-child td{border-bottom:none}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.row-link{cursor:pointer}.row-link:hover td{background:var(--surface-2)}.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}.filters .input{width:auto}.footer{background:var(--surface-2);border-top:1px solid var(--border);padding:14px var(--space);margin-top:auto}.footer-inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:13px;color:var(--muted)}.footer-copy{font-weight:500}.footer-sep{opacity:.4}.muted{color:var(--muted)}.page-title{margin:4px 0 16px}.pad{padding:16px 4px}.more{margin-top:14px;text-align:center}.section{margin-bottom:16px}.detail{display:grid;grid-template-columns:max-content 1fr;gap:8px 18px;font-size:14px}.detail dt{color:var(--muted)}.detail dd{margin:0;word-break:break-all}.field{margin-bottom:12px}.field>label{display:block;font-size:13px;color:var(--muted);margin-bottom:4px}.form-row{display:flex;gap:10px;flex-wrap:wrap}.form-row .field{flex:1;min-width:120px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:color-mix(in srgb,#000 50%,transparent);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:flex-start;justify-content:center;padding:8vh 16px 16px;overflow-y:auto}.modal{width:100%;max-width:460px;box-shadow:var(--shadow)}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}@media (max-width: 720px){:root{--space: 12px;--radius: 12px}.card{padding:16px}.icon-btn.nav-toggle{display:inline-flex}.user-chip,.nav{display:none}.nav.nav-open{display:block}.nav-inner{flex-direction:column;gap:2px;padding:6px var(--space) 10px}.nav a{font-size:15px;padding:9px 12px;border-radius:var(--radius-sm)}.page-title{font-size:1.4rem}.filters{gap:8px}.filters .input{width:100%}.modal-backdrop{padding:4vh 12px 12px}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}}:root{--tabbar-h: 62px;--accent-grad: linear-gradient(135deg, #ff9dbe 0%, var(--accent-strong) 100%);--accent-ghost: color-mix(in srgb, var(--accent) 15%, transparent);--accent-ghost-strong: color-mix(in srgb, var(--accent) 24%, transparent);--shadow-card: 0 1px 2px rgba(120, 60, 90, .05), 0 6px 20px rgba(120, 60, 90, .07);--shadow-pop: 0 8px 18px rgba(120, 60, 90, .12), 0 24px 48px rgba(120, 60, 90, .14);--ease: cubic-bezier(.22, 1, .36, 1)}:root[data-theme=dark],:root:not([data-theme]){--accent-ghost: color-mix(in srgb, var(--accent) 20%, transparent);--accent-ghost-strong: color-mix(in srgb, var(--accent) 30%, transparent)}@media (prefers-color-scheme: dark){:root:not([data-theme]){--shadow-card: 0 1px 2px rgba(0, 0, 0, .4), 0 8px 24px rgba(0, 0, 0, .42);--shadow-pop: 0 10px 24px rgba(0, 0, 0, .5), 0 28px 56px rgba(0, 0, 0, .55)}}:root[data-theme=dark]{--shadow-card: 0 1px 2px rgba(0, 0, 0, .4), 0 8px 24px rgba(0, 0, 0, .42);--shadow-pop: 0 10px 24px rgba(0, 0, 0, .5), 0 28px 56px rgba(0, 0, 0, .55)}body:before{content:"";position:fixed;inset:0 0 auto 0;height:380px;background:radial-gradient(70% 100% at 18% -10%,color-mix(in srgb,var(--accent) 24%,transparent),transparent 70%),radial-gradient(60% 100% at 100% -20%,color-mix(in srgb,var(--accent-strong) 14%,transparent),transparent 70%);pointer-events:none;z-index:0;opacity:.9}.app{position:relative;z-index:1}.topbar-inner{padding-top:10px;padding-bottom:10px}.brand-mark{font-size:24px;filter:drop-shadow(0 2px 4px rgba(240,101,149,.35));transition:transform .25s var(--ease)}.brand:hover .brand-mark{transform:rotate(-8deg) scale(1.08)}.brand-name{font-size:17px;letter-spacing:.01em}.brand-name b{background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.user-chip{text-decoration:none;padding:5px 11px;border-radius:999px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 70%,transparent);transition:border-color .15s,background .15s}.user-chip:hover{text-decoration:none;border-color:var(--accent);background:var(--accent-ghost)}.chip-dot{width:7px;height:7px;border-radius:50%;background:var(--success);flex:none;margin-left:2px}.chip-dot-bad{background:var(--danger)}.icon-btn{color:var(--muted);transition:border-color .15s,background .15s,color .15s,transform .06s}.icon-btn:hover{border-color:var(--accent);color:var(--accent-strong);background:var(--accent-ghost)}.icon-btn:active{transform:translateY(1px)}.lang-btn{font-size:13px;font-weight:700;color:var(--text)}.nav{background:color-mix(in srgb,var(--surface) 60%,transparent)}.nav-inner{padding-top:6px;padding-bottom:7px;gap:4px}.nav-link{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-weight:600;font-size:14px;padding:7px 13px;border-radius:999px;white-space:nowrap;transition:color .14s,background .14s}.nav-link:hover{color:var(--text);text-decoration:none;background:color-mix(in srgb,var(--border) 55%,transparent)}.nav-link .icon{opacity:.85}.nav-link.router-link-exact-active,.nav-link.is-active{color:var(--accent-strong);background:var(--accent-ghost)}.nav-link.router-link-exact-active .icon,.nav-link.is-active .icon{opacity:1}.card{box-shadow:var(--shadow-card);transition:border-color .16s,box-shadow .2s var(--ease),transform .2s var(--ease)}a.card,.row-link,.card-hover{cursor:pointer}a.card:hover,.card-hover:hover{border-color:var(--accent);box-shadow:var(--shadow-pop);transform:translateY(-2px)}.btn{background:var(--accent-grad);box-shadow:0 2px 8px color-mix(in srgb,var(--accent-strong) 32%,transparent);transition:filter .15s,box-shadow .18s,transform .06s,background .15s,border-color .15s,color .15s}.btn:hover{background:var(--accent-grad);filter:brightness(1.04) saturate(1.05);box-shadow:0 4px 14px color-mix(in srgb,var(--accent-strong) 42%,transparent)}.btn:active{transform:translateY(1px)}.btn:disabled{box-shadow:none;filter:none}.btn-ghost{background:var(--surface);box-shadow:var(--shadow-sm)}.btn-ghost:hover{background:var(--accent-ghost);border-color:var(--accent);color:var(--accent-strong);filter:none}.btn-danger{background:var(--danger);box-shadow:0 2px 8px color-mix(in srgb,var(--danger) 30%,transparent)}.btn-danger:hover{background:var(--danger);filter:brightness(1.05)}.btn .icon{margin:0 -2px}.btn-icon{padding:0;width:var(--control-h);min-height:var(--control-h)}.btn-icon.btn-sm{width:34px;min-height:34px}.input:hover:not(:disabled):not(:focus){border-color:color-mix(in srgb,var(--accent) 55%,var(--border))}.file-btn{position:relative;overflow:hidden;cursor:pointer}.file-btn input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.sec-title{margin:0 0 12px;font-size:16px;font-weight:700}.page-title{font-size:1.6rem;font-weight:800;letter-spacing:-.01em}.skeleton{border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--surface-2) 25%,color-mix(in srgb,var(--surface-2) 55%,var(--border)) 37%,var(--surface-2) 50%);background-size:400% 100%;animation:skeleton-shimmer 1.4s ease infinite}.skeleton+.skeleton{margin-top:10px}.sk-line{height:12px}.sk-row{height:64px}@keyframes skeleton-shimmer{0%{background-position:100% 0}to{background-position:0 0}}.empty-state{text-align:center;padding:44px 22px}.empty-state .emoji{font-size:46px;line-height:1;display:block;margin-bottom:12px;filter:drop-shadow(0 4px 10px rgba(240,101,149,.25))}.empty-state .empty-ico{margin:0 auto 14px;color:var(--accent);filter:drop-shadow(0 4px 10px rgba(240,101,149,.25))}.empty-state h3{margin:0 0 6px;font-size:17px;font-weight:700}.empty-state p{margin:0 auto 18px;max-width:360px;color:var(--muted);font-size:14px}.table thead th{position:sticky;top:0;background:var(--surface);z-index:1}.table tbody tr{transition:background .12s}@media (hover: hover){*{scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--accent) 45%,var(--border)) transparent}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--accent) 40%,var(--border));border-radius:99px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--accent)}}.tabbar,.sheet-backdrop{display:none}@media (max-width: 720px){.nav,.user-chip{display:none}.page-title{font-size:1.45rem}.app:has(.tabbar) .content{padding-bottom:calc(var(--tabbar-h) + env(safe-area-inset-bottom,0px) + var(--space))}.footer{display:none}.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:40;display:flex;padding-bottom:env(safe-area-inset-bottom,0px);background:color-mix(in srgb,var(--surface) 92%,transparent);-webkit-backdrop-filter:saturate(1.4) blur(12px);backdrop-filter:saturate(1.4) blur(12px);border-top:1px solid var(--border);box-shadow:0 -4px 20px #783c5a14}.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;height:var(--tabbar-h);padding:0;border:none;background:none;color:var(--muted);font:inherit;font-size:10.5px;font-weight:600;cursor:pointer;text-decoration:none;transition:color .14s;-webkit-tap-highlight-color:transparent}.tab .icon{transition:transform .18s var(--ease)}.tab.router-link-exact-active,.tab.is-active,.tab-active{color:var(--accent-strong)}.tab.router-link-exact-active .icon,.tab.is-active .icon,.tab-active .icon{transform:translateY(-1px) scale(1.06)}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:flex-end;background:color-mix(in srgb,#000 45%,transparent);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sheet{width:100%;background:var(--surface);border-radius:22px 22px 0 0;padding:10px 16px calc(18px + env(safe-area-inset-bottom,0px));box-shadow:var(--shadow-pop)}.sheet-grip{width:42px;height:5px;border-radius:99px;background:var(--border);margin:2px auto 14px}.sheet-user{display:flex;align-items:center;gap:12px;padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid var(--border)}.sheet-avatar{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-size:24px;background:var(--accent-ghost);flex:none}.sheet-user-text{flex:1;min-width:0}.sheet-user-name{font-weight:700;font-size:16px}.sheet-user-sub{font-size:13px}.sheet-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}.sheet-link{display:flex;align-items:center;gap:12px;padding:14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-weight:600;text-decoration:none;transition:border-color .14s,background .14s,color .14s}.sheet-link .icon{color:var(--accent-strong)}.sheet-link:active,.sheet-link.router-link-exact-active{border-color:var(--accent);background:var(--accent-ghost);color:var(--accent-strong);text-decoration:none}.sheet-logout{width:100%}.sheet-foot{margin-top:16px;padding-top:14px;border-top:1px solid var(--border);text-align:center}.sheet-docs{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--accent-strong);text-decoration:none}.sheet-copy{margin-top:8px;font-size:11.5px;color:var(--muted)}}@media (max-width: 900px){.nav-link{padding:7px 9px;gap:5px}}.page-enter-active,.page-leave-active{transition:opacity .18s ease,transform .18s var(--ease)}.page-enter-from{opacity:0;transform:translateY(7px)}.page-leave-to{opacity:0;transform:translateY(-5px)}.sheet-enter-active,.sheet-leave-active{transition:opacity .22s ease}.sheet-enter-active .sheet,.sheet-leave-active .sheet{transition:transform .28s var(--ease)}.sheet-enter-from,.sheet-leave-to{opacity:0}.sheet-enter-from .sheet,.sheet-leave-to .sheet{transform:translateY(100%)}@media (max-width: 720px){.card.table-wrap{padding:10px}.table-cards thead{display:none}.table-cards,.table-cards tbody,.table-cards tr,.table-cards td{display:block}.table-cards tr{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);margin-bottom:10px;overflow:hidden}.table-cards tr:last-child{margin-bottom:0}.table-cards td{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:9px 13px;border:none;white-space:normal;text-align:right;font-size:13.5px}.table-cards td+td{border-top:1px dashed var(--border)}.table-cards td:before{content:attr(data-label);color:var(--muted);font-weight:600;text-align:left;flex:none}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.page-enter-from,.page-leave-to{transform:none}}.op-app{display:flex;flex-direction:column;height:100vh;height:100dvh}.op-head{display:flex;align-items:center;gap:12px;height:56px;padding:0 16px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.op-brand{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:16px}.op-brand .cat-logo{font-size:24px}.op-head .sp{flex:1}.op-head-name{color:var(--muted);font-size:13px;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.op-live{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;white-space:nowrap;flex:none;padding:3px 10px;border-radius:999px;color:var(--success);background:color-mix(in srgb,var(--success) 14%,transparent);border:1px solid color-mix(in srgb,var(--success) 35%,var(--border))}.op-live:before{content:"";width:7px;height:7px;border-radius:999px;background:currentColor;animation:op-pulse 2.4s ease-in-out infinite}.op-live.down{color:var(--warning);background:color-mix(in srgb,var(--warning) 14%,transparent);border-color:color-mix(in srgb,var(--warning) 35%,var(--border))}.op-head-stats{display:flex;gap:6px}.op-stat{font-size:12px;color:var(--muted);padding:3px 9px;border-radius:var(--radius-sm);background:var(--surface-2)}.op-stat b{color:var(--text);font-weight:700}.op-stat-q b{color:var(--accent-strong)}.op-body{display:flex;flex:1;min-height:0;position:relative}.op-inbox{width:340px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:0;background:var(--surface)}.op-filters{padding:8px 10px;flex-shrink:0;border-bottom:1px solid var(--border)}.op-seg{display:flex;gap:2px;padding:3px;background:var(--surface-2);border-radius:999px}.op-filter{flex:1;min-height:26px;border:0;border-radius:999px;background:transparent;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:5px;transition:background .12s,color .12s}.op-filter:hover{color:var(--text)}.op-filter.on{background:var(--accent);color:var(--on-accent);box-shadow:var(--shadow-sm)}.op-filter-n{font-size:10px;font-weight:700;opacity:.75}.op-filter.on .op-filter-n{opacity:.9}.op-list{overflow-y:auto;flex:1;background:var(--bg)}.op-dlg{display:grid;grid-template-columns:40px 1fr;gap:2px 10px;padding:11px 14px;cursor:pointer;min-height:64px;transition:background .12s;width:100%;text-align:left;background:transparent;color:var(--text);font:inherit;border:0;border-bottom:1px solid var(--border)}.op-dlg:hover{background:color-mix(in srgb,var(--surface-2) 60%,transparent)}.op-dlg.on{background:var(--surface-2);box-shadow:inset 3px 0 0 var(--accent)}.op-dlg:focus-visible{outline:none;box-shadow:inset 3px 0 0 var(--accent-strong);background:var(--surface-2)}.op-dlg.unread .op-dlg-name,.op-dlg.unread .op-dlg-prev{color:var(--text);font-weight:600}.op-dlg-av{grid-row:1 / span 2;width:40px;height:40px;border-radius:999px;position:relative;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;background:color-mix(in srgb,var(--accent) 16%,var(--surface-2));color:var(--accent-strong)}.op-dlg-presence{position:absolute;right:-1px;bottom:-1px;width:11px;height:11px;border-radius:999px;border:2px solid var(--surface);background:var(--muted)}.op-dlg-presence.live{background:var(--success)}.op-dlg-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.op-dlg-name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.op-dlg-time{font-size:11px;color:var(--muted);flex:none}.op-dlg-mid{display:flex;align-items:center;gap:8px}.op-dlg-prev{font-size:13px;color:var(--muted);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.op-dlg-prev .op-prev-tag{font-style:italic}.op-badge{background:var(--accent);color:var(--on-accent);border-radius:999px;font-size:11px;font-weight:700;padding:1px 7px;flex:none}.op-dlg-chips{grid-column:2;display:flex;align-items:center;gap:6px;margin-top:3px;flex-wrap:wrap}.op-dlg-bot,.op-dlg-holder{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:1px 7px;border-radius:999px;border:1px solid var(--border);color:var(--muted);background:var(--surface-2);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.op-dlg-holder.mine{color:var(--accent-strong);background:color-mix(in srgb,var(--accent) 14%,transparent);border-color:color-mix(in srgb,var(--accent) 35%,var(--border))}.op-dlg-holder.free{border-style:dashed}.op-dlg-lock{color:var(--muted);display:inline-flex}.op-dlg-skel{display:grid;grid-template-columns:40px 1fr;gap:6px 10px;padding:13px 14px;border-bottom:1px solid var(--border)}.op-skel-av{grid-row:1 / span 2;width:40px;height:40px;border-radius:999px}.op-skel-a{height:12px;width:60%;border-radius:6px}.op-skel-b{height:10px;width:85%;border-radius:6px}.op-skel-av,.op-skel-a,.op-skel-b{background:linear-gradient(90deg,var(--surface-2) 25%,color-mix(in srgb,var(--accent) 8%,var(--surface-2)) 50%,var(--surface-2) 75%);background-size:200% 100%;animation:op-shimmer 1.3s linear infinite}.op-empty,.op-chat-empty,.op-lead-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 24px;text-align:center;color:var(--muted)}.op-empty .cat-logo,.op-chat-empty .cat-logo,.op-lead-empty .cat-logo{opacity:.55;margin-bottom:4px}.op-empty .cat-logo{font-size:48px}.op-chat-empty .cat-logo{font-size:56px}.op-lead-empty .cat-logo{font-size:40px}.op-empty-title,.op-chat-empty-title{font-weight:700;color:var(--text);font-size:15px}.op-empty-hint,.op-chat-empty-hint{font-size:13px;max-width:240px}.op-chat{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column}.op-chat-head{display:flex;flex-direction:column;gap:8px;padding:10px 16px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--surface)}.op-chat-id{display:flex;align-items:center;gap:10px}.op-chat-av{width:36px;height:36px;border-radius:999px;flex:none;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;background:color-mix(in srgb,var(--accent) 16%,var(--surface-2));color:var(--accent-strong)}.op-chat-idtext{min-width:0;flex:1}.op-chat-name{font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.op-chat-sub{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--muted);margin-top:1px}.op-chat-user{cursor:copy;display:inline-flex;align-items:center;gap:3px}.op-chat-user:hover{color:var(--accent-strong)}.op-chat-attr code{font-size:12px;padding:1px 6px;border-radius:6px;background:var(--surface-2);color:var(--accent-strong)}.op-chat-act{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-height:34px}.op-chat-act .op-held{color:var(--muted);font-size:13px;display:inline-flex;align-items:center;gap:6px}.op-chat-act .op-you{color:var(--accent-strong);font-size:13px;font-weight:600}.op-chat-act .sp{flex:1}.op-chat-back,.op-panel-btn{display:none}.op-panel-btn{position:relative}.op-panel-btn .op-pbtn-n{position:absolute;top:-4px;right:-4px;font-size:10px;font-weight:700;line-height:1;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--accent);color:var(--on-accent);display:inline-flex;align-items:center;justify-content:center}.op-thread{flex:1;overflow-y:auto;padding:16px;background:var(--bg);position:relative}.op-thread-inner{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:8px}.op-date-sep{align-self:center;font-size:11px;font-weight:600;color:var(--muted);background:var(--surface-2);border-radius:999px;padding:3px 12px;margin:6px 0}.op-msg{max-width:min(72%,560px);padding:8px 12px;font-size:15px;line-height:1.5;white-space:pre-wrap;word-break:break-word;position:relative}.op-msg.inb{align-self:flex-start;background:var(--surface-2);color:var(--text);border-radius:14px 14px 14px 4px}.op-msg.out{align-self:flex-end;background:var(--accent);color:var(--on-accent);border-radius:14px 14px 4px}.op-msg.stack{margin-top:-4px}.op-msg.inb.stack{border-top-left-radius:4px}.op-msg.out.stack{border-top-right-radius:4px}.op-msg.failed{box-shadow:inset 3px 0 0 var(--danger)}.op-msg-author{font-size:11px;font-weight:700;margin-bottom:3px}.op-msg.out .op-msg-author{color:color-mix(in srgb,var(--on-accent) 78%,transparent)}.op-msg.inb .op-msg-author{color:var(--accent-strong)}.op-msg-meta{display:flex;align-items:center;gap:4px;justify-content:flex-end;font-size:11px;margin-top:3px}.op-msg.inb .op-msg-meta{color:var(--muted)}.op-msg.out .op-msg-meta{color:color-mix(in srgb,var(--on-accent) 70%,transparent)}.op-msg-fail{display:flex;align-items:center;gap:8px;margin-top:5px;font-size:12px;color:var(--danger);flex-wrap:wrap}.op-resend{color:var(--danger);background:transparent;border:1px solid currentColor;border-radius:var(--radius-sm);padding:2px 10px;font-size:12px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:4px}.op-resend:hover{background:color-mix(in srgb,var(--danger) 12%,transparent)}.op-spin{width:11px;height:11px;border:2px solid currentColor;border-right-color:transparent;border-radius:999px;animation:op-spin .7s linear infinite;opacity:.75}.op-msg.sys{align-self:center;max-width:84%;text-align:center;font-size:12px;color:var(--muted);background:color-mix(in srgb,var(--surface-2) 70%,transparent);border:1px solid var(--border);border-radius:999px;padding:4px 12px;display:inline-flex;align-items:center;gap:6px;line-height:1.35}.op-sys-ic{opacity:.7;flex:none}.op-media{position:relative;display:inline-block}.op-media-img{max-width:260px;max-height:280px;border-radius:12px;display:block;cursor:zoom-in}video.op-media-img{cursor:default}.op-media-audio{display:block;min-width:220px;max-width:260px}.op-media-doc{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;background:color-mix(in srgb,var(--surface) 55%,transparent);border-radius:var(--radius-sm);color:inherit}.op-media-doc:hover{text-decoration:none;background:color-mix(in srgb,var(--surface) 80%,transparent)}.op-media-dl{position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;color:#fff;background:#00000080;opacity:0;transition:opacity .12s}.op-media:hover .op-media-dl,.op-media:focus-within .op-media-dl{opacity:1}.op-media-gone{font-size:13px;opacity:.75;font-style:italic}.op-sticker{background:transparent!important;box-shadow:none!important;padding:0;display:flex;flex-direction:column;align-items:flex-start;gap:2px}.op-stk-emoji{font-size:40px;line-height:1}.op-sticker .muted{font-size:11px}.op-newpill{position:absolute;right:16px;bottom:14px;z-index:5;display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700;background:var(--accent);color:var(--on-accent);border:0;cursor:pointer;box-shadow:var(--shadow-sm)}.op-tpl-pop{max-height:280px;overflow-y:auto;border-top:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;box-shadow:var(--shadow)}.op-tpl-search{padding:8px 10px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface)}.op-tpl-search .input{height:36px}.op-tpl{display:flex;align-items:flex-start;gap:8px;text-align:left;padding:10px 14px;background:transparent;border:0;border-bottom:1px solid var(--border);cursor:pointer;color:var(--text)}.op-tpl:hover,.op-tpl.on{background:var(--surface-2)}.op-tpl-kbd{font-size:11px;font-weight:700;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:1px 6px;flex:none;margin-top:1px}.op-tpl-body{min-width:0;flex:1;display:flex;flex-direction:column;gap:2px}.op-tpl-name{font-weight:600;display:flex;align-items:center;gap:6px}.op-tpl-text{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.op-tpl-media{color:var(--accent-strong);flex:none}.op-composer{padding:10px 14px;border-top:1px solid var(--border);background:var(--surface);flex-shrink:0}.op-composer-pad{max-width:820px;margin:0 auto}.op-composer-row{display:flex;align-items:flex-end;gap:8px}.op-composer-row textarea{flex:1;resize:none;min-height:42px;max-height:150px;line-height:1.5;padding:9px 12px;font-size:15px}.op-ic,.op-send{flex:none}.op-ic.on{color:var(--accent-strong);background:color-mix(in srgb,var(--accent) 14%,transparent);border-color:color-mix(in srgb,var(--accent) 35%,var(--border))}.op-pending{display:inline-flex;align-items:center;gap:8px;margin:0 0 8px;padding:6px 10px;font-size:13px;color:var(--muted);background:var(--surface-2);border-radius:var(--radius-sm)}.op-pending button{background:transparent;border:0;color:var(--muted);cursor:pointer;display:inline-flex}.op-hint{display:flex;align-items:center;gap:6px;margin:0 0 8px;font-size:12px;color:var(--accent-strong)}.op-readonly{display:flex;align-items:center;gap:8px;justify-content:center;padding:14px;color:var(--muted);font-size:13px;border-top:1px solid var(--border);background:var(--surface)}.op-panel{width:300px;flex-shrink:0;border-left:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;min-height:0}.op-panel-head{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.op-panel-head h3{font-size:14px;margin:0;font-weight:700}.op-panel-count{font-size:11px;font-weight:700;padding:1px 7px;border-radius:999px;background:var(--accent);color:var(--on-accent)}.op-panel-head .sp{flex:1}.op-panel-close,.op-panel-grip{display:none}.op-panel-body{overflow-y:auto;flex:1;padding:4px 0 12px}.op-lead{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 11px;margin:8px 12px;display:flex;flex-direction:column;gap:7px}.op-lead-head{display:flex;align-items:center;gap:8px}.op-lead-camp{flex:1;min-width:0;font-size:13px;font-weight:700;padding:2px 8px;border-radius:6px;background:var(--surface);color:var(--accent-strong);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.op-lead-head select.input{flex:none;width:112px;height:30px;font-size:12px;padding:0 26px 0 9px;background-position:right 8px center}.op-lead-head .badge{flex:none}.op-kv{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:12px}.op-kv>.op-kv-k{color:var(--muted);flex:none}.op-click{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-flex;align-items:center;gap:4px;cursor:copy;min-width:0}.op-click:hover{color:var(--accent-strong)}.op-confirm{width:100%;min-height:34px;font-size:13px}.op-evblock{display:flex;flex-direction:column;gap:4px}.op-evlabel{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.op-events{display:flex;flex-wrap:wrap;gap:5px}.op-ev{font-size:12px;font-weight:600;padding:4px 9px;border-radius:999px;cursor:pointer;background:var(--surface);border:1px solid var(--border);color:var(--text);display:inline-flex;align-items:center;gap:4px;transition:border-color .12s,background .12s}.op-ev:hover:not(:disabled){border-color:var(--accent)}.op-ev.fired{opacity:.6;cursor:default;color:var(--success);background:color-mix(in srgb,var(--success) 12%,transparent);border-color:color-mix(in srgb,var(--success) 35%,var(--border))}.op-login{max-width:460px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:24px;background:radial-gradient(120% 90% at 50% 0%,color-mix(in srgb,var(--accent) 12%,var(--bg)) 0%,var(--bg) 60%)}.op-login-top{position:fixed;top:14px;right:14px;display:flex;gap:8px;z-index:2}.op-login .card{width:100%;text-align:center;padding:32px 28px}.op-login .cat-logo{font-size:76px;margin:0 auto 14px;animation:op-bob 3.2s ease-in-out infinite}.op-login h1{font-size:22px;margin:0 0 8px}.op-login-lead{color:var(--text);font-size:14px;line-height:1.55;margin:0 0 16px}.op-login-gate{display:flex;gap:9px;align-items:flex-start;text-align:left;margin:16px 0 0;padding:11px 14px;font-size:14px;line-height:1.5;color:var(--text);background:color-mix(in srgb,var(--warning) 10%,var(--surface));border:1px solid color-mix(in srgb,var(--warning) 35%,var(--border));border-radius:var(--radius-sm)}.op-login-gate .icon{color:var(--warning);margin-top:2px;flex:none}.op-login-fine{font-size:13px;line-height:1.5;margin:14px 0 0;color:var(--muted)}.op-login-alt{margin-top:18px;padding-top:16px;border-top:1px solid var(--border);font-size:12px;color:var(--muted);line-height:1.5}.op-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#00000080;padding:24px 16px}.op-modal{width:100%;max-width:380px;max-height:80vh;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.op-modal-title{margin:0 0 12px;font-size:16px}.op-pick-list{display:flex;flex-direction:column;gap:4px;overflow-y:auto}.op-pick{display:flex;align-items:center;justify-content:space-between;gap:10px;text-align:left;padding:10px 12px;background:var(--surface-2);border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text);cursor:pointer;font-size:14px}.op-pick:hover:not(:disabled){border-color:var(--accent)}.op-pick.on{border-color:var(--accent)}.op-pick:disabled{opacity:.6;cursor:default}.op-pick-cur{color:var(--accent);font-size:11px}.op-modal-foot{display:flex;justify-content:flex-end;margin-top:14px}.op-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:flex;align-items:center;justify-content:center;background:#000000d9;cursor:zoom-out}.op-lightbox-img{max-width:92vw;max-height:92vh;border-radius:6px;cursor:default}.op-lightbox-x{position:absolute;top:16px;right:16px;width:40px;height:40px;border:0;border-radius:8px;background:#ffffff1f;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}@keyframes op-pulse{0%,to{opacity:1}50%{opacity:.45}}@keyframes op-spin{to{transform:rotate(360deg)}}@keyframes op-bob{0%,to{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-5px) rotate(2deg)}}@keyframes op-shimmer{to{background-position:-200% 0}}@media (max-width: 1099px){.op-inbox{width:320px}.op-panel{position:fixed;inset:0 0 0 auto;z-index:60;width:min(360px,86vw);transform:translate(100%);transition:transform .2s ease;box-shadow:var(--shadow);border-left:1px solid var(--border)}.op-panel.open{transform:translate(0)}.op-panel-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;background:color-mix(in srgb,#000 40%,transparent)}.op-panel-btn,.op-panel-close{display:inline-flex}}@media (max-width: 767px){.op-head-stats{display:none}.op-inbox{width:100%}.op-body.has-active .op-inbox{display:none}.op-body:not(.has-active) .op-chat{display:none}.op-chat-back{display:inline-flex}.op-msg{max-width:86%}.op-panel{inset:auto 0 0 0;width:100%;max-height:88dvh;border-left:0;border-top:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;transform:translateY(100%)}.op-panel.open{transform:translateY(0)}.op-panel-grip{display:block;width:36px;height:4px;border-radius:999px;background:var(--border);margin:8px auto 0}.op-panel-close{display:inline-flex}.op-composer .op-ic,.op-composer .op-send{min-width:44px;min-height:var(--control-h)}.op-filter{min-height:32px}}@media (prefers-reduced-motion: reduce){.op-live:before,.op-login .cat-logo,.op-spin,.op-skel-av,.op-skel-a,.op-skel-b{animation:none}.op-spin{border-right-color:currentColor}.op-panel{transition:none}}.icon[data-v-b42bdba6]{display:block;flex:none}.cat-logo[data-v-6f6aaf13]{display:block}
