*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #fafafa;--surface: #ffffff;--border: #eaeaea;--text: #1a1a1a;--text-secondary: #888;--accent: #3b82f6;--accent-light: #eff6ff;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 3px rgba(0,0,0,.04), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 12px rgba(0,0,0,.06);--transition: .2s ease}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;border:none;background:none}ul{list-style:none}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;padding-top:64px}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.navbar-inner{max-width:960px;margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between}.navbar-brand{font-size:1.125rem;font-weight:700;letter-spacing:-.02em;cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text)}.navbar-links{display:flex;gap:4px}.nav-link{padding:8px 16px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:all var(--transition);white-space:nowrap}.nav-link:hover{color:var(--text);background:#f0f0f0}.nav-link.active{color:var(--accent);background:var(--accent-light)}.page{max-width:960px;margin:0 auto;padding:48px 24px 64px}.page-header{margin-bottom:40px}.page-header h2{font-size:1.75rem;font-weight:700;margin-bottom:8px;letter-spacing:-.02em}.page-desc{color:var(--text-secondary);font-size:.95rem}.hero-section{text-align:center;padding:80px 0 56px;position:relative;overflow:hidden}.hero-visual{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.hero-shapes{position:relative;width:320px;height:320px}.shape{position:absolute;border-radius:50%;opacity:.08}.shape-1{width:280px;height:280px;background:var(--accent);top:20px;left:20px;animation:float 6s ease-in-out infinite}.shape-2{width:180px;height:180px;background:#8b5cf6;top:70px;left:70px;animation:float 8s ease-in-out infinite reverse}.shape-3{width:120px;height:120px;background:#06b6d4;top:100px;left:100px;animation:float 10s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.05)}}.hero-title{position:relative;font-size:3rem;font-weight:800;letter-spacing:-.03em;margin-bottom:12px;background:linear-gradient(135deg,var(--accent),#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{position:relative;color:var(--text-secondary);font-size:1.05rem}.portal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:0 0 48px}.portal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:40px 32px;text-align:center;cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow)}.portal-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent)}.portal-icon{font-size:3rem;margin-bottom:20px}.portal-card h3{font-size:1.3rem;font-weight:600;margin-bottom:10px}.portal-card p{font-size:1rem;color:var(--text-secondary)}.article-list{display:grid;gap:16px}.article-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow)}.article-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.article-meta{margin-bottom:8px}.article-category{display:inline-block;font-size:.75rem;font-weight:600;color:var(--accent);background:var(--accent-light);padding:2px 10px;border-radius:20px;letter-spacing:.02em}.article-card h3{font-size:1.1rem;font-weight:600;margin-bottom:6px}.article-card p{font-size:.875rem;color:var(--text-secondary);line-height:1.5}.back-btn{font-size:.875rem;color:var(--accent);margin-bottom:24px;padding:8px 0;display:inline-block;font-weight:500}.back-btn:hover{opacity:.8}.article-detail{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:40px;box-shadow:var(--shadow)}.article-detail h2{font-size:1.5rem;font-weight:700;margin-bottom:12px}.article-detail .article-category{margin-bottom:24px}.article-content{margin:24px 0}.article-content p{margin-bottom:16px;line-height:1.8;font-size:.95rem}.key-points{background:var(--accent-light);border-radius:var(--radius-sm);padding:24px;margin-top:24px}.key-points h4{font-size:.9rem;font-weight:600;color:var(--accent);margin-bottom:12px}.key-points li{font-size:.875rem;padding:4px 0;color:var(--text)}.key-points li:before{content:"•";color:var(--accent);margin-right:8px}.album-section{margin-bottom:48px}.album-section h3{font-size:1.25rem;font-weight:600;margin-bottom:4px}.album-desc{font-size:.875rem;color:var(--text-secondary);margin-bottom:20px}.photo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.photo-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all var(--transition);box-shadow:var(--shadow)}.photo-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.photo-placeholder{aspect-ratio:1;background:linear-gradient(135deg,#fef3c7,#fde68a);display:flex;align-items:center;justify-content:center}.photo-emoji{font-size:2.5rem}.photo-caption{padding:10px 12px;font-size:.8rem;text-align:center;color:var(--text-secondary)}.footer{border-top:1px solid var(--border);background:var(--surface)}.footer-inner{max-width:960px;margin:0 auto;padding:24px;text-align:center}.footer-inner p{font-size:.8rem;color:var(--text-secondary)}.empty-state{text-align:center;padding:80px 24px;color:var(--text-secondary)}.loading-spinner{width:28px;height:28px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.home-study-section{padding:0 0 48px}.section-header{text-align:center;margin-bottom:32px}.home-subject-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:900px;margin:0 auto}.home-subject-card{display:flex;align-items:center;gap:24px;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:36px 28px;text-decoration:none;color:inherit;transition:all .25s ease;box-shadow:0 2px 12px #0000000a;position:relative;overflow:hidden}.home-subject-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--card-accent);border-radius:4px 0 0 4px;opacity:0;transition:opacity .25s}.home-subject-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px #0000001a;border-color:var(--card-accent)}.home-subject-card:hover:before{opacity:1}.home-subject-icon{font-size:3rem;flex-shrink:0}.home-subject-info{flex:1}.home-subject-info h3{font-size:1.4rem;font-weight:700;margin:0 0 8px}.home-subject-info p{font-size:1.05rem;color:var(--text-secondary);margin:0}.home-subject-arrow{font-size:1.4rem;color:var(--text-secondary);transition:transform .25s,color .25s;flex-shrink:0}.home-subject-card:hover .home-subject-arrow{transform:translate(4px);color:var(--card-accent)}.home-tools-section{padding:0 0 48px}.cat-placeholder{background:linear-gradient(135deg,#fef3c7,#fdba74)!important}.auth-page{display:flex;justify-content:center;padding-top:60px}.auth-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:40px;width:400px;max-width:100%;box-shadow:var(--shadow)}.auth-box h2{font-size:1.5rem;font-weight:700;margin-bottom:24px;text-align:center}.auth-box label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px;margin-top:16px}.auth-box input[type=text],.auth-box input[type=password]{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;transition:border .2s}.auth-box input:focus{outline:none;border-color:var(--accent)}.auth-error{background:#fef2f2;color:#dc2626;padding:10px 14px;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:12px}.auth-error-visible{background:#fee2e2;color:#991b1b;padding:16px 20px;border-radius:var(--radius-sm);font-size:1.1rem;font-weight:700;margin-bottom:16px;border:2px solid #dc2626;text-align:center;box-shadow:0 2px 8px #dc262633}.captcha-row{display:flex;gap:8px;align-items:center}.captcha-row input{flex:1}.captcha-question{font-size:1.1rem;font-weight:700;color:var(--accent);white-space:nowrap;padding:0 8px}.btn-refresh{padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;background:var(--surface);cursor:pointer}.btn-refresh:hover{background:#f5f5f5}.btn-submit{width:100%;margin-top:24px;padding:12px;background:#1a1a2e;color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;cursor:pointer}.btn-submit:hover{background:#2d2d4e}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.auth-link{text-align:center;margin-top:16px;font-size:.85rem;color:var(--text-secondary)}.auth-link a{color:var(--accent)}.agree-row{display:flex;align-items:center;gap:8px;margin-top:16px;cursor:pointer}.agree-row input[type=checkbox]{width:16px;height:16px;cursor:pointer}.agree-row span{font-size:.85rem;color:var(--text-secondary)}.link-btn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:.85rem;padding:0;text-decoration:underline}.modal-overlay{position:fixed;inset:0;background:#0006;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}.modal-content{background:#fff;border-radius:var(--radius);padding:32px;max-width:600px;max-height:80vh;overflow-y:auto}.modal-content h3{margin-bottom:16px}.terms-text p{margin-bottom:8px;line-height:1.6;font-size:.9rem;color:#555}.quiz-config{max-width:600px;margin:0 auto}.config-section{margin-bottom:24px}.config-section h3{font-size:.95rem;font-weight:600;margin-bottom:12px;color:var(--text)}.count-selector,.type-selector{display:flex;flex-wrap:wrap;gap:8px}.count-btn,.type-btn{padding:10px 20px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-size:.9rem;cursor:pointer;transition:all .25s cubic-bezier(.25,.8,.25,1)}.count-btn.active,.type-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 3px 10px #3b82f64d}.count-btn:hover,.type-btn:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 3px 10px #0000000f}.count-btn:active,.type-btn:active{transform:translateY(0)}.btn-start{display:inline-block;padding:14px 36px;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;cursor:pointer;margin-top:8px;box-shadow:0 4px 15px #1a1a2e4d;transition:all .3s cubic-bezier(.25,.8,.25,1);position:relative;overflow:hidden}.btn-start:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff26;transition:all .5s ease;transform:translate(-50%,-50%)}.btn-start:hover:after{width:300px;height:300px}.btn-start:hover{transform:translateY(-2px);box-shadow:0 8px 25px #1a1a2e66}.btn-start:active{transform:translateY(0);box-shadow:0 2px 8px #1a1a2e4d}.btn-ghost{display:inline-block;padding:14px 36px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;cursor:pointer;text-decoration:none;color:var(--text);text-align:center;transition:all .3s cubic-bezier(.25,.8,.25,1)}.btn-ghost:hover{background:#f5f5f5;border-color:#ccc;transform:translateY(-1px);box-shadow:0 4px 12px #0000000f}.btn-ghost:active{transform:translateY(0)}.quiz-progress{display:flex;align-items:center;gap:12px;margin-bottom:24px}.progress-bar{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .3s}.progress-text{font-size:.85rem;color:var(--text-secondary);white-space:nowrap}.quiz-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}.q-meta{display:flex;gap:8px;margin-bottom:16px}.q-num{font-size:.8rem;color:var(--text-secondary)}.q-type{font-size:.8rem;color:var(--accent);background:var(--accent-light);padding:2px 10px;border-radius:20px}.q-chapter{font-size:.8rem;color:#888}.q-text{font-size:1.15rem;font-weight:600;line-height:1.6;margin-bottom:24px}.q-options{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}.q-option{padding:14px 18px;border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .25s cubic-bezier(.25,.8,.25,1);font-size:.95rem;line-height:1.5;position:relative}.q-option:hover{border-color:var(--accent);background:var(--accent-light);transform:translate(4px);box-shadow:0 2px 8px #3b82f61a}.q-option.selected{border-color:var(--accent);background:var(--accent-light);font-weight:500;transform:translate(4px);box-shadow:0 2px 8px #3b82f626}.q-nav{display:flex;justify-content:space-between}.q-nav button{padding:10px 24px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;font-size:.9rem}.q-nav button:disabled{opacity:.4;cursor:not-allowed}.q-nav button.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-color:transparent;box-shadow:0 3px 10px #3b82f640}.q-nav button.btn-primary:hover{box-shadow:0 5px 15px #3b82f659;color:#fff}.quiz-result-header{text-align:center;padding:48px 0 32px}.quiz-result-header h2{font-size:1.5rem;margin-bottom:16px}.score-display{display:flex;align-items:baseline;justify-content:center;gap:4px;margin-bottom:8px}.score-num{font-size:4rem;font-weight:800}.score-num.pass{color:#059669}.score-num.fail{color:#dc2626}.score-label{font-size:1.5rem;color:var(--text-secondary)}.score-detail{color:var(--text-secondary);font-size:.95rem}.quiz-review{display:flex;flex-direction:column;gap:20px;margin-bottom:32px}.review-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:all .3s ease}.review-card:hover{box-shadow:0 4px 16px #0000000f}.review-card.correct{border-left:4px solid #059669}.review-card.wrong{border-left:4px solid #dc2626}.review-meta{margin-bottom:8px}.review-badge{display:inline-block;padding:2px 12px;border-radius:20px;font-size:.8rem;font-weight:600}.badge-correct{background:#d1fae5;color:#059669}.badge-wrong{background:#fee2e2;color:#dc2626}.review-question{font-size:.95rem;font-weight:500;margin-bottom:12px;line-height:1.5}.review-options{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.review-opt{padding:6px 12px;border-radius:6px;font-size:.85rem;border:1px solid var(--border)}.opt-correct{background:#d1fae5;border-color:#059669}.opt-wrong{background:#fee2e2;border-color:#dc2626}.review-answer{font-size:.85rem;margin-bottom:4px}.review-user-answer{font-size:.85rem;color:#dc2626;margin-bottom:4px}.review-keyword{font-size:.85rem;color:#d97706;margin-bottom:4px}.review-ai-analysis{margin-top:10px;padding:10px 14px;background:#f0f7ff;border-radius:8px;border-left:3px solid #3b82f6}.ai-error-reason{font-size:.85rem;color:#1e40af;margin-bottom:6px;line-height:1.5}.ai-study-tip{font-size:.85rem;color:#166534;line-height:1.5}.ai-advice-section{margin-top:32px;padding:20px 24px;background:#fefce8;border-radius:12px;border:1px solid #fde68a}.ai-advice-section h3{margin:0 0 12px;font-size:1.1rem;color:#92400e}.advice-summary{font-size:.9rem;color:#555;margin-bottom:12px;line-height:1.6}.advice-weakness{margin-bottom:10px}.advice-weakness strong{font-size:.85rem}.weakness-tags{display:inline-flex;flex-wrap:wrap;gap:6px;margin-left:8px}.weakness-tag{padding:2px 10px;background:#fef3c7;color:#92400e;border-radius:12px;font-size:.8rem}.advice-suggestions strong{font-size:.85rem;display:block;margin-bottom:4px}.advice-suggestions ul{margin:0;padding-left:20px}.advice-suggestions li{font-size:.85rem;color:#555;line-height:1.6;margin-bottom:4px}.review-explanation{margin-top:8px}.review-explanation summary{cursor:pointer;font-size:.85rem;color:var(--accent)}.review-explanation p{font-size:.85rem;color:#666;margin-top:6px;line-height:1.6}.quiz-actions{display:flex;gap:12px;justify-content:center;margin-bottom:48px}.history-list{display:flex;flex-direction:column;gap:12px}.history-card{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px}.history-score{flex-shrink:0}.score-badge{display:inline-block;padding:6px 16px;border-radius:20px;font-size:1rem;font-weight:700}.score-badge.pass{background:#d1fae5;color:#059669}.score-badge.fail{background:#fee2e2;color:#dc2626}.history-info{flex:1}.history-info p{font-size:.9rem;margin-bottom:4px}.history-time{font-size:.8rem;color:var(--text-secondary)}.nav-user{display:flex;align-items:center;gap:8px;margin-left:8px}.nav-username{font-size:.8rem;color:var(--accent);font-weight:500}.auth-guard-page{display:flex;justify-content:center;padding-top:80px}.auth-guard-box{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:60px 40px;width:420px;max-width:100%;box-shadow:var(--shadow)}.auth-guard-icon{font-size:3rem;margin-bottom:16px}.auth-guard-box h2{font-size:1.5rem;font-weight:700;margin-bottom:8px}.auth-guard-box p{color:var(--text-secondary);font-size:.95rem;margin-bottom:24px}.auth-guard-link{margin-top:16px;font-size:.85rem}.auth-guard-link a{color:var(--accent)}.login-tip{position:fixed;top:72px;left:50%;transform:translate(-50%);background:#1a1a2e;color:#fff;padding:10px 24px;border-radius:var(--radius-sm);font-size:.85rem;z-index:200;white-space:nowrap;box-shadow:0 4px 16px #00000026;animation:tipFadeIn .2s ease}@keyframes tipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.nav-link-locked{opacity:.6}.footer-icp{margin-top:4px}.footer-icp a{font-size:.8rem;color:var(--text-secondary);text-decoration:none}.footer-icp a:hover{color:var(--accent)}.maritime-tabs{display:flex;gap:4px;margin-bottom:32px;border-bottom:1px solid var(--border);padding-bottom:0}.maritime-tab{padding:10px 20px;font-size:.9rem;font-weight:500;color:var(--text-secondary);border-bottom:2px solid transparent;transition:all var(--transition);margin-bottom:-1px}.maritime-tab{position:relative}.maritime-tab:after{content:"";position:absolute;bottom:-2px;left:50%;width:0;height:2.5px;background:var(--accent);border-radius:2px;transition:all .3s cubic-bezier(.25,.8,.25,1);transform:translate(-50%)}.maritime-tab:hover:after{width:70%}.maritime-tab.active:after{width:100%}.maritime-tab_oldhover{color:var(--text)}.maritime-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.quiz-page{padding-bottom:32px}.knowledge-page{padding:0 2px 32px}.knowledge-panel{display:flex;flex-wrap:wrap;gap:10px;position:sticky;top:60px;z-index:10;background:#0a0a1aeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:12px 0;margin-bottom:12px;border-bottom:1px solid var(--border-color, #2a2a4a)}.knowledge-panel input,.knowledge-panel select{flex:1;min-width:140px;padding:8px 12px;border:1px solid var(--border-color, #2a2a4a);border-radius:10px;background:var(--card-bg, #16162e);color:var(--text, #e2e8f0);font-size:.85rem}.knowledge-panel input::placeholder{color:var(--text-secondary, #7f8ea3)}.knowledge-wrong-btn{padding:8px 16px;border:1px solid var(--border-color, #2a2a4a);border-radius:10px;background:var(--card-bg, #16162e);color:var(--text, #e2e8f0);cursor:pointer;font-size:.85rem;white-space:nowrap}.knowledge-wrong-btn.active{background:#b91c1c;color:#fff;border-color:#b91c1c}.knowledge-stats{display:flex;gap:16px;margin-bottom:16px}.knowledge-stat{background:var(--card-bg, #16162e);border:1px solid var(--border-color, #2a2a4a);border-radius:12px;padding:10px 18px;font-size:.85rem;color:var(--text-secondary, #7f8ea3)}.knowledge-stat b{color:var(--accent, #0f766e);font-size:1.1rem}.knowledge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:14px}.knowledge-card{background:var(--card-bg, #16162e);border:1px solid var(--border-color, #2a2a4a);border-radius:14px;padding:16px;transition:border-color .15s}.knowledge-card:hover{border-color:var(--accent, #0f766e)}.knowledge-card.corrected{border-color:#b91c1c;background:#1c0f0f}.knowledge-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px;font-size:.75rem}.knowledge-meta span{background:#ffffff0f;padding:2px 8px;border-radius:999px;color:var(--text-secondary, #7f8ea3)}.knowledge-tag{background:#b91c1c!important;color:#fff!important}.knowledge-question{font-size:.95rem;line-height:1.6;margin:0 0 12px;color:var(--text, #e2e8f0);font-weight:500}.knowledge-options{padding-left:8px;margin-bottom:10px}.knowledge-opt{padding:4px 8px;font-size:.85rem;color:var(--text-secondary, #7f8ea3);line-height:1.7}.knowledge-opt.opt-correct{color:var(--accent, #0f766e);font-weight:600}.knowledge-details{margin-top:8px;font-size:.85rem}.knowledge-details summary{cursor:pointer;color:var(--accent, #0f766e);font-weight:600;padding:4px 0}.knowledge-law{color:#2563eb;font-size:.8rem;margin:8px 0 4px;padding:4px 8px;background:#2563eb1a;border-radius:6px}.knowledge-answer{margin:6px 0;color:#b91c1c}.knowledge-answer strong{font-weight:700}.knowledge-explanation{color:var(--text-secondary, #7f8ea3);line-height:1.7;margin:6px 0 0;padding-top:6px;border-top:1px solid var(--border-color, #2a2a4a)}@media(max-width:640px){.knowledge-grid{grid-template-columns:1fr}.knowledge-panel input,.knowledge-panel select{min-width:100px}}.knowledge-iframe-wrapper{width:100%;height:calc(100vh - 200px);min-height:600px;margin:0 -24px;padding:0}.knowledge-iframe{width:100%;height:100%;border:none;border-radius:0}.history-card.clickable{cursor:pointer;display:flex;align-items:center;gap:16px;transition:border-color .15s,background .15s}.history-card.clickable:hover{border-color:var(--accent, #0f766e);background:#0f766e0d}.history-arrow{margin-left:auto;font-size:1.5rem;color:var(--text-secondary, #7f8ea3);font-weight:300}.nav-dropdown{position:relative}.nav-dropdown-trigger{background:none;border:none;cursor:pointer;font:inherit;color:inherit;padding:8px 16px;display:flex;align-items:center;gap:4px;transition:color .2s}.nav-dropdown-trigger:hover,.nav-dropdown-trigger.active{color:var(--primary)}.nav-dropdown-menu{position:absolute;top:100%;left:50%;transform:translate(-50%);min-width:180px;padding:8px 0;background:#ffffffeb;-webkit-backdrop-filter:blur(16px) saturate(1.8);backdrop-filter:blur(16px) saturate(1.8);border-radius:12px;box-shadow:0 8px 32px #0000001f,0 0 0 1px #0000000a;z-index:100;animation:dropdownFade .2s ease}@keyframes dropdownFade{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.nav-dropdown-item{display:block;padding:10px 20px;color:#374151;font-size:.9rem;text-decoration:none;transition:all .15s}.nav-dropdown-item:hover{background:#3b82f614;color:var(--primary)}.nav-dropdown-item.active{color:var(--primary);font-weight:600}.particle-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;opacity:.4}.reading-training,.reading-exercise{max-width:900px;margin:0 auto}.reading-header{margin-bottom:24px}.reading-header h3{font-size:1.3rem;font-weight:700;margin-bottom:4px}.reading-hint{font-size:.85rem;color:var(--text-secondary, #888)}.reading-card{background:#fff;border-radius:12px;margin-bottom:12px;border:1px solid #e5e7eb;overflow:hidden;transition:box-shadow .2s}.reading-card:hover{box-shadow:0 4px 12px #00000014}.reading-card.expanded{box-shadow:0 8px 24px #0000001a}.reading-card-header{display:flex;align-items:center;padding:16px 20px;cursor:pointer;gap:12px;-webkit-user-select:none;user-select:none}.reading-num{font-weight:700;font-size:1rem;color:var(--primary, #3b82f6)}.reading-questions-count{background:#f3f4f6;padding:2px 10px;border-radius:12px;font-size:.8rem;color:#6b7280}.reading-toggle{margin-left:auto;font-size:.85rem;color:var(--primary, #3b82f6);font-weight:600}.reading-card-body{padding:0 20px 20px}.reading-passage,.reading-vocab{margin-bottom:20px}.reading-passage h4,.reading-vocab h4,.reading-questions h4{font-size:.95rem;font-weight:700;margin-bottom:8px;color:#374151}.reading-passage p{line-height:1.8;color:#374151;background:#f9fafb;padding:16px;border-radius:8px;border-left:3px solid var(--primary, #3b82f6)}.reading-vocab p{font-size:.85rem;color:#6b7280;line-height:1.6;background:#fefce8;padding:12px;border-radius:8px}.reading-question-card{background:#f9fafb;border-radius:8px;padding:16px;margin-bottom:12px;border:1px solid #e5e7eb}.rq-text{font-weight:600;margin-bottom:10px;color:#1f2937}.rq-options{display:grid;gap:6px;margin-bottom:10px}.rq-opt{padding:8px 12px;border-radius:6px;border:1px solid #e5e7eb;font-size:.9rem;transition:all .15s}.rq-opt.correct{background:#ecfdf5;border-color:#059669;color:#059669;font-weight:600}.rq-reveal-btn{background:none;border:1.5px solid var(--accent);color:var(--accent);padding:6px 18px;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .3s cubic-bezier(.25,.8,.25,1);font-weight:500}.rq-reveal-btn:hover{background:var(--accent);color:#fff;box-shadow:0 3px 10px #3b82f640;transform:translateY(-1px)}.rq-answer{margin-top:8px}.rq-explanation{font-size:.85rem;color:#6b7280;margin-top:4px;line-height:1.5}.reading-select-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.reading-select-card{background:#fff;border-radius:12px;padding:20px;cursor:pointer;border:1px solid #e5e7eb;transition:all .2s}.reading-select-card:hover{box-shadow:0 8px 25px #3b82f626;border-color:var(--accent);transform:translateY(-3px)}.rsc-num{font-weight:700;font-size:1rem;color:var(--primary, #3b82f6)}.rsc-count{margin-left:8px;font-size:.8rem;color:#6b7280}.rsc-preview{font-size:.8rem;color:#9ca3af;margin:10px 0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.rsc-btn{width:100%;padding:10px;border-radius:8px;border:none;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-weight:600;cursor:pointer;font-size:.9rem;transition:all .3s cubic-bezier(.25,.8,.25,1);box-shadow:0 3px 10px #3b82f640}.rsc-btn:hover{transform:translateY(-1px);box-shadow:0 5px 15px #3b82f659}.rsc-btn:active{transform:translateY(0)}.reading-passage-box{background:#fff;border-radius:12px;padding:20px;margin-bottom:16px;border:1px solid #e5e7eb}.reading-passage-box h4{font-size:.95rem;font-weight:700;margin-bottom:10px}.reading-passage-box p{line-height:1.8;color:#374151}.reading-vocab-box{margin-bottom:16px;border-radius:8px;background:#fefce8;padding:12px 16px;font-size:.85rem;color:#92400e;cursor:pointer}.reading-vocab-box summary{font-weight:600;cursor:pointer}.reading-exercise-questions{display:grid;gap:16px;margin-bottom:20px}.rsc-done{display:inline-block;margin-left:8px;font-size:.75rem;color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);padding:2px 10px;border-radius:20px;font-weight:600}.rsc-avg{display:inline-block;margin-left:8px;font-size:.75rem;color:#fff;background:linear-gradient(135deg,#f59e0b,#f97316);padding:2px 10px;border-radius:20px;font-weight:600}.profile-page{max-width:1200px;margin:0 auto;padding:24px 16px 100px}.profile-header-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-md);overflow:hidden;margin-bottom:24px}.profile-cover{height:120px;background:linear-gradient(135deg,#3b82f6,#6366f1,#8b5cf6)}.profile-info-row{display:flex;align-items:flex-start;gap:20px;padding:0 28px 24px;margin-top:-40px;position:relative}.profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;flex-shrink:0;border:4px solid var(--surface);box-shadow:var(--shadow-md);overflow:hidden}.profile-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.profile-meta{padding-top:44px;flex:1;min-width:0}.profile-name-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.profile-name-row h2{font-size:1.25rem;font-weight:700}.profile-id{font-size:.75rem;color:#888;background:#f3f4f6;padding:2px 10px;border-radius:20px}.profile-bio{color:var(--text-secondary);font-size:.9rem;margin-top:6px}.profile-stats-row{display:flex;gap:32px;margin-top:14px}.profile-stat-item{display:flex;flex-direction:column;align-items:center}.profile-stat-item strong{font-size:1.2rem;color:var(--text)}.profile-stat-item span{font-size:.8rem;color:var(--text-secondary)}.profile-content{display:flex;gap:24px;align-items:flex-start}.profile-sidebar{width:200px;flex-shrink:0;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px 0;position:sticky;top:80px}.profile-nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;font-size:.9rem;color:var(--text);transition:background var(--transition),color var(--transition);border-radius:0}.profile-nav-item:hover{background:var(--accent-light);color:var(--accent)}.profile-nav-item.active{background:var(--accent-light);color:var(--accent);font-weight:600;border-right:3px solid var(--accent)}.profile-nav-icon{font-size:1rem;width:20px;text-align:center}.profile-main{flex:1;min-width:0;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px}.profile-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.profile-stat-card{background:var(--surface);border:1px solid var(--border);border-top:3px solid #6366f1;border-radius:var(--radius-sm);padding:20px 16px;text-align:center;transition:transform var(--transition),box-shadow var(--transition)}.profile-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.psc-value{display:block;font-size:1.6rem;font-weight:700;color:var(--text);margin-bottom:4px}.psc-label{display:block;font-size:.8rem;color:var(--text-secondary)}.profile-form{max-width:480px}.pf-group{margin-bottom:18px}.pf-group label{display:block;font-size:.85rem;font-weight:600;margin-bottom:6px;color:var(--text)}.pf-group input,.pf-group textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;transition:border-color var(--transition);outline:none}.pf-group input:focus,.pf-group textarea:focus{border-color:var(--accent)}.profile-collections-layout{display:flex;gap:20px;align-items:flex-start}.profile-folder-list{width:240px;flex-shrink:0;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.profile-folder-item{padding:12px 16px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;border-bottom:1px solid var(--border);transition:background var(--transition);font-size:.9rem}.profile-folder-item:last-child{border-bottom:none}.profile-folder-item:hover{background:#f9fafb}.profile-folder-item.active{background:var(--accent-light);color:var(--accent);font-weight:600}.profile-folder-content{flex:1;min-width:0}.profile-folder-content h4{font-size:1rem;margin-bottom:12px}.profile-collection-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;font-size:.9rem}.profile-user-grid{display:grid;gap:12px}.profile-user-card{display:flex;align-items:center;gap:14px;padding:14px 18px;border:1px solid var(--border);border-radius:var(--radius-sm);transition:box-shadow var(--transition)}.profile-user-card:hover{box-shadow:var(--shadow)}.profile-user-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;flex-shrink:0;overflow:hidden}.profile-user-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.profile-user-info{flex:1;min-width:0}.profile-user-info strong{font-size:.95rem}.profile-user-info p{font-size:.8rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-notif-list{display:grid;gap:8px}.profile-notif-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);position:relative}.profile-notif-item:hover{background:#f9fafb}.profile-notif-item.unread{background:#eff6ff;border-color:#bfdbfe}.notif-icon{font-size:1.2rem;flex-shrink:0;margin-top:2px}.notif-content{flex:1;min-width:0}.notif-content strong{font-size:.9rem;display:block}.notif-content p{font-size:.82rem;color:var(--text-secondary);margin-top:2px}.notif-time{font-size:.75rem;color:#aaa;display:block;margin-top:4px}.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:6px}.nav-username-btn{background:none;border:none;font:inherit;font-size:.9rem;font-weight:600;color:var(--text);cursor:pointer;padding:6px 14px;border-radius:20px;transition:background var(--transition)}.nav-username-btn:hover{background:#f3f4f6}.nav-dropdown-menu-right{right:0;left:auto}.profile-mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:6px 0;z-index:100;justify-content:space-around}.profile-mobile-tab{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:.7rem;color:var(--text-secondary);padding:4px 12px;border-radius:8px;transition:color var(--transition)}.profile-mobile-tab.active{color:var(--accent);font-weight:600}.profile-mobile-icon{font-size:1.1rem}.level-badge{display:inline-block;font-size:.65rem;font-weight:700;padding:1px 7px;border-radius:10px;white-space:nowrap;vertical-align:middle;line-height:1.5}.level-badge-lg{display:inline-block;font-size:.8rem;font-weight:700;padding:3px 12px;border-radius:14px;white-space:nowrap;vertical-align:middle}.profile-avatar .level-badge{position:absolute;bottom:-2px;right:-2px;font-size:.6rem;padding:1px 5px}.profile-avatar{position:relative}.exp-bar-row{display:flex;align-items:center;gap:10px;margin-top:8px}.exp-bar{flex:1;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;min-width:100px}.exp-bar-fill{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:4px;transition:width .5s ease}.exp-bar-text{font-size:.75rem;color:var(--text-secondary);white-space:nowrap}.nav-level-badge{font-size:.65rem;font-weight:700;padding:1px 6px;border-radius:10px;margin-left:6px;vertical-align:middle}.checkin-section{max-width:800px;margin:0 auto 32px;padding:0 16px}.checkin-card{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 24px;gap:16px}.checkin-info{display:flex;align-items:center;gap:14px}.checkin-icon{font-size:1.8rem}.checkin-info strong{font-size:1rem;display:block}.checkin-info p{font-size:.82rem;color:var(--text-secondary);margin-top:2px}.checkin-btn{padding:10px 24px;border-radius:20px;font-weight:700;font-size:.9rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition);white-space:nowrap}.checkin-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.checkin-btn.done{background:#e5e7eb;color:#6b7280;cursor:default}.checkin-msg{text-align:center;margin-top:8px;font-size:.85rem;color:#059669;font-weight:600}.settings-avatar-section{display:flex;align-items:center;gap:20px;margin-bottom:28px;padding:20px;background:#fafafa;border-radius:var(--radius);border:1px solid var(--border)}.settings-avatar-preview{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;cursor:pointer;overflow:hidden;position:relative;flex-shrink:0;transition:box-shadow var(--transition)}.settings-avatar-preview:hover{box-shadow:0 0 0 3px #6366f14d}.settings-avatar-preview img{width:100%;height:100%;object-fit:cover}.avatar-overlay{position:absolute;inset:0;background:#00000080;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;opacity:0;transition:opacity var(--transition)}.settings-avatar-preview:hover .avatar-overlay{opacity:1}.settings-avatar-info{flex:1}.member-badge{display:inline-block;font-size:.65rem;font-weight:800;padding:1px 8px;border-radius:10px;white-space:nowrap;vertical-align:middle;line-height:1.5;color:#fff;background:linear-gradient(90deg,#ef4444,#f59e0b,#22c55e,#3b82f6,#a855f7,#ef4444);background-size:200% 100%;animation:memberBadgeShimmer 3s linear infinite;border:none;text-shadow:0 1px 2px rgba(0,0,0,.2)}.member-badge-lg{font-size:.85rem;padding:4px 16px;border-radius:14px}.profile-avatar .member-badge{position:absolute;bottom:-2px;right:-6px;font-size:.6rem;padding:1px 6px}@keyframes memberBadgeShimmer{0%{background-position:0% 50%}to{background-position:200% 50%}}@media(max-width:768px){.page{padding:16px 12px 80px}.main-content{padding-bottom:0}.navbar-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;background:none;border:none;cursor:pointer;padding:4px}.hamburger-line{display:block;width:24px;height:2.5px;background:var(--text);border-radius:2px;transition:transform .3s,opacity .3s}.hamburger-line.open:nth-child(1){transform:translateY(7.5px) rotate(45deg)}.hamburger-line.open:nth-child(2){opacity:0}.hamburger-line.open:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}.navbar-links{display:none!important}.navbar-toggle{display:flex}.navbar-inner{padding:0 12px}.navbar{height:auto;min-height:56px}.mobile-nav-page{position:fixed;inset:0;z-index:2000;background:var(--bg);display:flex;flex-direction:column;animation:mobileMenuIn .2s ease}@keyframes mobileMenuIn{0%{opacity:0}to{opacity:1}}.mobile-nav-top{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:56px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg)}.mobile-nav-top .navbar-brand{font-size:1.05rem}.mobile-nav-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:var(--text-secondary);border-radius:50%}.mobile-nav-close:active{background:#e5e7eb}.mobile-nav-list{flex:1;overflow-y:auto;padding:8px 0 40px;-webkit-overflow-scrolling:touch}.mobile-nav-link{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px 24px;font-size:1rem;color:var(--text);background:none;border:none;text-align:left;cursor:pointer;text-decoration:none;transition:background .12s}.mobile-nav-link:active{background:#f3f4f6}.mobile-nav-link.active{color:var(--accent);font-weight:600}.mobile-nav-divider{height:1px;background:var(--border);margin:8px 24px}.mobile-nav-heading{font-size:.75rem;color:var(--text-secondary);padding:8px 24px 4px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.mobile-nav-lock{font-size:.85rem;margin-left:8px}.mobile-nav-danger{color:#dc2626!important}.mobile-nav-login{color:var(--accent)!important;font-weight:600}.hero-title{font-size:2.2rem!important}.hero-subtitle{font-size:1rem!important;margin-bottom:32px!important}.home-subject-grid{grid-template-columns:1fr}.home-subject-card{padding:16px}.home-subject-icon{font-size:1.5rem;width:40px;height:40px}.home-subject-info h3{font-size:.95rem}.home-subject-info p{font-size:.8rem}.portal-grid{grid-template-columns:1fr}.checkin-card{flex-direction:column;align-items:flex-start;gap:12px}.checkin-btn{width:100%;text-align:center}.maritime-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important;gap:4px!important;padding:0 12px 4px;scrollbar-width:none;-ms-overflow-style:none;margin-bottom:16px}.maritime-tabs::-webkit-scrollbar{display:none}.maritime-tab{white-space:nowrap;flex-shrink:0;font-size:.78rem!important;padding:6px 12px!important}.quiz-card{padding:16px}.q-text{font-size:1rem;line-height:1.5}.q-option{padding:12px 14px;font-size:.9rem;min-height:44px;display:flex;align-items:center}.q-nav{gap:8px}.q-nav button{flex:1;padding:12px 8px;min-height:44px;font-size:.85rem}.quiz-config{padding:0}.count-btn,.type-btn{padding:10px 14px;font-size:.85rem;min-height:44px}.btn-start,.btn-ghost{width:100%;text-align:center;padding:14px;min-height:44px}.quiz-actions{flex-direction:column;gap:10px}.quiz-result-header{padding:24px 0 16px}.quiz-result-header h2{font-size:1.2rem}.score-num{font-size:3rem}.review-card{padding:14px}.review-options{gap:6px}.review-opt{padding:8px 10px;font-size:.82rem}.reading-card{margin-bottom:10px}.reading-card-header{padding:12px 14px;font-size:.9rem}.reading-card-body{padding:10px 14px}.reading-question-card{padding:10px 12px}.reading-select-grid{grid-template-columns:1fr}.reading-select-card{padding:14px}.rsc-num{font-size:.9rem}.rsc-preview{font-size:.8rem}.reading-exercise-questions{gap:12px}.reading-header h3{font-size:1.1rem}.reading-passage-box{padding:12px}.reading-exercise>div[style*="display: flex"][style*="gap: 20px"]{flex-direction:column!important;align-items:center}.reading-exercise>div[style*="display: flex"][style*="gap: 20px"]>div[style*="cursor: pointer"]{width:100%!important;padding:28px 24px!important}.history-card{padding:12px 14px}.history-card h4{font-size:.9rem}.history-meta{gap:8px;flex-wrap:wrap}.ai-advice-section{padding:16px}.advice-summary{font-size:.85rem}.weakness-tag{font-size:.75rem;padding:3px 10px}.auth-page{padding-top:32px}.auth-box{padding:24px 16px}.auth-box h2{font-size:1.3rem;margin-bottom:16px}.captcha-row{flex-wrap:wrap}.captcha-row input{min-width:80px}.btn-submit{padding:14px;min-height:48px}.knowledge-grid{grid-template-columns:1fr}.knowledge-iframe-wrapper{height:auto!important;min-height:0!important;margin:0 -12px}.knowledge-iframe{height:5000px}.profile-page{padding:10px 8px 80px}.profile-sidebar{display:none}.profile-mobile-bar{display:flex}.profile-content{flex-direction:column}.profile-main{padding:14px;border-radius:var(--radius-sm)}.profile-stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.profile-stat-card{padding:14px 10px}.psc-value{font-size:1.3rem}.profile-info-row{flex-direction:column;align-items:center;text-align:center;padding:0 12px 16px}.profile-meta{padding-top:10px}.profile-name-row{justify-content:center;flex-wrap:wrap}.profile-stats-row{justify-content:center}.profile-collections-layout{flex-direction:column}.profile-folder-list{width:100%}.profile-cover{height:70px}.profile-avatar{width:64px;height:64px;font-size:1.6rem;margin-top:-32px}.settings-avatar-section{flex-direction:column;text-align:center}.exp-bar-row{gap:6px}.photo-grid{grid-template-columns:repeat(2,1fr);gap:8px}}@media(min-width:769px){.navbar-toggle{display:none!important}}.forum-page{max-width:1100px;margin:0 auto}.forum-header{margin-bottom:24px}.forum-header h1{font-size:1.8rem;color:var(--text);margin-bottom:4px}.forum-subtitle{color:var(--text-secondary);font-size:.95rem;margin-bottom:16px}.forum-header-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.forum-search{flex:1;min-width:200px}.forum-search input{width:100%;padding:10px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;background:var(--bg)}.forum-search input:focus{outline:none;border-color:var(--primary)}.btn-create-post{display:inline-block;padding:10px 22px;background:#1a1a2e;color:#fff;border-radius:var(--radius-sm);text-decoration:none;font-weight:600;font-size:.95rem;white-space:nowrap}.btn-create-post:hover{background:#2d2d4e}.forum-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:20px}.forum-categories{display:flex;gap:6px;flex-wrap:wrap}.forum-cat-btn{padding:6px 16px;border:1px solid var(--border);border-radius:20px;background:var(--bg);cursor:pointer;font-size:.85rem;color:var(--text-secondary);transition:all .15s}.forum-cat-btn:hover{border-color:var(--primary);color:var(--primary)}.forum-cat-btn.active{background:#1a1a2e;color:#fff;border-color:#1a1a2e}.forum-sort{display:flex;gap:4px}.forum-sort-btn{padding:5px 12px;border:none;background:transparent;cursor:pointer;font-size:.85rem;color:var(--text-secondary);border-radius:12px}.forum-sort-btn.active{background:var(--bg-secondary);color:var(--text);font-weight:600}.forum-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.forum-card{background:var(--bg);border-radius:var(--radius-sm);overflow:hidden;text-decoration:none;color:var(--text);transition:transform .15s,box-shadow .15s;box-shadow:0 1px 4px #0000000f;display:flex;flex-direction:column}.forum-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.forum-card-cover{width:100%;height:150px;overflow:hidden}.forum-card-cover img{width:100%;height:100%;object-fit:cover}.forum-card-body{padding:14px;flex:1;display:flex;flex-direction:column}.forum-card-category{display:inline-block;font-size:.75rem;color:var(--primary);background:#3b82f61a;padding:2px 10px;border-radius:10px;margin-bottom:8px;width:fit-content}.forum-card-title{font-size:1rem;font-weight:600;margin-bottom:6px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.forum-card-summary{font-size:.82rem;color:var(--text-secondary);margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.forum-card-meta{display:flex;gap:12px;font-size:.78rem;color:var(--text-secondary);margin-bottom:8px}.forum-card-stats{display:flex;gap:14px;font-size:.8rem;color:var(--text-secondary);margin-bottom:8px}.forum-card-tags{display:flex;gap:4px;flex-wrap:wrap}.forum-tag{display:inline-block;padding:2px 8px;background:var(--bg-secondary);border-radius:8px;font-size:.75rem;color:var(--text-secondary)}.forum-pagination{display:flex;justify-content:center;gap:6px;margin-top:28px}.forum-pagination button{padding:6px 14px;border:1px solid var(--border);border-radius:6px;background:var(--bg);cursor:pointer;font-size:.85rem}.forum-pagination button.active{background:#1a1a2e;color:#fff;border-color:#1a1a2e}.forum-pagination button:disabled{opacity:.4;cursor:not-allowed}.post-detail-page{max-width:800px;margin:0 auto}.post-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.post-back{color:var(--text-secondary);text-decoration:none;font-size:.9rem}.post-back:hover{color:var(--primary)}.post-status-badge{padding:4px 12px;border-radius:12px;font-size:.8rem}.post-detail-article h1{font-size:1.6rem;margin-bottom:12px;line-height:1.4}.post-detail-meta{display:flex;gap:12px;flex-wrap:wrap;align-items:center;font-size:.85rem;color:var(--text-secondary);margin-bottom:16px}.post-detail-cover{width:100%;border-radius:var(--radius-sm);overflow:hidden;margin-bottom:20px;display:flex;justify-content:center;background:#000}.post-detail-cover img{width:100%;max-height:500px;object-fit:contain;display:block}.post-detail-content{font-size:.98rem;line-height:1.8;color:var(--text);margin-bottom:24px;word-break:break-word}.post-detail-content h1,.post-detail-content h2,.post-detail-content h3{margin:16px 0 8px}.post-detail-actions{display:flex;gap:16px;align-items:center;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:28px;flex-wrap:wrap}.post-like-btn{padding:8px 18px;border:1px solid var(--border);border-radius:20px;background:var(--bg);cursor:pointer;font-size:.9rem;transition:all .15s}.post-like-btn:hover{border-color:#ef4444}.post-like-btn.liked{background:#fef2f2;border-color:#ef4444}.post-comments-section h3{margin-bottom:16px}.comment-form{margin-bottom:20px}.comment-form textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;resize:vertical;font-family:inherit;background:var(--bg)}.comment-form textarea:focus{outline:none;border-color:var(--primary)}.comment-form .btn-start{margin-top:8px}.comment-list{display:flex;flex-direction:column;gap:12px}.comment-item{padding:12px 14px;background:var(--bg);border-radius:var(--radius-sm);box-shadow:0 1px 3px #0000000a}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:.85rem}.comment-header strong{color:var(--text)}.comment-header span{color:var(--text-secondary);font-size:.78rem}.comment-content{font-size:.9rem;color:var(--text);line-height:1.5}.comment-delete-btn{background:none;border:none;color:#dc2626;cursor:pointer;font-size:.78rem;padding:2px 6px;margin-top:4px}.empty-comments{text-align:center;color:var(--text-secondary);padding:20px;font-size:.9rem}.post-create-page{max-width:1000px;margin:0 auto}.post-create-page h1{margin-bottom:24px}.post-create-layout{display:grid;grid-template-columns:1fr 280px;gap:24px;align-items:start}.post-create-main{display:flex;flex-direction:column;gap:16px}.post-create-sidebar{display:flex;flex-direction:column;gap:16px;background:var(--bg);padding:20px;border-radius:var(--radius-sm);box-shadow:0 1px 4px #0000000f}.post-title-input{width:100%;padding:14px 16px;font-size:1.2rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);font-weight:600}.post-title-input:focus{outline:none;border-color:var(--primary)}.title-counter{font-size:.8rem;color:var(--text-secondary);text-align:right;display:block;margin-top:4px}.post-content-input{width:100%;padding:14px 16px;font-size:.95rem;border:1px solid var(--border);border-radius:var(--radius-sm);resize:vertical;font-family:inherit;line-height:1.7;background:var(--bg)}.post-content-input:focus{outline:none;border-color:var(--primary)}.editor-toolbar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm) var(--radius-sm) 0 0;border-bottom:none;flex-wrap:wrap}.editor-toolbar .toolbar-label{font-size:.8rem;color:var(--text-secondary);margin-right:4px}.toolbar-btn{padding:5px 12px;font-size:.8rem;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);cursor:pointer;white-space:nowrap;transition:background .15s}.toolbar-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.toolbar-btn:disabled{opacity:.5;cursor:not-allowed}.uploading-indicator{font-size:.75rem;color:var(--primary);animation:blink 1s infinite}@keyframes blink{50%{opacity:.3}}.editor-toolbar+.pf-group .post-content-input{border-radius:0 0 var(--radius-sm) var(--radius-sm)}.post-cover-section{border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;background:var(--bg-secondary)}.post-cover-label{font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.post-media-content img{max-width:100%;height:auto;border-radius:8px;margin:12px 0;display:block}.post-media-content audio{width:100%;margin:12px 0;border-radius:8px;display:block}.post-media-content video{max-width:100%;height:auto;border-radius:8px;margin:12px 0;background:#000;display:block}.post-select{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;background:var(--bg)}.post-select:focus{outline:none;border-color:var(--primary)}.post-cover-upload{display:flex;align-items:center;gap:12px}.post-cover-preview{position:relative;width:100%;max-height:200px;border-radius:var(--radius-sm);overflow:hidden}.post-cover-preview img{width:100%;max-height:200px;object-fit:cover}.post-cover-remove{position:absolute;top:8px;right:8px;padding:4px 10px;background:#0009;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.8rem}.post-create-buttons{display:flex;flex-direction:column;gap:8px}.tag-input-row{display:flex;gap:6px}.tag-input-row input{flex:1;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem}.tag-input-row input:focus{outline:none;border-color:var(--primary)}.btn-tag-add{padding:8px 14px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem}.tag-chips{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.tag-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--bg-secondary);border-radius:16px;font-size:.82rem}.tag-chip button{background:none;border:none;cursor:pointer;font-size:1rem;color:var(--text-secondary);padding:0;line-height:1}.tag-chip button:hover{color:#dc2626}@media(max-width:768px){.forum-page{padding:12px!important}.forum-grid{grid-template-columns:1fr}.forum-header h1{font-size:1.4rem}.forum-toolbar{flex-direction:column;align-items:flex-start}.forum-categories{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:4px;max-width:100%}.forum-cat-btn{white-space:nowrap;flex-shrink:0}.forum-sort{width:100%;justify-content:flex-end}.post-create-layout{grid-template-columns:1fr}.post-create-sidebar{order:2}.post-create-main{order:1}.post-title-input{font-size:1.05rem;padding:12px}.post-content-input{font-size:.9rem}.post-detail-page{padding:12px!important}.post-detail-article h1{font-size:1.3rem}.post-detail-cover img{max-height:220px}.post-detail-actions{gap:10px}.forum-header-actions{flex-direction:column}.forum-search{width:100%}.btn-create-post{width:100%;text-align:center}}.profile-post-list{display:flex;flex-direction:column;gap:10px}.profile-post-item{display:flex;justify-content:space-between;align-items:center;padding:14px;background:var(--bg);border-radius:var(--radius-sm);box-shadow:0 1px 3px #0000000a;gap:12px}.profile-post-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.profile-post-thumb{width:60px;height:40px;border-radius:6px;object-fit:cover;flex-shrink:0}.profile-post-title{font-weight:600;color:var(--text);text-decoration:none;display:block;margin-bottom:4px}.profile-post-title:hover{color:var(--primary)}.profile-post-meta{display:flex;gap:12px;flex-wrap:wrap;font-size:.78rem;color:var(--text-secondary)}.profile-post-actions{display:flex;gap:6px;flex-shrink:0}@media(max-width:768px){.profile-post-item{flex-direction:column;align-items:flex-start}.profile-post-actions{width:100%;justify-content:flex-end}}
