:root{color-scheme:light;--page-bg: linear-gradient(160deg, #f0f4ff, #f9fafb 60%);--font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:var(--font-body);background:var(--page-bg);color:#0f172a}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}button,input,textarea{font-family:inherit}::selection{background:#6366f140}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4f46e5,#6366f1);padding:20px}.login-card{background:#fff;border-radius:20px;box-shadow:0 25px 50px #0f172a40;padding:48px 40px;width:100%;max-width:400px}.login-title{margin:0 0 8px;font-size:28px;font-weight:700;color:#0f172a;text-align:center}.login-subtitle{margin:0 0 32px;font-size:14px;color:#64748b;text-align:center}.login-form{display:grid;gap:20px}.form-group{display:grid;gap:8px}.login-error{padding:12px 16px;border-radius:10px;background:#fee2e2b3;border:1px solid rgba(248,113,113,.6);color:#b91c1c;font-size:14px}.login-button{background:#6366f1;color:#fff;border:none;border-radius:999px;font-size:16px;font-weight:600;padding:14px 24px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;box-shadow:0 8px 20px #6366f14d;margin-top:8px}.login-button:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 10px 24px #6366f166}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}@media (max-width: 480px){.login-card{padding:36px 28px}.login-title{font-size:24px}}.layout{max-width:880px;margin:0 auto;padding:32px 16px 96px;min-height:100vh;display:flex;flex-direction:column;gap:24px}@media (min-width: 768px){.layout{padding:48px 24px 120px;gap:32px}}.hero{background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff;padding:32px;border-radius:20px;box-shadow:0 10px 30px #6366f159;position:relative}.hero-content{max-width:520px}.hero h1{margin:0 0 12px;font-size:28px;font-weight:700}.hero p{margin:0;line-height:1.6}.logout-btn{position:absolute;top:32px;right:32px;background:#fff3;color:#fff;border:none;border-radius:999px;font-size:14px;font-weight:600;padding:8px 16px;cursor:pointer;transition:background .15s ease}.logout-btn:hover{background:#ffffff4d}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;font-size:18px;color:#64748b}.panel{background:#fff;border-radius:20px;box-shadow:0 18px 40px #0f172a14;padding:28px}@media (min-width: 768px){.panel{padding:36px}}.text-form{display:grid;gap:16px}.field-label{font-size:14px;color:#475569;font-weight:600}.input,.textarea{width:100%;border:1px solid rgba(148,163,184,.4);border-radius:14px;padding:12px 14px;font-size:15px;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease;background:#f8fafc99}.input:focus,.textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f133;background:#fff}.textarea{resize:vertical;line-height:1.5}.form-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.upload-btn,.submit-btn,.refresh-btn,.action{border:none;border-radius:999px;font-size:15px;font-weight:600;cursor:pointer;padding:10px 20px;transition:transform .15s ease,box-shadow .15s ease}.upload-btn{background:#6366f124;color:#4338ca}.submit-btn{background:#6366f1;color:#fff;box-shadow:0 8px 20px #6366f133}.upload-btn:disabled,.submit-btn:disabled,.refresh-btn:disabled,.action:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.upload-btn:not(:disabled):hover,.submit-btn:not(:disabled):hover,.refresh-btn:not(:disabled):hover,.action:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 10px 20px #0f172a1f}.helper-text{margin:0;font-size:13px;color:#64748b}.panel-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px}.panel-header h2{margin:0;font-size:20px}.refresh-btn{background:#0f172a0d;color:#1e293b}.placeholder,.error{padding:36px 0;text-align:center;color:#64748b}.error{color:#dc2626}.error-banner{margin-bottom:20px;padding:14px 18px;border-radius:14px;background:#fee2e2b3;border:1px solid rgba(248,113,113,.6);color:#b91c1c}.history{list-style:none;margin:0;padding:0;display:grid;gap:18px}.history-item{border:1px solid rgba(226,232,240,.9);border-radius:16px;padding:18px 20px;background:#f8fafc99;display:grid;gap:14px}.history-meta{display:flex;flex-wrap:wrap;gap:12px;align-items:center;font-size:13px;color:#475569}.badge{padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-text{background:#10b98129;color:#047857}.badge-file{background:#3b82f629;color:#1d4ed8}.origin{color:#0f172a;font-weight:500}.history-meta time{margin-left:auto;color:#475569}.history-body{background:#fff;border-radius:12px;padding:14px 16px;font-size:15px;color:#0f172a;max-height:320px;overflow:auto;word-break:break-word;white-space:pre-wrap}.image-body{display:grid;gap:10px;max-height:none;overflow:visible}.image-preview{width:100%;max-height:360px;object-fit:contain;border-radius:10px;background:#f8fafc}.image-caption,.file-body{display:flex;justify-content:space-between;align-items:center;gap:12px}.file-name{font-weight:600;color:#0f172a}.file-meta{font-size:13px;color:#475569}.history-actions{display:flex;flex-wrap:wrap;gap:10px}.action{background:#0f172a14;color:#1e293b}.action.danger{background:#ef444424;color:#b91c1c}.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%);background:#0f172a;color:#fff;padding:14px 20px;border-radius:999px;box-shadow:0 12px 40px #0f172a4d;font-size:15px;display:inline-flex;gap:10px;align-items:center}.toast-warn{background:#f97316}.toast-error{background:#dc2626}@media (max-width: 640px){.hero{padding:26px}.panel{padding:24px}.history-item{padding:16px}.history-meta time{flex-basis:100%;margin-left:0}}
