:root{--bg:#f5f5f7;--surface:#fff;--surface-hover:#f0f0f5;--text:#1d1d1f;--text-secondary:#6e6e73;--text-muted:#aeaeb2;--border:#e5e5ea;--accent:#0071e3;--accent-light:#e8f2fd;--bookmark-color:#f59e0b;--danger:#ef4444;--danger-hover:#dc2626;--danger-bg:#fef2f2;--gradient:linear-gradient(135deg, #1d1d1f 0%, #2d2d3f 50%, #1a1a2e 100%);--radius:14px;--radius-sm:10px;--shadow-sm:0 1px 2px #0000000a;--shadow:0 2px 8px #0000000f, 0 1px 2px #0000000a;--shadow-lg:0 8px 30px #00000014;--font:"Inter", "SF Pro Display", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif}[data-theme=dark]{--bg:#0a0a0f;--surface:#13131a;--surface-hover:#1c1c28;--text:#f5f5f7;--text-secondary:#98989e;--text-muted:#5c5c66;--border:#262632;--accent:#4d9fff;--accent-light:#0f1f33;--bookmark-color:#fbbf24;--danger:#f87171;--danger-hover:#ef4444;--danger-bg:#1f1315;--gradient:linear-gradient(135deg, #0a0a1a 0%, #12122a 50%, #0d0d20 100%);--shadow-sm:0 1px 2px #0003;--shadow:0 2px 8px #00000040;--shadow-lg:0 8px 30px #00000059}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;transition:background .3s,color .3s}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.app{flex-direction:column;min-height:100vh;display:flex}.header{background:var(--gradient);z-index:100;padding:16px 24px;position:sticky;top:0}.header-content{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;max-width:1024px;margin:0 auto;display:flex}.header-brand{color:#fff;flex-shrink:0;align-items:center;gap:12px;text-decoration:none;display:flex}.header-brand:hover{opacity:.9;text-decoration:none}.header-brand h1{letter-spacing:-.3px;font-size:1.35rem;font-weight:700}.header-brand p{opacity:.7;margin-top:1px;font-size:.75rem}.header-actions{align-items:center;gap:8px;display:flex}.search-box{background:#ffffff1f;border:1.5px solid #ffffff26;border-radius:10px;align-items:center;min-width:180px;transition:all .25s;display:flex;position:relative}.search-box:focus-within{background:#fff3;border-color:#ffffff59;box-shadow:0 0 0 3px #ffffff14}.search-icon{color:#ffffff80;pointer-events:none;position:absolute;left:12px}.search-box input{color:#fff;font-family:var(--font);background:0 0;border:none;border-radius:10px;outline:none;width:100%;max-width:220px;padding:9px 32px 9px 36px;font-size:.85rem}.search-box input::placeholder{color:#fff6}.search-clear{color:#ffffff80;cursor:pointer;background:0 0;border:none;padding:2px 6px;font-size:1.1rem;line-height:1;position:absolute;right:8px}.search-clear:hover{color:#fff}.header-tab{color:#ffffffb3;cursor:pointer;background:#ffffff14;border:1.5px solid #ffffff26;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex;position:relative}.header-tab:hover{background:#ffffff26;border-color:#ffffff40}.header-tab.active{background:var(--bookmark-color);border-color:var(--bookmark-color);color:#1d1d1f}.badge{color:#fff;border:2px solid var(--gradient);background:#ef4444;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:.62rem;font-weight:700;display:flex;position:absolute;top:-6px;right:-6px}.theme-btn{color:#fff;cursor:pointer;background:#ffffff14;border:1.5px solid #ffffff26;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex}.theme-btn:hover{background:#ffffff2e}.btn-login{color:#fff;font-family:var(--font);cursor:pointer;white-space:nowrap;background:#ffffff26;border:1.5px solid #ffffff40;border-radius:10px;padding:8px 18px;font-size:.82rem;font-weight:600;text-decoration:none;transition:all .2s}.btn-login:hover{background:#ffffff40;text-decoration:none}.user-menu{cursor:pointer;position:relative}.user-avatar{color:#fff;background:#ffffff2e;border:2px solid #ffffff40;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.user-avatar:hover{background:#ffffff47}.user-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:180px;box-shadow:var(--shadow-lg);z-index:200;flex-direction:column;gap:2px;padding:8px;display:none;position:absolute;top:44px;right:0}.user-menu:hover .user-dropdown,.user-menu:focus-within .user-dropdown{display:flex}.user-name{color:var(--text);border-bottom:1px solid var(--border);white-space:nowrap;text-overflow:ellipsis;max-width:160px;margin-bottom:4px;padding:8px 12px;font-size:.82rem;font-weight:600;overflow:hidden}.user-link{color:var(--text-secondary);font-size:.82rem;font-family:var(--font);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;width:100%;padding:8px 12px;text-decoration:none;transition:all .15s;display:flex}.user-link:hover{background:var(--surface-hover);color:var(--text);text-decoration:none}.bookmarks-banner{max-width:1024px;color:var(--bookmark-color);align-items:center;gap:8px;margin:0 auto;padding:12px 24px;font-size:.85rem;font-weight:600;display:flex}.bookmarks-banner button{color:var(--accent);cursor:pointer;font-size:.82rem;font-family:var(--font);background:0 0;border:none;margin-left:auto;font-weight:600}.bookmarks-banner button:hover{text-decoration:underline}.filter-bar{flex-wrap:wrap;justify-content:center;gap:8px;max-width:1024px;margin:0 auto;padding:14px 24px 6px;display:flex}.filter-btn{border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;font-size:.82rem;font-weight:600;font-family:var(--font);white-space:nowrap;border-radius:20px;align-items:center;gap:6px;padding:7px 16px;transition:all .2s;display:flex}.filter-btn:hover{border-color:var(--accent);color:var(--accent)}.filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.grid{flex:1;grid-template-columns:1fr;gap:14px;max-width:1024px;margin:0 auto;padding:8px 24px 48px;display:grid}@media (width>=640px){.grid{grid-template-columns:repeat(2,1fr)}}.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);flex-direction:column;gap:10px;padding:18px 20px;transition:all .25s cubic-bezier(.2,0,0,1);display:flex;position:relative}.card:hover{box-shadow:var(--shadow-lg);border-color:var(--accent);transform:translateY(-2px)}.card.bookmarked{border-left:3px solid var(--bookmark-color)}.card-top{justify-content:space-between;align-items:center;display:flex}.card-category{color:var(--accent);text-transform:uppercase;letter-spacing:.4px;align-items:center;gap:6px;font-size:.73rem;font-weight:600;display:inline-flex}.bookmark-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:6px;padding:4px;transition:all .2s;display:flex}.bookmark-btn:hover{color:var(--bookmark-color);background:var(--accent-light)}.bookmark-btn.active{color:var(--bookmark-color)}.card-title{letter-spacing:-.2px;font-size:1.02rem;font-weight:700;line-height:1.4}.card-title a{color:inherit;text-decoration:none}.card-title a:hover{color:var(--accent)}.card-summary{color:var(--text-secondary);flex:1;font-size:.86rem;line-height:1.6}.card-insight{background:var(--accent-light);border-radius:var(--radius-sm);color:var(--accent);border-left:3px solid var(--accent);align-items:flex-start;gap:8px;padding:10px 14px;font-size:.79rem;font-weight:500;line-height:1.5;display:flex}.card-footer{color:var(--text-muted);border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding-top:5px;font-size:.72rem;display:flex}.card-source{color:var(--accent);align-items:center;gap:4px;font-size:.77rem;font-weight:600;text-decoration:none;display:flex}.card-source:hover{text-decoration:underline}.card-image{border-radius:var(--radius-sm);max-height:200px;margin:-4px 0;overflow:hidden}.card-image img{object-fit:cover;width:100%;height:100%;transition:transform .3s;display:block}.card-image-link:hover{text-decoration:none}.card:hover .card-image img{transform:scale(1.03)}.state-msg{text-align:center;color:var(--text-muted);flex-direction:column;grid-column:1/-1;align-items:center;gap:14px;padding:72px 20px;font-size:.95rem;display:flex}.spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.btn-back{border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);font-family:var(--font);cursor:pointer;border-radius:10px;align-items:center;gap:6px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-back:hover{border-color:var(--accent);color:var(--accent)}.detail-page{flex:1;width:100%;max-width:800px;margin:0 auto;padding:24px 24px 48px}.detail-image{border-radius:var(--radius);max-height:420px;margin:16px 0 24px;overflow:hidden}.detail-image img{object-fit:cover;width:100%;height:100%;display:block}.detail-content{flex-direction:column;gap:16px;display:flex}.detail-meta{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.detail-category{color:var(--accent);text-transform:uppercase;letter-spacing:.5px;background:var(--accent-light);border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-size:.78rem;font-weight:700;display:inline-flex}.detail-date{color:var(--text-muted);align-items:center;gap:4px;font-size:.8rem;display:flex}.detail-title{letter-spacing:-.5px;font-size:1.8rem;font-weight:800;line-height:1.3}@media (width<=600px){.detail-title{font-size:1.35rem}}.detail-summary{color:var(--text-secondary);font-size:1.05rem;line-height:1.8}.detail-insight{background:var(--accent-light);border-radius:var(--radius);border-left:4px solid var(--accent);color:var(--accent);gap:12px;padding:16px 20px;line-height:1.6;display:flex}.detail-insight strong{text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:.82rem;display:block}.detail-insight p{font-size:.92rem;font-weight:500}.detail-source-btn{background:var(--accent);color:#fff;font-family:var(--font);cursor:pointer;border:none;border-radius:10px;align-self:flex-start;align-items:center;gap:8px;padding:10px 20px;font-size:.88rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.detail-source-btn:hover{opacity:.88;color:#fff;text-decoration:none}.auth-page{flex:1;justify-content:center;align-items:center;padding:40px 24px;display:flex}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:420px;box-shadow:var(--shadow-lg);flex-direction:column;gap:20px;padding:32px 28px;display:flex}.auth-header{text-align:center}.auth-header h1{letter-spacing:-.3px;margin-bottom:4px;font-size:1.5rem;font-weight:700}.auth-header p{color:var(--text-secondary);font-size:.88rem}.auth-error{background:var(--danger-bg);color:var(--danger);border-radius:10px;align-items:center;gap:8px;padding:10px 14px;font-size:.82rem;font-weight:500;display:flex}.auth-form{flex-direction:column;gap:14px;display:flex}.auth-field{flex-direction:column;gap:5px;display:flex}.auth-field label{color:var(--text-secondary);align-items:center;gap:6px;font-size:.82rem;font-weight:600;display:flex}.auth-field input{border:1.5px solid var(--border);background:var(--bg);color:var(--text);font-family:var(--font);border-radius:10px;outline:none;padding:11px 14px;font-size:.9rem;transition:all .2s}.auth-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a}.auth-field input:disabled{opacity:.5;cursor:not-allowed}.auth-submit{background:var(--accent);color:#fff;font-family:var(--font);cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;margin-top:4px;padding:12px 20px;font-size:.92rem;font-weight:600;transition:all .2s;display:flex}.auth-submit:hover:not(:disabled){opacity:.88}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-divider{color:var(--text-muted);align-items:center;gap:12px;font-size:.78rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.google-btn-wrapper{justify-content:center;display:flex}.auth-switch{text-align:center;color:var(--text-secondary);font-size:.85rem}.auth-switch a{font-weight:600}.dashboard-page{flex:1;width:100%;max-width:1024px;margin:0 auto;padding:24px 24px 48px}.dashboard-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.dashboard-title{align-items:center;gap:12px;display:flex}.dashboard-title h1{letter-spacing:-.3px;font-size:1.35rem;font-weight:700}.dashboard-title p{color:var(--text-secondary);margin-top:2px;font-size:.8rem}.btn-create{background:var(--accent);color:#fff;font-family:var(--font);cursor:pointer;white-space:nowrap;border:none;border-radius:10px;align-items:center;gap:6px;padding:10px 20px;font-size:.85rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-create:hover:not(:disabled){opacity:.88}.btn-create:disabled{opacity:.5;cursor:not-allowed}.dashboard-stats{flex-wrap:wrap;gap:12px;margin-bottom:24px;display:flex}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:12px;min-width:140px;padding:14px 18px;display:flex}.stat-card svg{color:var(--accent);flex-shrink:0}.stat-card>div{flex-direction:column;display:flex}.stat-value{font-size:1.25rem;font-weight:700}.stat-label{color:var(--text-secondary);font-size:.75rem}.dashboard-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:24px;padding:24px}.form-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.form-header h2{font-size:1.1rem;font-weight:700}.form-close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px;transition:all .15s;display:flex}.form-close-btn:hover{color:var(--text);background:var(--surface-hover)}.dashboard-form form{flex-direction:column;gap:14px;display:flex}.form-row{gap:14px;display:flex}@media (width<=500px){.form-row{flex-direction:column}}.form-group{flex-direction:column;flex:1;gap:5px;display:flex}.form-group label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--border);background:var(--bg);color:var(--text);font-family:var(--font);resize:vertical;border-radius:10px;outline:none;padding:10px 13px;font-size:.85rem;transition:all .2s}.form-group select{cursor:pointer}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a}.table-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.dashboard-table{border-collapse:collapse;width:100%;font-size:.85rem}.dashboard-table thead{background:var(--surface-hover)}.dashboard-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);padding:12px 16px;font-size:.75rem;font-weight:700}.dashboard-table td{border-bottom:1px solid var(--border);color:var(--text);padding:12px 16px}.dashboard-table tr:last-child td{border-bottom:none}.dashboard-table tr:hover td{background:var(--surface-hover)}.table-title{align-items:center;gap:6px;max-width:320px;display:flex}.table-title span{white-space:nowrap;text-overflow:ellipsis;display:block;overflow:hidden}.table-link{color:var(--text-muted);flex-shrink:0;align-items:center;display:flex}.table-link:hover{color:var(--accent)}.table-category{background:var(--accent-light);color:var(--accent);text-transform:uppercase;border-radius:12px;padding:3px 10px;font-size:.73rem;font-weight:600;display:inline-block}.table-date{color:var(--text-muted);white-space:nowrap;font-size:.8rem}.table-empty{text-align:center;color:var(--text-muted);font-size:.88rem;padding:32px 16px!important}.btn-delete{background:var(--danger-bg);color:var(--danger);font-family:var(--font);cursor:pointer;border:1px solid #0000;border-radius:8px;align-items:center;gap:4px;padding:6px 12px;font-size:.78rem;font-weight:600;transition:all .15s;display:inline-flex}.btn-delete:hover{background:var(--danger);color:#fff}.modal-overlay{z-index:500;background:#00000080;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-content{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-lg);width:100%;max-width:420px;padding:28px}.modal-content h3{margin-bottom:8px;font-size:1.15rem;font-weight:700}.modal-content p{color:var(--text-secondary);margin-bottom:20px;font-size:.88rem;line-height:1.6}.modal-actions{justify-content:flex-end;gap:10px;display:flex}.btn-cancel{border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);font-family:var(--font);cursor:pointer;border-radius:10px;padding:9px 18px;font-size:.85rem;font-weight:600;transition:all .15s}.btn-cancel:hover:not(:disabled){border-color:var(--text-muted)}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.btn-delete-confirm{background:var(--danger);color:#fff;font-family:var(--font);cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:9px 18px;font-size:.85rem;font-weight:600;transition:all .15s;display:flex}.btn-delete-confirm:hover:not(:disabled){background:var(--danger-hover)}.btn-delete-confirm:disabled{opacity:.5;cursor:not-allowed}.footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);letter-spacing:.2px;padding:20px;font-size:.78rem}@media (width<=600px){.header-content{flex-direction:column;align-items:stretch;gap:10px}.header-actions{justify-content:center}.search-box{flex:1}.search-box input{max-width:none}.dashboard-header{flex-direction:column;align-items:flex-start}.dashboard-table{font-size:.78rem}.dashboard-table th,.dashboard-table td{padding:8px 10px}.table-title{max-width:160px}.auth-card{padding:24px 18px}}
