:root{--bg:#0f1220;--surface:#171b2f;--surface-2:#1f2440;--text:#e8ecff;--text-2:#aab2da;--primary:#5a8bff;--border:#7a8dc93d}[data-theme=light]{--bg:#f4f6fb;--surface:#fff;--surface-2:#f8f9ff;--text:#1a2340;--text-2:#586387;--primary:#366dff;--border:#14224e1f}*{box-sizing:border-box}html,body,#app{background:var(--bg);width:100%;min-height:100vh;color:var(--text);margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,PingFang SC,Microsoft YaHei,sans-serif}button,input{font:inherit}.layout-root{min-height:100vh;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);z-index:30;width:240px;padding:14px;position:fixed;top:0;bottom:0;left:0}.brand{letter-spacing:.5px;margin:8px 10px 18px;font-weight:800}.menu{flex-direction:column;gap:8px;display:flex}.menu-item{text-align:left;color:var(--text);cursor:pointer;background:0 0;border:0;border-radius:10px;padding:10px 12px}.menu-item.active{background:#5a8bff2e}.main{flex:1;min-width:0;margin-left:240px}.topbar{border-bottom:1px solid var(--border);background:var(--surface);z-index:20;align-items:center;gap:10px;height:60px;padding:0 12px;display:flex;position:sticky;top:0}.title{font-weight:700}.actions{align-items:center;gap:10px;margin-left:auto;display:inline-flex}.icon-btn{border:1px solid var(--border);background:var(--surface-2);color:var(--text);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;padding:0;line-height:1;display:inline-flex}.menu-btn{background-image:url(/favicon.svg);background-position:50%;background-repeat:no-repeat;background-size:18px 18px}.avatar-menu{position:relative}.avatar-btn{border:1px solid var(--border);background:var(--surface-2);width:36px;height:36px;color:var(--text);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;padding:0;line-height:1;display:inline-flex}.avatar-dropdown{background:var(--surface);border:1px solid var(--border);z-index:60;border-radius:10px;min-width:120px;padding:4px;position:absolute;top:46px;right:0}.avatar-dropdown button{width:100%;color:var(--text);text-align:left;cursor:pointer;background:0 0;border:0;border-radius:8px;padding:8px}.avatar-dropdown button:hover{background:var(--surface-2)}.content{padding:16px}.page-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px}.crud-page{flex-direction:column;gap:12px;display:flex}.crud-toolbar{flex-wrap:wrap;gap:10px;display:flex}.crud-toolbar select{border:1px solid var(--border);background:var(--surface-2);min-width:180px;height:38px;color:var(--text);border-radius:10px;padding:0 10px}.crud-table-wrap{overflow-x:auto}.crud-pager{justify-content:space-between;align-items:center;gap:12px;display:flex}.btn-primary,.btn-ghost,.btn-danger{border:1px solid var(--border);cursor:pointer;vertical-align:middle;border-radius:10px;justify-content:center;align-items:center;height:38px;padding:0 12px;line-height:1;display:inline-flex}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-ghost{background:var(--surface-2);color:var(--text)}.btn-danger{color:#fff;background:#dc3545;border-color:#dc3545}.btn-ghost:hover,.btn-primary:hover,.btn-danger:hover{transform:translateY(-1px);box-shadow:0 6px 14px #0000002e}.btn-ghost:active,.btn-primary:active,.btn-danger:active{transform:translateY(0);box-shadow:0 2px 6px #00000029}.btn-ghost:focus-visible,.btn-primary:focus-visible,.btn-danger:focus-visible{outline-offset:2px;outline:2px solid #366dff73}.btn-ghost:disabled,.btn-primary:disabled,.btn-danger:disabled{opacity:.55;cursor:not-allowed;box-shadow:none!important;transform:none!important}.login-page,.notfound-page{justify-content:center;align-items:center;min-height:100vh;padding:16px;display:flex}.login-card,.notfound-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:12px;width:min(420px,100%);padding:20px;display:flex}.login-card h1{text-align:center;margin:0 0 6px;font-size:28px}.login-card input,.dialog input{border:1px solid var(--border);background:var(--surface-2);width:100%;color:var(--text);border-radius:10px;padding:10px 12px}.login-card button,.notfound-card button,.dialog button{border:1px solid var(--border);background:var(--primary);color:#fff;cursor:pointer;vertical-align:middle;border-radius:10px;justify-content:center;align-items:center;padding:10px 12px;line-height:1;display:inline-flex}.error{color:#ff7f7f;margin:0}.dialog-mask{z-index:40;background:#0006;place-items:center;display:grid;position:fixed;inset:0}.dialog{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:10px;width:min(420px,92vw);padding:16px;display:flex}.dialog-actions{justify-content:flex-end;gap:8px;display:flex}.toast{background:var(--surface);border:1px solid var(--border);z-index:50;border-radius:10px;padding:10px 12px;position:fixed;bottom:16px;right:16px}.global-toast{border:1px solid var(--border);background:var(--surface);min-width:220px;max-width:min(92vw,520px);color:var(--text);z-index:1600;pointer-events:none;border-radius:12px;align-items:center;gap:10px;padding:12px 14px;display:inline-flex;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 12px 28px #00000040}.global-toast-icon{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:13px;font-weight:700;display:inline-flex}.global-toast.is-success{border-color:#2ea04366}.global-toast.is-success .global-toast-icon{background:#28a745}.global-toast.is-info{border-color:#366dff66}.global-toast.is-info .global-toast-icon{background:#366dff}.global-toast.is-warning{border-color:#ff980073}.global-toast.is-warning .global-toast-icon{background:#ff9800}.global-toast.is-error{border-color:#dc354573}.global-toast.is-error .global-toast-icon{background:#dc3545}.global-confirm-mask{z-index:1650;background:#00000073;place-items:center;display:grid;position:fixed;inset:0}.global-confirm-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:min(420px,92vw);padding:16px}.global-confirm-card h3{margin:0 0 8px}.global-confirm-card p{color:var(--text-2);margin:0 0 14px}.global-confirm-actions{justify-content:flex-end;gap:8px;display:flex}.mobile-mask,.mobile-only{display:none}@media (width<=900px){.topbar{gap:8px;padding:0 10px}.title{flex:1;min-width:0}.actions{gap:8px;margin-left:0}.mobile-only{display:inline-block}.main{margin-left:0}.sidebar{transition:transform .24s;transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.mobile-mask{pointer-events:none;z-index:25;background:0 0;transition:background-color .24s;display:block;position:fixed;inset:0}.mobile-mask.show{pointer-events:auto;background:#00000059}}
