:root{color-scheme:light;font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,Noto Sans SC,sans-serif;line-height:1.5;font-weight:400;color:#13213a;background:#f4f7fb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at top left,rgba(61,116,255,.1),transparent 28%),linear-gradient(180deg,#f7f9fc,#eef2f8)}a{color:inherit;text-decoration:none}button,input{font:inherit}#root{min-height:100vh}.screen-center{min-height:100vh;display:grid;place-items:center;padding:32px}.panel{background:#ffffffeb;border:1px solid #d9e2ef;border-radius:24px;box-shadow:0 16px 40px #1e345914}.panel-narrow{width:min(460px,100%);padding:28px}.panel-auth{width:min(460px,100%);padding:32px}.auth-header{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.brand-badge{display:inline-flex;align-items:center;justify-content:center;width:fit-content;min-width:72px;padding:6px 12px;border-radius:999px;background:#0f1f48;color:#f5f7fb;font-size:12px;font-weight:700;letter-spacing:.18em}.auth-header h1,.page-heading h1{margin:0;font-size:32px;line-height:1.1}.auth-header p,.page-heading p{margin:0;color:#5d6b85}.auth-form{display:grid;gap:16px}.field{display:grid;gap:8px;color:#1d2c49;font-weight:600}.input{width:100%;border:1px solid #cfd8e6;border-radius:14px;padding:14px 16px;background:#fdfefe;color:#13213a;transition:border-color .2s ease,box-shadow .2s ease}.input:focus{outline:none;border-color:#3563e9;box-shadow:0 0 0 3px #3563e929}.primary-button,.secondary-button{border:0;border-radius:14px;padding:12px 18px;cursor:pointer;transition:transform .15s ease,opacity .15s ease,background-color .15s ease}.primary-button{background:#10214e;color:#fff;font-weight:700}.secondary-button{background:#ecf1f8;color:#13213a;font-weight:600}.primary-button:hover,.secondary-button:hover{transform:translateY(-1px)}.primary-button:disabled,.secondary-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.form-error{border-radius:14px;padding:12px 14px;background:#fff0f0;color:#b42318;border:1px solid #f3c2c2}.auth-tip{color:#6a7892;font-size:14px}.shell{min-height:100vh;display:grid;grid-template-columns:260px 1fr}.sidebar{padding:24px 20px;border-right:1px solid #dce4f1;background:#f4f7fcd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sidebar-brand{display:flex;gap:12px;align-items:center;margin-bottom:24px}.brand-title{font-size:18px;font-weight:700}.brand-subtitle{font-size:13px;color:#62708a}.sidebar-nav{display:grid;gap:8px}.sidebar-link{padding:12px 14px;border-radius:14px;color:#30415f;font-weight:600}.sidebar-link:hover{background:#e9eef7}.sidebar-link-active{background:#10214e;color:#fff}.shell-main{min-width:0;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 28px;border-bottom:1px solid #dce4f1;background:#ffffffc7;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.topbar-title{font-size:20px;font-weight:700}.topbar-subtitle{color:#72819a;font-size:14px}.topbar-actions{display:flex;align-items:center;gap:16px}.admin-meta{text-align:right}.admin-email{font-weight:700}.admin-role{font-size:13px;color:#6e7d97}.content{padding:28px}.placeholder-page,.page-stack{display:grid;gap:20px}.page-heading-inline{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.page-back-link{margin-bottom:8px}.page-back-link a{color:#325bd4;font-weight:600}.placeholder-panel{padding:28px}.placeholder-tag{display:inline-flex;align-items:center;width:fit-content;padding:6px 12px;border-radius:999px;background:#edf2fe;color:#2f5adf;font-size:13px;font-weight:700;margin-bottom:16px}.placeholder-panel h2{margin:0 0 8px;font-size:24px}.placeholder-panel p{margin:0;color:#5f6d87}.filter-panel,.table-panel,.form-panel,.meta-panel{padding:22px}.filter-grid,.form-grid,.meta-grid{display:grid;gap:16px}.filter-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.field-span-2{grid-column:span 2}.sr-only-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.field-hint{color:#62708a;font-size:13px;font-weight:500}.media-upload-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.media-upload-status{display:grid;gap:8px;padding:12px 14px;border:1px solid #d7e0ed;border-radius:14px;background:#f8fbff}.media-upload-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#30415f;font-size:13px;font-weight:600}.media-upload-progress-track{width:100%;height:8px;background:#e4ebf6;border-radius:999px;overflow:hidden}.media-upload-progress-bar{height:100%;border-radius:inherit;background:linear-gradient(90deg,#2f5adf,#4f8bff);transition:width .2s ease}.media-upload-error{color:#b42318;font-size:13px;font-weight:600}.media-preview-card{overflow:hidden;width:min(280px,100%);border:1px solid #d9e2ef;border-radius:18px;background:#f8fbff}.media-preview-image{display:block;width:100%;aspect-ratio:16 / 9;object-fit:cover}.media-preview-fallback{display:grid;place-items:center;min-height:160px;padding:16px;color:#8a2d1f;background:#fff4f1;font-size:13px;font-weight:600;text-align:center}.textarea{width:100%;border:1px solid #cfd8e6;border-radius:14px;padding:14px 16px;background:#fdfefe;color:#13213a;resize:vertical}.textarea:focus{outline:none;border-color:#3563e9;box-shadow:0 0 0 3px #3563e929}.filter-actions,.editor-actions,.pagination-actions,.row-actions{display:flex;gap:10px;flex-wrap:wrap}.filter-actions{margin-top:16px}.section-heading{margin-bottom:20px}.section-heading h2{margin:0 0 6px;font-size:22px}.section-heading p{margin:0;color:#62708a}.editor-grid{display:grid;gap:20px}.compact-form{display:grid;gap:16px}.meta-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.meta-label{display:block;font-size:13px;color:#6e7d97;margin-bottom:6px}.meta-value{font-weight:700}.table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;min-width:1100px}.data-table th,.data-table td{text-align:left;padding:14px 12px;border-bottom:1px solid #e2e8f3;vertical-align:top}.data-table th{font-size:13px;color:#6a7892;font-weight:700}.table-link,.text-action{color:#325bd4;font-weight:600;background:none;border:0;padding:0;cursor:pointer}.text-action-danger{color:#b42318}.panel-state{padding:36px 12px;text-align:center;color:#60708d}.pagination-bar{margin-top:16px;display:flex;align-items:center;justify-content:space-between;gap:16px}.status-badge{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700}.status-badge-neutral{background:#edf1f7;color:#41516f}.status-badge-success{background:#e7f8ef;color:#067647}.status-badge-warning{background:#fff2e5;color:#b54708}.status-badge-danger{background:#fff0f0;color:#b42318}.inline-message{border-radius:16px;border:1px solid #d9e2ef;padding:14px 16px}.inline-message-info{background:#edf4ff;border-color:#c4d8ff}.inline-message-success{background:#eefbf3;border-color:#bfe6ce}.inline-message-danger{background:#fff4f3;border-color:#f2c6c2}.inline-message-title{font-weight:700;margin-bottom:8px}.inline-message-body{color:#30415f}.plain-list{margin:8px 0 0;padding-left:18px}.switch-field{display:flex;align-items:center;gap:10px;min-height:48px;border:1px solid #d7e0ed;border-radius:14px;padding:0 14px;background:#fbfcfe;font-weight:600}.tag-page-layout{display:grid;grid-template-columns:260px 1fr;gap:20px}.tag-sidebar{padding:22px;align-self:start}.tag-main{display:grid;gap:20px}.tag-type-list{display:grid;gap:8px}.tag-type-button{text-align:left;border:1px solid #d7e0ed;background:#fbfcfe;border-radius:14px;padding:12px 14px;cursor:pointer}.tag-type-button-active{background:#10214e;border-color:#10214e;color:#fff}.tag-type-name{font-weight:700}.tag-type-meta{margin-top:4px;font-size:13px;color:#6d7c96}.tag-type-button-active .tag-type-meta{color:#ffffffc7}.tag-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.config-sections{display:grid;gap:20px}.section-actions{margin-top:20px;display:flex;justify-content:flex-end}.checkbox-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.checkbox-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid #d7e0ed;border-radius:999px;padding:8px 12px;background:#fbfcfe;font-size:14px}.plan-day-list{display:grid;gap:18px;margin-top:24px}.plan-day-card{border:1px solid #dde5f0;border-radius:18px;padding:18px;background:#fbfcfe}.plan-day-header{display:flex;justify-content:space-between;gap:16px;margin-bottom:16px}.plan-day-header h3,.section-box h4{margin:0 0 6px}.plan-day-header p,.section-box p,.cell-subtext{margin:0;color:#65748f;font-size:14px}.section-box{margin-top:16px;border-top:1px dashed #d6dfeb;padding-top:16px}.compact-table{min-width:760px}.dashboard-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.dashboard-stat-card{padding:20px;display:grid;gap:8px}.dashboard-stat-title{color:#64748f;font-size:14px;font-weight:600}.dashboard-stat-value{font-size:28px;font-weight:800;color:#10214e}.dashboard-stat-link,.todo-item-link{color:#325bd4;font-weight:600;font-size:14px}.dashboard-panel-full{grid-column:1 / -1}.todo-list{display:grid;gap:14px}.todo-item-card{display:grid;gap:8px;border:1px solid #dde5f0;border-radius:16px;padding:18px;background:#fbfcfe}.todo-item-header{display:flex;justify-content:space-between;gap:16px;align-items:center}.todo-item-header h3{margin:0;font-size:18px}.todo-item-count{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;border-radius:999px;background:#10214e;color:#fff;font-weight:700}.todo-item-card p{margin:0;color:#64748f}.operation-log-table{min-width:980px}.log-details-viewer{display:grid;gap:16px;padding:8px 0}.log-details-meta,.log-json-grid{display:grid;gap:16px}.log-details-meta{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.log-json-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.log-json-card{border:1px solid #dde5f0;border-radius:16px;padding:16px;background:#fbfcfe}.log-json-card h4{margin:0 0 10px}.log-json-card pre{margin:0;max-height:360px;overflow:auto;padding:14px;border-radius:14px;background:#0f1f48;color:#eef3ff;font-size:12px;line-height:1.6}@media(max-width:960px){.shell{grid-template-columns:1fr}.sidebar{border-right:0;border-bottom:1px solid #dce4f1}.topbar{flex-direction:column;align-items:flex-start}.topbar-actions{width:100%;justify-content:space-between}.page-heading-inline,.pagination-bar{flex-direction:column;align-items:flex-start}.form-grid{grid-template-columns:1fr}.field-span-2{grid-column:span 1}.tag-page-layout,.tag-form-grid,.log-json-grid{grid-template-columns:1fr}.plan-day-header{flex-direction:column}}
