@import"https://fonts.googleapis.com/css2?family=Lexend:wght@400;500;600&display=swap";.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:300}.modal-card{background:var(--card-on-card);border-radius:16px;padding:24px;display:flex;flex-direction:column;gap:36px;align-items:center;width:100%;max-width:480px}.modal-header{display:flex;align-items:start;justify-content:space-between;width:100%}.modal-header-text{display:flex;flex-direction:column;align-items:center;text-align:center;gap:2px;flex:1;padding:0 32px}.modal-header-text h2{font-size:16px;font-weight:500;line-height:24px;color:var(--white-text)}.modal-header-text p{font-size:12px;font-weight:400;line-height:16px;color:var(--light-text)}.modal-close-btn{background:none;border:none;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;border-radius:8px;flex-shrink:0}.modal-close-btn:hover{background:var(--foreground)}.modal-spacer{width:32px;flex-shrink:0}.modal-form{display:flex;flex-direction:column;gap:16px;width:100%}.modal-select{background:var(--card);border:1px solid var(--foreground);border-radius:12px;padding:8px 17px;height:48px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;color:var(--light-text);font-family:inherit;font-size:14px;font-weight:500;line-height:20px}.modal-field{display:flex;flex-direction:column;gap:4px}.modal-field label{font-size:12px;font-weight:400;line-height:16px;color:var(--light-text)}.modal-input{background:var(--card);border:1px solid var(--foreground);border-radius:12px;padding:8px 17px;height:48px;display:flex;align-items:center;gap:8px}.modal-input input{background:none;border:none;outline:none;color:var(--white-text);font-family:inherit;font-size:14px;font-weight:500;line-height:20px;width:100%}.modal-input input::placeholder{color:var(--light-text)}.modal-input svg{flex-shrink:0}.modal-save-btn{background:var(--accent);border:none;border-radius:12px;padding:8px 16px;display:flex;align-items:center;gap:8px;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;line-height:20px;color:var(--background)}.modal-save-btn:hover{opacity:.9}.sidebar{width:296px;min-width:296px;height:100vh;background:var(--background);display:flex;flex-direction:column;justify-content:space-between;padding:32px 0 32px 32px;position:fixed;left:0;top:0;overflow-y:auto;transition:transform .3s ease}.sidebar-top{display:flex;flex-direction:column;gap:52px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding-right:32px}.logo{display:flex;align-items:center;gap:12px}.logo-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--card);border-radius:10px;color:var(--accent);flex-shrink:0}.logo-text{font-size:20px;font-weight:500;letter-spacing:-.6px;line-height:1;color:var(--white-text);white-space:nowrap}.sidebar .icon-btn:hover{background:var(--card);opacity:1}.collapse-btn,.filter-icon-btn{color:var(--light-text)}.filter-icon-btn{margin-left:auto}.filter-icon-btn svg{width:16px;height:16px}.universe-info{display:flex;flex-direction:column;gap:4px}.universe-name{font-size:16px;font-weight:500;line-height:24px;color:var(--white-text)}.universe-desc{font-size:14px;font-weight:400;line-height:1.68;color:var(--light-text)}.nav-sections{display:flex;flex-direction:column;gap:34px}.nav-section{display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:12px;text-decoration:none;color:var(--white-text);font-size:14px;font-weight:500;line-height:20px;cursor:pointer;background:none;border:none;width:100%;text-align:left;font-family:inherit}.nav-item:hover,.nav-item.active{background:var(--card)}.nav-item.create-new{opacity:.5;color:var(--light-text)}.nav-item.create-new:hover{opacity:.8;background:transparent}.nav-item svg{flex-shrink:0}.entities-section{display:flex;flex-direction:column;gap:12px}.section-header{display:flex;align-items:center;padding:0 12px;height:16px}.section-title{font-size:12px;font-weight:500;letter-spacing:.6px;line-height:16px;color:var(--white-text);text-transform:uppercase;flex:1}.sidebar-bottom{display:flex;flex-direction:column;gap:4px;margin-top:auto}.close-sidebar-btn{display:none}.collapse-btn{display:flex}@media(max-width:768px){.sidebar{position:fixed;left:0;top:0;height:100vh;z-index:200;transform:translate(-100%);transition:transform .3s ease;background:var(--background);padding-right:32px}.sidebar.open{transform:translate(0)}.close-sidebar-btn{display:flex}.collapse-btn{display:none}}.layout{display:flex;min-height:100vh;background:var(--background)}.main-content{flex:1;margin-left:296px;padding:28px 32px;min-height:100vh;overflow-x:hidden;transition:margin-left .3s ease;display:flex;justify-content:center}.main-content>*{width:100%;max-width:1384px}.mobile-menu-btn{display:none;background:var(--card);border:none;border-radius:12px;padding:12px;cursor:pointer;align-items:center;justify-content:center;flex-shrink:0}.mobile-menu-btn:hover{background:var(--card-on-card)}.mobile-header{display:none}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:199;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.sidebar-overlay.open{opacity:1;visibility:visible}.focus-mode .sidebar{transform:translate(-100%)}.focus-mode .main-content{margin-left:0}@media(max-width:768px){.mobile-menu-btn{display:flex}.mobile-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.mobile-header-content{flex:1;min-width:0}.sidebar-overlay{display:block}.main-content{margin-left:0;padding:24px 16px}}.landing{min-height:100vh;overflow-x:hidden}@keyframes fade-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-down{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:200% center}to{background-position:-200% center}}@keyframes glow-pulse{0%,to{opacity:.06}50%{opacity:.12}}@keyframes bar-fill{0%{width:0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}.reveal.visible{opacity:1;transform:translateY(0)}.landing-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:16px 48px;background:#101014cc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--foreground);animation:slide-down .6s cubic-bezier(.16,1,.3,1) both}.landing-logo{display:flex;align-items:center;gap:10px;text-decoration:none}.landing-logo svg{flex-shrink:0}.landing-logo span{font-size:18px;font-weight:600;color:var(--white-text);letter-spacing:-.4px}.nav-links{display:flex;align-items:center;gap:8px}.nav-link{padding:8px 16px;border-radius:12px;font-size:14px;font-weight:400;color:var(--light-text);text-decoration:none;background:none;border:none;cursor:pointer;transition:color .2s,background .2s}.nav-link:hover{color:var(--white-text);background:var(--card)}.nav-link.primary{background:var(--accent);color:var(--background);font-weight:500;transition:background .2s,transform .15s}.nav-link.primary:hover{background:#5c59d4;transform:translateY(-1px)}.nav-link.primary:active{transform:translateY(0)}.hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:180px 32px 120px;position:relative}.hero:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:800px;height:600px;background:radial-gradient(ellipse at center,rgba(111,108,237,.08) 0%,transparent 70%);pointer-events:none;animation:glow-pulse 6s ease-in-out infinite}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;border-radius:100px;background:var(--accent-20);color:var(--accent);font-size:13px;font-weight:500;margin-bottom:32px;border:1px solid rgba(111,108,237,.15);animation:fade-up .7s cubic-bezier(.16,1,.3,1) .15s both}.hero-badge svg{flex-shrink:0}.hero h1{font-size:64px;font-weight:600;line-height:1.1;letter-spacing:-2px;max-width:720px;margin-bottom:24px;color:var(--white-text);animation:fade-up .7s cubic-bezier(.16,1,.3,1) .3s both}.hero h1 .gradient-text{background:linear-gradient(90deg,var(--accent) 0%,#a78bfa 25%,#c084fc 50%,#a78bfa 75%,var(--accent) 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 6s linear infinite}.hero p{font-size:18px;line-height:1.7;color:var(--light-text);max-width:520px;margin-bottom:40px;animation:fade-up .7s cubic-bezier(.16,1,.3,1) .45s both}.hero-cta{display:flex;align-items:center;gap:12px;animation:fade-up .7s cubic-bezier(.16,1,.3,1) .6s both}.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:12px;background:var(--accent);color:var(--background);font-size:15px;font-weight:500;font-family:inherit;border:none;cursor:pointer;transition:background .2s,transform .15s,box-shadow .25s;text-decoration:none}.btn-primary:hover{background:#5c59d4;transform:translateY(-2px);box-shadow:0 8px 24px #6f6ced40}.btn-primary:hover svg{transform:translate(3px)}.btn-primary svg{transition:transform .2s}.btn-primary:active{transform:translateY(0);box-shadow:none}.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:12px;background:var(--card);color:var(--light-text);font-size:15px;font-weight:500;font-family:inherit;border:1px solid var(--foreground);cursor:pointer;transition:color .2s,border-color .2s,transform .15s;text-decoration:none}.btn-secondary:hover{color:var(--white-text);border-color:var(--light-text);transform:translateY(-2px)}.btn-secondary:active{transform:translateY(0)}.app-preview{display:flex;justify-content:center;padding:0 32px 120px;position:relative;animation:fade-up .8s cubic-bezier(.16,1,.3,1) .75s both}.app-preview:before{content:"";position:absolute;bottom:0;left:0;right:0;height:200px;background:linear-gradient(to top,var(--background),transparent);z-index:1;pointer-events:none}.preview-window{max-width:960px;width:100%;border-radius:16px;border:1px solid var(--foreground);background:var(--card);overflow:hidden;box-shadow:0 32px 64px #0006,0 0 0 1px #6f6ced0d;transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s}.preview-window:hover{transform:translateY(-4px);box-shadow:0 40px 80px #00000080,0 0 0 1px #6f6ced1a}.preview-titlebar{display:flex;align-items:center;gap:8px;padding:14px 18px;border-bottom:1px solid var(--foreground)}.preview-dot{width:12px;height:12px;border-radius:50%;background:var(--foreground)}.preview-body{display:grid;grid-template-columns:200px 1fr;min-height:320px}.preview-sidebar{padding:20px 16px;border-right:1px solid var(--foreground);display:flex;flex-direction:column;gap:4px}.preview-nav-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;font-size:13px;color:var(--light-text)}.preview-nav-item.active{background:var(--card-on-card);color:var(--white-text)}.preview-nav-item svg{flex-shrink:0}.preview-main{padding:24px;display:flex;flex-direction:column;gap:16px}.preview-main-title{font-size:16px;font-weight:500;color:var(--white-text)}.preview-cards{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.preview-card{background:var(--card-on-card);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:8px}.preview-card-label{font-size:11px;color:var(--light-text);text-transform:uppercase;letter-spacing:.5px}.preview-card-value{font-size:20px;font-weight:600;color:var(--white-text)}.preview-card-bar{height:4px;border-radius:100px;background:var(--accent-20);margin-top:4px}.preview-card-bar-fill{height:100%;border-radius:100px;background:var(--accent);animation:bar-fill 1.2s cubic-bezier(.16,1,.3,1) 1.2s both}.features{padding:80px 32px;display:flex;flex-direction:column;align-items:center}.section-label{font-size:13px;font-weight:500;color:var(--accent);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:16px}.landing .section-title{font-size:40px;font-weight:600;letter-spacing:-1.2px;text-align:center;margin-bottom:16px;color:var(--white-text)}.section-subtitle{font-size:16px;color:var(--light-text);text-align:center;max-width:480px;line-height:1.7;margin-bottom:64px}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1040px;width:100%}.feature-card{background:var(--card);border-radius:16px;padding:32px 28px;border:1px solid var(--foreground);transition:border-color .3s,transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s}.feature-card:hover{border-color:#6f6ced4d;transform:translateY(-4px);box-shadow:0 16px 40px #0003}.feature-icon{width:48px;height:48px;border-radius:12px;background:var(--accent-20);display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:transform .3s,background .3s}.feature-card:hover .feature-icon{transform:scale(1.1);background:#6f6ced4d}.feature-icon svg{color:var(--accent)}.feature-card h3{font-size:16px;font-weight:500;margin-bottom:8px;color:var(--white-text)}.feature-card p{font-size:14px;line-height:1.68;color:var(--light-text)}.feature-card:nth-child(1){transition-delay:0s}.feature-card:nth-child(2){transition-delay:.05s}.feature-card:nth-child(3){transition-delay:.1s}.feature-card:nth-child(4){transition-delay:.15s}.feature-card:nth-child(5){transition-delay:.2s}.feature-card:nth-child(6){transition-delay:.25s}.features-grid.reveal .feature-card{opacity:0;transform:translateY(24px)}.features-grid.reveal.visible .feature-card{opacity:1;transform:translateY(0);transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1),border-color .3s,box-shadow .3s}.features-grid.reveal.visible .feature-card:nth-child(1){transition-delay:0s}.features-grid.reveal.visible .feature-card:nth-child(2){transition-delay:.08s}.features-grid.reveal.visible .feature-card:nth-child(3){transition-delay:.16s}.features-grid.reveal.visible .feature-card:nth-child(4){transition-delay:.24s}.features-grid.reveal.visible .feature-card:nth-child(5){transition-delay:.32s}.features-grid.reveal.visible .feature-card:nth-child(6){transition-delay:.4s}.pricing{padding:80px 32px 100px;display:flex;flex-direction:column;align-items:center}.pricing-single{max-width:600px;width:100%}.pricing-header{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:28px}.pricing-card{background:var(--card);border-radius:16px;padding:36px 32px;border:1px solid var(--foreground);display:flex;flex-direction:column;transition:border-color .3s,transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s}.pricing-card:hover{border-color:#6f6ced66;transform:translateY(-4px);box-shadow:0 20px 48px #00000040,0 0 0 1px #6f6ced1a}.pricing-card.featured{border-color:var(--accent);position:relative}.pricing-card.featured:before{content:"7-day free trial";position:absolute;top:-13px;left:50%;transform:translate(-50%);padding:4px 14px;border-radius:100px;background:var(--accent);color:var(--background);font-size:12px;font-weight:500;white-space:nowrap}.pricing-tier{font-size:14px;font-weight:500;color:var(--accent);margin-bottom:8px}.pricing-price{display:flex;align-items:baseline;gap:4px;margin-bottom:4px}.pricing-price .amount{font-size:40px;font-weight:600;letter-spacing:-1px;color:var(--white-text)}.pricing-price .period{font-size:14px;color:var(--light-text)}.pricing-desc{font-size:14px;color:var(--light-text);margin-bottom:0;line-height:1.5}.pricing-divider{height:1px;background:var(--foreground);margin-bottom:28px}.pricing-features{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:14px}.pricing-features li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--light-text);line-height:1.4}.pricing-features li svg{flex-shrink:0;margin-top:2px;color:var(--accent)}.pricing-card .btn-primary,.pricing-card .btn-secondary{width:100%;justify-content:center}.bottom-cta{padding:80px 32px 120px;display:flex;justify-content:center}.cta-card{max-width:720px;width:100%;text-align:center;padding:64px 48px;background:var(--card);border-radius:16px;border:1px solid var(--foreground);position:relative;overflow:hidden;transition:border-color .3s,box-shadow .3s}.cta-card:hover{border-color:#6f6ced33;box-shadow:0 24px 48px #0003}.cta-card:before{content:"";position:absolute;top:-1px;left:50%;transform:translate(-50%);width:240px;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}.cta-card h2{font-size:32px;font-weight:600;letter-spacing:-.8px;margin-bottom:12px;color:var(--white-text)}.cta-card p{font-size:16px;color:var(--light-text);margin-bottom:32px;line-height:1.7}.landing-footer{padding:32px 48px;border-top:1px solid var(--foreground);display:flex;align-items:center;justify-content:space-between}.footer-text{font-size:13px;color:var(--light-text)}.footer-links{display:flex;gap:24px}.footer-links a{font-size:13px;color:var(--light-text);text-decoration:none;transition:color .2s}.footer-links a:hover{color:var(--white-text)}@media(max-width:900px){.features-grid{grid-template-columns:1fr;max-width:440px}.pricing-header{flex-direction:column;align-items:flex-start}.pricing-features{grid-template-columns:1fr}.hero h1{font-size:40px;letter-spacing:-1px}.landing .section-title{font-size:28px}.preview-body{grid-template-columns:1fr}.preview-sidebar{display:none}.preview-cards{grid-template-columns:1fr 1fr}}@media(max-width:600px){.landing-nav{padding:14px 20px}.landing-logo span{display:none}.hero{padding:140px 20px 80px}.hero h1{font-size:32px}.hero p{font-size:16px}.hero-cta{flex-direction:column;width:100%}.hero-cta .btn-primary,.hero-cta .btn-secondary{width:100%;justify-content:center}.app-preview{padding:0 20px 80px}.preview-cards{grid-template-columns:1fr}.features,.pricing{padding:60px 20px}.bottom-cta{padding:40px 20px 80px}.cta-card{padding:48px 24px}.cta-card h2{font-size:24px}.landing-footer{flex-direction:column;gap:16px;padding:24px 20px;text-align:center}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}.reveal{opacity:1;transform:none}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px}.auth-card{width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center}.auth-logo{display:flex;align-items:center;gap:10px;text-decoration:none;margin-bottom:40px}.auth-logo span{font-size:18px;font-weight:600;color:var(--white-text);letter-spacing:-.4px}.auth-card h1{font-size:24px;font-weight:600;color:var(--white-text);margin-bottom:6px;letter-spacing:-.5px}.auth-subtitle{font-size:14px;color:var(--light-text);margin-bottom:32px}.auth-card form{width:100%;display:flex;flex-direction:column;gap:16px}.auth-label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:500;color:var(--light-text)}.auth-label input{padding:12px 14px;border-radius:10px;border:1px solid var(--foreground);background:var(--card);color:var(--white-text);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}.auth-label input::placeholder{color:#555}.auth-label input:focus{border-color:var(--accent)}.auth-error{padding:10px 14px;border-radius:10px;background:#e13d331a;border:1px solid rgba(225,61,51,.2);color:var(--red-alert);font-size:13px}.auth-submit{padding:12px;border-radius:10px;border:none;background:var(--accent);color:var(--background);font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;transition:background .2s,transform .15s;margin-top:4px}.auth-submit:hover:not(:disabled){background:#5c59d4;transform:translateY(-1px)}.auth-submit:active:not(:disabled){transform:translateY(0)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-footer{margin-top:24px;font-size:13px;color:var(--light-text)}.auth-footer a{color:var(--accent);text-decoration:none;font-weight:500}.auth-footer a:hover{text-decoration:underline}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:24px}.page-header .header-left{display:flex;align-items:flex-start;gap:16px}.page-header .header-icon{width:56px;height:56px;background:var(--accent-20);border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.page-header .header-info{display:flex;flex-direction:column;gap:2px}.page-header .page-title{font-size:16px;font-weight:500;color:var(--white-text);margin:0}.page-header.large-title .page-title{font-size:24px;letter-spacing:-.72px;line-height:1.68}.page-header .page-subtitle{font-size:14px;color:var(--light-text);margin:0}.page-header .header-right{display:flex;gap:8px;align-items:center}.page-header .header-right.gap-16{gap:16px}.page-header .breadcrumb{display:flex;align-items:center;gap:4px;font-size:16px;font-weight:500;line-height:24px}.page-header .breadcrumb-parent,.page-header .breadcrumb-separator{color:var(--light-text)}.page-header .breadcrumb-current{color:var(--white-text)}@media(max-width:768px){.page-header{flex-wrap:wrap}.page-header .header-left{flex:1;min-width:0}.page-header .header-right{width:100%;order:3}.page-header .search-btn{flex:1;min-width:unset}}.book-card{background:var(--card-on-card);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:12px}.book-card.active{border:2px solid var(--accent)}.book-card-header{display:flex;justify-content:space-between;align-items:center}.book-icon{width:40px;height:40px;background:var(--accent-20);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--accent)}.book-icon.compact{width:28px;height:28px;border-radius:4px}.book-actions{display:flex;gap:8px}.book-card-content h4{font-size:16px;font-weight:500;line-height:24px;color:var(--white-text);margin-bottom:4px}.book-card-content p{font-size:12px;font-weight:400;line-height:16px;color:var(--light-text)}.book-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:8px}.book-divider{height:1px;background:var(--foreground);margin:4px 0}.book-stats{display:flex;gap:16px}.book-stat{display:flex;flex-direction:column}.book-stat .label{font-size:12px;font-weight:400;line-height:16px;color:var(--light-text)}.book-stat .value{font-size:14px;font-weight:500;line-height:20px;color:var(--white-text)}.dashboard{width:100%}.dashboard-content{display:flex;flex-direction:column;gap:16px}.dashboard .stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.dashboard .stat-card{display:flex;flex-direction:column;justify-content:space-between;min-height:160px}.stat-title{font-size:14px;color:var(--light-text)}.stat-content{display:flex;flex-direction:column;gap:4px}.dashboard .stat-card .stat-value{font-size:32px;font-weight:500;letter-spacing:-.96px;line-height:40px;color:var(--white-text)}.stat-subtitle{font-size:12px;color:var(--light-text)}.progress-card{display:flex;flex-direction:column;gap:16px}.progress-header{display:flex;flex-direction:column;gap:4px}.progress-header h3{font-size:16px;font-weight:500}.progress-bar-container{display:flex;flex-direction:column;gap:8px}.progress-labels{display:flex;justify-content:space-between;align-items:center}.progress-track{height:8px;background:var(--accent-20);border-radius:100px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:100px}.progress-stats{display:flex;gap:24px;justify-content:center;margin-top:8px}.progress-stat{display:flex;flex-direction:column;align-items:center;flex:1}.progress-stat .stat-value{font-size:24px;font-weight:500;line-height:32px}.progress-stat .stat-label{font-size:12px;color:var(--light-text)}.books-card{display:flex;flex-direction:column;gap:16px}.books-header{display:flex;justify-content:space-between;align-items:flex-start}.books-title{display:flex;flex-wrap:wrap;align-items:center;gap:4px}.books-title h3{font-size:16px;font-weight:500}.books-title .text-muted{width:100%;margin-top:4px}.books-actions{display:flex;gap:8px}.books-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.bottom-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.quick-access-card{display:flex;flex-direction:column;gap:16px}.quick-access-card h3{font-size:16px;font-weight:500}.quick-access-list{display:flex;flex-direction:column;gap:12px}.quick-access-item{display:flex;align-items:center;gap:12px;padding:16px;background:var(--card-on-card);border-radius:12px;cursor:pointer}.quick-access-item svg{flex-shrink:0}.quick-access-item:hover{background:var(--foreground)}.quick-access-info{display:flex;flex-direction:column}.item-name{font-size:14px;font-weight:400}.item-type{font-size:12px;color:var(--light-text)}@media(max-width:1200px){.dashboard .stats-row,.books-grid{grid-template-columns:repeat(2,1fr)}.bottom-row{grid-template-columns:1fr}}@media(max-width:768px){.dashboard .stats-row,.books-grid{grid-template-columns:1fr}}.series-page{width:100%}.groupings-content{display:flex;flex-direction:column;gap:16px}.group-header-bar{display:flex;justify-content:space-between;align-items:center;padding:16px 0}.group-header-info{display:flex;align-items:center;gap:16px}.series-icon-container{width:56px;height:56px;background:var(--accent-20);border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.series-title{font-size:36px;font-weight:500;line-height:normal;color:var(--white-text)}.groupings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.danger-btn{color:var(--red-alert);border-color:var(--red-alert)}.danger-btn:hover{background:#ff3b301a}.breadcrumb-parent{color:var(--light-text);text-decoration:none}.breadcrumb-parent:hover{color:var(--white-text)}.breadcrumb-separator{color:var(--light-text);margin:0 6px}.breadcrumb-current{color:var(--white-text)}@media(max-width:768px){.series-title{font-size:28px}.group-header-bar{flex-direction:column;align-items:flex-start;gap:12px}}.timeline-page{width:100%}.timeline-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.timeline-title-row h2{font-size:36px;font-weight:500;color:var(--white-text);line-height:1}.timeline-events{display:flex;flex-direction:column;gap:12px}.timeline-events .event-row{cursor:pointer}.timeline-events .event-row.active .event-card{border-color:var(--accent)}.timeline-events .event-row:not(.active) .event-card:hover{border-color:var(--light-text)}.timeline-events .event-row:not(.active) .event-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:768px){.timeline-title-row h2{font-size:28px}}.writing-page{width:100%;min-height:100%}.writing-container{max-width:824px;margin:0 auto;padding:48px 24px}.writing-top-row{display:flex;align-items:center;gap:12px;margin-bottom:24px}.writing-tags{display:flex;gap:4px}.writing-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.writing-title{font-size:36px;font-weight:500;color:var(--white-text);line-height:1.2;margin:0}.writing-title-input{background:transparent;border:none;outline:none;width:100%}.back-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:1px solid var(--card);border-radius:8px;color:var(--light-text);cursor:pointer;font-size:13px}.back-btn:hover{background:var(--card);color:var(--white-text)}.expand-btn{display:flex;align-items:center;justify-content:center;padding:10px;background:transparent;border:2px solid var(--card);border-radius:12px;cursor:pointer;flex-shrink:0}.expand-btn:hover{background:var(--card)}.writing-meta{display:flex;align-items:center;gap:18px;margin-bottom:32px}.meta-tag{background:var(--card-on-card);color:var(--light-text);font-size:12px;padding:4px 8px;border-radius:4px}.meta-stat{font-size:12px;color:var(--light-text);opacity:.5}.writing-content{width:100%}.writing-editor{outline:none}.writing-editor p{font-size:14px;font-weight:400;line-height:1.68;color:var(--light-text);margin-bottom:16px}.writing-editor p:last-child{margin-bottom:0}.writing-editor .mention{color:var(--accent);font-weight:500;text-decoration:underline;cursor:pointer}.writing-editor h1{font-size:32px;font-weight:500;color:var(--white-text);margin-bottom:16px}.writing-editor h2{font-size:24px;font-weight:500;color:var(--white-text);margin-bottom:16px}.writing-editor h3{font-size:18px;font-weight:500;color:var(--white-text);margin-bottom:16px}.writing-editor a{color:var(--accent);text-decoration:underline}.writing-editor strong{font-weight:500;color:var(--white-text)}.writing-editor em{font-style:italic}.writing-editor ul,.writing-editor ol{padding-left:24px;margin-bottom:16px}.writing-editor li{font-size:14px;line-height:1.68;color:var(--light-text);margin-bottom:4px}.writing-editor blockquote{border-left:3px solid var(--accent);padding-left:16px;margin:0 0 16px;color:var(--light-text);font-style:italic}.writing-editor code{background:var(--card-on-card);padding:2px 6px;border-radius:4px;font-family:monospace;font-size:13px}.writing-editor pre{background:var(--card-on-card);padding:16px;border-radius:8px;margin-bottom:16px;overflow-x:auto}.writing-editor pre code{background:none;padding:0}.ProseMirror-focused{outline:none}.ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--light-text);opacity:.5;pointer-events:none;float:left;height:0}@media(max-width:768px){.writing-container{padding:24px 0}.writing-title{font-size:28px}.writing-meta{flex-wrap:wrap;gap:8px}}.entities-page{width:100%}.entities-content{display:flex;flex-direction:column;gap:16px}.entities-page .stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}.entities-page .stat-card{display:flex;flex-direction:column;gap:40px;padding:24px}.entities-page .stat-value{font-size:24px;font-weight:500;color:var(--white-text);letter-spacing:-.72px;line-height:1.68}.entities-toolbar{display:flex;align-items:center;justify-content:flex-end;gap:8px}.toolbar-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--card);border:1px solid var(--foreground);border-radius:12px;color:var(--light-text);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:color .15s,border-color .15s}.toolbar-btn:hover{color:var(--white-text);border-color:var(--light-text)}.view-toggle{display:flex;background:var(--card);border:1px solid var(--foreground);border-radius:12px;overflow:hidden}.view-toggle-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:none;color:var(--light-text);cursor:pointer;transition:color .15s,background .15s}.view-toggle-btn.active{background:var(--accent);color:var(--background)}.view-toggle-btn:not(.active):hover{color:var(--white-text)}.entities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.entities-list{display:flex;flex-direction:column;gap:12px}.entities-list .entity-card{position:relative;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:16px}.entities-list .entity-card-header{flex-direction:column;gap:0}.entities-list .entity-card-header .icon-btn-small{position:absolute;top:12px;right:12px}.entities-list .entity-card-body{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.entities-list .entity-desc{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;align-self:stretch}.entities-list .entity-tags{display:none}.entities-list .entity-card-stats{border-top:none;padding-top:0;margin-top:0}.entity-card{padding:20px;display:flex;flex-direction:column;gap:0}.entity-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.entity-icon{width:36px;height:36px;border-radius:8px;background:var(--accent-20);color:var(--accent);display:flex;align-items:center;justify-content:center}.entity-card .icon-btn-small{background:none;border:none;cursor:pointer;color:var(--light-text);padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center}.entity-card .icon-btn-small:hover{color:var(--white-text);background:var(--card-on-card)}.entity-card-body{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.entity-name{font-size:16px;font-weight:500;color:var(--white-text)}.entity-desc{font-size:13px;line-height:1.5;color:var(--light-text)}.entity-tags{display:flex;flex-wrap:wrap;gap:6px}.entity-card-stats{display:flex;gap:24px;border-top:1px solid var(--foreground);padding-top:16px;margin-top:4px}.entity-stat .label{display:block;font-size:12px;color:var(--light-text);margin-bottom:2px}.entity-stat .value{font-size:14px;font-weight:500;color:var(--white-text)}.entities-empty{display:flex;flex-direction:column;align-items:center;gap:16px;padding:64px 24px;color:var(--light-text);font-size:14px}@media(max-width:1400px){.entities-page .stats-row{grid-template-columns:repeat(3,1fr)}}@media(max-width:1200px){.entities-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:1000px){.entities-page .stats-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.entities-page .stats-row,.entities-grid,.entities-list .entity-card{grid-template-columns:1fr}.entities-list .entity-card-body{flex-direction:column;align-items:flex-start}.entities-toolbar{flex-wrap:wrap}}.entity-detail-page{width:100%}.entity-detail-layout{display:grid;grid-template-columns:1fr 320px;gap:32px;align-items:start}.entity-detail-main{max-width:824px}.entity-detail-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.entity-detail-tags{display:flex;align-items:center;gap:6px}.icon-btn-subtle{background:none;border:none;color:var(--light-text);cursor:pointer;padding:6px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}.icon-btn-subtle:hover{color:var(--red-alert);background:var(--card-on-card)}.entity-detail-name{font-size:36px;font-weight:500;color:var(--white-text);line-height:1.2;margin-bottom:16px}.entity-detail-meta{display:flex;align-items:center;gap:18px;margin-bottom:32px;flex-wrap:wrap}.entity-detail-meta .meta-tag{background:var(--card-on-card);color:var(--light-text);font-size:12px;padding:4px 8px;border-radius:4px}.entity-detail-meta .meta-stat{font-size:12px;color:var(--light-text);opacity:.5}.entity-editor-wrapper{width:100%;margin-bottom:40px}.entity-editor{outline:none}.entity-editor p{font-size:14px;font-weight:400;line-height:1.68;color:var(--light-text);margin-bottom:16px}.entity-editor p:last-child{margin-bottom:0}.entity-editor .mention{color:var(--accent);font-weight:500;text-decoration:underline;cursor:pointer}.entity-editor h1{font-size:32px;font-weight:500;color:var(--white-text);margin-bottom:16px}.entity-editor h2{font-size:24px;font-weight:500;color:var(--white-text);margin-bottom:16px}.entity-editor h3{font-size:18px;font-weight:500;color:var(--white-text);margin-bottom:16px}.entity-editor a{color:var(--accent);text-decoration:underline}.entity-editor strong{font-weight:500;color:var(--white-text)}.entity-editor em{font-style:italic}.entity-editor ul,.entity-editor ol{padding-left:24px;margin-bottom:16px}.entity-editor li{font-size:14px;line-height:1.68;color:var(--light-text);margin-bottom:4px}.entity-editor blockquote{border-left:3px solid var(--accent);padding-left:16px;margin:0 0 16px;color:var(--light-text);font-style:italic}.entity-editor-wrapper .ProseMirror-focused{outline:none}.entity-editor-wrapper .ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--light-text);opacity:.5;pointer-events:none;float:left;height:0}.entity-detail-events{margin-top:8px}.events-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.events-header h2{font-size:16px;font-weight:500;color:var(--white-text)}.events-list{display:flex;flex-direction:column;gap:12px}.event-row{display:flex;gap:16px;align-items:flex-start}.event-dot{width:10px;height:10px;min-width:10px;border-radius:50%;background:var(--accent);margin-top:18px}.event-card{flex:1;background:var(--card);border:1px solid var(--foreground);border-radius:12px;padding:16px}.event-breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--light-text);margin-bottom:8px}.event-text{font-size:13px;line-height:1.6;color:var(--light-text);margin-bottom:8px}.event-text .mention{color:var(--accent);font-weight:500}.event-actions{display:flex;gap:4px;justify-content:flex-end}.event-icon-btn{background:none;border:none;color:var(--light-text);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}.event-icon-btn:hover{color:var(--white-text);background:var(--card-on-card)}.entity-detail-sidebar{display:flex;flex-direction:column;gap:24px}.sidebar-section{background:var(--card);border:1px solid var(--foreground);border-radius:16px;padding:20px}.sidebar-heading{font-size:14px;font-weight:500;color:var(--white-text);margin-bottom:16px}.sidebar-empty{font-size:13px;color:var(--light-text);opacity:.5;margin-bottom:16px}.field-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.field-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.field-key{font-size:13px;color:var(--light-text)}.field-value{font-size:13px;color:var(--white-text);text-align:right}.field-value.bold{font-weight:500;color:var(--accent)}.add-btn{display:flex;align-items:center;gap:6px;background:none;border:1px dashed var(--foreground);border-radius:8px;color:var(--light-text);font-size:13px;font-family:inherit;padding:8px 12px;cursor:pointer;width:100%;justify-content:center;transition:color .15s,border-color .15s}.add-btn:hover{color:var(--accent);border-color:var(--accent)}.btn-back{background:var(--card);border:1px solid var(--foreground);border-radius:12px;color:var(--light-text);font-size:13px;font-family:inherit;padding:8px 16px;cursor:pointer;margin-top:16px;transition:color .15s,border-color .15s}.btn-back:hover{color:var(--white-text);border-color:var(--light-text)}@media(max-width:900px){.entity-detail-layout{grid-template-columns:1fr}.entity-detail-sidebar{order:-1;display:grid;grid-template-columns:1fr 1fr}}@media(max-width:600px){.entity-detail-sidebar{grid-template-columns:1fr}.entity-detail-name{font-size:28px}.entity-detail-meta{flex-wrap:wrap;gap:8px}}.card{background:var(--card);border-radius:16px;padding:24px}.search-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--card);border:1px solid var(--foreground);border-radius:12px;color:var(--light-text);font-size:14px;font-weight:500;line-height:20px;cursor:pointer;font-family:inherit;min-width:200px}.search-btn:hover{background:var(--card-on-card)}.primary-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--accent);border:none;border-radius:12px;color:var(--background);font-size:14px;font-weight:500;line-height:20px;cursor:pointer;font-family:inherit}.primary-btn:hover{opacity:.9}.secondary-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--card);border:1px solid var(--foreground);border-radius:12px;color:var(--light-text);font-size:14px;font-weight:500;line-height:20px;cursor:pointer;font-family:inherit}.secondary-btn:hover{background:var(--card-on-card)}.filter-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--card);border:1px solid var(--foreground);border-radius:12px;color:var(--light-text);font-size:14px;font-weight:500;line-height:20px;cursor:pointer;font-family:inherit}.filter-btn:hover{background:var(--card-on-card)}.icon-btn{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:8px}.icon-btn:hover{opacity:.8}.icon-btn-small{background:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:opacity .2s;display:flex;align-items:center;justify-content:center}.icon-btn-small:hover{opacity:1}.text-muted{color:var(--light-text);font-size:14px}.tag{background:var(--accent-20);color:var(--accent);font-size:12px;font-weight:400;padding:4px 8px;border-radius:4px}.activity-card{display:flex;flex-direction:column;gap:12px;padding:16px}.activity-card h3{font-size:16px;font-weight:500;line-height:24px;color:var(--white-text)}.activity-list{display:flex;flex-direction:column;gap:16px}.activity-item{display:flex;gap:12px;align-items:flex-start}.activity-dot{width:6px;height:6px;background:var(--accent);border-radius:50%;margin-top:8px;flex-shrink:0}.activity-content{display:flex;flex-direction:column;gap:4px}.activity-title{font-size:14px;font-weight:400;line-height:20px;color:var(--white-text)}.activity-subtitle{font-size:12px;font-weight:400;line-height:16px;color:var(--light-text)}.activity-book{font-size:12px;color:var(--light-text)}.activity-time{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:400;line-height:16px;color:var(--light-text)}:root{--background: #101014;--card: #17171c;--card-on-card: #202027;--foreground: #292932;--accent: #6f6ced;--accent-20: rgba(111, 108, 237, .2);--white-text: #ffffff;--light-text: #ababba;--red-alert: #e13d33;font-family:Lexend,system-ui,sans-serif;line-height:1.5;font-weight:400;color:var(--white-text);background-color:var(--background)}*{margin:0;padding:0;box-sizing:border-box}body{min-width:320px;min-height:100vh}#root{min-height:100vh}
