:root{--blue-50: #EFF8FF;--blue-100: #DBEFFE;--blue-200: #BAE3FD;--blue-300: #7CCDFA;--blue-400: #38B3F5;--blue-500: #0E97E0;--blue-600: #0279BD;--blue-700: #035F99;--blue-800: #07507D;--blue-900: #0C4368;--navy: #0A2540;--navy-dark: #061829;--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: #F0F6FF;--surface: #FFFFFF;--surface-2: #F8FAFD;--border: #E2EBF6;--border-2: #C8D9F0;--text-main: #0D1F35;--text-sub: #4A6080;--text-muted: #7A95B0;--accent: #0E97E0;--accent-dark:#035F99;--danger: #E53935;--success: #10B981;--font-body: "DM Sans", sans-serif;--font-mono: "Space Mono", monospace;--header-h: 60px;--sidebar-w: 240px;--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--shadow-sm: 0 1px 3px rgba(14,50,100,.08), 0 1px 2px rgba(14,50,100,.05);--shadow-md: 0 4px 16px rgba(14,50,100,.1), 0 2px 6px rgba(14,50,100,.06);--shadow-lg: 0 10px 40px rgba(14,50,100,.14), 0 4px 12px rgba(14,50,100,.08)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-body);background:var(--bg);color:var(--text-main);min-height:100vh}button{cursor:pointer;font-family:inherit;border:none;background:none}input,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--navy)}.loading-logo{animation:fadeIn .4s ease}.logo-text{font-family:var(--font-body);font-size:2.4rem;font-weight:700;color:#fff;letter-spacing:-.5px}.logo-text em{font-style:italic;color:var(--blue-300)}.login-bg{min-height:100vh;background:var(--navy);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.login-grid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(59,158,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(59,158,255,.06) 1px,transparent 1px);background-size:40px 40px;pointer-events:none}.login-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}.login-orb-1{width:500px;height:500px;background:radial-gradient(circle,rgba(14,151,224,.25) 0%,transparent 70%);top:-150px;right:-100px}.login-orb-2{width:400px;height:400px;background:radial-gradient(circle,rgba(3,95,153,.2) 0%,transparent 70%);bottom:-100px;left:-100px}.login-container{position:relative;z-index:1;width:100%;max-width:420px;padding:2.5rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:slideUp .5s ease}.login-logo-wrap{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.login-logo-mark{display:flex}.login-logo-text{font-size:2rem;font-weight:700;color:#fff;letter-spacing:-.5px;line-height:1}.login-logo-text em{font-style:italic;color:var(--blue-300)}.login-tagline{font-size:.8rem;color:#fff6;letter-spacing:.12em;text-transform:uppercase;margin-bottom:2.5rem;margin-left:52px}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-field{display:flex;flex-direction:column;gap:.4rem}.login-label{font-size:.8rem;font-weight:600;color:#ffffff8c;letter-spacing:.04em;text-transform:uppercase}.login-input{padding:.75rem 1rem;background:#ffffff12;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);color:#fff;font-size:.95rem;outline:none;transition:border-color .2s,background .2s}.login-input::placeholder{color:#ffffff40}.login-input:focus{border-color:var(--blue-400);background:#ffffff1a}.login-error{padding:.6rem .9rem;background:#e5393526;border:1px solid rgba(229,57,53,.3);border-radius:var(--radius-sm);color:#fca5a5;font-size:.85rem}.login-btn{margin-top:.5rem;padding:.85rem;background:linear-gradient(135deg,var(--blue-500),var(--blue-700));border-radius:var(--radius-sm);color:#fff;font-size:1rem;font-weight:700;font-style:italic;letter-spacing:.02em;transition:opacity .2s,transform .1s}.login-btn:hover{opacity:.92;transform:translateY(-1px)}.login-btn:active{transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:default;transform:none}.login-btn-loading{display:flex;align-items:center;justify-content:center;gap:.6rem}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.login-hint{margin-top:1.5rem;text-align:center;font-size:.8rem;color:#ffffff40}.app-layout{height:100vh;display:flex;flex-direction:column;overflow:hidden}.app-header{height:var(--header-h);background:var(--navy);border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;position:sticky;top:0;z-index:100;flex-shrink:0}.header-left{display:flex;align-items:center;gap:1.5rem}.header-logo{display:flex;align-items:center;gap:.6rem}.header-logo-text{font-size:1.3rem;font-weight:700;color:#fff;letter-spacing:-.3px}.header-logo-text em{font-style:italic;color:var(--blue-300)}.header-back-btn{font-size:.82rem;color:#ffffff80;padding:.3rem .7rem;border-radius:var(--radius-sm);transition:color .2s,background .2s}.header-back-btn:hover{color:#fff;background:#ffffff14}.header-right{display:flex;align-items:center;gap:1rem}.header-user{display:flex;align-items:center;gap:.6rem}.header-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--blue-400),var(--blue-700));color:#fff;font-size:.85rem;font-weight:700;display:flex;align-items:center;justify-content:center}.header-username{font-size:.85rem;color:#ffffffb3}.header-admin-btn{font-size:.82rem;color:#ffffff80;padding:.35rem .75rem;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);transition:all .2s}.header-admin-btn:hover{color:#fff;border-color:#ffffff4d;background:#ffffff12}.header-logout-btn{font-size:.82rem;color:#ffffff73;transition:color .2s}.header-logout-btn:hover{color:#ffffffd9}.dashboard-body{display:flex;flex:1;overflow:hidden;min-height:0}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;height:100%;overflow:hidden}.sidebar-search{padding:1rem;border-bottom:1px solid var(--border);position:relative;flex-shrink:0}.search-icon{position:absolute;left:1.7rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input{width:100%;padding:.55rem .9rem .55rem 2.2rem;background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;color:var(--text-main);outline:none;transition:border-color .2s,background .2s}.search-input:focus{border-color:var(--blue-400);background:#fff}.search-input::placeholder{color:var(--text-muted)}.search-clear{position:absolute;right:1.5rem;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:.75rem;padding:.2rem .3rem;transition:color .2s}.search-clear:hover{color:var(--text-main)}.sidebar-nav{padding:.75rem;flex:1;display:flex;flex-direction:column;gap:.2rem;overflow-y:auto;min-height:0}.sidebar-nav-item{display:flex;align-items:center;gap:.6rem;padding:.55rem .75rem;border-radius:var(--radius-sm);width:100%;text-align:left;color:var(--text-sub);font-size:.85rem;transition:all .15s;position:relative}.sidebar-nav-item:hover{background:var(--blue-50);color:var(--blue-700)}.sidebar-nav-item.active{background:linear-gradient(135deg,var(--blue-50),#E8F4FE);color:var(--blue-700);font-weight:600}.sidebar-nav-item.active:before{content:"";position:absolute;left:0;top:15%;height:70%;width:3px;background:var(--accent);border-radius:0 3px 3px 0}.nav-icon{font-size:1rem;flex-shrink:0;width:18px;text-align:center}.nav-label{flex:1}.nav-count{font-size:.75rem;font-weight:600;color:var(--text-muted);background:var(--gray-100);padding:.1rem .4rem;border-radius:99px;min-width:22px;text-align:center}.sidebar-nav-item.active .nav-count{background:var(--blue-100);color:var(--blue-700)}.sidebar-footer{padding:1rem;border-top:1px solid var(--border);flex-shrink:0}.new-item-btn{width:100%;padding:.7rem;background:linear-gradient(135deg,var(--blue-500),var(--blue-700));border-radius:var(--radius-sm);color:#fff;font-size:.88rem;font-weight:700;font-style:italic;letter-spacing:.01em;display:flex;align-items:center;justify-content:center;gap:.4rem;transition:opacity .2s,transform .1s;box-shadow:0 2px 8px #0e97e04d}.new-item-btn:hover{opacity:.9;transform:translateY(-1px)}.new-item-btn:active{transform:none}.main-content{flex:1;overflow-y:auto;padding:1.75rem 2rem;height:100%;min-height:0}.content-header{margin-bottom:1.5rem}.content-title-row{display:flex;align-items:baseline;gap:.75rem}.content-title{font-size:1.4rem;font-weight:700;color:var(--text-main);letter-spacing:-.3px}.content-count{font-size:.85rem;color:var(--text-muted);font-weight:500}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.knowledge-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;transition:box-shadow .2s,transform .2s,border-color .2s;position:relative}.knowledge-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--blue-200)}.card-header{display:flex;align-items:center;justify-content:space-between}.card-category{font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.25rem .6rem;border-radius:99px}.cat-mail{background:#eff6ff;color:#1d4ed8}.cat-ai{background:#f5f3ff;color:#6d28d9}.cat-sheet{background:#ecfdf5;color:#065f46}.cat-support{background:#fff7ed;color:#c2410c}.cat-sales{background:#fff1f2;color:#be123c}.cat-other{background:var(--gray-100);color:var(--gray-600)}.card-actions{display:flex;gap:.3rem;opacity:0;transition:opacity .15s}.knowledge-card:hover .card-actions{opacity:1}.card-action-btn{padding:.3rem;border-radius:var(--radius-sm);color:var(--text-muted);transition:background .15s,color .15s;display:flex;align-items:center}.card-action-btn:hover{background:var(--gray-100);color:var(--text-main)}.card-action-btn.danger:hover{background:#fee2e2;color:var(--danger)}.card-title{font-size:.98rem;font-weight:700;color:var(--text-main);line-height:1.4}.card-content{overflow:hidden}.card-text{font-family:var(--font-mono);font-size:.75rem;color:var(--text-sub);line-height:1.65;white-space:pre-wrap;word-break:break-word;background:var(--gray-50);padding:.75rem;border-radius:var(--radius-sm);border:1px solid var(--border);max-height:130px;overflow:hidden}.card-content.expanded .card-text{max-height:none}.card-expand-btn{font-size:.76rem;color:var(--blue-600);padding:.1rem 0;transition:color .15s;align-self:flex-start}.card-expand-btn:hover{color:var(--blue-800)}.card-tags{display:flex;flex-wrap:wrap;gap:.35rem}.card-tag{font-size:.72rem;color:var(--text-muted);background:var(--gray-100);padding:.15rem .5rem;border-radius:99px;border:1px solid var(--border)}.card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:.5rem;border-top:1px solid var(--border)}.card-date{font-size:.75rem;color:var(--text-muted)}.card-copy-btn{display:flex;align-items:center;gap:.4rem;padding:.45rem 1rem;background:linear-gradient(135deg,var(--blue-500),var(--blue-700));border-radius:var(--radius-sm);color:#fff;font-size:.8rem;font-weight:700;transition:all .2s;box-shadow:0 2px 6px #0e97e04d}.card-copy-btn:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 10px #0e97e059}.card-copy-btn.copied{background:linear-gradient(135deg,var(--success),#059669);box-shadow:0 2px 6px #10b9814d}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6rem 2rem;text-align:center}.empty-icon{font-size:3rem;color:var(--blue-200);margin-bottom:1rem}.empty-text{color:var(--text-muted);font-size:.95rem;margin-bottom:1.5rem}.empty-cta{padding:.65rem 1.4rem;background:linear-gradient(135deg,var(--blue-500),var(--blue-700));border-radius:var(--radius-sm);color:#fff;font-size:.88rem;font-weight:700;font-style:italic;transition:opacity .2s,transform .15s;box-shadow:0 2px 8px #0e97e04d}.empty-cta:hover{opacity:.9;transform:translateY(-1px)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a25408c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:fadeIn .15s ease}.modal-panel{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.75rem 1rem;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1}.modal-title{font-size:1.1rem;font-weight:700;color:var(--text-main)}.modal-close{width:30px;height:30px;border-radius:50%;color:var(--text-muted);font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.modal-close:hover{background:var(--gray-100);color:var(--text-main)}.modal-form{padding:1.5rem 1.75rem;display:flex;flex-direction:column;gap:1.25rem}.modal-field{display:flex;flex-direction:column;gap:.4rem;position:relative}.modal-label{font-size:.8rem;font-weight:600;color:var(--text-sub);letter-spacing:.03em;display:flex;align-items:center;gap:.4rem}.modal-label-hint{font-weight:400;color:var(--text-muted);font-size:.76rem}.required{color:var(--blue-500)}.modal-input{padding:.65rem .9rem;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-sm);font-size:.9rem;color:var(--text-main);outline:none;transition:border-color .2s,box-shadow .2s;width:100%}.modal-input:focus{border-color:var(--blue-400);box-shadow:0 0 0 3px #0e97e01f}.modal-textarea{padding:.65rem .9rem;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-sm);font-size:.82rem;font-family:var(--font-mono);color:var(--text-main);outline:none;resize:vertical;min-height:180px;line-height:1.65;transition:border-color .2s,box-shadow .2s;width:100%}.modal-textarea:focus{border-color:var(--blue-400);box-shadow:0 0 0 3px #0e97e01f}.modal-char-count{position:absolute;bottom:.5rem;right:.75rem;font-size:.72rem;color:var(--text-muted);pointer-events:none}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:.5rem}.modal-btn-cancel{padding:.65rem 1.2rem;border:1px solid var(--border-2);border-radius:var(--radius-sm);color:var(--text-sub);font-size:.88rem;font-weight:600;transition:all .15s}.modal-btn-cancel:hover{background:var(--gray-50);border-color:var(--gray-300)}.modal-btn-save{padding:.65rem 1.4rem;background:linear-gradient(135deg,var(--blue-500),var(--blue-700));border-radius:var(--radius-sm);color:#fff;font-size:.88rem;font-weight:700;font-style:italic;transition:opacity .2s,transform .1s;box-shadow:0 2px 8px #0e97e04d}.modal-btn-save:hover{opacity:.9;transform:translateY(-1px)}.toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);background:var(--navy);color:#fff;padding:.7rem 1.4rem;border-radius:99px;font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:.6rem;box-shadow:var(--shadow-lg);z-index:999;animation:toastIn .25s cubic-bezier(.34,1.56,.64,1);white-space:nowrap}.toast-dot{width:6px;height:6px;border-radius:50%;background:var(--blue-400);flex-shrink:0}.admin-body{flex:1;overflow-y:auto;padding:2rem;background:var(--bg)}.admin-container{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.admin-title{font-size:1.5rem;font-weight:800;color:var(--text-main);letter-spacing:-.4px}.admin-subtitle{color:var(--text-muted);font-size:.9rem;margin-top:.25rem}.admin-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem;box-shadow:var(--shadow-sm)}.admin-card-title{font-size:1rem;font-weight:700;color:var(--text-main);margin-bottom:1.25rem;display:flex;align-items:center;gap:.6rem}.admin-count{font-size:.8rem;font-weight:500;color:var(--text-muted);background:var(--gray-100);padding:.15rem .5rem;border-radius:99px}.admin-form{display:flex;flex-direction:column;gap:1rem}.admin-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.admin-field{display:flex;flex-direction:column;gap:.35rem}.admin-label{font-size:.78rem;font-weight:600;color:var(--text-sub);letter-spacing:.03em}.admin-input{padding:.6rem .85rem;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-sm);font-size:.88rem;color:var(--text-main);outline:none;transition:border-color .2s,box-shadow .2s;width:100%}.admin-input:focus{border-color:var(--blue-400);box-shadow:0 0 0 3px #0e97e01f}.admin-error{padding:.5rem .75rem;background:#fee2e2;border:1px solid #FECACA;border-radius:var(--radius-sm);color:var(--danger);font-size:.82rem}.admin-btn-primary{padding:.65rem 1.4rem;background:linear-gradient(135deg,var(--blue-500),var(--blue-700));border-radius:var(--radius-sm);color:#fff;font-size:.88rem;font-weight:700;font-style:italic;align-self:flex-start;transition:opacity .2s,transform .1s;box-shadow:0 2px 8px #0e97e04d}.admin-btn-primary:hover{opacity:.9;transform:translateY(-1px)}.admin-user-list{display:flex;flex-direction:column;gap:.5rem}.admin-user-row{display:flex;align-items:center;gap:1rem;padding:.85rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);transition:background .15s}.admin-user-row:hover{background:var(--blue-50)}.admin-user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--blue-400),var(--blue-700));color:#fff;font-size:.9rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-user-info{display:flex;flex-direction:column;flex:1;min-width:0}.admin-user-name{font-size:.9rem;font-weight:600;color:var(--text-main)}.admin-user-id{font-size:.78rem;color:var(--text-muted);font-family:var(--font-mono)}.admin-badge{font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:.2rem .55rem;border-radius:99px;flex-shrink:0}.badge-admin{background:#eff6ff;color:#1d4ed8;border:1px solid #BFDBFE}.badge-user{background:var(--gray-100);color:var(--gray-600);border:1px solid var(--border)}.admin-user-actions{display:flex;align-items:center;gap:.5rem}.admin-btn-sm{padding:.3rem .65rem;border:1px solid var(--border-2);border-radius:var(--radius-sm);font-size:.76rem;font-weight:600;color:var(--text-sub);transition:all .15s;white-space:nowrap}.admin-btn-sm:hover{background:var(--gray-100)}.admin-btn-sm.danger{color:var(--danger);border-color:#fecaca}.admin-btn-sm.danger:hover{background:#fee2e2}.admin-btn-sm.cancel{color:var(--text-muted)}.admin-pw-change{display:flex;align-items:center;gap:.4rem}.admin-input-sm{padding:.3rem .6rem;border:1px solid var(--border-2);border-radius:var(--radius-sm);font-size:.8rem;color:var(--text-main);outline:none;width:140px}.admin-input-sm:focus{border-color:var(--blue-400)}.admin-hint-card{background:#fffbeb;border-color:#fde68a}.admin-hint-title{font-size:.88rem;font-weight:700;color:#92400e;margin-bottom:.5rem}.admin-hint{font-size:.85rem;color:#78350f;margin-bottom:.3rem}.admin-hint code{font-family:var(--font-mono);background:#00000014;padding:.1rem .35rem;border-radius:4px;font-size:.82rem}.admin-hint-note{font-size:.78rem;color:#b45309;margin-top:.4rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(12px) scale(.95)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}@media (max-width: 768px){:root{--sidebar-w: 0px}.sidebar{display:none}.main-content{padding:1rem}.cards-grid,.admin-form-row{grid-template-columns:1fr}.header-username{display:none}}.knowledge-card{border-top-style:solid}.card-color-row{display:flex;align-items:center;gap:.4rem;margin-top:.15rem}.color-dot{width:12px;height:12px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .15s,border-color .15s;opacity:.55}.color-dot:hover{transform:scale(1.25);opacity:1}.color-dot.active{border-color:#fff;box-shadow:0 0 0 1.5px currentColor;opacity:1}.card-color-hint{font-size:.68rem;color:var(--text-muted);margin-left:.3rem}.modal-row-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.color-picker-row{display:flex;gap:.5rem;align-items:center;padding:.5rem 0}.color-swatch{width:26px;height:26px;border-radius:50%;border:3px solid transparent;transition:transform .15s,box-shadow .15s;flex-shrink:0}.color-swatch:hover{transform:scale(1.15)}.color-swatch.active{border-color:#fff;box-shadow:0 0 0 2px var(--blue-400);transform:scale(1.1)}.catmgr-panel{max-width:520px}.catmgr-body{padding:1.25rem 1.75rem;display:flex;flex-direction:column;gap:1.25rem;max-height:60vh;overflow-y:auto}.catmgr-list{display:flex;flex-direction:column;gap:.4rem}.catmgr-row{display:flex;align-items:center;gap:.75rem;padding:.6rem .85rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);transition:background .15s}.catmgr-row:hover{background:var(--blue-50)}.catmgr-order{width:20px;font-size:.75rem;color:var(--text-muted);font-family:var(--font-mono);flex-shrink:0;text-align:center}.catmgr-icon{font-size:1.1rem;flex-shrink:0;width:22px;text-align:center}.catmgr-name{flex:1;font-size:.88rem;font-weight:500;color:var(--text-main)}.catmgr-actions{display:flex;gap:.4rem}.catmgr-edit-row{flex:1;display:flex;flex-direction:column;gap:.5rem}.catmgr-icon-picker{display:flex;flex-wrap:wrap;gap:.3rem}.icon-opt{width:28px;height:28px;border-radius:var(--radius-sm);font-size:.9rem;border:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.icon-opt:hover{background:var(--blue-50);border-color:var(--blue-300)}.icon-opt.selected{background:var(--blue-100);border-color:var(--blue-500);box-shadow:0 0 0 1px var(--blue-500)}.catmgr-name-input{flex:1}.catmgr-edit-actions{display:flex;gap:.4rem}.catmgr-add{background:var(--gray-50);border:1px dashed var(--border-2);border-radius:var(--radius-sm);padding:1rem;display:flex;flex-direction:column;gap:.6rem}.catmgr-add-label{font-size:.8rem;font-weight:600;color:var(--text-sub)}.catmgr-add-row{display:flex;gap:.5rem}.catmgr-add-btn{padding:.55rem 1rem;background:linear-gradient(135deg,var(--blue-500),var(--blue-700));border-radius:var(--radius-sm);color:#fff;font-size:.82rem;font-weight:700;white-space:nowrap;transition:opacity .2s}.catmgr-add-btn:hover{opacity:.9}.catmgr-add-btn:disabled{opacity:.4;cursor:default}.sidebar-cat-edit-btn{margin-top:.5rem;color:var(--text-muted)!important;border-top:1px dashed var(--border);padding-top:.75rem!important}.sidebar-cat-edit-btn:hover{color:var(--blue-600)!important;background:var(--blue-50)!important}.card-header-right{display:flex;align-items:center;gap:.25rem}.card-pin-btn{font-size:.85rem;opacity:.25;transition:opacity .2s,transform .15s;padding:.2rem;border-radius:4px;line-height:1}.card-pin-btn:hover{opacity:.7;transform:scale(1.15)}.card-pin-btn.pinned{opacity:1}.card-published-badge,.card-shared-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.68rem;font-weight:700;letter-spacing:.04em;padding:.2rem .55rem;border-radius:99px}.card-published-badge{background:#eff6ff;color:#1d4ed8;border:1px solid #BFDBFE}.card-shared-badge{background:#f0fdf4;color:#166534;border:1px solid #BBF7D0}.card-action-btn.published{color:#1d4ed8;background:#eff6ff}.card-version-count{color:var(--text-muted);font-size:.7rem}.sidebar-divider{height:1px;background:var(--border);margin:.5rem .75rem}.spotlight-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a254099;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:900;display:flex;align-items:flex-start;justify-content:center;padding-top:12vh;animation:fadeIn .12s ease}.spotlight-panel{width:100%;max-width:640px;background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 24px 80px #0a25404d,0 8px 24px #0a254026;overflow:hidden;animation:slideUp .15s cubic-bezier(.34,1.56,.64,1);border:1px solid var(--border-2)}.spotlight-input-row{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.spotlight-search-icon{color:var(--text-muted);flex-shrink:0}.spotlight-input{flex:1;font-size:1.05rem;font-weight:500;color:var(--text-main);background:transparent;border:none;outline:none}.spotlight-input::placeholder{color:var(--text-muted)}.spotlight-esc{padding:.2rem .5rem;background:var(--gray-100);border:1px solid var(--border-2);border-radius:var(--radius-sm);font-size:.72rem;color:var(--text-muted);cursor:pointer;font-family:var(--font-mono);transition:background .15s}.spotlight-esc:hover{background:var(--gray-200)}.spotlight-results{max-height:420px;overflow-y:auto;padding:.4rem}.spotlight-empty{padding:2rem;text-align:center;color:var(--text-muted);font-size:.9rem}.spotlight-item{display:flex;align-items:center;gap:.85rem;padding:.75rem 1rem;border-radius:var(--radius-sm);cursor:pointer;transition:background .1s}.spotlight-item:hover,.spotlight-item.active{background:var(--blue-50)}.spotlight-item-color{width:4px;height:36px;border-radius:99px;flex-shrink:0}.spotlight-item-body{flex:1;min-width:0}.spotlight-item-title{font-size:.9rem;font-weight:600;color:var(--text-main);display:flex;align-items:center;gap:.4rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spotlight-pin{font-size:.8rem}.spotlight-shared{font-size:.65rem;font-weight:700;background:#eff6ff;color:#1d4ed8;padding:.1rem .4rem;border-radius:99px;border:1px solid #BFDBFE}.spotlight-item-meta{display:flex;align-items:center;gap:.5rem;margin-top:.2rem;font-size:.76rem;color:var(--text-muted)}.spotlight-tag{background:var(--gray-100);padding:.05rem .35rem;border-radius:99px;font-size:.7rem}.spotlight-item-action{flex-shrink:0}.spotlight-enter-hint{display:flex;align-items:center;gap:.3rem;font-size:.75rem;color:var(--blue-600);font-weight:600}.spotlight-edit-btn{font-size:.75rem;color:var(--text-muted);padding:.2rem .5rem;border:1px solid var(--border);border-radius:var(--radius-sm);transition:all .15s}.spotlight-edit-btn:hover{background:var(--gray-100);color:var(--text-main)}.spotlight-footer{display:flex;align-items:center;gap:1.25rem;padding:.65rem 1.25rem;border-top:1px solid var(--border);background:var(--gray-50);font-size:.73rem;color:var(--text-muted)}.spotlight-footer kbd{display:inline-block;padding:.1rem .35rem;background:#fff;border:1px solid var(--border-2);border-radius:4px;font-size:.7rem;font-family:var(--font-mono);color:var(--text-sub)}.spotlight-footer-count{margin-left:auto;font-size:.72rem;color:var(--text-muted)}.header-spotlight-btn{display:flex;align-items:center;gap:.45rem;padding:.35rem .85rem;background:#ffffff12;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);color:#fff9;font-size:.82rem;transition:all .2s}.header-spotlight-btn:hover{background:#ffffff1f;color:#fff;border-color:#ffffff40}.header-spotlight-btn kbd{font-size:.7rem;font-family:var(--font-mono);opacity:.6;background:#ffffff1a;padding:.1rem .3rem;border-radius:3px}.spotlight-hint-btn{display:flex;align-items:center;gap:.3rem;width:100%;padding:.45rem .75rem;background:var(--gray-50);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:.6rem;color:var(--text-muted);font-size:.78rem;transition:all .15s}.spotlight-hint-btn:hover{background:var(--blue-50);border-color:var(--blue-200);color:var(--blue-700)}.spotlight-hint-btn kbd{padding:.1rem .3rem;background:#fff;border:1px solid var(--border-2);border-radius:3px;font-size:.7rem;font-family:var(--font-mono)}.spotlight-hint-label{flex:1;text-align:right;font-size:.76rem}.version-panel{max-width:580px}.version-subtitle{font-size:.8rem;color:var(--text-muted);margin-top:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:380px}.version-body{padding:1.25rem 1.75rem;display:flex;flex-direction:column;gap:.6rem;max-height:55vh;overflow-y:auto}.version-row{display:grid;grid-template-columns:48px 1fr auto;grid-template-rows:auto auto;column-gap:.85rem;row-gap:.2rem;padding:.85rem 1rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);transition:background .15s}.version-row:hover{background:var(--blue-50)}.version-current{background:#eff8ff;border-color:var(--blue-200)}.version-badge{grid-row:span 2;align-self:center;font-size:.72rem;font-weight:700;font-family:var(--font-mono);padding:.25rem .45rem;border-radius:var(--radius-sm);text-align:center;background:var(--gray-200);color:var(--gray-700)}.version-badge.current{background:var(--blue-100);color:var(--blue-700)}.version-info{display:flex;align-items:center;gap:.6rem;min-width:0}.version-title{font-size:.88rem;font-weight:600;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.version-date{font-size:.75rem;color:var(--text-muted);flex-shrink:0}.version-preview{grid-column:2;font-size:.74rem;color:var(--text-muted);font-family:var(--font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.version-restore-btn{grid-row:span 2;align-self:center;padding:.35rem .75rem;border:1px solid var(--blue-300);border-radius:var(--radius-sm);font-size:.78rem;font-weight:600;color:var(--blue-700);background:#fff;transition:all .15s;white-space:nowrap}.version-restore-btn:hover{background:var(--blue-50);border-color:var(--blue-500)}.version-empty{text-align:center;padding:2.5rem 1rem;color:var(--text-muted);font-size:.88rem;line-height:1.8}.version-footer{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.75rem 1.5rem;border-top:1px solid var(--border)}.version-note{font-size:.78rem;color:var(--text-muted)}.sp-preview-wrap{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:10;animation:fadeIn .12s ease}.sp-preview-panel{width:100%;max-width:580px;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border-2);border-top-width:3px;border-top-style:solid;overflow:hidden;animation:slideUp .18s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column}.sp-preview-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem .6rem}.sp-preview-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.sp-preview-cat{font-size:.78rem;font-weight:700;letter-spacing:.04em}.sp-badge{font-size:.68rem;font-weight:700;padding:.15rem .5rem;border-radius:99px;background:var(--gray-100);color:var(--gray-600);border:1px solid var(--border)}.sp-badge.blue{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.sp-preview-title{font-size:1.1rem;font-weight:700;color:var(--text-main);padding:0 1.5rem .85rem;line-height:1.4}.sp-preview-content{margin:0 1.5rem;background:var(--gray-50);border:1px solid var(--border);border-radius:var(--radius-sm);max-height:280px;overflow-y:auto}.sp-preview-text{font-family:var(--font-mono);font-size:.78rem;color:var(--text-sub);line-height:1.7;white-space:pre-wrap;word-break:break-word;padding:.9rem 1rem}.sp-preview-actions{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem 1.25rem;border-top:1px solid var(--border);margin-top:.85rem;gap:.75rem}.sp-preview-hint{display:flex;align-items:center;gap:.3rem;font-size:.75rem;color:var(--text-muted)}.sp-preview-hint kbd{padding:.1rem .35rem;background:var(--gray-100);border:1px solid var(--border-2);border-radius:4px;font-size:.7rem;font-family:var(--font-mono);color:var(--text-sub)}.sp-preview-btns{display:flex;gap:.6rem;align-items:center}.sp-copy-btn{display:flex;align-items:center;gap:.5rem;padding:.65rem 1.3rem;border-radius:var(--radius-sm);color:#fff;font-size:.88rem;font-weight:700;font-style:italic;transition:opacity .15s,transform .1s;box-shadow:0 2px 8px #0e97e040}.sp-copy-btn:hover{opacity:.92;transform:translateY(-1px)}.sp-copy-btn:active{transform:none}.spotlight-arrow{color:var(--text-muted);font-size:1.1rem;line-height:1}.loading-inner{flex:1;display:flex;align-items:center;justify-content:center}.spinner-blue{width:32px;height:32px;border:3px solid var(--blue-100);border-top-color:var(--blue-500);border-radius:50%;animation:spin .7s linear infinite}.comment-panel{max-width:560px}.comment-panel-subtitle{font-size:.8rem;color:var(--text-muted);margin-top:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:400px}.comment-list{max-height:380px;overflow-y:auto;padding:1rem 1.75rem;display:flex;flex-direction:column;gap:.85rem;border-bottom:1px solid var(--border)}.comment-loading,.comment-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 1rem;color:var(--text-muted);font-size:.88rem;text-align:center;gap:.35rem;line-height:1.7}.comment-row{display:flex;gap:.75rem;align-items:flex-start}.comment-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--blue-400),var(--blue-700));color:#fff;font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.1rem}.comment-body{flex:1;min-width:0}.comment-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem}.comment-author{font-size:.82rem;font-weight:700;color:var(--text-main)}.comment-date{font-size:.74rem;color:var(--text-muted)}.comment-edited{font-size:.72rem;color:var(--text-muted);font-style:italic}.comment-content{font-size:.85rem;color:var(--text-sub);line-height:1.65;white-space:pre-wrap;word-break:break-word;background:var(--gray-50);padding:.6rem .8rem;border-radius:var(--radius-sm);border:1px solid var(--border)}.comment-actions{display:flex;gap:.35rem;margin-top:.35rem}.comment-action-btn{font-size:.73rem;color:var(--text-muted);padding:.1rem .4rem;border-radius:4px;transition:all .15s}.comment-action-btn:hover{background:var(--gray-100);color:var(--text-main)}.comment-action-btn.danger:hover{background:#fee2e2;color:var(--danger)}.comment-edit-form{display:flex;flex-direction:column;gap:.4rem}.comment-edit-actions{display:flex;gap:.35rem}.comment-input-area{padding:1rem 1.75rem 1.5rem;display:flex;flex-direction:column;gap:.6rem}.comment-textarea{width:100%;padding:.65rem .9rem;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-sm);font-size:.85rem;font-family:var(--font-body);color:var(--text-main);outline:none;resize:vertical;line-height:1.6;transition:border-color .2s,box-shadow .2s}.comment-textarea:focus{border-color:var(--blue-400);box-shadow:0 0 0 3px #0e97e01f}.comment-textarea::placeholder{color:var(--text-muted)}.comment-input-footer{display:flex;align-items:center;justify-content:space-between}.comment-input-hint{font-size:.74rem;color:var(--text-muted);display:flex;align-items:center;gap:.3rem}.comment-input-hint kbd{padding:.1rem .3rem;background:var(--gray-100);border:1px solid var(--border-2);border-radius:3px;font-size:.7rem;font-family:var(--font-mono)}.comment-post-btn{padding:.55rem 1.2rem;background:linear-gradient(135deg,var(--blue-500),var(--blue-700));border-radius:var(--radius-sm);color:#fff;font-size:.84rem;font-weight:700;font-style:italic;transition:opacity .2s,transform .1s;box-shadow:0 2px 6px #0e97e040}.comment-post-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.comment-post-btn:disabled{opacity:.4;cursor:default}.stats-container{max-width:1100px;margin:0 auto;padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.stats-header{display:flex;flex-direction:column;gap:.25rem}.stats-loading{display:flex;align-items:center;justify-content:center;padding:5rem}.stats-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.stats-summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;text-align:center;box-shadow:var(--shadow-sm);transition:box-shadow .2s}.stats-summary-card:hover{box-shadow:var(--shadow-md)}.stats-summary-card.accent{border-color:var(--blue-200);background:var(--blue-50)}.stats-summary-value{font-size:2.2rem;font-weight:800;color:var(--text-main);letter-spacing:-.5px;line-height:1;margin-bottom:.4rem}.stats-summary-card.accent .stats-summary-value{color:var(--blue-700)}.stats-summary-label{font-size:.8rem;color:var(--text-muted);font-weight:500}.stats-main-grid{display:grid;grid-template-columns:1fr 380px;gap:1.25rem;align-items:start}.stats-card-wide{overflow-x:auto}.stats-side-col{display:flex;flex-direction:column;gap:1.25rem}.stats-user-table{display:flex;flex-direction:column;gap:.4rem;min-width:600px}.stats-user-thead{display:grid;grid-template-columns:2fr .8fr .8fr .8fr .6fr 1.2fr 1.2fr;gap:.5rem;padding:.4rem .75rem;font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.stats-user-row{display:grid;grid-template-columns:2fr .8fr .8fr .8fr .6fr 1.2fr 1.2fr;gap:.5rem;align-items:center;padding:.7rem .75rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);transition:background .15s}.stats-user-row:hover{background:var(--blue-50)}.stats-user-info{display:flex;align-items:center;gap:.6rem}.stats-user-name{font-size:.88rem;font-weight:600;color:var(--text-main)}.stats-user-id{font-size:.74rem;color:var(--text-muted);font-family:var(--font-mono)}.stats-cell{font-size:.85rem;font-weight:600;color:var(--text-sub);text-align:center}.stats-cell.accent{color:var(--blue-700)}.stats-cell.muted{font-size:.76rem;font-weight:400;color:var(--text-muted);text-align:left}.stats-top-list{display:flex;flex-direction:column;gap:.4rem}.stats-empty-note{font-size:.84rem;color:var(--text-muted);text-align:center;padding:1.5rem 0}.stats-top-row{display:flex;align-items:center;gap:.65rem;padding:.55rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);transition:background .15s}.stats-top-row:hover{background:var(--blue-50)}.stats-rank{width:22px;height:22px;border-radius:50%;background:var(--gray-200);color:var(--gray-600);font-size:.72rem;font-weight:800;font-family:var(--font-mono);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stats-rank.top{background:var(--blue-100);color:var(--blue-700)}.stats-top-color{width:4px;height:28px;border-radius:99px;flex-shrink:0}.stats-top-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.stats-top-title{font-size:.84rem;font-weight:600;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stats-top-meta{font-size:.73rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stats-top-count{display:flex;align-items:center;gap:.3rem;font-size:.82rem;font-weight:700;color:var(--blue-700);flex-shrink:0}.stats-cat-list{display:flex;flex-direction:column;gap:.75rem}.stats-cat-row{display:flex;flex-direction:column;gap:.3rem}.stats-cat-header{display:flex;justify-content:space-between;align-items:center}.stats-cat-name{font-size:.84rem;font-weight:600;color:var(--text-main)}.stats-cat-nums{font-size:.75rem;color:var(--text-muted)}.stats-bar-bg{height:6px;background:var(--gray-100);border-radius:99px;overflow:hidden}.stats-bar-fill{height:100%;background:linear-gradient(90deg,var(--blue-400),var(--blue-600));border-radius:99px;transition:width .4s ease;min-width:4px}.admin-top-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.stats-nav-btn{padding:.6rem 1.2rem;background:linear-gradient(135deg,var(--blue-500),var(--blue-700));border-radius:var(--radius-sm);color:#fff;font-size:.84rem;font-weight:700;font-style:italic;white-space:nowrap;transition:opacity .2s,transform .1s;box-shadow:0 2px 8px #0e97e040;align-self:center}.stats-nav-btn:hover{opacity:.9;transform:translateY(-1px)}@media (max-width: 900px){.stats-summary-grid{grid-template-columns:repeat(2,1fr)}.stats-main-grid{grid-template-columns:1fr}}
