:root{--z-sticky:200;--z-toast:10001;--z-tooltip:800;--z-max:9999;--z-overlay:9998;--primary:#2c3e50;--primary-dark:#1a252f;--primary-600:#486581;--accent-100:#dbeafe;--accent-500:#3b82f6;--accent:#3b82f6;--accent-light:#60a5fa;--accent-dark:#2563eb;--success:#059669;--success-light:#10b981;--warning:#d97706;--warning-light:#f59e0b;--danger:#dc2626;--danger-light:#ef4444;--info:#0891b2;--font-size-xs:clamp(0.75rem,0.7rem+0.25vw,0.875rem);--font-size-sm:clamp(0.875rem,0.8rem+0.375vw,1rem);--font-size-base:clamp(1rem,0.925rem+0.375vw,1.125rem);--font-size-lg:clamp(1.125rem,1rem+0.625vw,1.375rem);--font-size-xl:clamp(1.25rem,1.1rem+0.75vw,1.625rem);--font-size-2xl:clamp(1.5rem,1.25rem+1.25vw,2.25rem);--font-size-3xl:clamp(1.875rem,1.5rem+1.875vw,3rem);--font-size-4xl:clamp(2.25rem,1.75rem+2.5vw,4rem);--white:#ffffff;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--bg-body:#f8fafc;--bg-card:#ffffff;--bg-nav:linear-gradient(135deg,#1e293b 0%,#3b82f6 100%);--shadow-sm:0 1px 2px rgba(0,0,0,0.04),0 1px 3px rgba(0,0,0,0.08);--shadow-md:0 2px 4px rgba(0,0,0,0.04),0 4px 8px rgba(0,0,0,0.08),0 1px 2px rgba(0,0,0,0.04);--shadow-lg:0 4px 8px rgba(0,0,0,0.04),0 8px 16px rgba(0,0,0,0.08),0 16px 32px rgba(0,0,0,0.06);--shadow-xl:0 8px 16px rgba(0,0,0,0.04),0 16px 32px rgba(0,0,0,0.08),0 24px 48px rgba(0,0,0,0.08);--shadow-2xl:0 16px 32px rgba(0,0,0,0.08),0 32px 64px rgba(0,0,0,0.12);--shadow-inner:inset 0 2px 4px rgba(0,0,0,0.06);--shadow-glow:0 0 40px rgba(59,130,246,0.15);--shadow-glow-accent:0 4px 14px rgba(59,130,246,0.25),0 8px 32px rgba(59,130,246,0.15);--shadow-card-hover:0 20px 40px rgba(0,0,0,0.1),0 0 0 1px rgba(59,130,246,0.1);--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-2xl:32px;--radius-full:9999px;--transition-fast:0.2s cubic-bezier(0.25,0.46,0.45,0.94);--transition-normal:0.3s cubic-bezier(0.25,0.46,0.45,0.94);--transition-slow:0.45s cubic-bezier(0.25,0.46,0.45,0.94);--spring:0.5s cubic-bezier(0.34,1.56,0.64,1);--font-sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif,'Noto Sans KR';--space-2:8px;--space-3:12px;--space-5:20px;--space-6:24px;--space-8:32px;--space-12:48px;--space-16:64px}*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-sans);background-color:var(--bg-body);color:var(--primary);line-height:1.7;min-height:100vh;font-size:15px;letter-spacing:-0.01em;overflow-x:hidden;transition:background-color 0.5s ease,color 0.3s ease}a{text-decoration:none;color:inherit;transition:all var(--transition-fast)}a:hover{text-decoration:none}img{max-width:100%;height:auto;display:block}img.cover-image,.novel-card img{opacity:0;animation:img-reveal 0.5s cubic-bezier(0.25,0.46,0.45,0.94) forwards}@keyframes img-reveal{from{opacity:0;filter:blur(4px)}to{opacity:1;filter:blur(0)}}nav.navbar,.navbar,.navbar.fixed-top,body .navbar{background:var(--bg-nav);padding:0;box-shadow:var(--shadow-lg),0 0 0 1px rgba(255,255,255,0.05);position:fixed;top:0;left:0;right:0;z-index:var(--z-max);width:100%;transform:none;margin:0;bottom:auto}@supports (backdrop-filter:blur(12px)) or (-webkit-backdrop-filter:blur(12px)){nav.navbar,.navbar,.navbar.fixed-top,body .navbar{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}}body{padding-top:76px}.nav-container{max-width:1320px;margin:0 auto;padding:14px 28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:nowrap;gap:20px}.logo{font-size:28px;font-weight:800;color:var(--white);display:flex;align-items:center;gap:10px;text-shadow:0 2px 8px rgba(0,0,0,0.2);transition:all var(--transition-normal);letter-spacing:-0.5px}.logo:hover{transform:scale(1.03);color:var(--white);text-shadow:0 4px 16px rgba(0,0,0,0.3)}.nav-links{display:flex;align-items:center;gap:10px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.nav-links::-webkit-scrollbar{display:none}.nav-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;min-height:42px;border-radius:var(--radius-md);font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all var(--transition-normal);white-space:nowrap;position:relative;overflow:hidden}.nav-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,0.15) 0%,transparent 50%);opacity:0;transition:opacity var(--transition-fast)}.nav-btn:hover::before{opacity:1}.nav-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.nav-btn:active{transform:translateY(0)}.nav-btn-primary{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-light) 100%);color:var(--white);box-shadow:0 4px 14px rgba(59,130,246,0.35)}.nav-btn-primary:hover{box-shadow:0 6px 20px rgba(59,130,246,0.45)}.nav-btn-success{background:linear-gradient(135deg,var(--success) 0%,var(--success-light) 100%);color:var(--white);box-shadow:0 4px 14px rgba(39,174,96,0.35)}.nav-btn-warning{background:linear-gradient(135deg,var(--warning) 0%,var(--warning-light) 100%);color:var(--white);box-shadow:0 4px 14px rgba(243,156,18,0.35)}.nav-btn-danger{background:linear-gradient(135deg,var(--danger) 0%,var(--danger-light) 100%);color:var(--white);box-shadow:0 4px 14px rgba(231,76,60,0.35)}.nav-btn-light{background:rgba(255,255,255,0.12);color:var(--white);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.1)}.nav-btn-light:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.2)}.nav-btn-ghost{background:transparent;color:var(--white);padding:10px 14px}.nav-btn-ghost:hover{background:rgba(255,255,255,0.1)}.search-wrapper{position:relative;display:flex;align-items:center}.search-input{padding:12px 50px 12px 18px;border:2px solid rgba(255,255,255,0.15);border-radius:var(--radius-lg);background:rgba(255,255,255,0.08);color:var(--white);font-size:14px;font-weight:500;width:100%;max-width:300px;min-width:200px;transition:all var(--transition-normal);backdrop-filter:blur(8px)}.search-input::placeholder{color:rgba(255,255,255,0.6);font-weight:400}.search-input:focus{outline:none;border-color:rgba(255,255,255,0.4);background:rgba(255,255,255,0.15);box-shadow:0 0 0 4px rgba(255,255,255,0.08)}.search-btn{position:absolute;right:10px;background:none;border:none;color:var(--white);cursor:pointer;padding:8px;font-size:16px;opacity:0.7;transition:all var(--transition-fast);border-radius:var(--radius-sm)}.search-btn:hover{opacity:1;background:rgba(255,255,255,0.1)}.nav-toggle{display:none;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.15);color:var(--white);font-size:24px;cursor:pointer;padding:10px 14px;border-radius:var(--radius-md);transition:all var(--transition-fast)}.nav-toggle:hover{background:rgba(255,255,255,0.2)}@media (max-width:992px){body{padding-top:68px}.nav-container{padding:12px 18px}.nav-toggle{display:flex;align-items:center;justify-content:center}.logo{font-size:24px}.nav-links{display:none;position:fixed;top:68px;left:0;right:0;bottom:0;background:linear-gradient(180deg,var(--primary) 0%,var(--primary-dark) 100%);flex-direction:column;align-items:stretch;padding:24px;gap:12px;overflow-y:auto;animation:slideDown 0.3s ease}@keyframes slideDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.nav-links.active{display:flex}.search-wrapper{width:100%;order:-1;margin-bottom:12px}.search-input{width:100%;min-width:100%;padding:16px 50px 16px 20px;font-size:16px;border-radius:var(--radius-lg)}.nav-btn{justify-content:center;padding:16px 24px;font-size:15px;border-radius:var(--radius-lg)}}@media (max-width:480px){body{padding-top:62px}.nav-container{padding:10px 14px}.nav-links{top:62px;padding:18px;gap:10px}.logo{font-size:22px}.search-input{max-width:200px;min-width:0;padding:10px 40px 10px 14px;font-size:13px}}.container{max-width:1320px;margin:0 auto;padding:var(--space-8)}.card{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden;transition:transform var(--transition-normal),box-shadow var(--transition-slow),background-color 0.5s ease;border:1px solid rgba(0,0,0,0.04)}.card:hover{box-shadow:var(--shadow-xl);transform:translateY(-4px)}.novel-card{background:var(--bg-card);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md);transition:transform var(--transition-normal),box-shadow var(--transition-slow);cursor:pointer;position:relative;border:1px solid rgba(0,0,0,0.04)}.novel-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--accent),var(--accent-light));opacity:0;transition:opacity var(--transition-normal);z-index:1}.novel-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-2xl),var(--shadow-glow)}.novel-card:hover::before{opacity:1}.novel-title{font-size:16px;font-weight:700;color:var(--primary);margin-bottom:var(--space-2);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;letter-spacing:-0.2px}.section{margin-bottom:var(--space-12)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:2px solid var(--gray-100)}.chapter-number{font-weight:700;color:var(--accent);min-width:90px}.chapter-title{flex:1;color:var(--primary);margin:0 var(--space-4);font-weight:500}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all var(--transition-normal);text-decoration:none;position:relative;overflow:hidden;background:var(--gray-100);color:var(--gray-700)}.btn::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,0.2) 0%,transparent 50%);opacity:0;transition:opacity var(--transition-fast)}.btn:hover::before{opacity:1}.btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.btn:active{transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-light) 100%);color:var(--white);box-shadow:0 4px 14px rgba(59,130,246,0.35)}.btn-primary:hover{box-shadow:0 8px 25px rgba(59,130,246,0.45)}.btn-success{background:linear-gradient(135deg,var(--success) 0%,var(--success-light) 100%);color:var(--white);box-shadow:0 4px 14px rgba(39,174,96,0.35)}.btn-warning{background:linear-gradient(135deg,var(--warning) 0%,var(--warning-light) 100%);color:var(--white);box-shadow:0 4px 14px rgba(243,156,18,0.35)}.btn-danger{background:linear-gradient(135deg,var(--danger) 0%,var(--danger-light) 100%);color:var(--white);box-shadow:0 4px 14px rgba(231,76,60,0.35)}.btn-secondary{background:var(--gray-100);color:var(--gray-700);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--gray-200)}.btn-light{background:var(--gray-100);color:var(--gray-700);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200)}.btn-light:hover{background:var(--gray-200);color:var(--gray-800)}.btn-light:disabled,.btn-light[disabled]{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed;opacity:0.6}.btn-info{background:linear-gradient(135deg,var(--info) 0%,var(--accent) 100%);color:var(--white);box-shadow:0 4px 14px rgba(23,162,184,0.35)}.btn-info:hover{box-shadow:0 8px 25px rgba(23,162,184,0.45)}.btn-outline-primary{background:transparent;border:2px solid var(--accent);color:var(--accent)}.btn-outline-primary:hover{background:var(--accent);color:var(--white)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:13px}.form-group{margin-bottom:var(--space-5)}.tag{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:var(--radius-full);font-size:12px;font-weight:600;background:var(--gray-100);color:var(--gray-600);transition:all var(--transition-fast)}.tag:hover{transform:scale(1.05)}#toast-container{position:fixed;top:90px;right:var(--space-6);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-3)}.toast{padding:var(--space-4) var(--space-6);border-radius:var(--radius-lg);color:var(--white);min-width:300px;max-width:420px;box-shadow:var(--shadow-xl);display:flex;align-items:center;gap:var(--space-3);animation:toastSlideIn 0.5s cubic-bezier(0.34,1.56,0.64,1);font-weight:500;backdrop-filter:blur(8px)}@keyframes toastSlideIn{from{opacity:0;transform:translateX(100%) scale(0.8)}to{opacity:1;transform:translateX(0) scale(1)}}@media (max-width:480px){#toast-container{right:12px;left:12px}.toast{min-width:0;width:100%;max-width:none;font-size:14px;padding:14px 18px}}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--space-2);margin-top:var(--space-8);flex-wrap:wrap}.stat-label{font-size:13px;color:var(--gray-500);font-weight:500}.bookmark-actions{display:flex;gap:var(--space-2)}body.dark-theme{--bg-body:#0c1017;--bg-card:#161c2e;--surface-0:#0c1017;--surface-1:#161c2e;--surface-2:#334155;--surface-3:#475569;--surface-elevated:#1e293b;--primary:#f8fafc;--primary-light:#e2e8f0;--text-high-contrast:#f8fafc;--text-medium-contrast:#e2e8f0;--text-low-contrast:#94a3b8;--gray-50:#1e293b;--gray-100:#334155;--gray-200:#475569;--gray-300:#64748b;--gray-400:#94a3b8;--gray-500:#cbd5e1;--gray-600:#e2e8f0;--gray-700:#f1f5f9;--white:#f8fafc;--accent:#60a5fa;--accent-light:#93c5fd;--accent-dark:#3b82f6;--accent-50:rgba(96,165,250,0.1);--success:#34d399;--success-light:#6ee7b7;--warning:#fbbf24;--warning-light:#fcd34d;--danger:#f87171;--danger-light:#fca5a5;--shadow-sm:0 1px 2px rgba(0,0,0,0.5),0 0 0 1px rgba(255,255,255,0.03);--shadow-md:0 4px 6px rgba(0,0,0,0.5),0 0 0 1px rgba(255,255,255,0.03);--shadow-lg:0 10px 20px rgba(0,0,0,0.5),0 0 0 1px rgba(255,255,255,0.03);--shadow-xl:0 20px 40px rgba(0,0,0,0.5),0 0 0 1px rgba(255,255,255,0.03);--shadow-glow-accent:0 4px 14px rgba(96,165,250,0.3),0 8px 32px rgba(96,165,250,0.2);--shadow-card-hover:0 20px 40px rgba(0,0,0,0.4),0 0 0 1px rgba(96,165,250,0.2)}body.dark-theme .navbar{background:linear-gradient(135deg,#141a20 0%,#1a2530 100%);box-shadow:0 4px 20px rgba(0,0,0,0.5)}body.dark-theme .card,body.dark-theme .novel-card,body.dark-theme .section{background:var(--bg-card);color:var(--primary);border-color:rgba(255,255,255,0.05)}body.dark-theme .novel-title,body.dark-theme h1,body.dark-theme h2,body.dark-theme h3{color:var(--primary)}body.dark-theme .modal-content{background:var(--bg-card)}body.dark-theme .btn{background:var(--gray-200);color:var(--gray-600)}body.dark-theme .btn-secondary{background:var(--gray-200);color:var(--gray-600)}body.dark-theme .tag{background:var(--gray-200);color:var(--gray-500)}body.dark-theme .btn-light{background:var(--gray-200);color:var(--gray-600);border-color:var(--gray-300)}body.dark-theme .btn-light:hover{background:var(--gray-300);color:var(--gray-700)}body.dark-theme .btn-light:disabled,body.dark-theme .btn-light[disabled]{background:var(--gray-200);color:var(--gray-400)}body.dark-theme .btn-info{background:linear-gradient(135deg,var(--info) 0%,var(--accent) 100%)}body.dark-theme .btn-outline-primary{border-color:var(--accent);color:var(--accent)}body.dark-theme .btn-outline-primary:hover{background:var(--accent);color:var(--white)}@media (max-width:768px){.container{padding:var(--space-4)}.chapter-title{margin:0}}@media (max-width:480px){.btn{width:100%}.bookmark-actions{width:100%}.bookmark-actions .btn{flex:1}}.hidden{display:none !important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}button,a,input,select,textarea{font-family:inherit}a:not([class]){color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}a:not([class]):hover{color:var(--accent-dark);text-decoration-thickness:2px}@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--gray-100);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--radius-full);border:2px solid var(--gray-100)}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}body.dark-theme::-webkit-scrollbar-track{background:var(--gray-100)}body.dark-theme::-webkit-scrollbar-thumb{background:var(--gray-300);border-color:var(--gray-100)}::selection{background:var(--accent);color:var(--white)}::-moz-selection{background:var(--accent);color:var(--white)}.site-footer{background:var(--primary);color:var(--gray-200);padding:var(--space-8) 0;margin-top:var(--space-16);text-align:center}.site-footer p{margin-bottom:var(--space-2);font-size:0.875rem}.site-footer nav a{color:var(--gray-300);text-decoration:none;font-size:0.875rem;transition:color var(--transition-fast)}.site-footer nav a:hover{color:var(--white)}body.dark-theme .site-footer{background:var(--gray-900)}h1,h2,h3,h4{text-wrap:balance;font-weight:700}h1{font-size:var(--font-size-4xl);letter-spacing:-0.03em;line-height:1.1}h2{font-size:var(--font-size-3xl);letter-spacing:-0.025em;line-height:1.2}h3{font-size:var(--font-size-2xl);letter-spacing:-0.02em;line-height:1.3}h4{font-size:var(--font-size-xl);letter-spacing:-0.015em}.chapter-content p,article p{max-width:75ch;text-wrap:pretty}@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.7}}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}.novel-card:focus-visible{outline-offset:4px;border-radius:var(--radius-xl)}.nd-chapter-item:focus-visible{outline-offset:-2px}@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}}@keyframes revealFromBottom{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes revealFromLeft{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}@keyframes revealFromRight{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}@keyframes revealScale{from{opacity:0;transform:scale(0.92)}to{opacity:1;transform:scale(1)}}.reveal-on-scroll{opacity:0}.reveal-on-scroll.revealed{animation:revealFromBottom 0.6s cubic-bezier(0.25,0.46,0.45,0.94) forwards}.navbar{transition:background 0.5s ease,backdrop-filter 0.5s ease,box-shadow 0.5s ease}.navbar.scrolled{background:rgba(44,62,80,0.82) !important;backdrop-filter:blur(24px) saturate(1.2);-webkit-backdrop-filter:blur(24px) saturate(1.2);box-shadow:0 4px 30px rgba(0,0,0,0.15),0 1px 0 rgba(255,255,255,0.05)}body.dark-theme .navbar.scrolled{background:rgba(15,23,42,0.88) !important}@keyframes skeleton-shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}@keyframes pageEnter{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}main.container,.main-content{animation:pageEnter 0.4s cubic-bezier(0.25,0.46,0.45,0.94)}@keyframes gradient-shift{0%,100%{background-position:0% center}50%{background-position:100% center}}@keyframes pulse-glow{0%,100%{box-shadow:0 0 0 0 rgba(59,130,246,0.4)}50%{box-shadow:0 0 0 10px rgba(59,130,246,0)}}@keyframes floating{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes text-reveal{from{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}.nd-reading-list-wrapper{position:relative;display:inline-block}.nd-hidden{display:none !important}.nd-rl-divider{margin:4px 0;border:none;border-top:1px solid var(--border-color,#eee)}body.dark-theme .nd-rl-divider{border-top-color:rgba(255,255,255,0.1)}.nav-bell{position:relative;background:transparent;border:none;color:#fff;font-size:20px;cursor:pointer;padding:8px;line-height:1}.nav-bell-badge{position:absolute;top:2px;right:0;background:#e74c3c;color:#fff;font-size:11px;font-weight:700;min-width:18px;height:18px;line-height:18px;text-align:center;border-radius:9px;display:none}.nav-bell-badge.has-count{display:block}.notif-dropdown{position:absolute;top:100%;right:0;width:min(360px,calc(100vw - 20px));max-height:420px;overflow-y:auto;background:var(--bg-card,#fff);border:1px solid var(--border-color,rgba(0,0,0,0.1));border-radius:var(--radius-md,12px);box-shadow:0 12px 40px rgba(0,0,0,0.2);z-index:10000;display:none}.notif-dropdown.open{display:block}.notif-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border-color,#eee);font-weight:600;font-size:14px}.notif-dropdown-header button{background:none;border:none;color:var(--accent,#3b82f6);cursor:pointer;font-size:13px}.notif-item{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border-color,rgba(0,0,0,0.05));cursor:pointer;transition:background 0.15s}.notif-item:hover{background:var(--bg-body,#f8fafc)}.notif-item.unread{background:rgba(59,130,246,0.05)}.notif-item-icon{font-size:20px;flex-shrink:0}.notif-item-body{flex:1;min-width:0}.notif-item-title{font-size:13px;font-weight:600;color:var(--text-primary,#333);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-item-msg{font-size:12px;color:var(--text-secondary,#666);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-item-time{font-size:11px;color:var(--text-muted,#999);margin-top:2px}.notif-empty{padding:30px 16px;text-align:center;color:var(--text-muted,#999);font-size:14px}body.dark-theme .notif-dropdown{background:var(--bg-card,#1a1f26);border-color:rgba(255,255,255,0.1)}body.dark-theme .notif-item:hover{background:rgba(255,255,255,0.05)}@media (max-width:768px){.notif-dropdown{width:min(300px,calc(100vw - 24px));right:0}}@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}.optimistic-done{animation:optimistic-pop 0.25s cubic-bezier(0.22,1,0.36,1)}@keyframes optimistic-pop{0%{transform:scale(1)}50%{transform:scale(1.2)}100%{transform:scale(1)}}