*,*: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)}.home-new-page{min-height:100vh;background:var(--bg)}.hero-new{position:relative;background:linear-gradient(135deg,#0f172a,#1e3a5f 40%,#1e40af,#312e81);padding:100px 24px 80px;overflow:hidden;text-align:center}.hero-new .particle-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;opacity:.5}.hero-new-content{position:relative;z-index:2;max-width:680px;margin:0 auto}.hero-badge{display:inline-block;padding:6px 18px;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-radius:20px;color:#ffffffd9;font-size:.82rem;font-weight:500;margin-bottom:24px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeUp .6s ease both}.hero-new-title{font-size:3.8rem;font-weight:800;color:#fff;letter-spacing:-.03em;margin-bottom:16px;text-shadow:0 4px 30px rgba(59,130,246,.3);animation:fadeUp .6s ease .1s both}.hero-new-subtitle{font-size:1.15rem;color:#ffffffb3;margin-bottom:40px;font-weight:400;animation:fadeUp .6s ease .2s both}.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;animation:fadeUp .6s ease .3s both}.hero-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:12px;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .25s ease;cursor:pointer}.hero-btn-primary{background:#fff;color:#1e3a5f;box-shadow:0 4px 20px #00000026}.hero-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px #00000040}.hero-btn-ghost{background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.3)}.hero-btn-ghost:hover{background:#ffffff38;transform:translateY(-2px)}.hero-wave{position:absolute;bottom:-1px;left:0;right:0;z-index:1;line-height:0}.hero-wave svg{display:block;width:100%;height:80px}.home-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:fadeUp .3s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.hero-user-info{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:28px;animation:fadeUp .6s ease .4s both}.hero-level{padding:4px 14px;border-radius:14px;font-size:.8rem;font-weight:700;flex-shrink:0}.hero-exp-bar-wrap{display:flex;align-items:center;gap:10px}.hero-exp-bar{width:120px;height:8px;background:#ffffff26;border-radius:4px;overflow:hidden}.hero-exp-fill{height:100%;background:linear-gradient(90deg,#60a5fa,#a78bfa);border-radius:4px;transition:width .6s ease}.hero-xp{font-size:.78rem;color:#fff9;font-weight:500;white-space:nowrap}.home-checkin-section{max-width:900px;margin:-30px auto 0;padding:0 24px;position:relative;z-index:3}.home-checkin-card{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border-radius:16px;padding:18px 28px;box-shadow:0 4px 24px #0000000f,0 1px 4px #0000000a;border:1px solid var(--border);gap:16px;animation:fadeUp .5s ease .4s both}.home-checkin-left{display:flex;align-items:center;gap:16px}.home-checkin-icon{font-size:2rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eff6ff,#eef2ff);border-radius:12px;flex-shrink:0}.home-checkin-text strong{display:block;font-size:.95rem;margin-bottom:3px}.home-checkin-stats{display:flex;align-items:center;gap:4px;font-size:.8rem;margin-bottom:2px}.checkin-streak{font-weight:700;color:#f59e0b}.streak-fire{margin-right:2px;display:inline-block;animation:fireWiggle 1s ease-in-out infinite}@keyframes fireWiggle{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}.checkin-total{color:var(--text-secondary);font-weight:400}.checkin-reward-hint{font-size:.75rem;color:var(--text-secondary);margin:0}.home-checkin-btn{padding:10px 24px;border-radius:12px;font-weight:700;font-size:.88rem;background:linear-gradient(135deg,#1e3a8a,#8b5cf6);color:#fff;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}.home-checkin-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #2563eb59}.home-checkin-btn.done{background:#f3f4f6;color:#9ca3af;cursor:default}.home-checkin-msg{text-align:center;margin-top:8px;font-size:.85rem;color:#059669;font-weight:600;animation:fadeUp .3s ease}.home-checkin-msg.error{color:#dc2626}.home-section{max-width:900px;margin:0 auto;padding:48px 24px 0}.home-section-header{margin-bottom:28px}.home-section-header h2{font-size:1.5rem;font-weight:700;margin-bottom:6px;color:var(--text)}.home-section-header p{font-size:.92rem;color:var(--text-secondary)}.home-subjects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.home-subject-card{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px 20px;text-decoration:none;color:inherit;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 1px 4px #00000008}.home-subject-card:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--card-bg),transparent);opacity:0;transition:opacity .3s;pointer-events:none}.home-subject-card:hover{transform:translateY(-3px);box-shadow:0 8px 30px #00000014;border-color:var(--card-color)}.home-subject-card:hover:after{opacity:1}.home-subject-icon-wrap{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;background:var(--card-bg);flex-shrink:0;position:relative;z-index:1;transition:transform .3s}.home-subject-card:hover .home-subject-icon-wrap{transform:scale(1.08)}.home-subject-body{flex:1;position:relative;z-index:1}.home-subject-body h3{font-size:1.05rem;font-weight:650;margin-bottom:4px}.home-subject-body p{font-size:.82rem;color:var(--text-secondary);margin:0}.home-subject-go{color:var(--text-secondary);flex-shrink:0;position:relative;z-index:1;transition:all .3s;opacity:0;transform:translate(-8px)}.home-subject-card:hover .home-subject-go{opacity:1;transform:translate(0);color:var(--card-color)}.home-posts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.home-post-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;text-decoration:none;color:inherit;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 4px #00000008;display:flex;flex-direction:column}.home-post-card:hover{transform:translateY(-3px);box-shadow:0 8px 30px #00000014;border-color:var(--accent)}.home-post-cover{width:100%;height:140px;overflow:hidden}.home-post-cover img{width:100%;height:100%;object-fit:cover;transition:transform .4s}.home-post-card:hover .home-post-cover img{transform:scale(1.05)}.home-post-body{padding:16px;flex:1;display:flex;flex-direction:column}.home-post-cat{display:inline-block;font-size:.7rem;font-weight:600;color:var(--accent);background:var(--accent-light);padding:2px 10px;border-radius:8px;margin-bottom:8px;width:fit-content}.home-post-body h4{font-size:.95rem;font-weight:600;margin-bottom:6px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.home-post-summary{font-size:.8rem;color:var(--text-secondary);margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.home-post-meta{display:flex;gap:12px;font-size:.75rem;color:#9ca3af}.home-section-footer{text-align:center;margin-top:24px}.home-view-all{display:inline-flex;align-items:center;gap:6px;padding:10px 24px;border-radius:12px;font-size:.9rem;font-weight:600;color:var(--accent);text-decoration:none;border:1px solid var(--border);transition:all .2s}.home-view-all:hover{background:var(--accent-light);border-color:var(--accent)}.home-tools-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.home-tool-card{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px;text-decoration:none;color:inherit;transition:all .25s;box-shadow:0 1px 4px #00000008}.home-tool-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000014;border-color:var(--accent)}.home-tool-card-accent{background:linear-gradient(135deg,#eff6ff,#eef2ff);border-color:#c7d2fe}.home-tool-icon{font-size:1.8rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.home-tool-card strong{display:block;font-size:.95rem;margin-bottom:2px}.home-tool-card p{font-size:.8rem;color:var(--text-secondary);margin:0}.home-footer{margin-top:48px;position:relative}.home-footer-wave{line-height:0;color:#1e3a5f}.home-footer-wave svg{display:block;width:100%;height:60px}.home-footer-content{background:#1e3a5f;text-align:center;padding:20px 24px 28px}.home-footer-content p{color:#fffc;font-size:.85rem;margin:0}.home-footer-sub{font-size:.75rem!important;color:#fff6!important;margin-top:4px!important}@media(max-width:768px){.hero-new{padding:72px 16px 64px}.hero-new-title{font-size:2.4rem;margin-bottom:12px}.hero-new-subtitle{font-size:.95rem;margin-bottom:28px}.hero-badge{font-size:.75rem;padding:4px 14px;margin-bottom:18px}.hero-btn{padding:11px 22px;font-size:.88rem}.hero-wave svg{height:50px}.home-checkin-section{margin-top:-24px;padding:0 16px}.home-checkin-card{flex-direction:column;align-items:stretch;padding:16px;gap:12px}.home-checkin-btn{width:100%;text-align:center;padding:12px}.home-section{padding:36px 16px 0}.home-section-header h2{font-size:1.25rem}.home-section-header p{font-size:.82rem}.home-subjects-grid{grid-template-columns:1fr;gap:12px}.home-subject-card{padding:18px 16px;gap:14px}.home-subject-icon-wrap{width:44px;height:44px;font-size:1.3rem;border-radius:12px}.home-subject-body h3{font-size:.95rem}.home-subject-body p{font-size:.78rem}.home-subject-go{opacity:1;transform:none}.home-posts-grid{grid-template-columns:1fr;gap:12px}.home-post-cover{height:160px}.home-tools-row{grid-template-columns:1fr;gap:12px}.home-footer-wave svg{height:40px}.hero-user-info{margin-top:20px}}@media(min-width:769px){.home-subject-card{animation:cardFadeIn .5s ease both}.home-subject-card:nth-child(1){animation-delay:.05s}.home-subject-card:nth-child(2){animation-delay:.1s}.home-subject-card:nth-child(3){animation-delay:.15s}.home-subject-card:nth-child(4){animation-delay:.2s}.home-post-card{animation:cardFadeIn .5s ease both}.home-post-card:nth-child(1){animation-delay:.1s}.home-post-card:nth-child(2){animation-delay:.15s}.home-post-card:nth-child(3){animation-delay:.2s}.home-post-card:nth-child(4){animation-delay:.25s}}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.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}.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}.q-page-link{display:inline-block;margin-top:14px;padding:8px 16px;background:#64748b;color:#fff!important;border-radius:8px;font-size:.85rem;text-decoration:none;text-align:center}.q-page-link:hover{background:#475569}.q-page-link.review-page-link{display:block;margin-top:12px}.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,#1e3a8a,#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,#1e3a8a,#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,#1e3a8a,#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-nav-badge{margin-left:auto;min-width:20px;height:20px;line-height:20px;text-align:center;font-size:.65rem;font-weight:700;color:#fff;background:#ef4444;border-radius:10px;padding:0 6px}.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 #1e3a8a;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,#1e3a8a,#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}.notif-action-btn{padding:6px 14px;border-radius:8px;font-size:.78rem;font-weight:600;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:all .15s}.notif-action-btn:hover:not(:disabled){background:#f3f4f6}.notif-action-btn:disabled{opacity:.5;cursor:not-allowed}.notif-action-btn.small{padding:4px 10px;font-size:.72rem}.notif-action-btn.danger{color:#ef4444;border-color:#fecaca}.notif-action-btn.danger:hover:not(:disabled){background:#fef2f2}.notif-tab-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#22c55e;margin-left:4px;vertical-align:middle}.notif-batch-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:12px}.notif-select-all{display:flex;align-items:center;gap:8px;font-size:.82rem;cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-secondary)}.notif-batch-actions{display:flex;gap:6px}.notif-checkbox{width:18px;height:18px;border-radius:4px;border:2px solid #d1d5db;display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#fff;transition:all .15s;flex-shrink:0}.notif-checkbox.checked{background:var(--accent);border-color:var(--accent)}.notif-checkbox-wrap{cursor:pointer;padding:4px;display:flex;align-items:center}.notif-empty-state{text-align:center;padding:48px 20px;color:var(--text-secondary)}.notif-empty-icon{font-size:3rem;display:block;margin-bottom:12px;opacity:.6}.notif-empty-state p{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:4px}.notif-empty-state span{font-size:.8rem}.notif-full-list{display:flex;flex-direction:column;gap:4px}.notif-full-item{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;border-radius:var(--radius-sm);transition:background .15s;border:1px solid transparent}.notif-full-item:hover{background:#f9fafb;border-color:var(--border)}.notif-full-item.unread{background:#f0f9ff;border-color:#bae6fd}.notif-full-item.unread:hover{background:#e0f2fe}.notif-full-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.notif-full-body{flex:1;min-width:0;cursor:pointer}.notif-full-title{font-size:.88rem;font-weight:700;margin-bottom:2px;background:linear-gradient(135deg,#1e3a8a,#2563eb,#1e40af);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#1e40af;display:inline-block}.notif-full-content{font-size:.8rem;color:#1d4ed8;line-height:1.5}.notif-full-time{font-size:.7rem;color:#2563eb;margin-top:4px;font-weight:600}.notif-full-actions{display:flex;gap:4px;flex-shrink:0;opacity:0;transition:opacity .15s}.notif-full-item:hover .notif-full-actions{opacity:1}.notif-icon-btn{width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.notif-icon-btn:hover{background:#f3f4f6;color:var(--text)}.notif-icon-btn.danger:hover{background:#fef2f2;color:#ef4444}@media(max-width:768px){.notif-full-actions{opacity:1}.notif-batch-bar{flex-wrap:wrap;gap:8px}}.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}.nav-notif-wrap{position:relative;display:flex;align-items:center}.nav-notif-btn{position:relative;background:none;border:none;padding:8px 10px;border-radius:50%;cursor:pointer;color:var(--text-secondary);transition:all .2s;display:flex;align-items:center;justify-content:center}.nav-notif-btn:hover{background:#f3f4f6;color:var(--text)}.nav-notif-badge{position:absolute;top:2px;right:2px;min-width:18px;height:18px;line-height:18px;text-align:center;font-size:.65rem;font-weight:700;color:#fff;background:#ef4444;border-radius:9px;padding:0 4px;animation:badgePop .3s ease}@keyframes badgePop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.nav-notif-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:380px;max-height:480px;background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:0 12px 40px #0000001f,0 2px 8px #0000000f;z-index:200;display:flex;flex-direction:column;overflow:hidden;animation:notifSlide .2s ease}@keyframes notifSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.nav-notif-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;font-weight:700;font-size:.95rem;border-bottom:1px solid var(--border)}.nav-notif-markall{background:none;border:none;font-size:.75rem;color:var(--accent);cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .15s}.nav-notif-markall:hover{background:var(--accent-light)}.nav-notif-body{flex:1;overflow-y:auto;max-height:360px}.nav-notif-empty{padding:40px 20px;text-align:center;color:var(--text-secondary);font-size:.85rem}.nav-notif-item{display:flex;align-items:flex-start;gap:10px;padding:12px 20px;cursor:pointer;transition:background .15s;position:relative}.nav-notif-item:hover{background:#f9fafb}.nav-notif-item.unread{background:#eff6ff}.nav-notif-item.unread:hover{background:#e0ecff}.nav-notif-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}.nav-notif-info{flex:1;min-width:0}.nav-notif-title{font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-notif-desc{font-size:.76rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.nav-notif-time{font-size:.68rem;color:#aaa;margin-top:2px}.nav-notif-dot{width:7px;height:7px;border-radius:50%;background:#3b82f6;flex-shrink:0;margin-top:6px}.nav-notif-footer{display:block;text-align:center;padding:12px;font-size:.82rem;font-weight:600;color:var(--accent);border-top:1px solid var(--border);transition:background .15s;text-decoration:none}.nav-notif-footer:hover{background:var(--accent-light)}.nav-link{position:relative}.nav-tab-dot{position:absolute;top:4px;right:2px;width:8px;height:8px;border-radius:50%;background:#22c55e;border:2px solid var(--surface);animation:dotPulse 2s ease-in-out infinite}@keyframes dotPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}}@media(max-width:768px){.nav-notif-dropdown{position:fixed;top:60px;right:8px;left:8px;width: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,#1e3a8a,#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,#1e3a8a,#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,#1e3a8a,#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;gap:8px}.navbar{height:auto;min-height:56px}.navbar-brand{font-size:1.05rem!important;margin-right:auto}.nav-mobile-notif-btn{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--text);background:none;border:none;text-decoration:none;border-radius:50%;-webkit-tap-highlight-color:transparent;transition:background .15s}.nav-mobile-notif-btn:active{background:#0f172a14}.nav-mobile-notif-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;line-height:16px;text-align:center;border:1.5px solid var(--bg);box-shadow:0 2px 6px #ef444466}.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}.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,.nav-mobile-notif-btn{display:none!important}}.profile-overview-links{margin-top:28px}.profile-overview-links h4{margin:0 0 14px;font-size:1rem;color:var(--text)}.profile-overview-links-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px}.profile-overview-link{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:18px 8px;background:#fff;border:1px solid var(--border);border-radius:14px;text-decoration:none;color:var(--text);transition:all .2s;box-shadow:0 2px 8px #0f172a0a}.profile-overview-link:hover{transform:translateY(-2px);border-color:var(--link-color, #6366f1);box-shadow:0 6px 18px #0f172a1a}.profile-overview-link:active{transform:translateY(0)}.profile-overview-link-icon{font-size:1.6rem;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:color-mix(in srgb,var(--link-color, #6366f1) 12%,transparent)}.profile-overview-link-label{font-size:.82rem;font-weight:600;text-align:center}.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 a{color:#2563eb;text-decoration:underline;text-underline-offset:2px;transition:color .15s}.post-detail-content a:hover{color:#1d4ed8}.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;display:inline-flex;align-items:center;gap:6px}.post-like-btn:hover{border-color:#ef4444;transform:scale(1.02)}.post-like-btn.liked{background:#ef4444;border-color:#ef4444;color:#fff;box-shadow:0 2px 8px #ef44444d}.post-like-btn.liked .like-heart,.post-like-btn.liked .like-count{color:#fff}.like-heart{display:inline-block;font-size:1.1rem;line-height:1}.like-count{font-weight:600}.like-heart-active{animation:likeHeartPop .6s cubic-bezier(.17,.89,.32,1.49)}@keyframes likeHeartPop{0%{transform:scale(1)}30%{transform:scale(1.6)}50%{transform:scale(.9)}70%{transform:scale(1.3)}to{transform:scale(1)}}.like-particle{position:absolute;pointer-events:none;opacity:0;transform:translate(-50%,-50%);animation-fill-mode:forwards}.like-particle-tier1{animation:particleGray 1s ease-out forwards;color:#9ca3af}@keyframes particleGray{0%{opacity:1;transform:translate(-50%,-50%) scale(.5)}to{opacity:0;transform:translate(calc(-50% + var(--lx)),calc(-50% + var(--ly))) scale(1)}}.like-particle-tier2{animation:particleGreen 1.2s ease-out forwards;color:#059669}@keyframes particleGreen{0%{opacity:1;transform:translate(-50%,-50%) scale(0) rotate(0)}50%{opacity:1;transform:translate(calc(-50% + var(--lx) * .6),calc(-50% + var(--ly) * .6)) scale(1.3) rotate(180deg)}to{opacity:0;transform:translate(calc(-50% + var(--lx)),calc(-50% + var(--ly))) scale(.8) rotate(360deg)}}.like-particle-tier3{animation:particleBlue 1s ease-out forwards;color:#3b82f6}@keyframes particleBlue{0%{opacity:1;transform:translate(-50%,-50%) scale(0);filter:blur(0)}60%{opacity:.8;transform:translate(calc(-50% + var(--lx) * .7),calc(-50% + var(--ly) * .7)) scale(1.4);filter:blur(0)}to{opacity:0;transform:translate(calc(-50% + var(--lx)),calc(-50% + var(--ly))) scale(.5);filter:blur(2px)}}.like-particle-tier4{animation:particlePurple .8s ease-out forwards;color:#7c3aed}@keyframes particlePurple{0%{opacity:1;transform:translate(-50%,-50%) scale(1.5);filter:brightness(2)}30%{opacity:1;transform:translate(calc(-50% + var(--lx) * .4),calc(-50% + var(--ly) * .4)) scale(2);filter:brightness(1.5)}to{opacity:0;transform:translate(calc(-50% + var(--lx)),calc(-50% + var(--ly))) scale(.3);filter:brightness(1)}}.like-particle-tier5{animation:particleGold 1.4s ease-out forwards;color:#d97706}@keyframes particleGold{0%{opacity:1;transform:translate(-50%,-50%) scale(0) rotate(-90deg)}30%{opacity:1;transform:translate(calc(-50% + var(--lx) * .3),calc(-50% + var(--ly) * .3)) scale(1.8) rotate(0);filter:brightness(1.5) drop-shadow(0 0 4px #fbbf24)}70%{opacity:.7;transform:translate(calc(-50% + var(--lx) * .8),calc(-50% + var(--ly) * .8)) scale(1.2) rotate(90deg)}to{opacity:0;transform:translate(calc(-50% + var(--lx)),calc(-50% + var(--ly) + 20px)) scale(.6) rotate(180deg)}}.like-particle-tier6{animation:particleRed .7s cubic-bezier(.25,.46,.45,.94) forwards;color:#dc2626}@keyframes particleRed{0%{opacity:1;transform:translate(-50%,-50%) scale(2);filter:brightness(3)}20%{opacity:1;transform:translate(calc(-50% + var(--lx) * .5),calc(-50% + var(--ly) * .5)) scale(2.5)}to{opacity:0;transform:translate(calc(-50% + var(--lx)),calc(-50% + var(--ly))) scale(.2);filter:brightness(1)}}.like-particle-tier7{animation:particleRainbow 1.6s ease-out forwards}@keyframes particleRainbow{0%{opacity:1;transform:translate(-50%,-50%) scale(0) rotate(0);filter:hue-rotate(0deg) brightness(2)}20%{opacity:1;transform:translate(calc(-50% + var(--lx) * .3),calc(-50% + var(--ly) * .3)) scale(2) rotate(72deg);filter:hue-rotate(90deg) brightness(1.5)}50%{opacity:.9;transform:translate(calc(-50% + var(--lx) * .7),calc(-50% + var(--ly) * .7)) scale(1.5) rotate(180deg);filter:hue-rotate(180deg) brightness(1.2)}to{opacity:0;transform:translate(calc(-50% + var(--lx)),calc(-50% + var(--ly))) scale(.4) rotate(360deg);filter:hue-rotate(360deg) brightness(1)}}.post-like-btn.liked.tier-1{background:#f3f4f6;border-color:#9ca3af}.post-like-btn.liked.tier-2{background:#ecfdf5;border-color:#059669}.post-like-btn.liked.tier-3{background:#eff6ff;border-color:#3b82f6}.post-like-btn.liked.tier-4{background:#f5f3ff;border-color:#7c3aed}.post-like-btn.liked.tier-5{background:#fffbeb;border-color:#d97706}.post-like-btn.liked.tier-6{background:#fef2f2;border-color:#dc2626}.post-like-btn.liked.tier-7{background:linear-gradient(135deg,#fef2f2,#fffbeb,#ecfdf5,#eff6ff,#f5f3ff);border-color:#a855f7}.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;word-break:break-word}.comment-content img{max-width:100%;border-radius:8px;margin:6px 0}.comment-content a{color:#2563eb;text-decoration:underline;text-underline-offset:2px;transition:color .15s}.comment-content a:hover{color:#1d4ed8}.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}.comment-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover}.comment-avatar-default{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem}.comment-avatar-link{display:flex;flex-shrink:0}.comment-sort-tabs{display:flex;gap:4px}.comment-sort-tabs button{padding:4px 12px;font-size:.75rem;border:1px solid var(--border);border-radius:14px;background:var(--bg);color:var(--text-secondary);cursor:pointer}.comment-sort-tabs button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.comment-vote{display:flex;gap:8px;margin-top:6px}.vote-btn{padding:3px 10px;font-size:.78rem;border:1px solid var(--border);border-radius:14px;background:var(--bg);color:var(--text-secondary);cursor:pointer;transition:all .15s}.vote-btn:hover:not(.voted-like):not(.voted-dislike){border-color:var(--primary)}.vote-btn.voted-like{background:#059669;color:#fff;border-color:#059669;font-weight:600;box-shadow:0 1px 6px #0596694d}.vote-btn.voted-dislike{background:#dc2626;color:#fff;border-color:#dc2626;font-weight:600;box-shadow:0 1px 6px #dc26264d}.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:.75rem;color:var(--text-secondary);margin-right:2px;flex-shrink:0}.toolbar-group{display:flex;align-items:center;gap:4px;flex-wrap:nowrap}.toolbar-divider{width:1px;height:24px;background:var(--border);margin:0 4px;flex-shrink:0}.toolbar-btn{padding:4px 10px;font-size:.78rem;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}.editor-mode-tabs{display:flex;align-items:center;gap:4px;padding:6px 0}.editor-mode-tab{padding:5px 14px;font-size:.82rem;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text-secondary);cursor:pointer;transition:all .15s}.editor-mode-tab:hover{border-color:var(--primary);color:var(--primary)}.editor-mode-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.editor-mode-hint{margin-left:auto;font-size:.72rem;color:var(--text-secondary)}.editor-content-area{display:grid;gap:0;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;min-height:400px}.editor-content-area.mode-split{grid-template-columns:1fr 1fr}.editor-content-area.mode-edit,.editor-content-area.mode-preview{grid-template-columns:1fr}.editor-pane{display:flex;flex-direction:column}.editor-pane .post-content-input{border:none;border-radius:0;flex:1;min-height:400px;resize:none}.preview-pane{border-left:1px solid var(--border);background:var(--bg);display:flex;flex-direction:column;overflow-y:auto}.editor-content-area.mode-preview .preview-pane{border-left:none}.preview-header{padding:8px 14px;font-size:.75rem;font-weight:600;color:var(--text-secondary);background:var(--bg-secondary);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.5px}.preview-content{padding:16px;flex:1;font-size:.95rem;line-height:1.7;overflow-y:auto}.color-picker-popup{position:absolute;top:100%;left:0;margin-top:4px;background:var(--bg);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 30px #0000001f;padding:8px;display:grid;grid-template-columns:repeat(6,1fr);gap:4px;z-index:50;width:180px}.color-picker-item{background:none;border:1px solid transparent;border-radius:4px;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,transform .1s}.color-picker-item:hover{border-color:var(--primary);transform:scale(1.15)}.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}.editor-content-area{grid-template-columns:1fr!important}.preview-pane{border-left:none!important;border-top:1px solid var(--border)}.editor-mode-hint{display:none}.color-picker-popup{width:160px;grid-template-columns:repeat(6,1fr)}.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}.editor-toolbar{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding:6px 8px;gap:4px;scrollbar-width:none}.editor-toolbar::-webkit-scrollbar{display:none}.toolbar-group,.toolbar-divider{flex-shrink:0}.toolbar-btn{padding:4px 8px;font-size:.72rem}}.emoji-picker{background:var(--bg-primary, #fff);border:1px solid var(--border, #e5e7eb);border-radius:12px;box-shadow:0 8px 30px #0000001f;padding:8px;margin-bottom:8px;width:340px;max-width:calc(100vw - 32px);z-index:100}.emoji-category-tabs{display:flex;gap:2px;overflow-x:auto;scrollbar-width:none;border-bottom:1px solid var(--border, #e5e7eb);padding-bottom:6px;margin-bottom:8px}.emoji-category-tabs::-webkit-scrollbar{display:none}.emoji-cat-tab{background:none;border:none;font-size:1.2rem;padding:4px 6px;cursor:pointer;border-radius:6px;transition:background .15s;flex-shrink:0}.emoji-cat-tab:hover{background:var(--bg-secondary, #f3f4f6)}.emoji-cat-tab.active{background:var(--accent-light, #dbeafe)}.emoji-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(36px,1fr));gap:2px;max-height:200px;overflow-y:auto}.emoji-item{background:none;border:none;font-size:1.3rem;padding:4px;cursor:pointer;border-radius:6px;transition:background .15s,transform .1s;line-height:1.2;aspect-ratio:1;display:flex;align-items:center;justify-content:center}.emoji-item:hover{background:var(--bg-secondary, #f3f4f6);transform:scale(1.2)}.emoji-category-label{font-size:.75rem;color:var(--text-secondary, #6b7280);padding-top:6px;text-align:center}.drafts-open-btn{background:linear-gradient(135deg,#1e3a8a,#8b5cf6);color:#fff;border:none;border-radius:10px;padding:8px 20px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #2563eb4d;margin-bottom:16px}.drafts-open-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2563eb66}.drafts-overlay{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;justify-content:center;align-items:flex-start;padding-top:60px;animation:fadeIn .2s ease}.drafts-panel{background:var(--bg-card, #fff);border-radius:16px;width:560px;max-width:94vw;max-height:75vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000026;animation:slideDown .25s ease}.drafts-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border, #e5e7eb);flex-shrink:0}.drafts-header h2{margin:0;font-size:1.15rem;color:var(--text, #1f2937)}.drafts-close-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--text-secondary, #6b7280);padding:4px 8px;border-radius:6px;transition:all .15s}.drafts-close-btn:hover{background:var(--bg-secondary, #f3f4f6);color:var(--text, #1f2937)}.drafts-list{flex:1;overflow-y:auto;padding:16px}.drafts-empty{text-align:center;padding:40px 20px;color:var(--text-secondary, #6b7280)}.drafts-empty p{font-size:1rem;margin:8px 0 4px}.drafts-empty span{font-size:.82rem;color:var(--text-tertiary, #9ca3af)}.draft-card{background:var(--bg-primary, #fafafa);border:1px solid var(--border, #e5e7eb);border-radius:12px;padding:16px;margin-bottom:12px;transition:all .2s}.draft-card:hover{border-color:var(--accent, #1e3a8a);box-shadow:0 2px 8px #2563eb1a}.draft-card-main{margin-bottom:12px}.draft-card-title{font-size:1rem;font-weight:600;color:var(--text, #1f2937);margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.draft-card-meta{display:flex;align-items:center;gap:10px;font-size:.78rem;margin-bottom:6px}.draft-category{background:var(--bg-secondary, #f3f4f6);color:var(--text-secondary, #6b7280);padding:2px 8px;border-radius:4px;font-size:.72rem}.draft-time{color:var(--text-tertiary, #9ca3af)}.draft-card-preview{font-size:.82rem;color:var(--text-secondary, #6b7280);line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.draft-card-actions{display:flex;gap:8px;justify-content:flex-end}.draft-action-btn{border:none;border-radius:8px;padding:7px 16px;font-size:.82rem;cursor:pointer;transition:all .15s;font-weight:500}.draft-edit-btn{background:var(--accent, #1e3a8a);color:#fff}.draft-edit-btn:hover{background:var(--accent-hover, #4f46e5);transform:translateY(-1px)}.draft-delete-btn{background:transparent;color:var(--text-secondary, #6b7280);border:1px solid var(--border, #e5e7eb)}.draft-delete-btn:hover{background:#fef2f2;color:#dc2626;border-color:#fecaca}.draft-delete-btn:disabled{opacity:.5;cursor:not-allowed}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.comment-toolbar{display:flex;gap:6px;padding:6px 0;border-bottom:1px solid var(--border, #e5e7eb);margin-bottom:8px}.comment-toolbar-btn{background:var(--bg-secondary, #f3f4f6);border:1px solid var(--border, #e5e7eb);border-radius:6px;padding:5px 12px;font-size:.82rem;cursor:pointer;color:var(--text, #1f2937);transition:background .15s}.comment-toolbar-btn:hover{background:var(--bg-tertiary, #e5e7eb)}.comment-toolbar-btn:disabled{opacity:.5;cursor:not-allowed}.comment-form-footer{display:flex;justify-content:space-between;align-items:center;margin-top:8px}.comment-avatar-link{text-decoration:none;display:inline-flex}@media(max-width:768px){.emoji-picker{width:calc(100vw - 24px)}.emoji-grid{max-height:160px;grid-template-columns:repeat(auto-fill,minmax(32px,1fr))}.emoji-item{font-size:1.1rem;padding:3px}.drafts-overlay{padding-top:0;align-items:stretch}.drafts-panel{width:100%;max-width:100%;max-height:100vh;border-radius:0;min-height:100vh}.drafts-header{padding:16px}.drafts-header h2{font-size:1rem}.drafts-list,.draft-card{padding:12px}.draft-card-title{font-size:.9rem}.draft-card-actions{flex-direction:row;gap:8px}.draft-action-btn{flex:1;text-align:center;padding:8px 12px;font-size:.82rem}.drafts-open-btn{width:100%;padding:10px;text-align:center}}.follow-btn{position:relative;display:inline-flex;align-items:center;gap:6px;padding:8px 20px;border-radius:20px;font-size:.85rem;font-weight:600;cursor:pointer;border:2px solid transparent;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;white-space:nowrap;flex-shrink:0}.follow-btn--follow{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-color:transparent;box-shadow:0 2px 12px #3b82f659}.follow-btn--follow:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 18px #3b82f673;transform:translateY(-1px)}.follow-btn--follow:active{transform:translateY(0);box-shadow:0 2px 8px #3b82f64d}.follow-btn--following{background:#f0f9ff;color:#3b82f6;border-color:#bfdbfe}.follow-btn--following:hover{background:#fef2f2;color:#ef4444;border-color:#fecaca}.follow-btn--animating{animation:followPop .4s cubic-bezier(.4,0,.2,1)}@keyframes followPop{0%{transform:scale(1)}30%{transform:scale(1.12)}60%{transform:scale(.95)}to{transform:scale(1)}}.follow-btn__icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;transition:transform .3s ease}.follow-btn--follow:hover .follow-btn__icon{transform:rotate(90deg)}.follow-btn--following:hover .follow-btn__icon{transform:scale(1.15)}.follow-btn__text{transition:opacity .2s}.follow-btn__badge{width:6px;height:6px;background:#3b82f6;border-radius:50%;animation:badgePulse 2s ease-in-out infinite}.follow-btn--following:hover .follow-btn__badge{display:none}@keyframes badgePulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.follow-btn__spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(59,130,246,.3);border-top-color:#3b82f6;border-radius:50%;animation:followSpin .6s linear infinite}.follow-btn--following .follow-btn__spinner{border-color:#3b82f633;border-top-color:#3b82f6}@keyframes followSpin{to{transform:rotate(360deg)}}.follow-btn:disabled{opacity:.7;cursor:not-allowed;transform:none!important}@media(max-width:768px){.follow-btn{padding:10px 18px;font-size:.88rem;border-radius:22px;min-height:44px}}.pub-profile{max-width:720px;margin:0 auto}.pub-cover{width:100%;height:220px;border-radius:16px;overflow:hidden;position:relative}.pub-cover img{width:100%;height:100%;object-fit:cover}.pub-cover-placeholder{width:100%;height:100%}.pub-header{display:flex;align-items:flex-end;justify-content:space-between;margin-top:-44px;padding:0 20px;position:relative;z-index:2}.pub-avatar-wrap{position:relative;width:88px;height:88px;border-radius:50%;border:4px solid var(--surface);overflow:visible;background:#e5e7eb;box-shadow:0 2px 16px #0000001f;flex-shrink:0}.pub-avatar-wrap img{width:100%;height:100%;border-radius:50%;object-fit:cover}.pub-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:36px;color:#9ca3af;background:#e5e7eb;border-radius:50%}.pub-avatar-badge{position:absolute;bottom:-2px;right:-2px;padding:1px 8px;border-radius:10px;font-size:.6rem;font-weight:800;background:linear-gradient(90deg,#ef4444,#f59e0b,#22c55e,#3b82f6,#a855f7,#ef4444);background-size:200% 100%;color:#fff;border:2px solid var(--surface);white-space:nowrap}.pub-header-actions{padding-bottom:6px}.pub-identity{padding:16px 20px 0}.pub-name-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.pub-name-row h2{margin:0;font-size:1.5rem}.pub-level-tag{padding:2px 12px;border-radius:12px;font-size:.72rem;font-weight:700;letter-spacing:.02em}.pub-handle{color:var(--text-secondary);font-size:.85rem;margin:2px 0 0}.pub-bio{color:var(--text-secondary);font-size:.9rem;line-height:1.65;margin:10px 0 0}.pub-social-row{display:flex;gap:0;padding:20px 20px 0}.pub-social-item{flex:1;text-align:center;padding:12px 0;position:relative;cursor:default;transition:background .2s;border-radius:10px}.pub-social-item:hover{background:var(--bg)}.pub-social-item strong{display:block;font-size:1.15rem;font-weight:700}.pub-social-item span{display:block;font-size:.72rem;color:var(--text-secondary);margin-top:2px}.pub-stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;padding:20px 20px 0}.pub-stat-card{text-align:center;padding:16px 8px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);transition:transform .2s,box-shadow .2s}.pub-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.pub-stat-icon{font-size:1.3rem;display:block;margin-bottom:4px}.pub-stat-value{font-size:1.1rem;font-weight:700;color:var(--text)}.pub-stat-label{font-size:.72rem;color:var(--text-secondary);margin-top:2px}.pub-quiz-overview{display:flex;align-items:center;gap:20px;padding:20px;background:linear-gradient(135deg,#eff6ff,#f0f9ff);border-radius:var(--radius);border:1px solid #bfdbfe;margin-bottom:16px}.pub-quiz-big{text-align:center;flex-shrink:0;min-width:80px}.pub-quiz-score{font-size:2.2rem;font-weight:800;color:#2563eb;line-height:1}.pub-quiz-score span{font-size:.75rem;font-weight:500;color:#60a5fa}.pub-quiz-label{font-size:.72rem;color:#3b82f6;margin-top:4px}.pub-quiz-details{flex:1;display:flex;gap:16px;justify-content:space-around}.pub-quiz-detail-item{text-align:center}.pub-quiz-num{display:block;font-size:1.2rem;font-weight:700;color:var(--text)}.pub-quiz-dlabel{display:block;font-size:.7rem;color:var(--text-secondary);margin-top:2px}.pub-quiz-subjects{display:flex;flex-direction:column;gap:10px}.pub-subject-bar{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border)}.pub-subject-info{min-width:90px}.pub-subject-name{font-size:.82rem;font-weight:600}.pub-subject-count{font-size:.7rem;color:var(--text-secondary);margin-left:6px}.pub-subject-progress{flex:1;height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.pub-subject-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#3b82f6,#2563eb);transition:width .6s cubic-bezier(.4,0,.2,1)}.pub-subject-score{font-size:.82rem;font-weight:700;color:#2563eb;min-width:38px;text-align:right}.pub-joined{display:flex;align-items:center;gap:6px;padding:16px 20px;color:var(--text-secondary);font-size:.8rem}.pub-section{padding:0 20px;margin-top:8px}.pub-section-title{display:flex;align-items:center;gap:8px;font-size:1.05rem;font-weight:700;margin-bottom:16px;color:var(--text)}.pub-section-count{font-size:.72rem;font-weight:500;color:var(--text-secondary);background:var(--bg);padding:2px 8px;border-radius:10px;margin-left:4px}.pub-post-list{display:flex;flex-direction:column;gap:10px}.pub-post-card{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s,border-color .2s}.pub-post-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#c4b5fd}.pub-post-cover{width:56px;height:42px;border-radius:8px;object-fit:cover;flex-shrink:0}.pub-post-body{flex:1;min-width:0}.pub-post-title{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pub-post-meta{display:flex;align-items:center;gap:10px;margin-top:4px;font-size:.72rem;color:var(--text-secondary)}.pub-post-cat{background:var(--bg);padding:1px 8px;border-radius:6px;font-size:.68rem}.pub-post-stat{display:inline-flex;align-items:center;gap:3px}.pub-post-date{font-size:.72rem;color:var(--text-secondary);flex-shrink:0}@media(max-width:768px){.pub-profile{padding-bottom:80px}.pub-cover{height:160px;border-radius:0}.pub-header{padding:0 16px;margin-top:-36px}.pub-avatar-wrap{width:72px;height:72px}.pub-identity{padding:12px 16px 0}.pub-name-row h2{font-size:1.25rem}.pub-social-row{padding:16px 16px 0}.pub-social-item strong{font-size:1rem}.pub-stats-grid{grid-template-columns:repeat(2,1fr);padding:16px 16px 0;gap:8px}.pub-section{padding:0 16px}.pub-quiz-overview{flex-direction:column;text-align:center;padding:16px}.pub-quiz-details{width:100%}.pub-joined{padding:16px}.pub-post-card{padding:12px}.pub-post-date{display:none}}.subject-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}.subject-header-actions{flex-shrink:0}.feedback-trigger-btn{position:relative;display:inline-flex;align-items:center;gap:8px;padding:10px 22px;font-size:1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#f59e0b,#ef4444,#ec4899);background-size:200% 200%;border:none;border-radius:999px;cursor:pointer;box-shadow:0 6px 20px #ef444459,0 0 #ef444480;animation:feedbackGradient 4s ease infinite,feedbackPulseRing 2s ease-out infinite;transition:transform .15s,box-shadow .25s}.feedback-trigger-btn:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 10px 28px #ef444480,0 0 0 6px #ef444426}.feedback-trigger-btn:active{transform:scale(.98)}.feedback-trigger-icon{font-size:1.15rem;animation:feedbackShake 1.6s ease-in-out infinite;display:inline-block}.feedback-trigger-pulse{position:absolute;inset:0;border-radius:999px;background:#ef444459;animation:feedbackPulseExpand 2s ease-out infinite;pointer-events:none;z-index:-1}@keyframes feedbackGradient{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes feedbackShake{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}@keyframes feedbackPulseRing{0%{box-shadow:0 6px 20px #ef444459,0 0 #ef444499}70%{box-shadow:0 6px 20px #ef444459,0 0 0 14px #ef444400}to{box-shadow:0 6px 20px #ef444459,0 0 #ef444400}}@keyframes feedbackPulseExpand{0%{transform:scale(1);opacity:.8}to{transform:scale(1.6);opacity:0}}.feedback-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:9999;display:flex;justify-content:center;align-items:center;animation:feedbackFadeIn .2s ease-out;padding:16px}.feedback-modal{background:var(--bg-card, #fff);color:var(--text, #1f2937);border-radius:20px;padding:28px 32px;width:580px;max-width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 24px 60px #00000059;animation:feedbackSlideUp .3s ease-out}@keyframes feedbackFadeIn{0%{opacity:0}to{opacity:1}}@keyframes feedbackSlideUp{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.feedback-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border:none;border-radius:50%;background:#0000000d;color:var(--text, #1f2937);cursor:pointer;font-size:1rem;transition:background .15s}.feedback-close:hover{background:#0000001a}.feedback-header h2{margin:0 0 6px;font-size:1.5rem;background:linear-gradient(135deg,#f59e0b,#ef4444,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.feedback-header p{margin:0 0 20px;color:var(--text-secondary, #6b7280);font-size:.9rem}.feedback-section{margin-bottom:18px}.feedback-label{display:flex;justify-content:space-between;align-items:center;font-weight:600;margin-bottom:10px;font-size:.92rem}.feedback-counter{font-weight:400;font-size:.8rem;color:var(--text-secondary, #6b7280)}.feedback-type-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px}.feedback-type-card{display:flex;flex-direction:column;align-items:flex-start;padding:10px 12px;background:#00000008;border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .15s;font:inherit;color:inherit;text-align:left}.feedback-type-card:hover{background:#f59e0b14;border-color:#f59e0b4d}.feedback-type-card.active{background:linear-gradient(135deg,#f59e0b26,#ef44441a);border-color:#f59e0b;box-shadow:0 4px 14px #f59e0b40}.feedback-type-icon{font-size:1.4rem;margin-bottom:2px}.feedback-type-name{font-weight:700;font-size:.92rem}.feedback-type-desc{font-size:.75rem;color:var(--text-secondary, #6b7280);margin-top:2px}.feedback-textarea{width:100%;padding:12px 14px;border:2px solid rgba(0,0,0,.08);border-radius:12px;background:#00000005;color:inherit;font:inherit;font-size:.92rem;resize:vertical;min-height:120px;transition:border-color .15s}.feedback-textarea:focus{outline:none;border-color:#f59e0b;background:#ffffff0a}.feedback-msg{padding:10px 14px;border-radius:10px;font-size:.88rem;margin-bottom:12px}.feedback-msg.success{background:#10b9811a;color:#059669}.feedback-msg.error{background:#ef44441a;color:#dc2626}.feedback-actions{display:flex;gap:10px;justify-content:flex-end;margin-bottom:18px}.feedback-cancel{padding:10px 22px;border:1px solid rgba(0,0,0,.1);background:transparent;color:var(--text-secondary, #6b7280);border-radius:10px;cursor:pointer;font:inherit}.feedback-cancel:hover{background:#0000000a}.feedback-submit{padding:10px 26px;background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;border:none;border-radius:10px;font:inherit;font-weight:700;cursor:pointer;box-shadow:0 4px 14px #f59e0b59;transition:transform .15s,box-shadow .15s}.feedback-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #f59e0b80}.feedback-submit:disabled{opacity:.6;cursor:not-allowed}.feedback-wechat{background:linear-gradient(135deg,#22c55e14,#10b9810a);border:1.5px dashed rgba(34,197,94,.35);border-radius:14px;padding:14px 18px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.88rem;color:var(--text-secondary, #6b7280)}.feedback-wechat strong{color:var(--text, #1f2937)}.feedback-wechat-id{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:1.05rem;font-weight:700;color:#16a34a;letter-spacing:.5px;-webkit-user-select:all;user-select:all}.feedback-wechat-copy{margin-left:auto;padding:4px 12px;border:1px solid rgba(34,197,94,.35);background:#ffffff80;color:#16a34a;border-radius:8px;cursor:pointer;font:inherit;font-size:.8rem;font-weight:600}.feedback-wechat-copy:hover{background:#22c55e1a}@media(max-width:600px){.feedback-modal{padding:22px 18px}.feedback-header h2{font-size:1.25rem}.feedback-type-grid{grid-template-columns:1fr 1fr}.feedback-type-desc{display:none}.feedback-trigger-btn{padding:8px 16px;font-size:.9rem}.feedback-trigger-text{display:none}.subject-header-row{gap:8px}}.feedback-my-list{display:flex;flex-direction:column;gap:14px}.feedback-my-card{background:var(--card-bg, rgba(255, 255, 255, .04));border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:16px 18px}.feedback-my-card.status-pending{border-left:3px solid #f59e0b}.feedback-my-card.status-replied{border-left:3px solid #10b981}.feedback-my-card.status-closed{border-left:3px solid #6b7280;opacity:.78}.feedback-my-header{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:8px;font-size:.85rem}.feedback-my-type{background:linear-gradient(135deg,#2563eb38,#1e3a8a2e);color:#1d4ed8;padding:2px 10px;border-radius:10px;font-weight:700;border:1px solid rgba(37,99,235,.25)}.feedback-my-status{font-weight:700}.feedback-my-card.status-pending .feedback-my-status{color:#fbbf24}.feedback-my-card.status-replied .feedback-my-status{background:linear-gradient(135deg,#1e3a8a,#2563eb);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#1e40af}.feedback-my-card.status-closed .feedback-my-status{color:#94a3b8}.feedback-my-time{color:#0c4a6e;margin-left:auto;font-weight:500}.feedback-my-content{color:#1e40af;line-height:1.65;white-space:pre-wrap;word-break:break-word}.feedback-my-reply{margin-top:12px;padding:12px 14px;background:linear-gradient(135deg,#1e3a8a14,#2563eb0f);border-radius:10px;border-left:3px solid #2563eb}.feedback-my-reply-title{font-weight:700;font-size:.9rem;margin-bottom:6px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:linear-gradient(135deg,#2563eb,#1e3a8a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#1d4ed8}.feedback-my-reward{background:linear-gradient(135deg,#fbbf24,#f97316);color:#1f2937;padding:2px 8px;border-radius:8px;font-size:.75rem;font-weight:700;-webkit-text-fill-color:#1f2937}.feedback-my-reply-body{color:#1e40af;line-height:1.65;white-space:pre-wrap}.admin-feedback-filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:18px}.admin-feedback-filters select{padding:8px 12px;background:#2563eb0d;border:1px solid rgba(37,99,235,.25);border-radius:8px;color:#1e40af;font-size:.85rem;cursor:pointer}.admin-feedback-count{margin-left:auto;color:#1d4ed8;font-size:.85rem;font-weight:600}.admin-feedback-list{display:flex;flex-direction:column;gap:12px}.admin-feedback-card{background:var(--card-bg, rgba(255, 255, 255, .04));border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px 16px}.admin-feedback-card.status-pending{border-left:3px solid #f59e0b}.admin-feedback-card.status-replied{border-left:3px solid #10b981}.admin-feedback-card.status-closed{opacity:.7;border-left:3px solid #6b7280}.admin-feedback-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:10px}.admin-feedback-user{display:flex;align-items:center;gap:10px}.admin-feedback-user img{width:36px;height:36px;border-radius:50%;object-fit:cover}.admin-feedback-avatar-fallback{width:36px;height:36px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#2563eb40;color:#1e40af;font-weight:700}.admin-feedback-username{font-weight:700;background:linear-gradient(135deg,#2563eb,#1e3a8a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#1d4ed8}.admin-feedback-sub{font-size:.75rem;color:#1d4ed8}.admin-feedback-status{padding:4px 10px;border-radius:10px;font-size:.78rem;font-weight:600;flex-shrink:0}.admin-feedback-status.pending{background:#f59e0b26;color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.admin-feedback-status.replied{background:linear-gradient(135deg,#2563eb2e,#1e3a8a24);color:#1d4ed8;border:1px solid rgba(37,99,235,.35)}.admin-feedback-status.closed{background:#6b728033;color:#cbd5e1;border:1px solid rgba(148,163,184,.25)}.admin-feedback-content{color:#1e40af;line-height:1.65;white-space:pre-wrap;word-break:break-word;padding:8px 0}.admin-feedback-prev-reply{margin-top:8px;padding:10px 12px;background:linear-gradient(135deg,#2563eb12,#1e3a8a0d);border-radius:8px;border-left:3px solid #2563eb;font-size:.9rem}.admin-feedback-prev-title{font-weight:700;margin-bottom:4px;display:flex;gap:8px;align-items:center;background:linear-gradient(135deg,#2563eb,#1e3a8a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#1d4ed8}.admin-feedback-prev-reward{background:linear-gradient(135deg,#fbbf24,#f97316);color:#1f2937;padding:1px 8px;border-radius:8px;font-size:.72rem;font-weight:700;-webkit-text-fill-color:#1f2937}.admin-feedback-prev-body{color:#1e40af;white-space:pre-wrap}.admin-feedback-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px;gap:10px;flex-wrap:wrap}.admin-feedback-time{font-size:.78rem;color:#0c4a6e;font-weight:500}.admin-feedback-actions{display:flex;gap:8px}.admin-feedback-btn{padding:6px 14px;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;border:none;transition:all .2s}.admin-feedback-btn.primary{background:linear-gradient(135deg,#2563eb,#1e3a8a);color:#fff}.admin-feedback-btn.primary:hover{filter:brightness(1.15);transform:translateY(-1px)}.admin-feedback-btn.ghost{background:#2563eb1a;color:#1d4ed8;border:1px solid rgba(37,99,235,.3)}.admin-feedback-btn.ghost:hover{background:#2563eb33;color:#bfdbfe}.admin-reply-modal{position:relative;background:var(--bg-card, #1f2937);color:var(--text-primary, #e5e7eb);border-radius:18px;padding:28px;width:min(560px,92vw);max-height:90vh;overflow-y:auto;box-shadow:0 25px 80px #0009;animation:feedback-in .35s ease}.admin-reply-meta{display:flex;gap:12px;font-size:.82rem;color:#1d4ed8;margin:6px 0 12px;font-weight:600}.admin-reply-quote{padding:10px 12px;background:linear-gradient(135deg,#2563eb0f,#1e3a8a0a);border-left:3px solid rgba(37,99,235,.55);border-radius:8px;font-size:.85rem;color:#1e40af;margin-bottom:16px;max-height:120px;overflow-y:auto;white-space:pre-wrap;word-break:break-word}.admin-reply-label{display:block;font-size:.85rem;font-weight:700;color:#1d4ed8;margin:12px 0 6px}.admin-reply-hint{font-weight:500;color:#0c4a6e;font-size:.75rem}.admin-reply-reward-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.admin-reward-input{flex:0 0 120px;padding:9px 12px;background:#2563eb0d;border:1px solid rgba(37,99,235,.3);border-radius:8px;color:#1d4ed8;font-size:1rem;font-weight:700}.admin-reward-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb2e}.admin-reward-quick{display:flex;gap:6px;flex-wrap:wrap}.admin-reward-quick-btn{padding:6px 12px;background:#fbbf241f;color:#fbbf24;border:1px solid rgba(251,191,36,.25);border-radius:8px;font-weight:600;font-size:.82rem;cursor:pointer;transition:all .2s}.admin-reward-quick-btn:hover{background:#fbbf2438;transform:translateY(-1px)}.profile-nav-item.admin{background:linear-gradient(90deg,rgba(245,158,11,.12),transparent);border-left:2px solid #f59e0b}.profile-nav-item.admin.active{background:linear-gradient(90deg,rgba(245,158,11,.25),transparent);color:#fbbf24}.notif-detail{max-width:760px;margin:0 auto}.notif-detail-back{background:none;border:none;color:#1e40af;cursor:pointer;padding:6px 0;margin-bottom:12px;font-size:.9rem;font-weight:700}.notif-detail-back:hover{color:#1e3a8a}.notif-detail-card{background:var(--card-bg, rgba(255, 255, 255, .04));border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:24px 26px}.notif-detail-header{display:flex;gap:16px;align-items:flex-start;margin-bottom:18px}.notif-detail-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;flex-shrink:0}.notif-detail-meta{flex:1;min-width:0}.notif-detail-type{font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;background:linear-gradient(135deg,#2563eb,#1e3a8a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#2563eb}.notif-detail-title{margin:4px 0 6px;font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,#2563eb,#1d4ed8 40%,#1e3a8a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#1d4ed8;line-height:1.3;letter-spacing:.01em}.notif-detail-time{font-size:.82rem;color:#0c4a6e;font-weight:500}.notif-detail-content{color:#1e40af;line-height:1.75;font-size:1rem;white-space:pre-wrap;word-break:break-word;padding:16px 0;border-top:1px solid rgba(37,99,235,.15)}.notif-detail-link{display:inline-block;margin-top:8px;color:#1e40af;font-weight:600;text-decoration:none;padding:6px 12px;background:#2563eb1a;border-radius:8px;font-size:.88rem}.notif-detail-link:hover{background:#2563eb33}.notif-detail-reward{margin-top:18px;padding:18px 20px;border-radius:14px;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}.notif-detail-reward.active{background:linear-gradient(135deg,#fbbf242e,#f973161f);border:1px solid rgba(251,191,36,.35);box-shadow:0 0 24px #fbbf241f}.notif-detail-reward.claimed{background:#6b72801f;border:1px solid rgba(107,114,128,.25)}.notif-reward-info{display:flex;align-items:center;gap:14px}.notif-reward-emoji{font-size:2rem}.notif-reward-amount{font-size:1.4rem;font-weight:800;background:linear-gradient(135deg,#fbbf24,#f97316);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.notif-detail-reward.claimed .notif-reward-amount{background:none;-webkit-text-fill-color:#9ca3af;color:#9ca3af}.notif-reward-status{font-size:.82rem;color:var(--text-secondary, #9ca3af);margin-top:2px}.notif-claim-btn{padding:11px 24px;border-radius:12px;border:none;font-weight:700;font-size:.95rem;cursor:pointer;transition:all .25s}.notif-claim-btn.active{background:linear-gradient(135deg,#fbbf24,#f97316);color:#1f2937;box-shadow:0 6px 20px #fbbf2459;animation:claim-pulse 2s ease-in-out infinite}.notif-claim-btn.active:hover{transform:translateY(-2px);box-shadow:0 10px 28px #fbbf2473}.notif-claim-btn.claimed{background:#6b728033;color:#9ca3af;cursor:not-allowed}@keyframes claim-pulse{0%,to{box-shadow:0 6px 20px #fbbf2459}50%{box-shadow:0 6px 28px #fbbf248c}}.notif-detail-msg{margin-top:14px;padding:10px 14px;background:#10b9811f;border:1px solid rgba(16,185,129,.3);color:#34d399;border-radius:10px;font-weight:600}.notif-detail-actions{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}.notif-detail-action{flex:1;min-width:120px;padding:10px 16px;border-radius:10px;border:1px solid rgba(37,99,235,.25);background:linear-gradient(135deg,#2563eb1a,#1e3a8a14);color:#1d4ed8;font-weight:600;cursor:pointer;transition:all .2s}.notif-detail-action:hover{background:linear-gradient(135deg,#2563eb38,#1e3a8a2e);border-color:#2563eb80;color:#bfdbfe}.notif-detail-action.danger{color:#fca5a5;border-color:#ef444440;background:linear-gradient(135deg,#ef444414,#ef44440a)}.notif-detail-action.danger:hover{background:#ef444426;border-color:#ef444480;color:#fecaca}.notif-reward-chip{display:inline-block;margin-left:8px;padding:2px 8px;border-radius:8px;font-size:.7rem;font-weight:700;vertical-align:middle}.notif-reward-chip.active{background:linear-gradient(135deg,#fbbf24,#f97316);color:#1f2937;animation:claim-pulse 2s ease-in-out infinite}.notif-reward-chip.claimed{background:#6b728033;color:#9ca3af}@media(max-width:600px){.notif-detail-card{padding:18px}.notif-detail-icon{width:44px;height:44px;font-size:1.4rem}.notif-detail-title{font-size:1.15rem}.admin-reply-modal{padding:20px}.admin-feedback-card-footer{flex-direction:column;align-items:stretch}.admin-feedback-actions{justify-content:stretch}.admin-feedback-btn{flex:1}}.admin-post-title{display:inline-block;font-weight:700;background:linear-gradient(135deg,#2563eb,#1d4ed8,#1e3a8a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#1d4ed8;text-decoration:none;font-size:1rem;line-height:1.4;margin-bottom:4px}.admin-post-title:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.admin-post-summary{color:#1e40af;font-size:.85rem;line-height:1.55;padding:4px 0;max-height:60px;overflow:hidden}.admin-feedback-card.status-published{border-left:3px solid #10b981}.admin-feedback-card.status-rejected{border-left:3px solid #ef4444}.admin-feedback-card.status-hidden{border-left:3px solid #6b7280;opacity:.7}.admin-feedback-card.status-draft{border-left:3px solid #1e3a8a}.admin-feedback-status.published{background:linear-gradient(135deg,#2563eb2e,#1e3a8a24);color:#1d4ed8;border:1px solid rgba(37,99,235,.35)}.admin-feedback-status.rejected{background:#ef444426;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.admin-feedback-status.hidden{background:#6b728033;color:#cbd5e1;border:1px solid rgba(148,163,184,.25)}.admin-feedback-status.draft{background:#2563eb26;color:#1e40af;border:1px solid rgba(37,99,235,.3)}.admin-feedback-card.status-rejected .admin-feedback-status.rejected{color:#f87171}.admin-post-editor{width:min(780px,95vw);max-height:92vh}.admin-post-input,.admin-post-select{width:100%;padding:9px 12px;background:#2563eb0d;border:1px solid rgba(37,99,235,.3);border-radius:8px;color:#1e40af;font-size:.92rem;font-family:inherit;box-sizing:border-box}.admin-post-input:focus,.admin-post-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb2e}.admin-post-input::placeholder{color:#6b7280}.admin-post-content{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem;min-height:200px;line-height:1.5}.admin-post-editor-actions{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap;justify-content:flex-end}.admin-post-editor-actions .feedback-cancel,.admin-post-editor-actions .feedback-submit{padding:10px 20px;border-radius:10px;font-weight:600;cursor:pointer}.admin-post-editor-actions .admin-feedback-btn.ghost{padding:10px 16px;border-radius:10px;background:#ef44441a;color:#f87171;border:1px solid rgba(239,68,68,.25)}.admin-post-editor-actions .admin-feedback-btn.ghost:hover{background:#ef44442e}.admin-pagination{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:20px;color:#1d4ed8;font-size:.88rem;font-weight:600}.admin-pagination button{padding:6px 14px;border-radius:8px;background:linear-gradient(135deg,#2563eb1f,#1e3a8a14);color:#1d4ed8;border:1px solid rgba(37,99,235,.3);cursor:pointer;font-weight:600}.admin-pagination button:disabled{opacity:.4;cursor:not-allowed}.admin-pagination button:not(:disabled):hover{background:linear-gradient(135deg,#2563eb38,#1e3a8a29);color:#bfdbfe}@media(max-width:600px){.admin-post-editor{padding:18px}.admin-post-content{min-height:140px}.admin-post-editor-actions{flex-direction:column-reverse}.admin-post-editor-actions button{width:100%}}.collection-create-row{display:flex;gap:10px;margin-bottom:20px}.collection-input{flex:1;padding:10px 14px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--text);font-size:.92rem;transition:border-color .15s,box-shadow .15s}.collection-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.collection-create-btn{padding:9px 22px!important;font-size:.88rem!important}.collection-empty{color:var(--text-secondary);font-size:.9rem;padding:14px 0}.collection-empty-link{display:inline-block;margin-top:8px;color:#2563eb;font-weight:600;text-decoration:none}.folder-name{font-weight:600}.folder-meta{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.8rem}.folder-del-btn{color:#ef4444!important;background:none!important;border:none!important;cursor:pointer;font-size:.78rem!important;padding:2px 6px!important;border-radius:4px}.folder-del-btn:hover{background:#ef44441f!important}.collection-items-list{display:flex;flex-direction:column;gap:12px}.collection-item-card{display:flex;gap:14px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px;transition:all .2s;box-shadow:0 2px 8px #0f172a0a}.collection-item-card:hover{border-color:#2563eb;box-shadow:0 6px 20px #2563eb1a;transform:translateY(-1px)}.collection-item-thumb{flex-shrink:0;width:70px;height:70px;border-radius:10px;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);display:flex;align-items:center;justify-content:center;font-size:1.8rem;overflow:hidden}.collection-item-thumb img{width:100%;height:100%;object-fit:cover}.collection-item-body{flex:1;min-width:0}.collection-item-title-row{margin-bottom:4px}.collection-item-title{font-weight:700;color:var(--text);text-decoration:none;font-size:.95rem;line-height:1.4;display:inline-block}.collection-item-title:hover{color:#2563eb}.collection-item-title-plain{color:var(--text)}.collection-item-status{font-size:.75rem;color:#f59e0b;font-weight:500;margin-left:4px}.collection-item-summary{font-size:.82rem;color:var(--text-secondary);line-height:1.5;margin:4px 0 8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.collection-item-meta{display:flex;gap:12px;align-items:center;flex-wrap:wrap;font-size:.78rem;color:var(--text-secondary)}.collection-item-cat{background:#e0f2fe;color:#075985;padding:2px 8px;border-radius:8px;font-weight:600}.collection-item-author{display:inline-flex;align-items:center;gap:6px;text-decoration:none;color:#2563eb;font-weight:600}.collection-item-author:hover{color:#1d4ed8;text-decoration:underline}.collection-item-author-avatar{width:20px;height:20px;border-radius:50%;overflow:hidden;background:#e0e7ff;display:inline-flex;align-items:center;justify-content:center;font-size:11px;color:#4338ca;font-weight:700}.collection-item-author-avatar img{width:100%;height:100%;object-fit:cover}.collection-item-time{margin-left:auto}.collection-item-del{flex-shrink:0;width:30px;height:30px;border-radius:50%;background:#ef444414;color:#ef4444;border:none;cursor:pointer;font-size:14px;transition:all .15s;align-self:flex-start}.collection-item-del:hover{background:#ef44442e;transform:rotate(90deg)}.profile-user-link{display:flex;gap:12px;align-items:center;flex:1;min-width:0;text-decoration:none;color:inherit}.profile-user-link:hover .profile-user-info strong{color:#2563eb;text-decoration:underline}.profile-user-handle{display:block;font-size:.75rem;color:var(--text-secondary);margin-top:2px}.post-author-link{color:var(--text);text-decoration:none;font-weight:600}.post-author-link:hover{color:#2563eb;text-decoration:underline}.forum-card-author{color:var(--text);text-decoration:none;font-weight:500}.forum-card-author:hover{color:#2563eb;text-decoration:underline}@media(max-width:600px){.collection-item-thumb{width:56px;height:56px;font-size:1.4rem}.collection-item-summary{-webkit-line-clamp:1}.collection-item-meta{font-size:.72rem;gap:8px}.my-comment-content{font-size:.88rem}}.notif-toast-container{position:fixed;top:80px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:10px;max-width:380px;pointer-events:none}.notif-toast{pointer-events:auto;background:#fff;border-radius:14px;box-shadow:0 12px 32px #0f172a2e,0 0 0 1px #0f172a0a;padding:12px 14px;display:flex;align-items:flex-start;gap:12px;cursor:pointer;border-left:4px solid #2563eb;animation:notifToastIn .35s cubic-bezier(.21,1.02,.73,1);transition:transform .2s,box-shadow .2s}.notif-toast:hover{transform:translate(-4px);box-shadow:0 16px 40px #0f172a38}.notif-toast-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;flex-shrink:0}.notif-toast-body{flex:1;min-width:0}.notif-toast-title{font-weight:700;color:#1e3a8a;font-size:.92rem;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-toast-content{color:#475569;font-size:.82rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.notif-toast-close{flex-shrink:0;background:none;border:none;color:#94a3b8;font-size:.85rem;cursor:pointer;padding:2px 6px;border-radius:6px;line-height:1}.notif-toast-close:hover{background:#f1f5f9;color:#475569}@keyframes notifToastIn{0%{opacity:0;transform:translate(40px) scale(.92)}to{opacity:1;transform:translate(0) scale(1)}}@media(max-width:600px){.notif-toast-container{inset:auto 10px 80px;max-width:none}.notif-toast{padding:10px 12px}.notif-toast-icon{width:32px;height:32px;font-size:16px}.notif-toast-title{font-size:.86rem}.notif-toast-content{font-size:.78rem}}.notif-detail-post{margin-top:14px;padding-top:14px;border-top:1px dashed #e2e8f0}.notif-detail-post-label{font-size:.75rem;color:#64748b;font-weight:600;margin-bottom:8px;letter-spacing:.02em}.notif-post-card{display:flex;gap:12px;padding:12px;border-radius:12px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;text-decoration:none;color:inherit;transition:all .2s}.notif-post-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0f172a14;border-color:#bfdbfe;background:linear-gradient(135deg,#eff6ff,#dbeafe)}.notif-post-card.disabled{opacity:.55;cursor:not-allowed;background:#f8fafc}.notif-post-card.disabled:hover{transform:none;box-shadow:none}.notif-post-card-cover{width:64px;height:64px;border-radius:8px;overflow:hidden;background:#e2e8f0;flex-shrink:0}.notif-post-card-cover img{width:100%;height:100%;object-fit:cover}.notif-post-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.notif-post-card-cat{display:inline-block;font-size:.7rem;color:#1d4ed8;background:#dbeafe;padding:1px 8px;border-radius:10px;align-self:flex-start;font-weight:600}.notif-post-card-title{margin:0;font-size:.95rem;font-weight:700;color:#1e3a8a;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}.notif-post-card-summary{margin:0;font-size:.78rem;color:#64748b;line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.notif-post-card-author{display:flex;align-items:center;gap:6px;font-size:.75rem;color:#64748b;margin-top:2px}.notif-post-card-author img{width:18px;height:18px;border-radius:50%;object-fit:cover}.notif-post-card-author .avatar-fallback{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#3b82f6;color:#fff;font-size:.7rem;font-weight:700}.notif-post-card-status{color:#ef4444;font-size:.72rem;margin-left:4px}.notif-post-compact{display:inline-flex;align-items:center;gap:6px;margin-top:6px;padding:5px 10px;border-radius:8px;background:#f1f5f9;border:1px solid #e2e8f0;text-decoration:none;color:#1e3a8a;font-size:.78rem;font-weight:600;max-width:100%;transition:all .15s}.notif-post-compact:hover{background:#dbeafe;border-color:#93c5fd;transform:translate(2px)}.notif-post-compact.disabled{color:#94a3b8;background:#f8fafc;cursor:not-allowed}.notif-post-compact.disabled:hover{transform:none}.notif-post-compact-label{font-size:.85rem}.notif-post-compact-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:280px}.notif-post-compact-status{color:#ef4444;font-weight:500}.nav-notif-post{font-size:.72rem;color:#1d4ed8;background:#eff6ff;padding:2px 8px;border-radius:6px;margin-top:4px;display:flex;align-items:center;gap:4px;font-weight:600;border-left:2px solid #3b82f6;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-toast-post{font-size:.75rem;color:#1e3a8a;background:#eff6ff;padding:3px 8px;border-radius:6px;margin-top:5px;border-left:2px solid #3b82f6;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:600px){.notif-post-card-cover{width:52px;height:52px}.notif-post-card-title{font-size:.88rem}.notif-post-card-summary{font-size:.74rem;-webkit-line-clamp:1}.notif-post-compact-title{max-width:200px}}.comments-list{display:flex;flex-direction:column;gap:14px}.comment-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px 16px;transition:border-color .2s,box-shadow .2s;display:flex;flex-direction:column;gap:10px}.comment-card:hover{border-color:#bfdbfe;box-shadow:0 6px 18px #0f172a0f}.comment-card.reply-to-me{border-left:3px solid #10b981}.comment-card-post{display:flex;gap:12px;padding:10px;border-radius:10px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;text-decoration:none;color:inherit;transition:all .2s;cursor:pointer}.comment-card-post:hover{transform:translateY(-1px);border-color:#bfdbfe;background:linear-gradient(135deg,#eff6ff,#dbeafe)}.comment-card-cover{width:48px;height:48px;border-radius:8px;overflow:hidden;background:#e2e8f0;flex-shrink:0}.comment-card-cover img{width:100%;height:100%;object-fit:cover}.comment-card-post-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.comment-card-post-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.comment-card-cat{font-size:.7rem;color:#1d4ed8;background:#dbeafe;padding:1px 7px;border-radius:10px;font-weight:600}.comment-card-status{color:#f59e0b;font-size:.72rem;font-weight:500}.comment-card-post-title{font-weight:700;color:#1e3a8a;font-size:.9rem;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.comment-card-post-author{font-size:.72rem;color:#64748b}.comment-card-quote{background:#fff7ed;border-left:3px solid #fb923c;padding:8px 10px;border-radius:0 8px 8px 0;font-size:.78rem;color:#9a3412}.comment-card-quote.mine{background:#eff6ff;border-left-color:#3b82f6;color:#1e3a8a}.comment-card-quote-label{display:block;font-weight:700;margin-bottom:3px;font-size:.72rem;letter-spacing:.02em}.comment-card-quote-text{color:inherit;opacity:.85;line-height:1.5}.comment-card-body{color:var(--text);line-height:1.65;font-size:.92rem;white-space:pre-wrap;word-break:break-word;background:#f8fafc;padding:10px 12px;border-radius:8px;border-left:3px solid #cbd5e1;position:relative}.comment-card-body.reply{border-left-color:#10b981;background:#f0fdf4}.comment-card-reply-chip{display:inline-block;background:#dcfce7;color:#047857;padding:2px 8px;border-radius:6px;font-size:.7rem;font-weight:700;margin-right:6px;vertical-align:middle}.comment-card-footer{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:var(--text-secondary)}.comment-card-stats{display:flex;gap:8px}.comment-card-stat{font-weight:600}.comment-card-stat.like{color:#ef4444}.comment-card-stat.dislike{color:#64748b}.comment-card-from{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.comment-card-from-avatar{width:28px;height:28px;border-radius:50%;overflow:hidden;background:#e0e7ff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;color:#4338ca;font-weight:700;text-decoration:none;flex-shrink:0}.comment-card-from-avatar img{width:100%;height:100%;object-fit:cover}.comment-card-from-name{color:#1d4ed8;font-weight:700;font-size:.88rem;text-decoration:none}.comment-card-from-name:hover{text-decoration:underline}.comment-card-reply-arrow{color:var(--text-secondary);font-size:.82rem}.comment-card-time{color:var(--text-secondary);font-size:.72rem;margin-left:auto}.comment-card-source{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;background:#f8fafc;border:1px solid #e2e8f0;text-decoration:none;color:inherit;transition:all .15s}.comment-card-source:hover{background:#eff6ff;border-color:#93c5fd;transform:translate(2px)}.comment-card-source-cover{width:36px;height:36px;border-radius:6px;overflow:hidden;background:#e2e8f0;flex-shrink:0}.comment-card-source-cover img{width:100%;height:100%;object-fit:cover}.comment-card-source-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.comment-card-source-label{font-size:.68rem;color:#64748b;font-weight:600}.comment-card-source-title{font-size:.84rem;color:#1e3a8a;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.comment-card-source-arrow{color:#94a3b8;font-size:1.1rem;font-weight:700}@media(max-width:600px){.comment-card{padding:12px}.comment-card-post{padding:8px;gap:10px}.comment-card-cover{width:42px;height:42px}.comment-card-post-title{font-size:.85rem}.comment-card-body{font-size:.88rem;padding:8px 10px}.comment-card-source-cover{width:32px;height:32px}.comment-card-source-title{font-size:.78rem}}.comment-item.comment-focused{outline:2px solid #f59e0b;outline-offset:2px;background:#fffbeb;border-radius:10px;animation:commentHighlight 2.4s ease-out}@keyframes commentHighlight{0%{background:#fef3c7;box-shadow:0 0 0 6px #f59e0b40}to{background:#fffbeb;box-shadow:none}}.feedback-my-card.validity-pending{border-left:3px dashed #f59e0b;background:#fffbeb}.feedback-my-card.validity-invalid{opacity:.72;border-left:3px solid #9ca3af}.feedback-my-card.validity-valid{border-left:3px solid #10b981}.feedback-my-validity{font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:10px}.feedback-my-validity.pending{background:#fef3c7;color:#b45309}.feedback-my-validity.valid{background:#ecfdf5;color:#047857}.feedback-my-validity.invalid{background:#f3f4f6;color:#6b7280}.feedback-my-score{font-size:.75rem;font-weight:700;color:#dc2626;background:#fef2f2;padding:2px 8px;border-radius:10px}.feedback-my-dup{font-size:.7rem;font-weight:600;color:#9ca3af;background:#f3f4f6;padding:2px 6px;border-radius:8px}.feedback-followup-toggle{margin-top:8px;background:transparent;border:1px dashed #3b82f6;color:#3b82f6;font-size:.78rem;padding:6px 12px;border-radius:8px;cursor:pointer}.feedback-followup-toggle:hover{background:#eff6ff}.feedback-followup-panel{margin-top:10px;padding:12px;background:#f9fafb;border-radius:10px}.feedback-followup-loading,.feedback-followup-empty{font-size:.85rem;color:#6b7280;padding:8px 4px}.feedback-followup-messages{max-height:280px;overflow-y:auto;margin-bottom:10px}.feedback-msg-row{margin-bottom:8px;padding:8px 10px;border-radius:8px;font-size:.85rem}.feedback-msg-row.user{background:#dbeafe;text-align:right}.feedback-msg-row.ai{background:#fff;border:1px solid #e5e7eb}.feedback-msg-role{font-size:.7rem;color:#6b7280;margin-bottom:2px}.feedback-msg-row.ai .feedback-msg-role{color:#7c3aed}.feedback-msg-body{white-space:pre-wrap;word-break:break-word;line-height:1.55}.feedback-followup-input{width:100%;box-sizing:border-box;padding:8px 10px;border:1px solid #d1d5db;border-radius:8px;font-size:.88rem;font-family:inherit;resize:vertical;background:#fff}.feedback-followup-actions{display:flex;justify-content:space-between;align-items:center;margin-top:6px}.feedback-followup-msg{font-size:.78rem;color:#6b7280}.feedback-followup-msg.ok{color:#059669}.feedback-followup-msg.err{color:#dc2626}.feedback-followup-submit{background:#3b82f6;color:#fff;border:none;padding:6px 16px;border-radius:8px;font-size:.85rem;cursor:pointer}.feedback-followup-submit:disabled{opacity:.5;cursor:not-allowed}.admin-feedback-badges{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.admin-validity-badge{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:10px}.admin-validity-badge.pending{background:#fef3c7;color:#b45309}.admin-validity-badge.valid{background:#ecfdf5;color:#047857}.admin-validity-badge.invalid{background:#f3f4f6;color:#6b7280}.admin-feedback-card.validity-pending{border-left:3px dashed #f59e0b}.admin-feedback-card.validity-invalid{opacity:.78}.admin-ai-panel{margin:8px 0;padding:10px;background:#f9fafb;border-radius:8px;border-left:3px solid #6366f1}.admin-ai-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:.8rem}.admin-ai-label{color:#6b7280}.admin-ai-score{font-weight:700;color:#dc2626}.admin-ai-dup{font-size:.72rem;background:#f3f4f6;color:#6b7280;padding:1px 6px;border-radius:6px}.admin-ai-summary{font-size:.82rem;color:#374151;margin-bottom:4px;font-weight:500}.admin-ai-reason{font-size:.78rem;color:#6b7280;font-style:italic;margin-bottom:6px}.admin-ai-reply{margin-top:6px;padding:6px 8px;background:#fff;border-radius:6px;border-left:2px solid #a78bfa}.admin-ai-reply-title{font-size:.72rem;color:#7c3aed;font-weight:600;margin-bottom:2px}.admin-ai-reply-body{font-size:.82rem;color:#374151;white-space:pre-wrap}.notif-override-chip{display:inline-block;margin-left:8px;vertical-align:middle;padding:3px 10px;font-size:.72rem;font-weight:700;background:#fef2f2;border-radius:12px;border:1px solid #fca5a5;color:#dc2626}.notif-override-chip.loss{background:#ecfdf5;border-color:#6ee7b7;color:#059669}.notif-full-title.title-gain,.notif-detail-title.title-gain{color:#dc2626}.notif-full-title.title-loss,.notif-detail-title.title-loss{color:#059669}.feedback-override-list,.admin-override-list{margin-bottom:10px;padding:10px 12px;border-radius:10px;background:linear-gradient(135deg,#ecfdf5,#d1fae5,#a7f3d0);border-left:3px solid #10b981}.feedback-override-title,.admin-override-empty{font-size:.78rem;color:#065f46;font-weight:600;margin-bottom:6px}.feedback-override-row,.admin-override-row{padding:6px 8px;margin-bottom:4px;background:#fff;border-radius:6px;display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:.8rem}.feedback-override-delta,.admin-override-delta{font-weight:700;padding:2px 10px;border-radius:10px;font-size:.8rem;background:#fef2f2;color:#dc2626;border:1px solid #fca5a5}.feedback-override-row.loss .feedback-override-delta,.admin-override-row.loss .admin-override-delta{background:#ecfdf5;color:#059669;border:1px solid #6ee7b7}.feedback-override-time,.admin-override-meta{color:#6b7280;font-size:.72rem}.feedback-override-reply,.admin-override-reply{flex-basis:100%;color:#374151;font-size:.78rem;margin-top:2px;padding:4px 6px;background:#f9fafb;border-radius:4px}.admin-override-toggle{margin-top:8px;background:transparent;border:1px dashed #10b981;color:#047857;font-size:.75rem;padding:4px 10px;border-radius:6px;cursor:pointer}.admin-override-toggle:hover{background:#ecfdf5}.forgot-step-indicator{display:flex;justify-content:space-between;margin:14px 0 18px;font-size:.78rem;color:var(--text-secondary)}.forgot-step-indicator span{flex:1;text-align:center;padding:6px 0;border-bottom:2px solid #e5e7eb}.forgot-step-indicator span.active{color:#3b82f6;border-color:#3b82f6;font-weight:600}.forgot-question-display{padding:10px 12px;background:#f3f4f6;border-radius:8px;font-size:.92rem;color:#111827;margin-bottom:12px}.btn-back{background:transparent;border:none;color:#6b7280;font-size:.85rem;cursor:pointer;margin-top:8px;width:100%}.btn-back:hover{color:#374151}
