:root{--vt-c-white:#fff;--vt-c-white-soft:#f8f8f8;--vt-c-white-mute:#f2f2f2;--vt-c-black:#181818;--vt-c-black-soft:#222;--vt-c-black-mute:#282828;--vt-c-indigo:#2c3e50;--vt-c-divider-light-1:#3c3c3c4a;--vt-c-divider-light-2:#3c3c3c1f;--vt-c-divider-dark-1:#545454a6;--vt-c-divider-dark-2:#5454547a;--vt-c-text-light-1:var(--vt-c-indigo);--vt-c-text-light-2:#3c3c3ca8;--vt-c-text-dark-1:var(--vt-c-white);--vt-c-text-dark-2:#ebebeba3;--color-background:var(--vt-c-white);--color-background-soft:var(--vt-c-white-soft);--color-background-mute:var(--vt-c-white-mute);--color-border:var(--vt-c-divider-light-2);--color-border-hover:var(--vt-c-divider-light-1);--color-heading:var(--vt-c-text-light-1);--color-text:var(--vt-c-text-light-1);--section-gap:160px}@media (prefers-color-scheme:dark){:root{--color-background:var(--vt-c-black);--color-background-soft:var(--vt-c-black-soft);--color-background-mute:var(--vt-c-black-mute);--color-border:var(--vt-c-divider-dark-2);--color-border-hover:var(--vt-c-divider-dark-1);--color-heading:var(--vt-c-text-dark-1);--color-text:var(--vt-c-text-dark-2)}}:root{--vt-c-white:#fff;--vt-c-white-soft:#f8f8f8;--vt-c-white-mute:#f2f2f2;--vt-c-black:#181818;--vt-c-black-soft:#222;--vt-c-black-mute:#282828;--vt-c-indigo:#2c3e50;--vt-c-divider-light-1:#3c3c3c4a;--vt-c-divider-light-2:#3c3c3c1f;--vt-c-divider-dark-1:#545454a6;--vt-c-divider-dark-2:#5454547a;--vt-c-text-light-1:var(--vt-c-indigo);--vt-c-text-light-2:#3c3c3ca8;--vt-c-text-dark-1:var(--vt-c-white);--vt-c-text-dark-2:#ebebeba3;--color-background:var(--vt-c-white);--color-background-soft:var(--vt-c-white-soft);--color-background-mute:var(--vt-c-white-mute);--color-border:var(--vt-c-divider-light-2);--color-border-hover:var(--vt-c-divider-light-1);--color-heading:var(--vt-c-text-light-1);--color-text:var(--vt-c-text-light-1);--section-gap:160px}@media (prefers-color-scheme:dark){:root{--color-background:var(--vt-c-black);--color-background-soft:var(--vt-c-black-soft);--color-background-mute:var(--vt-c-black-mute);--color-border:var(--vt-c-divider-dark-2);--color-border-hover:var(--vt-c-divider-dark-1);--color-heading:var(--vt-c-text-dark-1);--color-text:var(--vt-c-text-dark-2)}}*,:before,:after{box-sizing:border-box;margin:0;font-weight:400}body{min-height:100vh;color:var(--color-text);background:var(--color-background);text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:15px;line-height:1.6;transition:color .5s,background-color .5s}#app{max-width:1280px;margin:0 auto;padding:2rem;font-weight:400}a,.green{color:#00bd7e;padding:3px;text-decoration:none;transition:all .4s}@media (hover:hover){a:hover{background-color:#00bd7e33}}@media (width>=1024px){body{place-items:center;display:flex}#app{grid-template-columns:1fr 1fr;padding:0 2rem;display:grid}}[data-v-695fcf83]{box-sizing:border-box}html[data-v-695fcf83],body[data-v-695fcf83]{height:100%;margin:0;padding:0}.login-container[data-v-695fcf83]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100dvh;padding:20px;display:flex}.form-card[data-v-695fcf83]{background:#fff;border-radius:24px;width:100%;max-width:420px;padding:40px;box-shadow:0 25px 80px #0003}h2[data-v-695fcf83]{text-align:center;color:#333;letter-spacing:2px;margin:0 0 35px;font-size:28px}.input-group[data-v-695fcf83]{margin-bottom:22px}.input-group label[data-v-695fcf83]{color:#555;margin-bottom:10px;font-size:14px;font-weight:500;display:block}.input-group input[data-v-695fcf83]{border:2px solid #eee;border-radius:12px;width:100%;padding:16px 18px;font-size:16px;transition:border-color .3s}.input-group input[data-v-695fcf83]:focus{border-color:#667eea;outline:none}.submit-btn[data-v-695fcf83]{color:#fff;cursor:pointer;letter-spacing:2px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:12px;width:100%;margin-top:15px;padding:18px;font-size:17px;font-weight:700;transition:all .3s}.submit-btn[data-v-695fcf83]:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.submit-btn[data-v-695fcf83]:disabled{cursor:not-allowed;box-shadow:none;background:#ccc;transform:none}.toggle-text[data-v-695fcf83]{text-align:center;color:#666;margin-top:30px;font-size:14px}.toggle-text a[data-v-695fcf83]{color:#667eea;font-weight:700;text-decoration:none}.toggle-text a[data-v-695fcf83]:hover{text-decoration:underline}.back-btn[data-v-695fcf83]{color:#667eea;cursor:pointer;background:0 0;border:2px solid #667eea;border-radius:12px;width:100%;margin-top:20px;padding:14px;font-size:15px;transition:all .3s}.back-btn[data-v-695fcf83]:hover{background:#667eea1a}.error-msg[data-v-695fcf83]{color:#c62828;text-align:center;background:#ffebee;border-radius:12px;margin-top:25px;padding:16px;font-size:14px}.success-msg[data-v-695fcf83]{color:#2e7d32;text-align:center;background:#e8f5e9;border-radius:12px;margin-top:25px;padding:16px;font-size:14px}@media (width<=600px){.form-card[data-v-695fcf83]{padding:30px 25px}h2[data-v-695fcf83]{margin-bottom:30px;font-size:24px}.input-group[data-v-695fcf83]{margin-bottom:18px}.input-group input[data-v-695fcf83]{padding:14px 16px;font-size:15px}.submit-btn[data-v-695fcf83]{padding:16px;font-size:16px}}.profile-panel[data-v-a15230c5]{z-index:1000;background:#fff;flex-direction:column;width:100%;max-width:420px;height:100vh;display:flex;position:fixed;top:0;right:0;overflow-y:auto;box-shadow:-4px 0 30px #00000026}.panel-header[data-v-a15230c5]{background:#fff;border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:20px;display:flex;position:sticky;top:0}.panel-header h3[data-v-a15230c5]{color:#333;margin:0;font-size:18px}.close-btn[data-v-a15230c5]{color:#666;cursor:pointer;background:#f5f5f5;border:none;border-radius:50%;width:36px;height:36px;font-size:20px;transition:all .3s}.close-btn[data-v-a15230c5]:hover{color:#333;background:#e0e0e0}.panel-content[data-v-a15230c5]{flex:1;padding:25px}.avatar-section[data-v-a15230c5]{text-align:center;margin-bottom:25px}.avatar[data-v-a15230c5]{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;margin:0 auto;font-size:40px;font-weight:700;transition:all .3s;display:flex;overflow:hidden}.avatar[data-v-a15230c5]:hover{transform:scale(1.05)}.avatar img[data-v-a15230c5]{object-fit:cover;width:100%;height:100%}.avatar-hint[data-v-a15230c5]{color:#999;margin:10px 0 0;font-size:13px}.uploading-area[data-v-a15230c5]{color:#666;background:#f5f5f5;border-radius:8px;justify-content:center;align-items:center;gap:10px;margin-top:15px;padding:12px;font-size:14px;display:flex}.spinner[data-v-a15230c5]{border:2px solid #ddd;border-top-color:#667eea;border-radius:50%;width:16px;height:16px;animation:1s linear infinite spin-a15230c5}@keyframes spin-a15230c5{to{transform:rotate(360deg)}}.form-section[data-v-a15230c5]{flex-direction:column;gap:18px;display:flex}.form-group[data-v-a15230c5]{flex-direction:column;gap:6px;display:flex}.form-group label[data-v-a15230c5]{color:#555;font-size:14px;font-weight:500}.form-group input[data-v-a15230c5],.form-group select[data-v-a15230c5]{border:2px solid #eee;border-radius:10px;padding:14px;font-size:15px;transition:border-color .3s}.form-group input[data-v-a15230c5]:focus,.form-group select[data-v-a15230c5]:focus{border-color:#667eea;outline:none}.hint[data-v-a15230c5]{color:#999;margin:4px 0 0;font-size:12px}.cooldown-hint[data-v-a15230c5]{color:#e65100;margin:4px 0 0;font-size:12px}.cooldown-hint strong[data-v-a15230c5]{color:#ff6d00}.btn-group[data-v-a15230c5]{gap:12px;margin-top:20px;display:flex}.save-btn[data-v-a15230c5]{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:10px;flex:1;padding:15px;font-size:15px;font-weight:500}.save-btn[data-v-a15230c5]:disabled{cursor:not-allowed;background:#ccc}.cancel-btn[data-v-a15230c5]{color:#666;cursor:pointer;background:#f5f5f5;border:none;border-radius:10px;padding:15px 24px;font-size:15px}.success-msg[data-v-a15230c5]{color:#2e7d32;text-align:center;background:#efe;border-radius:10px;margin-top:15px;padding:14px;font-size:14px}.error-msg[data-v-a15230c5]{color:#c62828;text-align:center;background:#fee;border-radius:10px;margin-top:15px;padding:14px;font-size:14px}[data-v-ab1ee035]{box-sizing:border-box}html[data-v-ab1ee035],body[data-v-ab1ee035]{height:100%;margin:0;padding:0}.dashboard[data-v-ab1ee035]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);flex-direction:column;min-height:100vh;display:flex}.header[data-v-ab1ee035]{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#ffffff26;justify-content:space-between;align-items:center;padding:20px 40px;display:flex}.header h1[data-v-ab1ee035]{color:#fff;letter-spacing:6px;margin:0;font-size:32px;font-weight:700}.user-section[data-v-ab1ee035]{flex-direction:column;align-items:flex-end;gap:10px;display:flex}.user-info[data-v-ab1ee035]{align-items:center;gap:12px;display:flex}.user-actions[data-v-ab1ee035]{gap:8px;display:flex}.action-btn[data-v-ab1ee035]{color:#fff;cursor:pointer;background:#fff3;border:1px solid #ffffff4d;border-radius:15px;padding:6px 14px;font-size:12px;transition:all .3s}.action-btn[data-v-ab1ee035]:hover{background:#ffffff4d}.logout-btn[data-v-ab1ee035]{background:#ff64644d;border-color:#ff646466}.logout-btn[data-v-ab1ee035]:hover{background:#ff646480}.user-avatar[data-v-ab1ee035]{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;font-weight:700;display:flex}.user-name[data-v-ab1ee035]{color:#fff;font-size:15px}.main-content[data-v-ab1ee035]{flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px 20px;display:flex}.year-tabs[data-v-ab1ee035]{gap:30px;margin-bottom:50px;display:flex}.year-tabs button[data-v-ab1ee035]{color:#fff;cursor:pointer;background:#ffffff1a;border:3px solid #0000;border-radius:30px;padding:16px 60px;font-size:22px;font-weight:700;transition:all .3s}.year-tabs button.active[data-v-ab1ee035]{color:#667eea;background:#fff;border-color:#ffffff80}.modules-grid[data-v-ab1ee035]{gap:50px;display:flex}.module-card[data-v-ab1ee035]{text-align:center;cursor:pointer;background:#fff;border-radius:24px;width:350px;padding:60px 50px;transition:all .3s;box-shadow:0 15px 50px #0003}.module-card[data-v-ab1ee035]:hover{transform:translateY(-12px);box-shadow:0 25px 70px #0000004d}.module-card h2[data-v-ab1ee035]{color:#333;margin:0 0 12px;font-size:32px}.module-card p[data-v-ab1ee035]{color:#667eea;margin:0;font-size:16px}.login-btn[data-v-ab1ee035]{color:#fff;cursor:pointer;background:#fff3;border:2px solid #ffffff80;border-radius:20px;padding:10px 24px;font-size:14px;font-weight:500;transition:all .3s}.login-btn[data-v-ab1ee035]:hover{background:#ffffff4d}.browse-hint[data-v-ab1ee035]{color:#ffffffb3;margin-top:30px;font-size:14px}@media (width<=600px){.header[data-v-ab1ee035]{flex-wrap:wrap;padding:15px 20px}.header h1[data-v-ab1ee035]{letter-spacing:3px;font-size:22px}.user-section[data-v-ab1ee035]{flex-direction:row;justify-content:space-between;align-items:center;width:100%;margin-top:12px}.user-info[data-v-ab1ee035]{gap:8px}.user-avatar[data-v-ab1ee035]{width:35px;height:35px;font-size:15px}.user-name[data-v-ab1ee035]{font-size:13px}.user-actions[data-v-ab1ee035]{gap:6px}.action-btn[data-v-ab1ee035]{padding:5px 12px;font-size:11px}.login-btn[data-v-ab1ee035]{padding:8px 18px;font-size:13px}.main-content[data-v-ab1ee035]{padding:30px 15px}.year-tabs[data-v-ab1ee035]{flex-direction:column;gap:15px;margin-bottom:30px}.year-tabs button[data-v-ab1ee035]{padding:14px 50px;font-size:18px}.module-card[data-v-ab1ee035]{width:280px;padding:40px 30px}.module-card h2[data-v-ab1ee035]{font-size:26px}.module-card p[data-v-ab1ee035]{font-size:14px}.browse-hint[data-v-ab1ee035]{text-align:center;padding:0 20px;font-size:13px}}[data-v-5a926257]{box-sizing:border-box}.memoir-page[data-v-5a926257]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);flex-direction:column;min-height:100dvh;display:flex}.header[data-v-5a926257]{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);z-index:100;background:#ffffff26;justify-content:space-between;align-items:center;padding:15px 20px;display:flex;position:sticky;top:0}.back-btn[data-v-5a926257]{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:8px;padding:8px 16px;font-size:14px}.header h1[data-v-5a926257]{color:#fff;letter-spacing:2px;margin:0;font-size:18px}.user-name[data-v-5a926257]{color:#fff;background:#fff3;border-radius:15px;padding:6px 12px;font-size:14px}.main-content[data-v-5a926257]{flex:1;width:100%;max-width:800px;margin:0 auto;padding:15px 15px 80px}.chapters-nav[data-v-5a926257]{background:#fffffff2;border-radius:16px;flex-wrap:wrap;gap:8px;margin-bottom:15px;padding:12px;display:flex}.chapters-nav button[data-v-5a926257]{color:#555;cursor:pointer;background:#f0f0f0;border:none;border-radius:20px;padding:8px 14px;font-size:12px;transition:all .3s}.chapters-nav button.active[data-v-5a926257]{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.chapter-header[data-v-5a926257]{text-align:center;background:#fff;border-radius:16px;margin-bottom:15px;padding:16px}.chapter-header h2[data-v-5a926257]{color:#333;margin:0;font-size:16px;font-weight:500}.posts-section[data-v-5a926257]{background:#fff;border-radius:16px;margin-bottom:15px;padding:16px}.loading[data-v-5a926257],.error-msg[data-v-5a926257],.empty-msg[data-v-5a926257]{text-align:center;color:#666;padding:40px 20px;font-size:14px}.sub-text[data-v-5a926257]{color:#999;margin-top:8px;font-size:13px}.posts-list[data-v-5a926257]{flex-direction:column;gap:20px;display:flex}.post-card[data-v-5a926257]{border-bottom:1px solid #eee;padding-bottom:20px}.post-card[data-v-5a926257]:last-child{border-bottom:none;padding-bottom:0}.post-meta[data-v-5a926257]{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:10px;display:flex}.post-author[data-v-5a926257]{color:#333;font-size:14px;font-weight:500}.post-time[data-v-5a926257]{color:#999;flex:1;font-size:12px}.delete-btn[data-v-5a926257]{color:#fff;cursor:pointer;background:#f44;border:none;border-radius:4px;padding:4px 12px;font-size:12px}.post-content[data-v-5a926257]{color:#444;margin-bottom:10px;font-size:14px;line-height:1.7}.post-image[data-v-5a926257]{cursor:pointer;border-radius:12px;position:relative;overflow:hidden}.post-image img[data-v-5a926257]{object-fit:cover;width:100%;max-height:400px;transition:opacity .3s}.post-image:hover img[data-v-5a926257]{opacity:.8}.image-overlay[data-v-5a926257]{opacity:0;background:#0000004d;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:absolute;inset:0}.post-image:hover .image-overlay[data-v-5a926257]{opacity:1}.image-overlay span[data-v-5a926257]{color:#fff;background:#00000080;border-radius:20px;padding:8px 16px;font-size:14px}.comment-form-expanded[data-v-5a926257]{z-index:200;background:#fff;border-radius:20px 20px 0 0;max-width:800px;margin:0 auto;padding:20px;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 30px #0003}.comment-form-expanded textarea[data-v-5a926257]{resize:vertical;border:2px solid #eee;border-radius:12px;width:100%;margin-bottom:12px;padding:14px;font-family:inherit;font-size:14px}.comment-form-expanded textarea[data-v-5a926257]:focus{border-color:#667eea;outline:none}.upload-section[data-v-5a926257]{margin-bottom:12px}.upload-btn[data-v-5a926257]{color:#666;cursor:pointer;background:#f5f5f5;border:2px dashed #ddd;border-radius:10px;width:100%;padding:10px 20px;font-size:14px}.uploading[data-v-5a926257]{color:#666;background:#f9f9f9;border-radius:10px;justify-content:center;align-items:center;gap:10px;padding:15px;font-size:14px;display:flex}.spinner[data-v-5a926257]{border:2px solid #ddd;border-top-color:#667eea;border-radius:50%;width:18px;height:18px;animation:1s linear infinite spin-5a926257}@keyframes spin-5a926257{to{transform:rotate(360deg)}}.image-preview[data-v-5a926257]{display:inline-block;position:relative}.image-preview img[data-v-5a926257]{object-fit:cover;border-radius:10px;max-width:200px;max-height:150px}.remove-btn[data-v-5a926257]{color:#fff;cursor:pointer;background:#f44;border:none;border-radius:50%;width:24px;height:24px;font-size:14px;line-height:24px;position:absolute;top:-8px;right:-8px}.form-actions[data-v-5a926257]{justify-content:flex-end;gap:10px;display:flex}.submit-btn[data-v-5a926257]{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:10px;padding:12px 28px;font-size:14px}.submit-btn[data-v-5a926257]:disabled{opacity:.6}.cancel-btn[data-v-5a926257]{color:#666;cursor:pointer;background:#f5f5f5;border:none;border-radius:10px;padding:12px 20px;font-size:14px}.fab[data-v-5a926257]{color:#fff;cursor:pointer;z-index:100;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:32px;display:flex;position:fixed;bottom:20px;left:20px;box-shadow:0 4px 20px #667eea80}.login-prompt[data-v-5a926257]{text-align:center;background:#fff;border-radius:16px;margin-top:15px;padding:30px 20px}.login-prompt p[data-v-5a926257]{color:#666;margin:0 0 15px;font-size:14px}.login-prompt-btn[data-v-5a926257]{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:10px;padding:12px 28px;font-size:14px}.preview-overlay[data-v-5a926257]{z-index:1000;background:#000000f2;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.preview-content[data-v-5a926257]{flex-direction:column;gap:20px;max-width:100%;max-height:100%;display:flex;position:relative}.preview-content img[data-v-5a926257]{object-fit:contain;border-radius:12px;max-width:100%;max-height:calc(100vh - 150px)}.close-preview[data-v-5a926257]{color:#fff;cursor:pointer;z-index:10;background:#f44;border:none;border-radius:50%;width:36px;height:36px;font-size:20px;line-height:36px;position:absolute;top:-10px;right:-10px}.save-hint[data-v-5a926257]{color:#fff;pointer-events:none;background:#00000080;border-radius:20px;padding:8px 20px;font-size:14px;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}@media (width<=600px){.header[data-v-5a926257]{padding:12px 15px}.header h1[data-v-5a926257]{font-size:16px}.main-content[data-v-5a926257]{padding:12px 12px 80px}.chapters-nav[data-v-5a926257]{gap:6px;padding:10px}.chapters-nav button[data-v-5a926257]{padding:7px 11px;font-size:11px}.chapter-header[data-v-5a926257]{padding:12px}.chapter-header h2[data-v-5a926257]{font-size:14px}.posts-section[data-v-5a926257]{padding:12px}.post-content[data-v-5a926257]{font-size:13px}.fab[data-v-5a926257]{width:50px;height:50px;font-size:28px;bottom:15px;left:15px}.comment-form-expanded[data-v-5a926257]{padding:15px}}
