.admin-body{margin:0;min-height:100vh;background:#0b0d10;color:#eef2f3;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,sans-serif}.admin-body *{box-sizing:border-box;-webkit-user-select:text;-moz-user-select:text;user-select:text}.admin-shell{min-height:100vh;padding:20px}.admin-topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:16px;padding:18px 20px;border:1px solid rgba(255,255,255,.1);background:#ffffff0b}.admin-topbar p{margin:0 0 6px;color:#eef2f38c;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em}.admin-topbar h1{margin:0;font-size:1.4rem}.admin-actions,.module-actions,.item-actions,.sidebar-head,.preview-head,.list-head,.template-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}button,.admin-actions a{border:1px solid rgba(255,255,255,.14);background:#ffffff14;color:#eef2f3;padding:8px 10px;font:inherit;font-size:.86rem;cursor:pointer}button:hover,.admin-actions a:hover{background:#b7f7dc29;border-color:#b7f7dc6b}.admin-actions a{text-decoration:none}.auth-panel{margin-bottom:16px}.admin-locked .admin-topbar,.admin-locked .admin-layout,.admin-locked .admin-actions{display:none}.auth-card{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,360px) auto;gap:14px;align-items:end;padding:16px;border:1px solid rgba(183,247,220,.22);background:#b7f7dc12}.auth-card p{margin:5px 0 0;color:#eef2f39e;font-size:.84rem}.auth-card code{color:#b7f7dc}.auth-card label{display:grid;gap:6px}.auth-card input{width:100%}.auth-actions{display:grid;gap:7px}#auth-message{min-height:1em;color:#f7d28be6;font-size:.78rem}.admin-layout{display:grid;grid-template-columns:250px minmax(520px,1fr) 380px;gap:16px;align-items:start}.admin-sidebar,.editor-panel,.preview-panel{min-height:calc(100vh - 116px);border:1px solid rgba(255,255,255,.1);background:#ffffff0a}.admin-sidebar,.preview-panel{position:sticky;top:20px;max-height:calc(100vh - 40px);overflow:auto}.sidebar-head,.preview-head{justify-content:space-between;padding:14px;border-bottom:1px solid rgba(255,255,255,.1)}.page-list,.section-tabs{display:grid;gap:8px;padding:12px}.section-tabs button,.page-list button{display:grid;gap:5px;width:100%;text-align:left}.page-list button span{color:#eef2f38c;font-size:.78rem}.section-tabs button.active,.page-list button.active{background:#b7f7dc21;border-color:#b7f7dc80}.editor-panel{padding:16px;border-color:#70b2ff3d;background:linear-gradient(180deg,rgba(112,178,255,.08),transparent 210px),#ffffff0a}.editor-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}label{display:grid;gap:7px;color:#eef2f3ad;font-size:.82rem}input,textarea,select{width:100%;border:1px solid rgba(255,255,255,.13);background:#00000042;color:#eef2f3;padding:10px;font:inherit;font-size:.92rem}textarea{resize:vertical;line-height:1.55}input:focus,textarea:focus,select:focus{outline:1px solid rgba(183,247,220,.48);border-color:#b7f7dc7a}.wide-field,.template-panel{margin-top:12px}.wide-field,.editor-grid label,.extra-fields label{padding:10px;border:1px solid rgba(112,178,255,.18);background:#70b2ff0e}.checkbox-field{display:flex;align-items:center;gap:10px}.checkbox-field input,.important-tag-list input{width:auto}.important-tag-selector{display:grid;gap:10px;padding:10px;border:1px solid rgba(112,178,255,.18);background:#70b2ff0e}.important-tag-head{display:grid;gap:5px}.important-tag-head span,.important-tag-list small{color:#eef2f394;font-size:.78rem;line-height:1.6}.important-tag-list{display:flex;flex-wrap:wrap;gap:8px}.important-tag-list label{width:auto;display:flex;align-items:center;gap:6px;padding:7px 9px;border:1px solid rgba(255,255,255,.12);background:#ffffff0b}.extra-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px}.extra-fields label:last-child:nth-child(odd){grid-column:1 / -1}.page-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.page-actions button:first-child{border-color:#ff7c7c5c;color:#ffb1b1}.template-panel{display:grid;gap:12px;padding:14px 0;border-top:1px solid rgba(183,247,220,.14);border-bottom:1px solid rgba(183,247,220,.14);background:#b7f7dc09}.template-head{justify-content:space-between;align-items:flex-end}.template-head p{margin:5px 0 0;color:#eef2f38a;font-size:.82rem}.template-head select{width:auto;min-width:150px}.template-library{display:grid;grid-template-columns:repeat(auto-fit,minmax(178px,1fr));gap:10px}.template-card{display:grid;grid-template-columns:1fr auto;gap:7px 10px;min-height:158px;padding:12px;text-align:left;align-content:start;border-color:#b7f7dc38;background:#b7f7dc0f}.template-name{font-weight:700}.template-type{color:#b7f7dcc7;font-size:.75rem}.template-visual{grid-column:1 / -1;display:flex;align-items:center;gap:7px;min-height:58px;padding:9px;border:1px solid rgba(255,255,255,.09);background:#00000030;overflow:hidden}.template-visual mark,.template-visual i,.template-visual em,.template-visual code,.template-visual strong,.template-visual small{display:inline-grid;place-items:center;min-width:34px;min-height:28px;padding:4px 6px;border:1px solid rgba(255,255,255,.13);background:#ffffff14;color:#eef2f3d1;font-style:normal;font:inherit;font-size:.76rem}.template-visual b{width:22px;height:1px;background:#b7f7dc94}.template-visual em{min-width:42px;min-height:38px;background:linear-gradient(135deg,#b7f7dc57,#658dff29),#ffffff0f}.template-visual code{display:block;min-width:0;place-items:start;border:0;background:transparent;font-family:Consolas,SFMono-Regular,monospace}.template-fileTree .template-visual{display:grid;gap:2px}.template-latex .template-visual strong{min-width:46px;min-height:46px;color:#b7f7dc;font-size:1.3rem}.module-list{display:grid;gap:14px}.module-card,.list-item,.export-box{border:1px solid rgba(255,255,255,.1);background:#0000002e}.module-card{border-color:#f7d28b47;background:linear-gradient(180deg,rgba(247,210,139,.08),transparent 96px),#0000002e}.module-card.is-layout-active{border-color:#b7f7dca8;box-shadow:0 0 0 2px #b7f7dc14}.module-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px;border-bottom:1px solid rgba(255,255,255,.1)}.module-head small{display:block;margin-bottom:4px;color:#f7d28bdb}.module-body{display:grid;gap:12px;padding:12px;background:#658dff0b}.list-editor{display:grid;gap:10px;padding:12px;border:1px dashed rgba(255,160,122,.32);background:#ffa07a0e}.list-head{justify-content:space-between}.list-item{display:grid;gap:10px;padding:12px;border-color:#d8b4fe4d;background:#d8b4fe12}.item-actions{justify-content:flex-end}.file-hint{display:grid;gap:8px;color:#eef2f399;font-size:.82rem}.upload-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.upload-row input[type=file]{max-width:100%;color:#eef2f3b8}.upload-row small{color:#b7f7dcb8}.rich-text-assistant{position:fixed;right:22px;bottom:22px;z-index:1200}.rich-format-bubble{display:grid;place-items:center;width:72px;height:72px;padding:0;border-radius:999px;border-color:#b7f7dc61;background:radial-gradient(circle at 35% 20%,rgba(183,247,220,.24),transparent 48%),#121b1cf5;box-shadow:0 16px 38px #00000057}.rich-format-bubble strong{display:block;color:#eef2f3;font-size:.88rem;line-height:1}.rich-format-bubble span{display:block;margin-top:4px;color:#b7f7dcb8;font-size:.68rem;line-height:1}.rich-text-assistant.has-selection .rich-format-bubble{border-color:#b7f7dcb8;box-shadow:0 0 0 4px #b7f7dc14,0 18px 42px #00000061}.rich-text-assistant.is-expanded .rich-format-bubble,.rich-text-popover[hidden]{display:none}.rich-text-popover{position:fixed;right:22px;bottom:22px;z-index:1200;display:grid;grid-template-rows:auto auto minmax(0,1fr) auto;gap:12px;width:clamp(360px,30vw,560px);height:clamp(360px,50vh,620px);padding:14px;border:1px solid rgba(183,247,220,.34);background:#0c1112fa;box-shadow:0 22px 58px #00000075}.rich-popover-head,.rich-popover-actions{display:flex;align-items:center;justify-content:space-between;gap:8px}.rich-popover-head>div{min-width:0}.rich-popover-head strong{display:block;color:#eef2f3;font-size:.9rem}.rich-popover-head span,.rich-module-layout span{display:block;margin-top:4px;overflow:hidden;color:#eef2f39e;font-size:.74rem;line-height:1.35;text-overflow:ellipsis;white-space:nowrap}.rich-context-box,.rich-module-layout{display:grid;gap:8px;padding:10px;border:1px solid rgba(183,247,220,.16);background:#b7f7dc0b}.rich-context-box small{color:#b7f7dcb8;font-size:.72rem}.rich-context-box p{display:-webkit-box;min-height:2.8em;max-height:5.6em;margin:0;overflow:hidden;color:#eef2f3d6;font-size:.82rem;line-height:1.45;-webkit-box-orient:vertical;-webkit-line-clamp:4}.rich-popover-scroll{display:grid;gap:10px;min-height:0;overflow:auto;padding-right:4px}.rich-popover-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.rich-module-layout{border-color:#70b2ff33;background:#70b2ff0e}.rich-module-layout>div:first-child{min-width:0}.rich-module-select-wrap{padding:0;border:0;background:transparent}.rich-text-popover label{gap:5px;font-size:.76rem}.rich-text-popover input,.rich-text-popover select{min-width:0;padding:8px;font-size:.82rem}.rich-text-popover :disabled{cursor:not-allowed;opacity:.45}.rich-popover-actions{justify-content:flex-end;flex-wrap:wrap}.rich-popover-actions button,.rich-popover-head button{padding:6px 8px;font-size:.78rem}@media (max-width: 760px){.rich-text-assistant{right:12px;bottom:12px}.rich-text-popover{right:12px;bottom:12px;width:calc(100vw - 24px);height:min(72vh,620px)}}.field-tools{display:flex;gap:6px;flex-wrap:wrap;padding-top:2px}.field-tools button{padding:5px 7px;color:#eef2f3ad;font-size:.75rem}.image-tools{display:grid;gap:10px;padding:10px;border:1px solid rgba(112,178,255,.22);background:#70b2ff11}.image-tool-head,.image-tool-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.image-tool-head{justify-content:space-between;color:#eef2f3b8}.image-tool-head span{color:#eef2f385;font-size:.78rem}.image-tool-actions button{padding:6px 8px}.image-mini-preview{display:grid;place-items:center;min-height:180px;overflow:hidden;border:1px dashed rgba(255,255,255,.16);background:#0003}.image-mini-preview img{max-width:min(100%,260px);max-height:180px;transform:rotate(var(--admin-img-rotate, 0deg));-o-object-fit:contain;object-fit:contain}.image-mini-preview img.is-quarter-turn{width:180px;height:180px;max-width:min(100%,260px);max-height:260px}.image-mini-preview span{color:#eef2f373;font-size:.82rem}.file-hint code{color:#b7f7dc}#dirty-state{color:#eef2f385;font-size:.82rem}#dirty-state.is-dirty{color:#f7d28b}#preview{padding:14px}#preview-frame{display:block;width:100%;height:calc(100vh - 190px);min-height:520px;border:0;background:#111}.resource-manager{display:grid;gap:10px;margin:14px;padding:12px;border:1px solid rgba(112,178,255,.24);background:#70b2ff0e}.resource-head,.resource-roots,.resource-create,.resource-upload,.resource-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.resource-head{justify-content:space-between}.resource-head>div{display:grid;gap:3px}#resource-current-path,#resource-state,#resource-target-field{color:#eef2f385;font-size:.78rem}.resource-roots button,.resource-actions button{padding:6px 8px;font-size:.78rem}.resource-roots button.active{border-color:#b7f7dc7a;background:#b7f7dc29;color:#b7f7dc}.resource-create input,.resource-upload input[type=text],#resource-search,#resource-selected-path{min-width:0;flex:1 1 150px}.resource-upload input[type=file]{flex:1 1 170px;max-width:100%;color:#eef2f3b8}.resource-list{display:grid;gap:6px;max-height:260px;overflow:auto;padding-right:2px}.resource-item{display:grid;grid-template-columns:44px minmax(0,1fr) auto;gap:8px;align-items:center;width:100%;min-height:46px;text-align:left;border-color:#ffffff1a;background:#0000002e}.resource-item:hover,.resource-item.active{border-color:#70b2ff80;background:#70b2ff24}.resource-item span{display:grid;place-items:center;min-height:28px;color:#b7f7dc;font-size:.68rem;letter-spacing:0;border:1px solid rgba(183,247,220,.16);background:#b7f7dc12}.resource-item strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.resource-item small{color:#eef2f370;font-size:.72rem;white-space:nowrap}.resource-empty{margin:0;padding:12px;color:#eef2f385;border:1px dashed rgba(255,255,255,.14)}.resource-detail{display:grid;gap:8px}.resource-preview{display:grid;place-items:center;min-height:150px;overflow:hidden;color:#eef2f37a;border:1px dashed rgba(255,255,255,.14);background:#0003}.resource-preview img,.resource-preview video{max-width:100%;max-height:220px}.resource-preview iframe{width:100%;height:220px;border:0;background:#111}.resource-preview span{color:#b7f7dc;font-size:.82rem}.inline-note{margin:0;padding:10px 12px;border:1px solid rgba(247,210,139,.24);background:#f7d28b14;color:#f7d28bdb;font-size:.84rem}.preview-page{display:grid;gap:12px}.preview-page h2{margin:0;font-size:1.5rem}.preview-page h3{margin:18px 0 8px;color:#b7f7dc}.preview-page p,.preview-page ul{margin:0;color:#eef2f3bf;line-height:1.6}.preview-page small,.preview-tags{color:#eef2f37a}.preview-chips{display:flex;gap:8px;flex-wrap:wrap}.preview-chips span{border:1px solid rgba(255,255,255,.1);background:#ffffff0f;padding:6px 8px;color:#eef2f3bd;font-size:.82rem}.export-box{margin:14px;padding:10px}.export-box summary{cursor:pointer;color:#eef2f3b3}#json-output{margin-top:10px;min-height:280px;font-family:Consolas,SFMono-Regular,monospace;font-size:.78rem}@media (max-width: 1180px){.admin-layout{grid-template-columns:220px 1fr}.preview-panel{grid-column:1 / -1;position:static;max-height:none}}@media (max-width: 760px){.admin-shell{padding:12px}.admin-topbar,.admin-layout,.editor-grid,.extra-fields{grid-template-columns:1fr}.admin-topbar{display:grid}.auth-card{grid-template-columns:1fr}.resource-item{grid-template-columns:38px minmax(0,1fr)}.resource-item small{grid-column:2}.admin-sidebar{position:static;min-height:0}}
