:root{font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,sans-serif;color:#17202a;background:#f3f6f8;line-height:1.5}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select,textarea{font:inherit}button{cursor:pointer}input,select,textarea{width:100%;border:1px solid #ccd6e3;border-radius:8px;padding:10px 12px;color:#17202a;background:#fff}textarea{resize:vertical}.app-loading{min-height:100vh;display:grid;place-items:center;color:#435266}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px}.login-panel{width:min(420px,100%);display:grid;gap:18px;padding:28px;border:1px solid #dfe5ee;border-radius:8px;background:#fff;box-shadow:0 16px 40px #23324b14}.login-panel h1,.search-header h1,.detail-section h1,.admin-page h1{margin:0;font-size:24px;letter-spacing:0}.login-panel p,.search-header p,.section-header p,.image-section p{margin:6px 0 0;color:#687789}.login-panel label,.field{display:grid;gap:8px;color:#344256;font-weight:600}.password-input-wrap{position:relative}.password-input-wrap input{padding-right:46px}.password-visibility-button{width:34px;height:34px;min-height:34px;position:absolute;top:50%;right:5px;display:inline-grid;place-items:center;padding:0;border:0;border-radius:8px;background:transparent;color:#687789;transform:translateY(-50%)}.password-visibility-button:hover,.password-visibility-button:focus-visible{background:#e8edf4;color:#253449}.primary-button,.text-button,.danger-button,.secondary-button,.back-button,.filter-chip,.tag-option{min-height:38px;border-radius:8px;border:1px solid #cfd8e5;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;background:#fff;color:#253449}.primary-button{border-color:#176b5f;background:#176b5f;color:#fff}.secondary-button,.back-button{border-color:#cfd8e5;background:#fff;color:#253449}.secondary-button:hover,.back-button:hover{border-color:#9ab7b1;color:#0f574d}.text-button{border-color:transparent;background:transparent;color:#176b5f}.danger-button{border-color:transparent;background:transparent;color:#b42318}.danger-button:disabled{cursor:not-allowed;opacity:.65}.form-error,.error-panel{margin:0;color:#b42318}.success-text{margin:0;color:#176b5f}.helper-text{margin:0;color:#687789;font-size:14px}.app-shell{min-height:100vh}.topbar{min-height:64px;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;background:#fffffff0;border-bottom:1px solid #dfe5ee;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:10}.brand-button{border:0;padding:0;background:transparent;text-align:left}.brand-button strong{display:block;color:#17202a}.brand-button span{color:#687789;font-size:13px}.topbar-actions{display:flex;align-items:center;gap:10px}.topbar-actions select{min-width:150px}.account-menu{position:relative}.account-menu:after{content:"";position:absolute;top:100%;right:0;width:320px;max-width:calc(100vw - 32px);height:12px}.account-button{width:44px;height:44px;display:inline-grid;place-items:center;align-items:center;padding:5px;border:1px solid #d6dde8;border-radius:8px;background:#fff;color:#17202a}.account-button:hover,.account-button.is-open,.account-menu:focus-within .account-button{border-color:#176b5f;background:#f6fbfa}.account-avatar{width:32px;height:32px;flex:0 0 auto;display:inline-grid;place-items:center;border-radius:50%;background:#176b5f;color:#fff;font-weight:700}.account-avatar.large{width:42px;height:42px;font-size:18px}.account-popover-header strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#17202a;font-size:14px}.account-popover-header span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#687789;font-size:12px}.account-popover{position:absolute;top:calc(100% + 10px);right:0;z-index:20;width:min(320px,calc(100vw - 32px));display:none;gap:14px;padding:16px;border:1px solid #dfe5ee;border-radius:8px;background:#fff;box-shadow:0 18px 42px #23324b24}.account-popover.is-open{display:grid}.account-popover-header{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px}.account-popover-header div{min-width:0;display:grid;gap:2px}.account-details{display:grid;gap:10px;margin:0}.account-details div{display:grid;grid-template-columns:78px minmax(0,1fr);gap:10px}.account-details dt{color:#687789;font-size:13px}.account-details dd{margin:0;overflow-wrap:anywhere;color:#253449;font-size:13px}.account-actions{display:grid;gap:8px}.account-action-button{width:100%}.password-form{display:grid;gap:16px}.icon-button{width:38px;height:38px;display:inline-grid;place-items:center;border:1px solid #d6dde8;background:#fff;border-radius:8px;color:#2c3a4b}.icon-button.active,.filter-chip.selected,.tag-option.selected{border-color:#176b5f;background:#e8f3f1;color:#0f574d}.view-toggle{display:flex;flex-wrap:wrap;gap:8px}.page-body{max-width:1180px;margin:0 auto;padding:28px 24px 40px}.empty-panel,.error-panel{border:1px solid #dfe5ee;background:#fff;padding:22px;border-radius:8px;color:#687789}.empty-panel p{margin:6px 0 0}.content-search,.admin-page,.detail-page{display:grid;gap:20px}.search-header,.section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}.search-box{min-width:min(620px,100%);display:grid;grid-template-columns:22px 1fr 148px auto;gap:10px;align-items:center;padding:10px;border:1px solid #dfe5ee;border-radius:8px;background:#fff;box-shadow:0 12px 28px #2f3f540f}.search-box input{border:0;padding:8px;background:#f6f8fb}.keyword-input-wrap{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:4px;border-radius:8px;background:#f6f8fb}.keyword-input-wrap input{min-width:0;background:transparent}.search-box .keyword-clear-button{width:30px;height:30px;min-height:30px;border:0;border-radius:8px;padding:0;background:transparent;color:#687789}.search-box .keyword-clear-button:hover{background:#e8edf4;color:#253449}.search-box select,.search-box .date-input{height:38px;border:0;padding:0 8px;background:#f6f8fb}.search-box button{height:38px;border:0;border-radius:8px;padding:0 14px;background:#176b5f;color:#fff}.filter-panel{display:grid;gap:12px;padding:16px;border:1px solid #dfe5ee;border-radius:8px;background:#fff;box-shadow:0 10px 24px #2f3f540d}.filter-group{display:grid;grid-template-columns:92px minmax(0,1fr);gap:10px;align-items:start}.filter-label{display:grid;gap:2px;padding-top:6px}.filter-label span{color:#435266;font-weight:700}.filter-label small{color:#7a8798;font-size:12px}.filter-chip-list{display:flex;flex-wrap:wrap;gap:8px;padding-right:4px}.filter-chip.subtle{border-style:dashed;color:#176b5f}.clear-filter-button{justify-self:start;min-height:34px;border:0;display:inline-flex;align-items:center;gap:6px;padding:0 8px;background:transparent;color:#176b5f}.content-list{display:grid;gap:12px}.content-row{width:100%;display:grid;gap:8px;padding:20px;border:1px solid #dfe5ee;border-radius:8px;background:#fff;text-align:left;box-shadow:0 8px 20px #2f3f540a}.content-row:hover{border-color:#9ab7b1;box-shadow:0 12px 26px #2f3f5412}.clickable-row{cursor:pointer}.clickable-row:focus-visible{outline:2px solid #176b5f;outline-offset:2px}.content-row>div:first-child{display:flex;justify-content:space-between;gap:14px}.row-meta-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:8px}.favorite-button{min-height:32px;border:1px solid #d8e0ea;border-radius:8px;display:inline-flex;align-items:center;gap:6px;padding:0 10px;background:#fff;color:#435266}.view-count{min-height:28px;display:inline-flex;align-items:center;gap:5px;color:#687789;font-size:13px}.result-summary{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 2px}.result-summary strong{color:#17202a;font-size:17px}.result-summary span{color:#687789}.favorite-button.active{border-color:#d7c48d;background:#fff7df;color:#795b12}.favorite-button:disabled{cursor:not-allowed;opacity:.65}.row-tags{display:flex;flex-wrap:wrap;gap:6px}.row-actions{display:flex;justify-content:flex-end;gap:8px}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px solid #dfe5ee;border-radius:8px;background:#fff}.admin-search{flex:1;display:grid;grid-template-columns:22px minmax(0,1fr);align-items:center;gap:8px}.admin-search input{border:0;background:#f6f8fb}.admin-toolbar span{color:#687789;font-size:14px}.content-row strong{color:#17202a}.keyword-highlight{border-radius:4px;padding:0 3px;background:#fff1a8;color:#17202a;font-weight:700}.content-row span,.content-row p,.muted-text{margin:0;color:#687789}.detail-section{display:grid;gap:14px;padding:22px;border:1px solid #dfe5ee;border-radius:8px;background:#fff;box-shadow:0 10px 24px #2f3f540d}.detail-toolbar,.editor-header{display:flex;align-items:center;justify-content:flex-start}.detail-toolbar{justify-content:space-between}.detail-loading-note{padding:10px 14px;border:1px solid #d8e8e5;border-radius:8px;background:#f3fbf9;color:#176b5f;font-size:14px}.section-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.detail-section h2{margin:0;font-size:18px;letter-spacing:0}.meta-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;color:#687789}.tag,.status-badge{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;background:#eef3f8;color:#344256;font-size:13px}.tag-type{background:#f3efe7;color:#694f20}.detail-body{margin:0;padding:16px;border-left:3px solid #176b5f;border-radius:8px;background:#f8fafc;white-space:pre-wrap;color:#253449}.image-section{border-color:#c6d8d5;background:#fbfefd}.image-figure{margin:0;display:grid;gap:8px;border:1px solid #dfe5ee;border-radius:8px;padding:12px;background:#fff}.image-figure img{width:100%;max-height:680px;object-fit:contain;border-radius:6px;background:#f6f8fb}.image-preview-trigger{width:100%;border:0;padding:0;border-radius:6px;background:transparent;cursor:zoom-in}.image-preview-trigger:focus-visible{outline:3px solid rgba(23,107,95,.24);outline-offset:3px}.image-preview-trigger:hover img{box-shadow:0 0 0 2px #176b5f38}.image-preview-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:grid;place-items:center;padding:24px;background:#17202ab8}.image-preview-dialog{width:min(1200px,100%);max-height:calc(100vh - 48px);display:grid;grid-template-rows:auto minmax(0,1fr);gap:12px;padding:14px;border-radius:8px;background:#fff;box-shadow:0 24px 64px #0a121e57}.image-preview-toolbar{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px}.image-preview-toolbar strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#17202a}.image-preview-dialog img{width:100%;max-height:calc(100vh - 132px);object-fit:contain;border-radius:6px;background:#f6f8fb}.image-fallback{min-height:160px;display:grid;place-items:center;gap:6px;padding:18px;border-radius:6px;background:#f6f8fb;color:#435266;text-align:center}.image-fallback span{max-width:100%;overflow-wrap:anywhere;color:#687789;font-size:13px}.image-figure figcaption{color:#435266;font-size:14px}.editor-form{display:grid;gap:16px;padding:22px;border:1px solid #dfe5ee;border-radius:8px;background:#fff}.panel-title{margin:0;color:#17202a;font-size:18px;letter-spacing:0}.editor-actions{padding-top:6px;justify-content:flex-start}.editor-actions .primary-button,.editor-actions .text-button{width:auto}.tag-picker{display:grid;gap:8px}.tag-picker>span{color:#344256;font-weight:700}.tag-picker>div,.form-actions{display:flex;flex-wrap:wrap;gap:8px}.dropzone{min-height:120px;display:grid;place-items:center;gap:6px;padding:18px;border:1px dashed #9fb0c3;border-radius:8px;background:#f8fafc;color:#435266;text-align:center}.dropzone.dragging{border-color:#176b5f;background:#e8f3f1}.dropzone input{display:none}.dropzone strong{color:#253449}.dropzone span{color:#687789;font-size:14px}.pending-files{display:grid;gap:8px}.pending-files>span{color:#344256;font-weight:700}.pending-files>div{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 10px;border:1px solid #dfe5ee;border-radius:8px;background:#fff}.pending-files>div>span{overflow-wrap:anywhere;color:#435266}.attachment-manager{display:grid;gap:10px}.attachment-manager>span{color:#344256;font-weight:700}.attachment-manager>div{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.attachment-preview{display:grid;gap:8px;align-content:start;padding:10px;border:1px solid #dfe5ee;border-radius:8px;background:#fff}.attachment-preview img,.attachment-placeholder{width:100%;aspect-ratio:4 / 3;border-radius:6px;background:#f6f8fb}.attachment-preview img{object-fit:contain}.attachment-placeholder{display:grid;place-items:center;color:#687789}.attachment-preview span{overflow-wrap:anywhere;color:#435266;font-size:13px}.admin-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}.user-feedback,.user-management-panel{display:grid;gap:16px;padding:22px;border:1px solid #dfe5ee;border-radius:8px;background:#fff}.user-list{display:grid;gap:12px}.user-card{display:grid;gap:16px;padding:18px;border:1px solid #dfe5ee;border-radius:8px;background:#fff}.user-card.inactive{background:#f8fafc}.user-card-main{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(220px,.8fr);gap:18px}.user-title-line{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.user-title-line strong{color:#17202a}.user-card-main p,.user-meta span{margin:4px 0 0;color:#687789}.user-meta{display:grid;justify-items:end;align-content:start;gap:4px;text-align:right}.status-pill{display:inline-flex;align-items:center;min-height:24px;padding:0 10px;border-radius:999px;background:#eef3f7;color:#435266;font-size:13px}.status-pill.active{background:#e8f3f1;color:#0f574d}.status-pill.inactive{background:#fff0ed;color:#b42318}.user-edit-panel{display:grid;gap:14px;padding:16px;border:1px solid #e3e9f1;border-radius:8px;background:#f8fafc}.compact-form{grid-template-columns:180px 1fr auto;align-items:start}.compact-form .form-error{grid-column:1 / -1}.tag-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.tag-create-panel{display:grid;gap:12px;padding:18px;border:1px solid #dfe5ee;border-radius:8px;background:#fff;box-shadow:0 10px 24px #2f3f540d}.tag-create-panel>div{display:grid;grid-template-columns:180px minmax(0,1fr) auto;gap:12px;align-items:end}.tag-create-panel label{display:grid;gap:8px;color:#344256;font-weight:700}.tag-admin-card{align-content:start}.tag-admin-card h2{margin:0}.tag-admin-card p{margin:6px 0 0;color:#687789}.tag-admin-list{display:grid;gap:10px}.tag-admin-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:10px;border:1px solid #eef2f6;border-radius:8px;background:#fbfcfe}.tag-admin-row .tag{justify-self:start}.tag-admin-row input{min-width:0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;background:#17202a5c;z-index:20}.modal-panel{width:min(640px,100%);max-height:min(760px,90vh);overflow:auto;padding:22px;border-radius:8px;background:#fff}@media(max-width:780px){.topbar,.search-header,.section-header{align-items:stretch;flex-direction:column}.topbar-actions{flex-wrap:wrap}.admin-toolbar{align-items:stretch;flex-direction:column}.search-box{grid-template-columns:22px 1fr}.search-box button,.search-box select,.search-box .date-input{grid-column:1 / -1}.filter-group{grid-template-columns:1fr}.page-body{padding:16px}.topbar{padding:0 12px}.topbar-actions{gap:6px}.account-button{width:42px;height:42px}.compact-form,.tag-columns,.tag-create-panel>div,.tag-admin-row,.user-card-main{grid-template-columns:1fr}.user-meta{justify-items:start;text-align:left}}
