:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#1d1f23;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;background:#f4f5f7;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.5}html,body,#root{min-height:100%;margin:0;padding:0}body{background:#f4f5f7}:root{--ink:#1d1f23;--ink-soft:#5b6470;--ink-mute:#8b95a3;--line:#e5e7eb;--line-soft:#eef0f3;--bg:#f7f8fa;--bg-card:#fff;--accent:#1d1f23;--accent-soft:#f5f6f8;--warn:#f0b400;--error:#b91c1c;--focus:#6b8afd}html,body,#root{background:var(--bg);color:var(--ink);max-width:100vw;min-height:100vh;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,system-ui,sans-serif;overflow-x:clip}*{box-sizing:border-box}.app{grid-template-columns:240px minmax(0,1fr);width:100%;min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--line);background:#fff;width:100%;min-width:0;max-width:100%;height:100vh;padding:18px 12px;position:sticky;top:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid var(--line-soft);align-items:center;gap:10px;margin-bottom:12px;padding:6px 8px 18px;display:flex}.brand-mark{color:#fff;letter-spacing:.5px;background:linear-gradient(135deg,#1d1f23,#3a3f47);border-radius:10px;place-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:grid}.brand-title{font-size:15px;font-weight:600;line-height:1.1}.brand-sub{color:var(--ink-mute);margin-top:2px;font-size:12px}.sidebar-nav{flex-direction:column;gap:2px;display:flex}.nav-item{color:var(--ink);border-radius:10px;flex-direction:column;padding:10px 12px;text-decoration:none;transition:background .12s;display:flex;position:relative}.nav-item:hover{background:var(--accent-soft)}.nav-item.active{box-shadow:inset 3px 0 0 var(--focus);background:#eef1f8}.nav-item.disabled{color:var(--ink-soft)}.nav-title{font-size:15px;font-weight:500}.nav-hint{color:var(--ink-mute);margin-top:1px;font-size:12px}.nav-badge{text-transform:uppercase;letter-spacing:.04em;background:var(--line-soft);color:var(--ink-soft);border-radius:999px;padding:2px 7px;font-size:10px;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.content{text-align:left;width:100%;min-width:0;max-width:760px;color:var(--ink);margin:0 auto;padding:24px 16px 140px;font-size:18px;line-height:1.5}.loading{text-align:center;color:var(--ink-soft);padding:80px 0;font-size:20px}.section-head h1{letter-spacing:-.01em;margin:8px 0 6px;font-size:28px}.subtitle{color:var(--ink-soft);margin:0 0 24px;font-size:16px}.placeholder{background:var(--bg-card);border:1px solid var(--line);border-radius:14px;padding:22px}.placeholder-badge{background:var(--accent-soft);color:var(--ink-soft);letter-spacing:.02em;border-radius:999px;margin-bottom:14px;padding:4px 10px;font-size:13px;font-weight:600;display:inline-block}.placeholder-list{color:var(--ink);margin:0;padding-left:22px}.placeholder-list li{margin-bottom:8px;line-height:1.5}.block{background:var(--bg-card);border:1px solid var(--line);border-radius:14px;margin-bottom:16px;padding:18px;transition:border-color .2s,box-shadow .2s}.block.changed{border-color:var(--warn);box-shadow:0 0 0 3px #f0b4001f}.block label{color:var(--ink);margin-bottom:10px;font-size:19px;font-weight:600;display:block}.block textarea{width:100%;min-height:120px;color:var(--ink);box-sizing:border-box;resize:vertical;background:#fafbfc;border:1px solid #d6dae0;border-radius:10px;outline:none;padding:12px 14px;font-family:inherit;font-size:17px;line-height:1.55}.block textarea:focus{border-color:var(--focus);background:#fff;box-shadow:0 0 0 3px #6b8afd2e}.section-foot{border-top:1px solid var(--line);padding:14px 16px calc(14px + env(safe-area-inset-bottom));z-index:10;background:#fff;justify-content:center;gap:10px;display:flex;position:fixed;bottom:0;left:240px;right:0}.btn{cursor:pointer;border:1px solid #0000;border-radius:12px;flex:auto;justify-content:center;align-items:center;gap:8px;max-width:360px;min-height:50px;padding:14px 18px;font-family:inherit;font-size:17px;font-weight:600;transition:background .15s,opacity .15s,border-color .15s;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.primary{background:var(--accent);color:#fff}.btn.primary:not(:disabled):hover{background:#2f3238}.btn.secondary{color:var(--ink);background:#fff;border-color:#d6dae0}.btn.secondary:not(:disabled):hover{background:var(--accent-soft)}.badge{background:var(--warn);color:var(--ink);text-align:center;border-radius:999px;min-width:18px;padding:1px 8px;font-size:13px;font-weight:700}.toast{background:var(--ink);color:#fff;z-index:20;border-radius:10px;max-width:calc(100vw - 272px);padding:12px 18px;font-size:15px;position:fixed;bottom:96px;left:calc(50% + 120px);transform:translate(-50%);box-shadow:0 8px 24px #0000002e}.toast.err{background:var(--error)}@media (width<=760px){.app{grid-template-columns:minmax(0,1fr)}.sidebar{border-right:none;border-bottom:1px solid var(--line);z-index:30;height:auto;padding:10px;position:sticky;top:0;overflow:hidden}.sidebar-nav{max-width:100%}.sidebar-brand{border-bottom:none;margin:0 0 6px;padding:4px 4px 8px}.sidebar-nav{flex-direction:row;gap:6px;padding:0 18px 4px 0;overflow-x:auto;-webkit-mask-image:linear-gradient(90deg,#000 0 calc(100% - 24px),#0000 100%);mask-image:linear-gradient(90deg,#000 0 calc(100% - 24px),#0000 100%)}.nav-item{border-radius:8px;flex:none;padding:8px 12px}.nav-item.active{box-shadow:inset 0 -3px 0 var(--focus)}.nav-hint{display:none}.nav-badge{margin-left:8px;position:static;transform:none}.content{max-width:100vw;padding:16px 12px 180px;font-size:17px}.section-head h1{font-size:24px}.block,.placeholder{padding:14px}.block textarea{max-width:100%;font-size:16px}.btn{width:100%;max-width:100%;padding:13px 14px;font-size:16px}.section-foot{padding:10px 12px calc(10px + env(safe-area-inset-bottom));flex-direction:column;gap:8px;left:0}.toast{max-width:calc(100vw - 32px);left:50%}}.sidebar-user{border-top:1px solid var(--line-soft);margin-top:18px;padding:14px 12px}.user-name{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.user-role{color:var(--ink-mute);margin-top:2px;font-size:12px}.user-logout{border:1px solid var(--line);color:var(--ink-soft);cursor:pointer;background:0 0;border-radius:8px;width:100%;margin-top:10px;padding:6px 10px;font-family:inherit;font-size:13px;font-weight:500;transition:background .12s,border-color .12s,color .12s}.user-logout:hover{background:var(--accent-soft);color:var(--ink);border-color:var(--ink-mute)}@media (width<=760px){.sidebar-user{border-top:1px solid var(--line-soft);align-items:center;gap:10px;margin-top:8px;padding:8px 8px 4px;display:flex}.user-name{max-width:50vw;font-size:13px}.user-role{margin-top:0;font-size:11px}.user-logout{width:auto;margin:0 0 0 auto;padding:5px 10px}}.block-meta{color:var(--ink-mute);margin-top:8px;font-size:12px}.block-meta strong{color:var(--ink-soft);font-weight:600}.login-wrap{background:var(--bg);place-items:center;min-height:100vh;padding:24px 16px;display:grid}.login-card{background:var(--bg-card);border:1px solid var(--line);border-radius:18px;width:100%;max-width:420px;padding:28px 24px 24px;box-shadow:0 12px 32px #1018280f}.login-brand{align-items:center;gap:12px;margin-bottom:18px;display:flex}.login-title{letter-spacing:-.01em;margin:4px 0 6px;font-size:24px}.login-sub{color:var(--ink-soft);margin:0 0 18px;font-size:14px;line-height:1.5}.login-form{flex-direction:column;gap:10px;display:flex}.login-form label{color:var(--ink);font-size:13px;font-weight:600}.login-form input{color:var(--ink);background:#fafbfc;border:1px solid #d6dae0;border-radius:10px;outline:none;padding:12px 14px;font-family:inherit;font-size:17px}.login-form input:focus{border-color:var(--focus);background:#fff;box-shadow:0 0 0 3px #6b8afd2e}.login-form input:disabled{opacity:.6}.login-form .btn{width:100%;max-width:none;margin-top:4px}.btn.link{color:var(--focus);background:0 0;border:none;min-height:auto;padding:8px;font-size:14px}.btn.link:hover{background:var(--accent-soft)}.login-hint{background:var(--accent-soft);color:var(--ink-soft);border-radius:10px;margin-top:14px;padding:10px 12px;font-size:13px;line-height:1.45}.login-error{color:var(--error);background:#fde8e8;border:1px solid #f7c5c5;border-radius:10px;margin-top:14px;padding:10px 12px;font-size:13px;line-height:1.45}
