:root{--text:#e0e6ff;--text-h:#fff;--bg:#0a0e27;--border:#2d3558;--code-bg:#141929;--accent:#e8c97a;--accent-bg:#e8c97a1a;--accent-border:#e8c97a80;--social-bg:#00d4ff1a;--shadow:#0000004d 0 10px 15px -3px, #00d4ff1a 0 4px 6px -2px;--sans:-apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--heading:"Playfair Display", Georgia, serif;--mono:"Courier New", Courier, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#e0e6ff;--text-h:#fff;--bg:#0a0e27;--border:#2d3558;--code-bg:#141929;--accent:#e8c97a;--accent-bg:#e8c97a26;--accent-border:#e8c97a80;--social-bg:#00d4ff1a;--shadow:#0006 0 10px 15px -3px, #00d4ff26 0 4px 6px -2px}#social .button-icon{filter:brightness(1.2)hue-rotate(30deg)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{--color-primary:#00d4ff;--color-primary-alt:#4dd9ff;--color-primary-dim:#0a4d5f;--color-accent:#e8c97a;--color-accent-alt:#f0d999;--color-accent-dim:#5f4a2a;--color-bg:#0a0e27;--color-bg-light:#141929;--color-text:#e0e6ff;--color-text-dim:#8b92b1;--color-border:#2d3558;--color-signal-high:#00ff41;--color-signal-med:#ffb800;--color-signal-low:#ff6b6b;--color-success:#00ff41;--color-warning:#ffb800;--color-error:#ff6b6b;--color-info:#00d4ff;--color-primary-dark:#0a4d5f;--color-primary-light:#4dd9ff;--color-accent-dark:#5f4a2a;--color-accent-light:#f0d999;--font-family-serif:"Playfair Display", Georgia, serif;--font-family-sans:-apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-family-mono:"Courier New", "OCR-A", monospace;--font-xs:11px;--font-sm:13px;--font-base:15px;--font-lg:17px;--font-xl:19px;--font-2xl:24px;--font-3xl:32px;--font-4xl:48px;--line-height-tight:1.2;--line-height-normal:1.5;--line-height-relaxed:1.8;--letter-spacing-tight:-.5px;--letter-spacing-normal:0;--letter-spacing-wide:1px;--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:24px;--space-2xl:32px;--space-3xl:48px;--space-4xl:64px;--radius-sm:3px;--radius-md:4px;--radius-lg:6px;--radius-xl:8px;--shadow-sm:0 1px 2px #00000080;--shadow-md:0 2px 8px #00d4ff1a;--shadow-lg:0 4px 12px #00d4ff26;--shadow-xl:0 12px 24px #00d4ff33;--glow-sm:0 0 8px #00d4ff4d;--glow-md:0 0 16px #00d4ff80;--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.3s;--easing:cubic-bezier(.4, 0, .2, 1);--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-normal:.25s cubic-bezier(.4, 0, .2, 1)}body{background-color:var(--color-bg);color:var(--color-text);font-family:var(--font-family-sans);font-size:var(--font-base);line-height:var(--line-height-normal);margin:0;padding:0;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:9999;background:repeating-linear-gradient(0deg,#00000026,#00000026 1px,#0000 1px 3px);width:100%;height:100%;position:fixed;top:0;left:0}*{box-sizing:border-box}button{cursor:pointer;transition:all var(--duration-normal) var(--easing);border:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit;border:1px solid var(--color-border);padding:var(--space-md);border-radius:var(--radius-md);background-color:var(--color-bg);color:var(--color-text);transition:all var(--duration-normal) var(--easing)}input:focus,textarea:focus,select:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #00d4ff33}.dashboard-header{background:var(--color-bg,#fff);border-bottom:1px solid var(--color-border,#e5e7eb);padding:var(--space-lg,20px) var(--space-xl,24px);z-index:100;transition:all var(--transition-std,.2s) ease-out;position:sticky;top:0;box-shadow:0 2px 8px #0000000a}.header-content{justify-content:space-between;align-items:center;gap:var(--space-xl,24px);flex-wrap:wrap;max-width:1400px;margin:0 auto;display:flex}.header-left{align-items:center;gap:var(--space-lg,20px);display:flex}.menu-btn{cursor:pointer;color:var(--color-text,#111827);transition:all var(--transition-fast,.15s) ease-out;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:8px;font-size:1.5rem;display:none}.menu-btn:hover{color:var(--color-primary,#00d4ff);background:#00d4ff1a}.header-title h1{font-size:var(--font-2xl,1.875rem);color:var(--color-text,#111827);margin:0;font-weight:700;line-height:1.2}.header-subtitle{font-size:var(--font-sm,.875rem);color:var(--color-text-secondary,#4b5563);margin:4px 0 0;font-weight:500}.header-right{align-items:center;gap:var(--space-lg,20px);flex-wrap:wrap;justify-content:flex-end;display:flex}.user-info{align-items:center;gap:var(--space-md,12px);display:flex}.user-greeting{text-align:right}.greeting{font-size:var(--font-sm,.875rem);color:var(--color-text-secondary,#4b5563);margin:0;font-weight:500}.user-name{color:var(--color-text,#111827);font-weight:700}.interests-summary{font-size:var(--font-xs,.75rem);color:var(--color-primary,#00d4ff);justify-content:flex-end;align-items:center;gap:6px;margin:4px 0 0;font-weight:600;display:flex}.interests-badge{color:var(--color-primary,#00d4ff);background:#00d4ff26;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 4px;font-size:.7rem;font-weight:700;display:inline-flex}.header-actions{align-items:center;gap:var(--space-md,12px);display:flex}.btn-icon{border:1px solid var(--color-border,#e5e7eb);color:var(--color-text,#111827);border-radius:var(--radius-md,8px);cursor:pointer;transition:all var(--transition-fast,.15s) ease-out;background:0 0;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:8px 12px;font-size:1rem;display:flex}.btn-icon:hover{border-color:var(--color-primary,#00d4ff);color:var(--color-primary,#00d4ff);background:#00d4ff1a}.btn-logout{border:1px solid var(--color-border,#e5e7eb);background:var(--color-bg,#fff);color:var(--color-text,#111827);border-radius:var(--radius-md,8px);font-size:var(--font-sm,.875rem);cursor:pointer;transition:all var(--transition-fast,.15s) ease-out;justify-content:center;align-items:center;min-height:44px;padding:8px 20px;font-weight:600;display:flex}.btn-logout:hover{color:#ef4444;background:#ef44441a;border-color:#ef4444}[data-theme=dark] .dashboard-header{background:var(--color-bg,#0c0d0f);border-bottom-color:var(--color-border,#2d3342);box-shadow:0 2px 8px #0000004d}[data-theme=dark] .header-title h1{color:var(--color-text,#e2e4e9)}[data-theme=dark] .header-subtitle,[data-theme=dark] .greeting{color:var(--color-text-secondary,#a0a6b4)}[data-theme=dark] .user-name{color:var(--color-text,#e2e4e9)}[data-theme=dark] .btn-icon,[data-theme=dark] .btn-logout{background:var(--color-bg-secondary,#131518);border-color:var(--color-border,#2d3342);color:var(--color-text,#e2e4e9)}[data-theme=dark] .btn-icon:hover{background:#00d4ff1a}[data-theme=dark] .btn-logout:hover{background:#ef444426;border-color:#ef4444}@media (width<=768px){.dashboard-header{padding:var(--space-md,12px) var(--space-lg,20px)}.header-content{gap:var(--space-md,12px)}.menu-btn{display:flex}.header-left{gap:var(--space-md,12px)}.header-title h1{font-size:1.5rem}.header-subtitle{display:none}.header-right{gap:var(--space-sm,8px)}.user-greeting{text-align:left}.interests-summary{justify-content:flex-start}}@media (width<=375px){.header-content{flex-direction:column;align-items:flex-start}.header-right{justify-content:space-between;width:100%}.user-greeting{flex:1}.header-actions{gap:8px}.btn-logout{padding:8px 16px;font-size:.75rem}}.sidebar{background:var(--color-bg-secondary,#f9fafb);border:1px solid var(--color-border,#e5e7eb);border-radius:var(--radius-lg,12px);padding:var(--space-lg,20px);height:fit-content;transition:all var(--transition-std,.2s) ease-out;min-width:250px;position:sticky;top:20px}.sidebar-header{margin-bottom:var(--space-lg,20px);justify-content:space-between;align-items:center;gap:10px;display:flex}.sidebar-header h3{font-size:var(--font-lg,1.1rem);color:var(--color-text,#111827);margin:0;font-weight:700}.close-btn{cursor:pointer;color:var(--color-text-secondary,#4b5563);width:32px;height:32px;transition:all var(--transition-fast,.15s) ease-out;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:0;font-size:1.5rem;display:none}.close-btn:hover{color:var(--color-text,#111827);background:#0000000d}.sidebar-content{gap:var(--space-xl,24px);flex-direction:column;display:flex}.filter-section{gap:var(--space-md,12px);flex-direction:column;display:flex}.filter-label{font-size:var(--font-sm,.875rem);color:var(--color-text,#111827);align-items:center;gap:8px;margin:0;font-weight:600;display:flex}.badge{background:var(--color-primary,#00d4ff);color:#fff;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 4px;font-size:.7rem;font-weight:700;display:inline-flex}.category-buttons{gap:var(--space-sm,8px);flex-direction:column;display:flex}.filter-btn{padding:var(--space-sm,8px) var(--space-md,12px);border:1px solid var(--color-border,#e5e7eb);background:var(--color-bg,#fff);color:var(--color-text,#111827);border-radius:var(--radius-md,8px);font-size:var(--font-sm,.875rem);cursor:pointer;transition:all var(--transition-fast,.15s) ease-out;text-align:left;justify-content:center;align-items:center;min-height:40px;font-weight:500;display:flex}.filter-btn:hover{border-color:var(--color-primary,#00d4ff);color:var(--color-primary,#00d4ff);background:#00d4ff0d}.filter-btn.active{background:var(--color-primary,#00d4ff);border-color:var(--color-primary,#00d4ff);color:#fff;font-weight:600;box-shadow:0 4px 12px #00d4ff4d}.sort-select{padding:var(--space-sm,8px) var(--space-md,12px);border:1px solid var(--color-border,#e5e7eb);background:var(--color-bg,#fff);color:var(--color-text,#111827);border-radius:var(--radius-md,8px);font-size:var(--font-sm,.875rem);cursor:pointer;transition:all var(--transition-fast,.15s) ease-out;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23111827' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;min-height:40px;padding-right:32px;font-weight:500}.sort-select:hover{border-color:var(--color-primary,#00d4ff);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%2300d4ff' d='M1 1l5 5 5-5'/%3E%3C/svg%3E")}.clear-filters{padding:var(--space-sm,8px) var(--space-md,12px);border:2px dashed var(--color-primary,#00d4ff);color:var(--color-primary,#00d4ff);border-radius:var(--radius-md,8px);font-size:var(--font-sm,.875rem);cursor:pointer;transition:all var(--transition-fast,.15s) ease-out;text-align:center;background:#00d4ff0d;min-height:40px;font-weight:600}.clear-filters:hover{border-color:var(--color-primary,#00d4ff);background:#00d4ff1a;box-shadow:0 2px 8px #00d4ff33}.sidebar-backdrop{z-index:999;background:#00000080;display:none;position:fixed;inset:0}[data-theme=dark] .sidebar{background:var(--color-bg-secondary,#131518);border-color:var(--color-border,#2d3342)}[data-theme=dark] .sidebar-header h3,[data-theme=dark] .filter-label{color:var(--color-text,#e2e4e9)}[data-theme=dark] .filter-btn{background:var(--color-bg,#0c0d0f);border-color:var(--color-border,#2d3342);color:var(--color-text,#e2e4e9)}[data-theme=dark] .filter-btn:hover{background:#00d4ff1a}[data-theme=dark] .sort-select{background-color:var(--color-bg,#0c0d0f);border-color:var(--color-border,#2d3342);color:var(--color-text,#e2e4e9)}[data-theme=dark] .clear-filters{background:#00d4ff1a}@media (width<=768px){.sidebar{border-right:1px solid var(--color-border,#e5e7eb);z-index:1000;width:280px;height:100vh;padding:var(--space-lg,20px);border-radius:0;position:fixed;top:0;left:0;overflow-y:auto;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.close-btn{display:flex}.sidebar-backdrop{display:block}}@media (width<=375px){.sidebar{width:100%}.filter-btn{min-height:44px;padding:10px 8px}.sort-select{min-height:44px}}.article-card{background:var(--color-bg-light);border:1px solid var(--color-border);transition:all var(--transition-normal);border-radius:0;flex-direction:column;gap:0;min-height:300px;padding:0;display:flex;overflow:hidden}.article-card:hover{border-color:var(--color-primary);transform:none;box-shadow:0 0 16px #00ff8826}.article-header{padding:var(--space-md);border-bottom:1px solid var(--color-border);flex-direction:column;align-items:flex-start;gap:8px;display:flex}.article-title{font-family:var(--font-family-mono);font-size:var(--font-sm);letter-spacing:.05em;text-transform:uppercase;color:var(--color-primary);word-break:break-word;margin:0;font-weight:700;line-height:1.2}.article-source{font-family:var(--font-family-mono);font-size:var(--font-xs);color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.1em;margin:0;font-weight:600}.codec-frame{aspect-ratio:4/3;background:linear-gradient(135deg,#00ff880d 0%,#0000 100%);position:relative;overflow:hidden}.codec-portrait{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.codec-portrait img{object-fit:cover;filter:grayscale()hue-rotate(90deg)saturate(2);opacity:.9;width:100%;height:100%}.codec-portrait:before{content:"";pointer-events:none;background:radial-gradient(circle,#0000 0%,#0006 100%);position:absolute;inset:0}.article-description{color:var(--color-text);font-size:var(--font-sm);padding:var(--space-md);flex-grow:1;margin:0;line-height:1.5}.article-meta{gap:var(--space-md);font-size:var(--font-xs);color:var(--color-text-dim);padding:var(--space-md);border-top:1px solid var(--color-border);flex-wrap:wrap;display:flex}.category-badge{border:1px solid var(--color-primary-dim);color:var(--color-primary-dim);font-family:var(--font-family-mono);text-transform:uppercase;font-weight:600;font-size:var(--font-xs);letter-spacing:.05em;background:0 0;border-radius:0;padding:4px 8px;display:inline-block}.date,.quality-score{display:inline-block}.article-actions{border-top:1px solid var(--color-border);grid-template-columns:repeat(4,1fr);gap:0;margin-top:auto;padding:0;display:grid}.action-btn{border:none;border-right:1px solid var(--color-border);background:var(--color-bg-light);color:var(--color-text-dim);font-family:var(--font-family-mono);font-size:var(--font-xs);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-transform:uppercase;letter-spacing:.05em;border-radius:0;justify-content:center;align-items:center;min-height:36px;padding:8px 6px;font-weight:600;display:flex;position:relative;overflow:hidden}.action-btn:last-child{border-right:none}.action-btn:hover:not(.read-btn){border-color:var(--color-primary);color:var(--color-primary);background:#00ff880d}.action-btn.like-btn.active{border-right-color:var(--color-primary);color:var(--color-primary);background:#00ff881a;box-shadow:inset 0 0 8px #00ff8826}.action-btn.dislike-btn.active{border-right-color:var(--color-error);color:var(--color-error);background:#ff66661a;box-shadow:inset 0 0 8px #ff666626}.action-btn.save-btn.active{border-right-color:var(--color-primary);color:var(--color-primary);background:#00ff881a;box-shadow:inset 0 0 8px #00ff8826}.read-btn{background:var(--color-bg-light);color:var(--color-primary);border-right-color:var(--color-primary);font-weight:700}.read-btn:hover{background:#00ff880d;transform:none;box-shadow:0 0 12px #0f83}@media (width<=768px){.article-card{min-height:auto}.codec-frame{aspect-ratio:16/9}.article-actions{gap:0}.action-btn{min-height:40px;font-size:var(--font-xs)}}@media (width<=375px){.codec-frame{aspect-ratio:3/2}.article-actions{grid-template-columns:repeat(2,1fr);gap:0}.action-btn{border-bottom:1px solid var(--color-border);min-height:44px;border-right:none!important}.action-btn:nth-child(3),.action-btn:nth-child(4){border-bottom:none}.action-btn:nth-child(2n){border-right:1px solid var(--color-border)!important}}.dashboard{background-color:var(--color-bg,#fff);flex-direction:column;min-height:100vh;display:flex}.dashboard-container{gap:var(--space-2xl,32px);width:100%;max-width:1400px;padding:var(--space-2xl,32px) var(--space-xl,24px);flex:1;grid-template-columns:250px 1fr;margin:0 auto;display:grid}.feed-container{gap:var(--space-2xl,32px);flex-direction:column;min-height:400px;display:flex}.feed-header{padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.feed-header h2{font-family:var(--font-family-mono);font-size:var(--font-lg);letter-spacing:.05em;text-transform:uppercase;color:var(--color-primary);margin:0;font-weight:700}.feed-info{font-family:var(--font-family-mono);font-size:var(--font-xs);color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em;margin:0;font-weight:600}.interest-tabs{padding:var(--space-md,16px) 0 var(--space-sm,8px);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md,16px);flex-wrap:wrap;gap:6px;display:flex}.interest-tab{border:1px solid var(--color-border);color:var(--color-text-dim);font-family:var(--font-family-mono);font-size:var(--font-xs,11px);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;background:0 0;border-radius:2px;align-items:center;gap:6px;padding:6px 14px;font-weight:600;transition:all .15s;display:inline-flex}.interest-tab:hover{border-color:var(--color-primary);color:var(--color-primary)}.interest-tab.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg,#0a0e27)}.tab-emoji{font-size:14px}@media (width<=768px){.interest-tabs{gap:4px}.interest-tab{padding:5px 10px;font-size:10px}.tab-emoji{display:none}}.feed-grid{gap:var(--space-lg,20px);padding:var(--space-lg,20px) 0;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.loading-state{justify-content:center;align-items:center;gap:var(--space-lg,20px);min-height:400px;padding:var(--space-3xl,48px);text-align:center;flex-direction:column;display:flex}.spinner{border:4px solid #00d4ff33;border-top-color:var(--color-primary,#00d4ff);border-radius:50%;width:50px;height:50px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-state p{font-size:var(--font-lg,1.1rem);color:var(--color-text-secondary,#4b5563);margin:0;font-weight:500}.empty-state,.error-state{justify-content:center;align-items:center;gap:var(--space-lg,20px);min-height:400px;padding:var(--space-3xl,48px);text-align:center;background:var(--color-bg-secondary,#f9fafb);border-radius:var(--radius-lg,12px);border:2px dashed var(--color-border,#e5e7eb);flex-direction:column;display:flex}.empty-icon,.error-icon{font-size:3rem;line-height:1}.empty-state h3,.error-state h3{font-size:var(--font-xl,1.25rem);color:var(--color-text,#111827);margin:0;font-weight:700}.empty-state p,.error-state p{font-size:var(--font-sm,.875rem);color:var(--color-text-secondary,#4b5563);max-width:300px;margin:0}.empty-state button,.error-state button{padding:var(--space-sm,8px) var(--space-lg,20px);border:1px solid var(--color-primary,#00d4ff);background:var(--color-primary,#00d4ff);color:#fff;border-radius:var(--radius-md,8px);font-size:var(--font-sm,.875rem);cursor:pointer;transition:all var(--transition-fast,.15s) ease-out;min-width:150px;min-height:44px;font-weight:600}.empty-state button:hover,.error-state button:hover{background:var(--color-primary-dark,#0099b8);transform:translateY(-2px);box-shadow:0 4px 12px #00d4ff4d}.pagination{justify-content:center;align-items:center;gap:var(--space-lg,20px);padding:var(--space-2xl,32px) var(--space-lg,20px);margin-top:var(--space-xl,24px);border-top:1px solid var(--color-border,#e5e7eb);flex-wrap:wrap;display:flex}.pagination-btn{padding:var(--space-sm,8px) var(--space-lg,20px);border:1px solid var(--color-border,#e5e7eb);background:var(--color-bg,#fff);color:var(--color-text,#111827);border-radius:var(--radius-md,8px);font-size:var(--font-sm,.875rem);cursor:pointer;transition:all var(--transition-fast,.15s) ease-out;justify-content:center;align-items:center;min-width:120px;min-height:44px;font-weight:600;display:flex}.pagination-btn:hover:not(:disabled){background:var(--color-primary,#00d4ff);border-color:var(--color-primary,#00d4ff);color:#fff;box-shadow:0 4px 12px #00d4ff4d}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{align-items:center;gap:var(--space-md,12px);font-size:var(--font-sm,.875rem);color:var(--color-text-secondary,#4b5563);display:flex}.page-number{color:var(--color-text,#111827);text-align:center;min-width:80px;font-weight:600}[data-theme=dark] .dashboard{background-color:var(--color-bg,#0c0d0f)}[data-theme=dark] .feed-header{border-bottom-color:var(--color-border,#2d3342)}[data-theme=dark] .feed-header h2{color:var(--color-text,#e2e4e9)}[data-theme=dark] .feed-info{color:var(--color-text-secondary,#a0a6b4)}[data-theme=dark] .empty-state,[data-theme=dark] .error-state{background:var(--color-bg-secondary,#131518);border-color:var(--color-border,#2d3342)}[data-theme=dark] .empty-state h3,[data-theme=dark] .error-state h3{color:var(--color-text,#e2e4e9)}[data-theme=dark] .empty-state p,[data-theme=dark] .error-state p{color:var(--color-text-secondary,#a0a6b4)}[data-theme=dark] .pagination{border-top-color:var(--color-border,#2d3342)}[data-theme=dark] .pagination-btn{background:var(--color-bg-secondary,#131518);border-color:var(--color-border,#2d3342);color:var(--color-text,#e2e4e9)}[data-theme=dark] .pagination-info,[data-theme=dark] .page-number{color:var(--color-text-secondary,#a0a6b4)}[data-theme=dark] .page-number{color:var(--color-text,#e2e4e9)}@media (width<=1024px){.dashboard-container{gap:var(--space-lg,20px);padding:var(--space-lg,20px);grid-template-columns:1fr}.feed-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (width<=768px){.dashboard-container{gap:var(--space-lg,20px);padding:var(--space-lg,20px)}.feed-grid{grid-template-columns:1fr}.feed-header{align-items:flex-start;gap:var(--space-sm,8px);flex-direction:column}.feed-header h2{font-size:1.5rem}.pagination{gap:var(--space-md,12px)}.pagination-btn{min-width:100px;padding:8px 16px;font-size:.8rem}}@media (width<=375px){.dashboard-container{padding:var(--space-md,12px)}.feed-grid{gap:var(--space-md,12px)}.feed-header h2{font-size:1.25rem}.empty-state,.error-state{padding:var(--space-2xl,32px) var(--space-lg,20px);min-height:300px}.pagination{gap:var(--space-sm,8px);flex-direction:column}.pagination-btn{width:100%}}.dashboard-error{justify-content:center;align-items:center;gap:var(--space-lg,20px);background-color:var(--color-bg,#fff);text-align:center;min-height:100vh;padding:var(--space-lg,20px);flex-direction:column;display:flex}.dashboard-error p{font-size:var(--font-lg,1.1rem);color:var(--color-text,#111827);margin:0;font-weight:500}.dashboard-error button{padding:var(--space-sm,8px) var(--space-lg,20px);border:1px solid var(--color-primary,#00d4ff);background:var(--color-primary,#00d4ff);color:#fff;border-radius:var(--radius-md,8px);font-size:var(--font-sm,.875rem);cursor:pointer;transition:all var(--transition-fast,.15s) ease-out;min-width:150px;min-height:44px;font-weight:600}.dashboard-error button:hover{background:var(--color-primary-dark,#0099b8);box-shadow:0 4px 12px #00d4ff4d}.btn{font-family:var(--font-family-mono);font-size:var(--font-sm);letter-spacing:.05em;text-transform:uppercase;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);background:var(--color-bg-light);color:var(--color-text-dim);cursor:pointer;transition:all var(--transition-fast);border-radius:0;font-weight:600;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{border-color:var(--color-primary);color:var(--color-primary)}.btn-primary:hover:not(:disabled){box-shadow:var(--glow-md);background:#00ff880d}.btn-secondary{border-color:var(--color-primary-dim);color:var(--color-text)}.btn-secondary:hover:not(:disabled){color:var(--color-primary);border-color:var(--color-primary)}.btn-accent{border-color:var(--color-accent);color:var(--color-accent)}.btn-accent:hover:not(:disabled){background:#ff44440d;box-shadow:0 0 8px #ff44444d}.btn-sm{font-size:var(--font-xs);padding:4px 8px}.btn-md{padding:var(--space-sm) var(--space-md);font-size:var(--font-sm)}.btn-lg{padding:var(--space-md) var(--space-lg);font-size:var(--font-base)}.btn-block{width:100%;display:block}.search-page{background:var(--color-bg);min-height:100vh;padding:var(--space-2xl) var(--space-lg)}.search-header{text-align:center;margin-bottom:var(--space-2xl);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-lg);animation:.5s ease-out slideDown}.search-header h1{font-family:var(--font-family-mono);font-size:var(--font-xl);letter-spacing:.05em;text-transform:uppercase;margin:0 0 var(--space-md) 0;color:var(--color-primary)}.search-header p{font-family:var(--font-family-mono);font-size:var(--font-xs);color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em;margin:0}.search-container{max-width:1200px;margin:0 auto var(--space-2xl);gap:var(--space-2xl);grid-template-columns:1fr 300px;display:grid}@media (width<=768px){.search-container{grid-template-columns:1fr}}.search-form{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 20px #0000001a}.search-input-group{flex-wrap:wrap;gap:10px;margin-bottom:25px;display:flex}.search-input{border:2px solid #e0e0e0;border-radius:8px;flex:1;min-width:250px;padding:12px 16px;font-size:1rem;transition:all .3s}.search-input:focus{border-color:#007bff;outline:none;box-shadow:0 0 0 3px #007bff1a}.filters{border-top:2px solid #f0f0f0;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;padding-top:25px;display:grid}.filter-group{flex-direction:column;gap:8px;display:flex}.filter-group label{color:#333;font-size:.95rem;font-weight:600}.filter-group select,.filter-group input[type=date],.filter-group input[type=range]{border:1px solid #ddd;border-radius:6px;padding:10px 12px;font-family:inherit;font-size:.95rem}.filter-group select:focus,.filter-group input[type=date]:focus{border-color:#007bff;outline:none;box-shadow:0 0 0 3px #007bff1a}.filter-group input[type=range]{cursor:pointer}.saved-searches{background:#fff;border-radius:12px;height:fit-content;padding:20px;position:sticky;top:20px;box-shadow:0 4px 20px #0000001a}.saved-searches h3{color:#333;margin:0 0 15px;font-size:1.1rem}.searches-list{margin:0;padding:0;list-style:none}.search-item{align-items:center;gap:8px;margin-bottom:10px;display:flex}.search-btn{cursor:pointer;text-align:left;white-space:nowrap;text-overflow:ellipsis;background:#f0f0f0;border:1px solid #ddd;border-radius:6px;flex:1;padding:10px;font-size:.9rem;transition:all .3s;overflow:hidden}.search-btn:hover{background:#e0e0e0;border-color:#007bff}.delete-btn{color:#fff;cursor:pointer;background:#ff6b6b;border:none;border-radius:6px;padding:8px 12px;font-size:.9rem;transition:background .3s}.delete-btn:hover{background:#ff5252}.empty{text-align:center;color:#999;padding:20px;font-size:.95rem}.results{background:#fff;border-radius:12px;max-width:1200px;margin:0 auto;padding:30px;box-shadow:0 4px 20px #0000001a}.results-count{color:#666;background:#f8f9fa;border-left:4px solid #007bff;border-radius:4px;margin-bottom:25px;padding:15px;font-size:1.1rem}.results-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;margin-bottom:30px;display:grid}@media (width<=768px){.results-grid{grid-template-columns:1fr}}.pagination{border-top:2px solid #f0f0f0;justify-content:center;align-items:center;gap:15px;margin-top:30px;padding-top:20px;display:flex}.pagination button{color:#fff;cursor:pointer;background:#007bff;border:none;border-radius:6px;padding:10px 20px;font-size:.95rem;transition:background .3s}.pagination button:hover:not(:disabled){background:#0056b3}.pagination button:disabled{cursor:not-allowed;background:#ccc}.pagination span{color:#666;font-weight:600}.loading{text-align:center;color:#666;padding:60px 20px;font-size:1.1rem}.loading:after{content:"";border:3px solid #f3f3f3;border-top-color:#007bff;border-radius:50%;width:20px;height:20px;margin-left:10px;animation:1s linear infinite spin;display:inline-block}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.input-wrapper{gap:var(--space-sm);margin-bottom:var(--space-lg);flex-direction:column;display:flex}.input-wrapper label{font-family:var(--font-family-mono);font-size:var(--font-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--color-primary-dim);font-weight:700}.input-wrapper input{padding:var(--space-md);border:1px solid var(--color-border);background-color:var(--color-bg-light);color:var(--color-text);font-family:var(--font-family-mono);font-size:var(--font-base);transition:all var(--transition-fast);border-radius:0}.input-wrapper input::placeholder{color:var(--color-text-dim);opacity:.5}.input-wrapper input:focus{border-color:var(--color-primary);background:#00ff8805;outline:none;box-shadow:0 0 12px #0f83}.input-wrapper input.error{border-color:var(--color-error)}.input-wrapper input.error:focus{box-shadow:0 0 12px #ff6b6b33}.error-text{font-size:var(--font-sm);color:var(--color-error)}.settings-page{background:var(--color-bg);min-height:100vh;padding:var(--space-2xl) var(--space-lg)}.settings-header{text-align:center;margin-bottom:var(--space-2xl);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-lg);animation:.5s ease-out slideDown}.settings-header h1{font-family:var(--font-family-mono);font-size:var(--font-xl);letter-spacing:.05em;text-transform:uppercase;margin:0 0 var(--space-md) 0;color:var(--color-primary)}.settings-header p{font-family:var(--font-family-mono);font-size:var(--font-xs);color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em;margin:0}.settings-container{background:var(--color-bg-light);border:1px solid var(--color-border);border-radius:0;max-width:900px;margin:0 auto}.error-alert,.success-alert{border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px 20px;animation:.3s ease-out slideDown;display:flex}.error-alert{color:#fff;background:#ff6b6b;border-left:4px solid #ff5252}.success-alert{color:#fff;background:#51cf66;border-left:4px solid #40c057}.close-btn{color:#fff;cursor:pointer;background:0 0;border:none;padding:0;font-size:1.2rem}.settings-form{background:#fff;border-radius:12px;margin-bottom:30px;padding:40px;box-shadow:0 8px 32px #0000001a}@media (width<=768px){.settings-form{padding:25px}}.settings-section{border-bottom:2px solid #f0f0f0;margin-bottom:40px;padding-bottom:30px}.settings-section:last-of-type{border-bottom:none}.settings-section h2{color:#333;margin:0 0 20px;font-size:1.4rem}.section-hint{color:#666;margin:0 0 15px;font-size:.95rem}.form-group{flex-direction:column;gap:10px;margin-bottom:25px;display:flex}.form-group label{color:#333;justify-content:space-between;align-items:center;font-weight:600;display:flex}.form-group .value{color:#667eea;background:#f0f0f0;border-radius:4px;padding:4px 12px;font-size:1.1rem;font-weight:700}.form-group select,.form-group input[type=time],.form-group input[type=range]{border:1px solid #ddd;border-radius:6px;padding:12px;font-family:inherit;font-size:.95rem;transition:all .3s}.form-group select:focus,.form-group input[type=time]:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.form-group input[type=range]{cursor:pointer;appearance:none;background:#e0e0e0;border-radius:3px;outline:none;height:6px}.form-group input[type=range]::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#667eea;border-radius:50%;width:20px;height:20px;transition:all .3s;box-shadow:0 2px 8px #667eea4d}.form-group input[type=range]::-webkit-slider-thumb:hover{background:#764ba2;box-shadow:0 4px 12px #667eea66}.form-group input[type=range]::-moz-range-thumb{cursor:pointer;background:#667eea;border:none;border-radius:50%;width:20px;height:20px;transition:all .3s;box-shadow:0 2px 8px #667eea4d}.form-group input[type=range]::-moz-range-thumb:hover{background:#764ba2;box-shadow:0 4px 12px #667eea66}.range-labels{color:#999;justify-content:space-between;margin-top:5px;font-size:.85rem;display:flex}.categories-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:15px;margin:20px 0;display:grid}@media (width<=768px){.categories-grid{grid-template-columns:repeat(2,1fr)}}.category-checkbox{cursor:pointer;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;align-items:center;gap:10px;padding:12px;transition:all .3s;display:flex}.category-checkbox:hover{background:#f0f0f0;border-color:#667eea}.category-checkbox input[type=checkbox]{cursor:pointer;accent-color:#667eea;width:18px;height:18px}.category-checkbox input[type=checkbox]:checked~.category-label{color:#667eea;font-weight:600}.category-checkbox .category-label{color:#333;-webkit-user-select:none;user-select:none;flex:1;font-size:.95rem;transition:all .3s}.warning-text{color:#ff6b6b;margin-top:10px;font-size:.9rem}.settings-actions{border-top:2px solid #f0f0f0;align-items:center;gap:15px;margin-top:30px;padding-top:20px;display:flex}.saved-message{color:#51cf66;font-weight:600;animation:.3s ease-out slideIn}.settings-info{background:#fff;border-radius:12px;padding:25px;box-shadow:0 4px 15px #0000001a}.settings-info h3{color:#333;margin:0 0 15px;font-size:1.2rem}.settings-info ul{margin:0;padding:0;list-style:none}.settings-info li{color:#666;border-bottom:1px solid #f0f0f0;padding:10px 0;font-size:.95rem}.settings-info li:last-child{border-bottom:none}.settings-info a{color:#667eea;font-weight:600;text-decoration:none}.settings-info a:hover{text-decoration:underline}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.digest-page{background:var(--color-bg);min-height:100vh;padding:var(--space-2xl) var(--space-lg)}.digest-header{text-align:center;margin-bottom:var(--space-2xl);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-lg);animation:.5s ease-out slideDown}.digest-header h1{font-family:var(--font-family-mono);font-size:var(--font-xl);letter-spacing:.05em;text-transform:uppercase;margin:0 0 var(--space-md) 0;color:var(--color-primary)}.digest-header p{font-family:var(--font-family-mono);font-size:var(--font-xs);color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em;margin:0}.digest-controls{max-width:1200px;margin:0 auto var(--space-2xl);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;display:flex}@media (width<=768px){.digest-controls{flex-direction:column}}.date-nav{background:#fff;border-radius:8px;align-items:center;gap:10px;padding:12px;display:flex;box-shadow:0 4px 15px #0000001a}.date-input{cursor:pointer;border:1px solid #ddd;border-radius:6px;padding:8px 12px;font-size:.95rem}.date-input:focus{border-color:#667eea;outline:none}.digest-content{max-width:1200px;margin:0 auto}.digest-summary{background:#fff;border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:15px;margin-bottom:25px;padding:20px;display:flex;box-shadow:0 4px 15px #0000001a}.digest-summary .article-count{color:#333;margin:0;font-size:1.1rem;font-weight:600}.digest-summary .generated-at{color:#666;margin:0;font-size:.9rem}@media (width<=768px){.digest-summary{text-align:center;flex-direction:column}}.digest-section{margin-bottom:40px;animation:.5s ease-out fadeIn}.section-title{color:#fff;border-bottom:3px solid #ffffff4d;justify-content:space-between;align-items:center;margin:0 0 20px;padding-bottom:12px;font-size:1.6rem;display:flex}.article-count-badge{color:#fff;background:#fff3;border-radius:20px;padding:4px 12px;font-size:.9rem;font-weight:500;display:inline-block}.articles-grid{grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:20px;display:grid}@media (width<=768px){.articles-grid{grid-template-columns:1fr}}.loading,.empty,.error-message{text-align:center;background:#fff;border-radius:12px;padding:60px 40px;box-shadow:0 4px 15px #0000001a}.loading{color:#666;font-size:1.2rem}.loading:after{content:"";vertical-align:middle;border:3px solid #f3f3f3;border-top-color:#667eea;border-radius:50%;width:24px;height:24px;margin-left:12px;animation:1s linear infinite spin;display:inline-block}.empty{color:#999;font-size:1.1rem}.error-message{background:#fff3cd;border-left:4px solid #ffc107}.error-message p{color:#333;margin:10px 0}.error-message p.error-hint{color:#666;font-size:.95rem}.error-message a{color:#667eea;font-weight:600;text-decoration:none}.error-message a:hover{text-decoration:underline}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.node-detail{background:var(--color-bg-light);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);max-height:calc(100vh - 200px);animation:.3s ease-out slideIn;position:relative;overflow-y:auto;box-shadow:0 4px 12px #00000026}.detail-header{margin-bottom:var(--space-lg);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.detail-header h3{font-size:var(--font-lg);color:var(--color-text);word-break:break-word;margin:0;font-weight:600}.close-btn{font-size:var(--font-xl);cursor:pointer;color:var(--color-text-dim);border-radius:var(--radius-md);width:32px;height:32px;transition:all var(--duration-fast) var(--easing);background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.close-btn:hover{background:var(--color-bg);color:var(--color-text)}.detail-content{gap:var(--space-lg);flex-direction:column;display:flex}.detail-stat{padding:var(--space-md);background:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.detail-stat .label{color:var(--color-text-dim);font-size:var(--font-sm);font-weight:500}.detail-stat .value{color:var(--color-primary);font-weight:700;font-size:var(--font-md)}.detail-section{padding:var(--space-md);background:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border)}.detail-section h4{font-size:var(--font-md);margin:0 0 var(--space-md) 0;color:var(--color-text);font-weight:600}.concept-description,.related-info{color:var(--color-text-dim);font-size:var(--font-sm);margin:0;line-height:1.6}.article-list{gap:var(--space-sm);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.article-item{padding:var(--space-sm);background:var(--color-bg-light);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:all var(--duration-fast) var(--easing)}.article-item:hover{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg)}.article-item a{color:inherit;font-size:var(--font-sm);font-weight:600;text-decoration:none}.article-item:hover a{color:var(--color-bg)}.article-item .source{font-size:var(--font-xs);opacity:.7;color:inherit;margin-top:4px;display:block}.node-detail::-webkit-scrollbar{width:6px}.node-detail::-webkit-scrollbar-track{background:0 0}.node-detail::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.node-detail::-webkit-scrollbar-thumb:hover{background:var(--color-text-dim)}.search-graph{padding:var(--space-lg);border-bottom:1px solid var(--color-border);background:var(--color-bg-light);position:relative}.search-input-wrapper{align-items:center;display:flex;position:relative}.search-input{width:100%;padding:var(--space-md) var(--space-lg);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text);font-size:var(--font-base);transition:all var(--duration-fast) var(--easing);padding-right:40px;font-family:inherit}.search-input::placeholder{color:var(--color-text-dim)}.search-input:focus{border-color:var(--color-primary);background:var(--color-bg);outline:none;box-shadow:0 0 0 3px #00d4ff1a}.clear-btn{color:var(--color-text-dim);cursor:pointer;font-size:var(--font-base);border-radius:var(--radius-sm);transition:all var(--duration-fast) var(--easing);background:0 0;border:none;padding:4px 8px;position:absolute;right:12px}.clear-btn:hover{color:var(--color-text);background:#00d4ff1a}.search-results{top:calc(100% + 8px);left:var(--space-lg);right:var(--space-lg);background:var(--color-bg-light);border:1px solid var(--color-border);border-radius:var(--radius-md);z-index:1000;max-height:300px;margin:0;padding:0;list-style:none;animation:.2s ease-out slideDown;position:absolute;overflow-y:auto;box-shadow:0 8px 24px #0003}.search-result{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);cursor:pointer;transition:all var(--duration-fast) var(--easing);justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.search-result:last-child{border-bottom:none}.search-result:hover{background:var(--color-primary);color:var(--color-bg)}.result-content{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.concept-name{font-weight:600;font-size:var(--font-sm);color:inherit;word-break:break-word}.search-result:hover .concept-name{color:var(--color-bg)}.concept-size{font-size:var(--font-xs);opacity:.7;color:inherit}.search-result:hover .concept-size{color:var(--color-bg)}.result-arrow{font-size:var(--font-sm);opacity:0;transition:opacity var(--duration-fast) var(--easing);color:inherit}.search-result:hover .result-arrow{opacity:1}.search-empty{padding:var(--space-lg);text-align:center;color:var(--color-text-dim);font-size:var(--font-sm);top:calc(100% + 8px);left:var(--space-lg);right:var(--space-lg);background:var(--color-bg-light);border:1px solid var(--color-border);border-radius:var(--radius-md);z-index:1000;position:absolute;box-shadow:0 8px 24px #0003}.search-results::-webkit-scrollbar{width:6px}.search-results::-webkit-scrollbar-track{background:0 0}.search-results::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.search-results::-webkit-scrollbar-thumb:hover{background:var(--color-text-dim)}@media (width<=768px){.search-graph{padding:var(--space-md)}.search-results,.search-empty{left:var(--space-md);right:var(--space-md)}}.graph-page{background-color:var(--color-bg);flex-direction:column;min-height:100vh;display:flex;overflow:hidden}.graph-header{padding:var(--space-2xl);text-align:center;border-bottom:1px solid var(--color-border);background:linear-gradient(135deg, var(--color-bg) 0%, var(--color-bg-light) 100%)}.graph-header h1{font-family:var(--font-family-mono);font-size:var(--font-lg);letter-spacing:.05em;text-transform:uppercase;margin:0 0 var(--space-md) 0;color:var(--color-primary);font-weight:700}.graph-header p{font-family:var(--font-family-mono);margin:0 0 var(--space-lg) 0;color:var(--color-text-dim);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.05em}.topic-selector{justify-content:center;gap:var(--space-md);display:flex}.topic-selector select{padding:var(--space-md) var(--space-lg);border:1px solid var(--color-border);background:var(--color-bg-light);color:var(--color-text);font-family:var(--font-family-mono);font-size:var(--font-sm);cursor:pointer;transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:.05em;border-radius:0}.topic-selector select:hover{border-color:var(--color-primary);box-shadow:0 0 8px #0f83}.topic-selector select:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 12px #00ff884d}.graph-container{gap:var(--space-lg);padding:var(--space-lg);flex:1;grid-template-columns:1fr 350px;display:grid;position:relative;overflow:hidden}.graph-canvas{background-color:var(--color-bg-light);border:1px solid var(--color-border);cursor:grab;border-radius:0;width:100%;height:100%}.graph-canvas:active{cursor:grabbing}.loading,.error{color:var(--color-text-dim);font-size:var(--font-lg);grid-column:1/-1;justify-content:center;align-items:center;font-weight:500;display:flex}.error{color:#ef4444}@media (width<=1024px){.graph-container{grid-template-columns:1fr}.graph-header{padding:var(--space-lg)}.graph-header h1{font-size:var(--font-2xl)}}
