.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 60px #0006;max-width:500px;width:calc(100% - 2rem);max-height:calc(100vh - 4rem);overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border)}.modal-header h2{margin:0;font-size:1.25rem;font-weight:700;color:var(--text)}.btn-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:transparent;color:var(--text-muted);border-radius:6px;cursor:pointer;transition:all .2s}.btn-icon:hover{background:var(--hover-bg);color:var(--text)}.feedback-form{padding:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;font-size:.875rem;color:var(--text)}.form-control{width:100%;padding:.625rem .875rem;border:1px solid var(--border);border-radius:8px;background:var(--input-bg);color:var(--text);font-family:inherit;font-size:.9375rem;transition:all .2s}.form-control:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #7bc8a41a}textarea.form-control{resize:vertical;min-height:120px}select.form-control{cursor:pointer}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--border);margin-top:1.5rem}.feedback-success{padding:3rem 1.5rem;text-align:center}.feedback-success p{font-size:1.125rem;font-weight:600;color:var(--brand);margin:0}.btn-icon-text{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem}.btn-text{font-size:.875rem;font-weight:500}.user-menu-wrapper{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:transparent;border:1px solid color-mix(in oklab,var(--nav-bg) 70%,white 30%);border-radius:8px;color:var(--nav-text);cursor:pointer;transition:all .2s;font-family:inherit;font-size:.875rem}.user-menu-trigger:hover{background:#ffffff0f;border-color:color-mix(in oklab,var(--nav-bg) 55%,white 45%)}.user-menu-trigger:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.user-avatar{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--brand);color:#04110a;border-radius:50%;font-weight:600;font-size:.75rem}.user-name{font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chevron{transition:transform .2s;opacity:.7}.chevron.open{transform:rotate(180deg)}.user-menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:240px;background:var(--card-bg);border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 40px #0000004d;z-index:100;animation:dropdownSlide .2s ease;overflow:hidden}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.user-menu-header{padding:1rem;background:#7bc8a40d}.user-info-name{font-weight:600;font-size:.9375rem;color:var(--text);margin-bottom:.25rem}.user-info-email{font-size:.8125rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-divider{height:1px;background:var(--border)}.user-menu-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:transparent;border:none;color:var(--text);font-family:inherit;font-size:.875rem;text-align:left;cursor:pointer;transition:all .15s}.user-menu-item:hover{background:var(--hover-bg)}.user-menu-item:focus-visible{outline:2px solid var(--brand);outline-offset:-2px}.user-menu-item svg{color:var(--text-muted);transition:color .15s}.user-menu-item:hover svg{color:var(--text)}.user-menu-item.logout{color:#ef4444}.user-menu-item.logout svg{color:#ef4444}.user-menu-item.logout:hover{background:#ef44441a}@media (max-width: 640px){.btn-text{display:none}.btn-icon-text{padding:.5rem}.user-name{display:none}.user-menu-trigger{padding:.375rem}.chevron{display:none}.user-menu-dropdown{right:-.5rem}}.language-switcher{display:flex;gap:.25rem;align-items:center;padding:.25rem;background:#ffffff1a;border-radius:.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lang-btn{padding:.375rem .75rem;font-size:.875rem;font-weight:500;color:#ffffffb3;background:transparent;border:none;border-radius:.375rem;cursor:pointer;transition:all .2s ease}.lang-btn:hover{color:#ffffffe6;background:#ffffff1a}.lang-btn.active{color:#fff;background:var(--brand, #6366f1);box-shadow:0 2px 4px #0000001a}.lang-btn:focus-visible{outline:2px solid var(--brand, #6366f1);outline-offset:2px}:root{--swiper-theme-color: #007aff}:host{position:relative;display:block;margin-left:auto;margin-right:auto;z-index:1}.swiper{margin-left:auto;margin-right:auto;position:relative;overflow:hidden;list-style:none;padding:0;z-index:1;display:block}.swiper-vertical>.swiper-wrapper{flex-direction:column}.swiper-wrapper{position:relative;width:100%;height:100%;z-index:1;display:flex;transition-property:transform;transition-timing-function:var(--swiper-wrapper-transition-timing-function, initial);box-sizing:content-box}.swiper-android .swiper-slide,.swiper-ios .swiper-slide,.swiper-wrapper{transform:translateZ(0)}.swiper-horizontal{touch-action:pan-y}.swiper-vertical{touch-action:pan-x}.swiper-slide{flex-shrink:0;width:100%;height:100%;position:relative;transition-property:transform;display:block}.swiper-slide-invisible-blank{visibility:hidden}.swiper-autoheight,.swiper-autoheight .swiper-slide{height:auto}.swiper-autoheight .swiper-wrapper{align-items:flex-start;transition-property:transform,height}.swiper-backface-hidden .swiper-slide{transform:translateZ(0);backface-visibility:hidden}.swiper-3d.swiper-css-mode .swiper-wrapper{perspective:1200px}.swiper-3d .swiper-wrapper{transform-style:preserve-3d}.swiper-3d{perspective:1200px}.swiper-3d .swiper-slide,.swiper-3d .swiper-cube-shadow{transform-style:preserve-3d}.swiper-css-mode>.swiper-wrapper{overflow:auto;scrollbar-width:none;-ms-overflow-style:none}.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar{display:none}.swiper-css-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:start start}.swiper-css-mode.swiper-horizontal>.swiper-wrapper{scroll-snap-type:x mandatory}.swiper-css-mode.swiper-vertical>.swiper-wrapper{scroll-snap-type:y mandatory}.swiper-css-mode.swiper-free-mode>.swiper-wrapper{scroll-snap-type:none}.swiper-css-mode.swiper-free-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:none}.swiper-css-mode.swiper-centered>.swiper-wrapper:before{content:"";flex-shrink:0;order:9999}.swiper-css-mode.swiper-centered>.swiper-wrapper>.swiper-slide{scroll-snap-align:center center;scroll-snap-stop:always}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child{margin-inline-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper:before{height:100%;min-height:1px;width:var(--swiper-centered-offset-after)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child{margin-block-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper:before{width:100%;min-width:1px;height:var(--swiper-centered-offset-after)}.swiper-3d .swiper-slide-shadow,.swiper-3d .swiper-slide-shadow-left,.swiper-3d .swiper-slide-shadow-right,.swiper-3d .swiper-slide-shadow-top,.swiper-3d .swiper-slide-shadow-bottom{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none;z-index:10}.swiper-3d .swiper-slide-shadow{background:#00000026}.swiper-3d .swiper-slide-shadow-left{background-image:linear-gradient(to left,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-right{background-image:linear-gradient(to right,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-top{background-image:linear-gradient(to top,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-bottom{background-image:linear-gradient(to bottom,#00000080,#0000)}.swiper-lazy-preloader{width:42px;height:42px;position:absolute;left:50%;top:50%;margin-left:-21px;margin-top:-21px;z-index:10;transform-origin:50%;box-sizing:border-box;border:4px solid var(--swiper-preloader-color, var(--swiper-theme-color));border-radius:50%;border-top-color:transparent}.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader{animation:swiper-preloader-spin 1s infinite linear}.swiper-lazy-preloader-white{--swiper-preloader-color: #fff}.swiper-lazy-preloader-black{--swiper-preloader-color: #000}@keyframes swiper-preloader-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--swiper-navigation-size: 44px}.swiper-button-prev,.swiper-button-next{position:absolute;width:var(--swiper-navigation-size);height:var(--swiper-navigation-size);z-index:10;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--swiper-navigation-color, var(--swiper-theme-color))}.swiper-button-prev.swiper-button-disabled,.swiper-button-next.swiper-button-disabled{opacity:.35;cursor:auto;pointer-events:none}.swiper-button-prev.swiper-button-hidden,.swiper-button-next.swiper-button-hidden{opacity:0;cursor:auto;pointer-events:none}.swiper-navigation-disabled .swiper-button-prev,.swiper-navigation-disabled .swiper-button-next{display:none!important}.swiper-button-prev svg,.swiper-button-next svg{width:100%;height:100%;object-fit:contain;transform-origin:center;fill:currentColor;pointer-events:none}.swiper-button-lock{display:none}.swiper-button-prev,.swiper-button-next{top:var(--swiper-navigation-top-offset, 50%);margin-top:calc(0px - (var(--swiper-navigation-size) / 2))}.swiper-button-prev{left:var(--swiper-navigation-sides-offset, 4px);right:auto}.swiper-button-prev .swiper-navigation-icon{transform:rotate(180deg)}.swiper-button-next{right:var(--swiper-navigation-sides-offset, 4px);left:auto}.swiper-horizontal .swiper-button-prev,.swiper-horizontal .swiper-button-next,.swiper-horizontal~.swiper-button-prev,.swiper-horizontal~.swiper-button-next{top:var(--swiper-navigation-top-offset, 50%);margin-top:calc(0px - (var(--swiper-navigation-size) / 2));margin-left:0}.swiper-horizontal .swiper-button-prev,.swiper-horizontal~.swiper-button-prev,.swiper-horizontal.swiper-rtl .swiper-button-next,.swiper-horizontal.swiper-rtl~.swiper-button-next{left:var(--swiper-navigation-sides-offset, 4px);right:auto}.swiper-horizontal .swiper-button-next,.swiper-horizontal~.swiper-button-next,.swiper-horizontal.swiper-rtl .swiper-button-prev,.swiper-horizontal.swiper-rtl~.swiper-button-prev{right:var(--swiper-navigation-sides-offset, 4px);left:auto}.swiper-horizontal .swiper-button-prev .swiper-navigation-icon,.swiper-horizontal~.swiper-button-prev .swiper-navigation-icon,.swiper-horizontal.swiper-rtl .swiper-button-next .swiper-navigation-icon,.swiper-horizontal.swiper-rtl~.swiper-button-next .swiper-navigation-icon{transform:rotate(180deg)}.swiper-horizontal.swiper-rtl .swiper-button-prev .swiper-navigation-icon,.swiper-horizontal.swiper-rtl~.swiper-button-prev .swiper-navigation-icon{transform:rotate(0)}.swiper-vertical .swiper-button-prev,.swiper-vertical .swiper-button-next,.swiper-vertical~.swiper-button-prev,.swiper-vertical~.swiper-button-next{left:var(--swiper-navigation-top-offset, 50%);right:auto;margin-left:calc(0px - (var(--swiper-navigation-size) / 2));margin-top:0}.swiper-vertical .swiper-button-prev,.swiper-vertical~.swiper-button-prev{top:var(--swiper-navigation-sides-offset, 4px);bottom:auto}.swiper-vertical .swiper-button-prev .swiper-navigation-icon,.swiper-vertical~.swiper-button-prev .swiper-navigation-icon{transform:rotate(-90deg)}.swiper-vertical .swiper-button-next,.swiper-vertical~.swiper-button-next{bottom:var(--swiper-navigation-sides-offset, 4px);top:auto}.swiper-vertical .swiper-button-next .swiper-navigation-icon,.swiper-vertical~.swiper-button-next .swiper-navigation-icon{transform:rotate(90deg)}.swiper-pagination{position:absolute;text-align:center;transition:.3s opacity;transform:translateZ(0);z-index:10}.swiper-pagination.swiper-pagination-hidden{opacity:0}.swiper-pagination-disabled>.swiper-pagination,.swiper-pagination.swiper-pagination-disabled{display:none!important}.swiper-pagination-fraction,.swiper-pagination-custom,.swiper-horizontal>.swiper-pagination-bullets,.swiper-pagination-bullets.swiper-pagination-horizontal{bottom:var(--swiper-pagination-bottom, 8px);top:var(--swiper-pagination-top, auto);left:0;width:100%}.swiper-pagination-bullets-dynamic{overflow:hidden;font-size:0}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transform:scale(.33);position:relative}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active,.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main{transform:scale(1)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev{transform:scale(.66)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev{transform:scale(.33)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next{transform:scale(.66)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next{transform:scale(.33)}.swiper-pagination-bullet{width:var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));height:var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));display:inline-block;border-radius:var(--swiper-pagination-bullet-border-radius, 50%);background:var(--swiper-pagination-bullet-inactive-color, #000);opacity:var(--swiper-pagination-bullet-inactive-opacity, .2)}button.swiper-pagination-bullet{border:none;margin:0;padding:0;box-shadow:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.swiper-pagination-clickable .swiper-pagination-bullet{cursor:pointer}.swiper-pagination-bullet:only-child{display:none!important}.swiper-pagination-bullet-active{opacity:var(--swiper-pagination-bullet-opacity, 1);background:var(--swiper-pagination-color, var(--swiper-theme-color))}.swiper-vertical>.swiper-pagination-bullets,.swiper-pagination-vertical.swiper-pagination-bullets{right:var(--swiper-pagination-right, 8px);left:var(--swiper-pagination-left, auto);top:50%;transform:translate3d(0,-50%,0)}.swiper-vertical>.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet{margin:var(--swiper-pagination-bullet-vertical-gap, 6px) 0;display:block}.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic{top:50%;transform:translateY(-50%);width:8px}.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{display:inline-block;transition:.2s transform,.2s top}.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet{margin:0 var(--swiper-pagination-bullet-horizontal-gap, 4px)}.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic{left:50%;transform:translate(-50%);white-space:nowrap}.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transition:.2s transform,.2s left}.swiper-horizontal.swiper-rtl>.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transition:.2s transform,.2s right}.swiper-pagination-fraction{color:var(--swiper-pagination-fraction-color, inherit)}.swiper-pagination-progressbar{background:var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, .25));position:absolute}.swiper-pagination-progressbar .swiper-pagination-progressbar-fill{background:var(--swiper-pagination-color, var(--swiper-theme-color));position:absolute;left:0;top:0;width:100%;height:100%;transform:scale(0);transform-origin:left top}.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill{transform-origin:right top}.swiper-horizontal>.swiper-pagination-progressbar,.swiper-pagination-progressbar.swiper-pagination-horizontal,.swiper-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite{width:100%;height:var(--swiper-pagination-progressbar-size, 4px);left:0;top:0}.swiper-vertical>.swiper-pagination-progressbar,.swiper-pagination-progressbar.swiper-pagination-vertical,.swiper-horizontal>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite{width:var(--swiper-pagination-progressbar-size, 4px);height:100%;left:0;top:0}.swiper-pagination-lock{display:none}:root{--bg-primary: #0a0e1a;--bg-secondary: #0f1420;--bg-tertiary: #1a1f2e;--text-primary: #ffffff;--text-secondary: #b4bcd0;--text-muted: #6b7280;--brand-primary: #6366f1;--brand-secondary: #8b5cf6;--brand-accent: #ec4899;--cyan: #06b6d4;--purple: #a855f7;--pink: #ec4899;--orange: #f97316;--glass-bg: rgba(255, 255, 255, .05);--glass-border: rgba(255, 255, 255, .1);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .1);--shadow-md: 0 4px 16px rgba(0, 0, 0, .15);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .2);--shadow-xl: 0 16px 64px rgba(0, 0, 0, .25);--glow-primary: 0 0 20px rgba(99, 102, 241, .3);--glow-secondary: 0 0 30px rgba(236, 72, 153, .3);--title-shadow-lg: 0 6px 24px rgba(0,0,0,.65), 0 2px 8px rgba(0,0,0,.7);--title-shadow-sm: 0 1px 2px rgba(0,0,0,.7)}.landing-page{background:var(--bg-primary);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;line-height:1.6;position:relative;overflow-x:hidden}.landing-page *{box-sizing:border-box}.landing-page a{color:inherit;text-decoration:none}.landing-page .container{width:min(1200px,92%);margin:0 auto;position:relative;z-index:1}.gradient-orb{position:fixed;border-radius:50%;filter:blur(100px);opacity:.15;pointer-events:none;z-index:0;animation:float 20s ease-in-out infinite}.orb-1{width:500px;height:500px;background:radial-gradient(circle,var(--brand-primary),transparent 70%);top:-250px;right:-250px;animation-delay:0s}.orb-2{width:400px;height:400px;background:radial-gradient(circle,var(--brand-accent),transparent 70%);bottom:-200px;left:-200px;animation-delay:-7s}.orb-3{width:600px;height:600px;background:radial-gradient(circle,var(--brand-secondary),transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-50px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}.landing-header{position:fixed;top:0;left:0;right:0;z-index:100;padding:1rem 0;transition:all .3s ease}.landing-header.scrolled{-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);background:#0a0e1acc;border-bottom:1px solid var(--glass-border);box-shadow:var(--shadow-md)}.landing-header .inner{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0}.landing-header .brand{display:flex;align-items:center;gap:.75rem;font-weight:700;font-size:1.25rem;transition:transform .2s ease}.landing-header .brand:hover{transform:scale(1.05)}.landing-header .brand-logo{width:40px;height:40px;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(99,102,241,.3))}.landing-header .brand-text{background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-header nav{display:flex;align-items:center;gap:2rem}.landing-header .nav-link{color:var(--text-secondary);font-weight:500;transition:all .2s ease;position:relative}.landing-header .nav-link:hover{color:var(--text-primary)}.landing-header .nav-link:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--brand-primary),var(--brand-accent));transform:scaleX(0);transition:transform .2s ease}.landing-header .nav-link:hover:after{transform:scaleX(1)}.landing-page .btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:12px;font-weight:600;font-size:.95rem;transition:all .3s ease;cursor:pointer;border:none;position:relative;overflow:hidden}.landing-page .btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(45deg,transparent,rgba(255,255,255,.1),transparent);transform:translate(-100%);transition:transform .6s ease}.landing-page .btn:hover:before{transform:translate(100%)}.landing-page .btn-primary{background:linear-gradient(135deg,var(--brand-primary),var(--brand-secondary));color:#fff;box-shadow:var(--shadow-md),var(--glow-primary)}.landing-page .btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--glow-primary)}.landing-page .btn-secondary{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-primary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.landing-page .btn-secondary:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-2px)}.landing-page .btn-hero{padding:1rem 2rem;font-size:1.1rem;background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));box-shadow:var(--shadow-lg),0 0 30px #ec489966}.landing-page .btn-hero:hover{transform:translateY(-3px) scale(1.02)}.landing-page .btn-outline{background:transparent;border:2px solid var(--glass-border);color:var(--text-primary)}.landing-page .btn-outline:hover{background:var(--glass-bg);border-color:var(--brand-primary);transform:translateY(-2px)}.landing-page .btn-large{padding:1.25rem 2.5rem;font-size:1.15rem;background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));box-shadow:var(--shadow-xl),var(--glow-secondary)}.landing-page .btn-ghost{background:transparent;color:var(--text-secondary);border:none}.landing-page .btn-ghost:hover{color:var(--text-primary);background:var(--glass-bg)}.landing-page .btn-icon{width:20px;height:20px}.landing-page .arrow-icon{width:16px;height:16px}.landing-page .hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding-top:80px}.landing-page .hero .bg{position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;background-size:cover;background-position:center;filter:brightness(.4) saturate(1.2);z-index:0}.landing-page .hero-gradient{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 120% 80% at 50% 0%,rgba(99,102,241,.15),transparent 50%),linear-gradient(180deg,#0a0e1a99,#0a0e1af2);z-index:1}.landing-page .hero-content{position:relative;z-index:2;text-align:center;padding:3rem 0}.landing-page .hero-text{transition:transform .1s ease-out}.landing-page .hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:50px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:.9rem;color:var(--text-secondary);margin-bottom:1.5rem;animation:fadeInUp .6s ease-out}.landing-page .badge-dot{width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,var(--cyan),var(--purple));animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.landing-page .hero-title{font-size:clamp(2.5rem,8vw,5rem);font-weight:800;line-height:1.1;margin:0 0 1.5rem;animation:fadeInUp .6s ease-out .2s both;color:#fff;text-shadow:var(--title-shadow-lg);letter-spacing:-.01em}.landing-page .gradient-text{background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent),var(--orange));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;background-size:200% auto;animation:gradientFlow 3s linear infinite;filter:drop-shadow(0 6px 18px rgba(0,0,0,.55)) drop-shadow(0 1px 2px rgba(0,0,0,.75))}@keyframes gradientFlow{0%{background-position:0% center}to{background-position:200% center}}.landing-page .hero-lead{font-size:clamp(1.1rem,2vw,1.35rem);color:var(--text-secondary);max-width:700px;margin:0 auto 2.5rem;line-height:1.7;animation:fadeInUp .6s ease-out .4s both}.landing-page .hero-cta{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap;margin-bottom:3rem;animation:fadeInUp .6s ease-out .6s both}.landing-page .hero-stats{display:flex;justify-content:center;gap:3rem;flex-wrap:wrap;margin-top:4rem;padding-top:3rem;border-top:1px solid var(--glass-border);animation:fadeInUp .6s ease-out .8s both}.landing-page .stat{text-align:center}.landing-page .stat-value{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,var(--text-primary),var(--brand-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.5rem}.landing-page .stat-label{font-size:.95rem;color:var(--text-secondary)}.landing-page .scroll-indicator{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);z-index:2;animation:bounce 2s ease-in-out infinite}.landing-page .scroll-mouse{width:24px;height:40px;border:2px solid var(--glass-border);border-radius:20px;position:relative}.landing-page .scroll-wheel{width:4px;height:8px;background:var(--brand-primary);border-radius:2px;position:absolute;top:8px;left:50%;transform:translate(-50%);animation:scrollWheel 1.5s ease-in-out infinite}@keyframes bounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-10px)}}@keyframes scrollWheel{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(16px)}}.fade-in-section{opacity:0;transform:translateY(30px);transition:opacity .6s ease-out,transform .6s ease-out}.fade-in-section.animate-in{opacity:1;transform:translateY(0)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.landing-page .section{padding:6rem 0;position:relative}.landing-page .section-header{text-align:center;margin-bottom:4rem;display:grid;justify-items:center}.landing-page .section-badge{display:inline-block;padding:.4rem 1rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:50px;font-size:.85rem;font-weight:600;color:var(--brand-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.landing-page .section-title{font-size:clamp(2rem,5vw,3rem);color:var(--text-primary);font-weight:800;margin:0 auto 1rem;line-height:1.2;max-width:960px;text-align:center;text-shadow:var(--title-shadow-lg);letter-spacing:-.01em}.landing-page .section-subtitle{font-size:clamp(1rem,2vw,1.2rem);color:var(--text-secondary);max-width:700px;margin:0 auto}.title-backplate{display:inline-block;padding:.35rem .9rem;border-radius:14px;background:linear-gradient(180deg,#0a0e1ab3,#0a0e1a59);border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.landing-page .features-section{background:linear-gradient(180deg,transparent,rgba(99,102,241,.03),transparent)}.landing-page .features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.landing-page .feature-card{padding:2rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;position:relative;overflow:hidden}.landing-page .feature-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));opacity:0;transition:opacity .3s ease}.landing-page .feature-card:hover{transform:translateY(-8px);border-color:var(--brand-primary);box-shadow:var(--shadow-lg),var(--glow-primary)}.landing-page .feature-card:hover:before{opacity:.05}.landing-page .feature-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));border-radius:12px;margin-bottom:1.5rem;box-shadow:var(--glow-primary);position:relative;z-index:1}.landing-page .feature-icon svg{width:24px;height:24px;stroke-width:2;color:#fff}.landing-page .feature-title{font-size:1.25rem;font-weight:700;margin:0 0 .75rem;position:relative;z-index:1;color:#fff;text-shadow:var(--title-shadow-sm)}.landing-page .feature-description{color:var(--text-secondary);line-height:1.6;margin:0;position:relative;z-index:1}.landing-page .parallax{position:relative;min-height:70vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:6rem 0}.landing-page .parallax__bg{position:absolute;top:-15%;right:-15%;bottom:-15%;left:-15%;background-size:cover;background-position:center;filter:brightness(.5) saturate(1.3);z-index:0}.landing-page .parallax-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 100% 100% at 50% 50%,#0a0e1a99,#0a0e1ae6);z-index:1}.landing-page .quote-card{position:relative;z-index:2;max-width:900px;padding:3rem;background:#ffffff08;border:1px solid var(--glass-border);border-radius:24px;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);box-shadow:var(--shadow-xl)}.landing-page .quote-icon{width:48px;height:48px;margin-bottom:1.5rem;color:var(--brand-primary);opacity:.3}.landing-page .quote-icon svg{width:100%;height:100%}.landing-page .quote-text{font-family:Playfair Display,Georgia,serif;font-size:clamp(1.5rem,3vw,2.2rem);line-height:1.5;margin:0 0 1.5rem;font-weight:600;font-style:italic}.landing-page .quote-author{display:flex;flex-direction:column;gap:.25rem;padding-top:1.5rem;border-top:1px solid var(--glass-border)}.landing-page .author-name{font-weight:600;color:var(--text-primary)}.landing-page .author-role{font-size:.9rem;color:var(--text-muted)}.landing-page .pricing-section{background:linear-gradient(180deg,transparent,rgba(139,92,246,.03),transparent)}.landing-page .pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;max-width:1100px;margin:0 auto}.landing-page .pricing-card{padding:2.5rem 2rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:24px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;display:flex;flex-direction:column;position:relative}.landing-page .pricing-card:hover{transform:translateY(-8px);border-color:var(--brand-primary);box-shadow:var(--shadow-lg)}.landing-page .pricing-featured{border-color:var(--brand-primary);background:linear-gradient(135deg,#6366f11a,#8b5cf61a);box-shadow:var(--glow-primary)}.landing-page .featured-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);padding:.4rem 1rem;background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));border-radius:50px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;box-shadow:var(--shadow-md)}.landing-page .pricing-header{margin-bottom:1.5rem}.landing-page .pricing-title{font-size:1.5rem;font-weight:700;margin:0 0 .5rem;color:#fff;text-shadow:var(--title-shadow-sm)}.landing-page .pricing-description{color:var(--text-secondary);margin:0}.landing-page .pricing-price{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--glass-border)}.landing-page .price-amount{font-size:3rem;font-weight:800;line-height:1}.landing-page .price-period{font-size:1rem;color:var(--text-secondary)}.landing-page .pricing-features{list-style:none;padding:0;margin:0 0 2rem;flex-grow:1}.landing-page .feature-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 0}.landing-page .check-icon{width:20px;height:20px;flex-shrink:0;stroke-width:2.5;color:var(--brand-primary)}.landing-page .cta-section{padding:8rem 0;background:radial-gradient(ellipse 120% 100% at 50% 50%,rgba(99,102,241,.1),transparent)}.landing-page .cta-card{padding:4rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:32px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow-xl);display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative;overflow:hidden}.landing-page .cta-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#6366f11a,#ec48991a);opacity:.5}.landing-page .cta-content{position:relative;z-index:1}.landing-page .cta-title{font-size:clamp(2rem,4vw,2.8rem);font-weight:800;margin:0 0 1rem;line-height:1.2}.landing-page .cta-description{font-size:1.1rem;color:var(--text-secondary);line-height:1.7;margin:0 0 2rem}.landing-page .cta-buttons{display:flex;gap:1rem;flex-wrap:wrap}.landing-page .cta-visual{position:relative;height:300px;z-index:1}.landing-page .floating-element{position:absolute;width:80px;height:80px;background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));border-radius:20px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg),var(--glow-primary);animation:float 6s ease-in-out infinite}.landing-page .floating-element svg{width:40px;height:40px;color:#fff;stroke-width:2}.landing-page .element-1{top:20%;left:10%;animation-delay:0s}.landing-page .element-2{top:50%;right:20%;animation-delay:-2s}.landing-page .element-3{bottom:20%;left:40%;animation-delay:-4s}.landing-page .landing-footer{padding:4rem 0 2rem;background:var(--bg-secondary);border-top:1px solid var(--glass-border)}.landing-page .footer-content{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}.landing-page .footer-brand{max-width:300px}.landing-page .footer-logo{width:48px;height:48px;object-fit:contain;margin-bottom:1rem;filter:drop-shadow(0 4px 8px rgba(99,102,241,.3))}.landing-page .footer-tagline{color:var(--text-secondary);line-height:1.6;margin:0}.landing-page .footer-title{font-size:.95rem;font-weight:700;margin:0 0 1rem;text-transform:uppercase;letter-spacing:.05em;color:#fff;text-shadow:var(--title-shadow-sm)}.landing-page .footer-list{list-style:none;padding:0;margin:0}.landing-page .footer-list li{margin-bottom:.75rem}.landing-page .footer-list a{color:var(--text-secondary);transition:color .2s ease}.landing-page .footer-list a:hover{color:var(--brand-primary)}.landing-page .footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:2rem;border-top:1px solid var(--glass-border)}.landing-page .copyright{color:var(--text-muted);margin:0}.landing-page .social-links{display:flex;gap:1rem}.landing-page .social-link{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:10px;color:var(--text-secondary);transition:all .2s ease}.landing-page .social-link:hover{background:var(--brand-primary);border-color:var(--brand-primary);color:#fff;transform:translateY(-2px);box-shadow:var(--glow-primary)}.landing-page .social-link svg{width:20px;height:20px}@media (max-width: 1024px){.landing-page .cta-card{grid-template-columns:1fr;gap:3rem}.landing-page .cta-visual{display:none}.landing-page .footer-content{grid-template-columns:1fr 1fr;gap:2rem}}@media (max-width: 768px){.landing-header nav{gap:1rem}.landing-header .nav-link{display:none}.landing-page .hero-stats{gap:2rem}.landing-page .features-grid,.landing-page .pricing-grid{grid-template-columns:1fr}.landing-page .section{padding:4rem 0}.landing-page .quote-card{padding:2rem}.landing-page .cta-card{padding:2.5rem 1.5rem}.landing-page .footer-content{grid-template-columns:1fr}.landing-page .footer-bottom{flex-direction:column;gap:1.5rem;text-align:center}}@media (max-width: 480px){.landing-page .hero-cta{flex-direction:column;width:100%}.landing-page .hero-cta .btn{width:100%}.landing-page .hero-stats{flex-direction:column;gap:1.5rem}}@media (prefers-reduced-motion: reduce){.landing-page *,.landing-page *:before,.landing-page *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.gradient-orb{display:none}}.landing-page .hero-title .gradient-text{filter:none;text-shadow:none}@supports (-webkit-text-stroke: .5px black){.landing-page .hero-title .gradient-text{-webkit-text-stroke:.2px rgba(0,0,0,.08)}}.support-wrap{max-width:1000px;margin:0 auto}.support-card{position:relative;display:grid;grid-template-columns:1.2fr 1fr;gap:2.5rem;padding:clamp(1.75rem,4vw,3rem);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:28px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-xl);overflow:hidden;grid-template-areas:"pill pill" "left right" "cta  right"}.support-card:before{content:"";position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;background:radial-gradient(60% 60% at 20% 20%,rgba(99,102,241,.15),transparent 60%),radial-gradient(50% 50% at 90% 80%,rgba(236,72,153,.12),transparent 60%);opacity:.9;z-index:0}.support-left{position:relative;z-index:1;grid-area:left}.support-title{margin:0 0 .4rem;font-size:clamp(1.6rem,3vw,2rem);font-weight:800}.support-subtitle{color:var(--text-secondary);margin:0 0 1rem}.thanks-pill{display:inline-block;margin-bottom:.75rem;padding:.35rem .7rem;font-size:.8rem;font-weight:700;border-radius:999px;background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));color:#fff;box-shadow:var(--glow-primary);grid-area:pill;justify-self:center;margin-bottom:.25rem}.support-visual{position:relative;display:grid;place-items:center;z-index:1;grid-area:right}.coffee-medallion{position:relative;width:clamp(140px,22vw,200px);height:clamp(140px,22vw,200px);border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.18),transparent 60%),linear-gradient(135deg,var(--brand-primary),var(--brand-accent));box-shadow:0 0 60px #6366f159,inset 0 0 40px #ffffff26;display:grid;place-items:center}.steam.s1{top:24%;animation-delay:0s}.steam.s2{top:20%;left:58%;animation-delay:.6s}.steam.s3{top:22%;left:42%;animation-delay:1.2s}.support-actions{display:flex;flex-direction:column;gap:.5rem;margin-top:.25rem;align-items:center}.support-actions .btn{margin-inline:auto}.support-note{font-size:.85rem;color:var(--text-muted);text-align:center}.support-cta{grid-area:cta;display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:.25rem}.support-cta .btn{margin-inline:auto}.support-cta .support-note{text-align:center}@media (max-width: 860px){.support-card{grid-template-columns:1fr;gap:1.75rem;grid-template-areas:"pill" "right" "left" "cta"}}@media (max-width: 480px){.support-cta .btn,.support-actions .btn{width:100%}}.support-centered{position:relative;max-width:820px;margin:0 auto;padding:clamp(2rem,5vw,3rem);text-align:center;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:28px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-xl);overflow:hidden}.support-centered:before{content:"";position:absolute;inset:-30% -10% auto -10%;height:70%;background:radial-gradient(55% 55% at 50% 20%,rgba(99,102,241,.18),transparent 60%),radial-gradient(45% 45% at 50% 80%,rgba(236,72,153,.14),transparent 60%);filter:blur(8px);opacity:.9;z-index:0}.support-hero{position:relative;z-index:1}.coffee-medallion.coffee-lg{margin:0 auto .75rem;width:clamp(140px,22vw,200px);height:clamp(140px,22vw,200px);border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.18),transparent 60%),linear-gradient(135deg,var(--brand-primary),var(--brand-accent));box-shadow:0 0 60px #6366f159,inset 0 0 40px #ffffff26;display:grid;place-items:center}.coffee-emoji{font-size:clamp(56px,8vw,80px);filter:drop-shadow(0 6px 16px rgba(0,0,0,.35))}.steam{position:absolute;width:8px;height:24px;background:radial-gradient(ellipse at center,#ffffffa6,#fff0);filter:blur(2px);border-radius:8px;left:50%;transform:translate(-50%);animation:rise 3s ease-in-out infinite;opacity:.6}.steam.s1{top:18%;animation-delay:0s}.steam.s2{top:14%;left:58%;animation-delay:.6s}.steam.s3{top:16%;left:42%;animation-delay:1.2s}@keyframes rise{0%{transform:translate(-50%) scale(.9);opacity:0}20%{opacity:.65}to{transform:translate(-50%,-28px) scale(1.1);opacity:0}}.thanks-pill{display:inline-block;margin:.4rem auto .6rem;padding:.35rem .7rem;font-size:.8rem;font-weight:700;border-radius:999px;background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));color:#fff;box-shadow:var(--glow-primary);position:relative;z-index:1}.support-heading{margin:.25rem 0;font-size:clamp(1.6rem,3vw,2rem);font-weight:800}.support-copy{color:var(--text-secondary);margin:0 auto 1.25rem;max-width:680px}.benefits-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem 1.25rem;max-width:600px;margin:0 auto 1.5rem;text-align:left}@media (max-width: 640px){.benefits-grid{grid-template-columns:1fr}}.support-cta-btn{display:inline-flex;min-width:320px;max-width:420px;justify-content:center;margin:.25rem auto 0}.support-note{display:block;margin-top:.4rem;font-size:.85rem;color:var(--text-muted)}.feature-item{display:flex;align-items:center;gap:.75rem;padding:.5rem 0}.features-showcase{display:flex;flex-direction:column;gap:1.5rem;margin-top:2.5rem}.feature-tabs-compact{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;padding:.75rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:12px}.feature-tab-compact{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.875rem 1.25rem;background:transparent;border:2px solid transparent;border-radius:10px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;min-width:90px}.feature-tab-compact:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:0;height:3px;background:linear-gradient(90deg,var(--brand-primary),var(--brand-accent));transition:width .3s ease;border-radius:3px 3px 0 0}.feature-tab-compact:hover{background:#ffffff0d;transform:translateY(-2px)}.feature-tab-compact.active{background:#6366f11f;border-color:#6366f14d}.feature-tab-compact.active:after{width:60%}.feature-tab-icon-wrap{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));border-radius:10px;transition:all .3s ease;box-shadow:0 2px 8px #6366f133}.feature-tab-compact:hover .feature-tab-icon-wrap{transform:scale(1.05);box-shadow:0 4px 16px #6366f14d}.feature-tab-compact.active .feature-tab-icon-wrap{transform:scale(1.1);box-shadow:0 6px 20px #6366f166}.feature-tab-icon-wrap svg{width:22px;height:22px;stroke-width:2.5;color:#fff}.feature-tab-name{font-size:.875rem;font-weight:600;color:var(--text-secondary);transition:color .2s ease;text-align:center}.feature-tab-compact.active .feature-tab-name{background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700}.features-showcase-3col{display:grid;grid-template-columns:200px 1fr 280px;gap:2rem;align-items:start}.feature-tabs-vertical{display:flex;flex-direction:column;gap:.75rem;position:sticky;top:100px}.feature-tab-vertical{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--glass-bg);border:2px solid transparent;border-left:3px solid transparent;border-radius:10px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;text-align:left}.feature-tab-vertical:hover{background:#ffffff14;transform:translate(4px);border-left-color:#6366f14d}.feature-tab-vertical.active{background:#6366f11f;border-color:#6366f14d;border-left-color:var(--brand-primary);box-shadow:0 4px 16px #6366f126}.feature-tab-vertical .feature-tab-icon-wrap{width:40px;height:40px;flex-shrink:0}.feature-tab-vertical.active .feature-tab-icon-wrap{transform:scale(1.05)}.feature-tab-vertical .feature-tab-name{font-size:.9375rem;text-align:left;white-space:nowrap}.feature-screenshot-center{display:flex;flex-direction:column}.feature-description-sidebar{padding:1.5rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:12px;position:sticky;top:100px}.feature-description-sidebar .feature-description-title{font-size:1.375rem;font-weight:700;margin:0 0 1rem;background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.feature-description-sidebar .feature-description-text{font-size:.9375rem;line-height:1.7;color:var(--text-secondary);margin:0}.features-showcase-unified{display:flex;flex-direction:column}.feature-unified-card{padding:2rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:20px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;gap:2rem}.feature-nav-pills{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.feature-pill{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:transparent;border:1px solid transparent;border-radius:20px;cursor:pointer;transition:all .2s ease}.feature-pill:hover{background:#ffffff0d;border-color:#ffffff1a}.feature-pill.active{background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));border-color:transparent;box-shadow:0 4px 12px #6366f14d}.feature-pill-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.feature-pill-icon svg{width:18px;height:18px;stroke-width:2.5;color:var(--text-secondary);transition:color .2s ease}.feature-pill.active .feature-pill-icon svg{color:#fff}.feature-pill-label{font-size:.875rem;font-weight:600;color:var(--text-secondary);transition:color .2s ease}.feature-pill.active .feature-pill-label{color:#fff}.feature-unified-card .feature-tabs-compact{background:transparent;border:none;padding:0;justify-content:center}.feature-unified-card .feature-content-row{display:grid;grid-template-columns:1fr 340px;gap:2.5rem;align-items:start}.feature-screenshot-unified{display:flex}.screenshot-mockup-unified{background:var(--bg-tertiary);border-radius:12px;overflow:hidden;box-shadow:0 8px 24px #0003;border:1px solid rgba(255,255,255,.05)}.feature-description-unified{padding:1.5rem 0;display:flex;flex-direction:column;gap:1rem}.feature-description-unified .feature-description-title{font-size:1.75rem;font-weight:700;margin:0;background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.3}.feature-description-unified .feature-description-text{font-size:1.0625rem;line-height:1.75;color:var(--text-secondary);margin:0}.feature-screenshot-full{display:flex;flex-direction:column;gap:1.5rem}.screenshot-mockup{background:var(--bg-tertiary);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-xl);border:1px solid var(--glass-border)}.mockup-header{display:flex;align-items:center;justify-content:space-between;padding:.625rem 1rem;background:#0f1420e6;border-bottom:1px solid var(--glass-border);gap:1rem}.mockup-controls{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.mockup-buttons{display:flex;gap:.5rem}.mockup-button{width:12px;height:12px;border-radius:50%}.mockup-button.red{background:#ff5f57}.mockup-button.yellow{background:#ffbd2e}.mockup-button.green{background:#28ca42}.mockup-title{font-size:.8125rem;color:var(--text-secondary);font-weight:500}.mockup-tabs{display:flex;gap:.5rem;align-items:center;flex:1;justify-content:flex-end;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none}.mockup-tabs::-webkit-scrollbar{display:none}.mockup-tab{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:#ffffff0d;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.mockup-tab:hover{background:#ffffff14;border-color:#ffffff1a}.mockup-tab.active{background:#6366f126;border-color:var(--brand-primary);box-shadow:0 0 12px #6366f126}.mockup-tab-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mockup-tab-icon svg{width:16px;height:16px;stroke-width:2.5;color:var(--text-secondary);transition:color .2s ease}.mockup-tab.active .mockup-tab-icon svg{color:var(--brand-primary)}.mockup-tab-label{font-size:.8125rem;font-weight:500;color:var(--text-secondary);transition:color .2s ease}.mockup-tab.active .mockup-tab-label{color:var(--brand-primary);font-weight:600}.mockup-content{position:relative;background:#0a0e1a;overflow:hidden}.screenshot-image{width:100%;height:auto;display:block;animation:fadeInScale .4s ease}@keyframes fadeInScale{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.feature-description-panel{padding:2rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:12px;text-align:center}.feature-description-title{font-size:1.5rem;font-weight:700;margin:0 0 1rem;background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.feature-description-text{font-size:1.0625rem;line-height:1.7;color:var(--text-secondary);max-width:800px;margin:0 auto}@media (max-width: 1200px){.features-showcase-3col{grid-template-columns:180px 1fr 260px;gap:1.5rem}.feature-description-sidebar{padding:1.25rem}.feature-description-sidebar .feature-description-title{font-size:1.25rem}.feature-description-sidebar .feature-description-text{font-size:.875rem}}@media (max-width: 1024px){.feature-unified-card{padding:1.5rem;gap:1.75rem}.feature-unified-card .feature-content-row{grid-template-columns:1fr;gap:2rem}.feature-description-unified{padding:1rem 0}.feature-description-unified .feature-description-title{font-size:1.5rem}.feature-description-unified .feature-description-text{font-size:1rem}.features-showcase-3col{grid-template-columns:1fr;gap:2rem}.feature-tabs-vertical{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:.625rem;position:relative;top:0}.feature-tab-vertical{flex-direction:column;gap:.5rem;padding:.75rem 1rem;min-width:90px}.feature-tab-vertical:hover{transform:translateY(-2px)}.feature-tab-vertical .feature-tab-name{text-align:center;font-size:.8125rem}.feature-description-sidebar{position:relative;top:0}.feature-content-row{grid-template-columns:1fr;gap:1.5rem}.feature-description-seamless{padding:1rem 0}.feature-nav-pills{gap:.625rem}.feature-pill{padding:.5rem .875rem}.feature-pill-icon svg{width:16px;height:16px}.feature-pill-label{font-size:.8125rem}.feature-tabs-compact{gap:.625rem;padding:.625rem}.feature-tab-compact{padding:.75rem 1rem;min-width:85px}.feature-tab-icon-wrap{width:40px;height:40px}.feature-tab-icon-wrap svg{width:20px;height:20px}.feature-tab-name{font-size:.8125rem}}@media (max-width: 768px){.feature-unified-card{padding:1.25rem;gap:1.5rem}.feature-unified-card .feature-content-row{gap:1.5rem}.feature-description-unified .feature-description-title{font-size:1.375rem}.feature-description-unified .feature-description-text{font-size:.9375rem}.features-showcase{gap:1.25rem;margin-top:2rem}.feature-nav-pills{gap:.5rem}.feature-pill{padding:.5rem .75rem}.feature-pill-icon{width:18px;height:18px}.feature-pill-icon svg{width:15px;height:15px}.feature-pill-label{font-size:.75rem}.feature-description-seamless .feature-description-title{font-size:1.25rem}.feature-description-seamless .feature-description-text{font-size:.9375rem}.feature-tabs-compact{gap:.5rem;padding:.5rem}.feature-tab-compact{padding:.625rem .875rem;min-width:80px}.feature-tab-icon-wrap{width:38px;height:38px}.feature-tab-icon-wrap svg{width:19px;height:19px}.feature-tab-name{font-size:.75rem}.feature-description-panel{padding:1.5rem}.feature-description-title{font-size:1.25rem}.feature-description-text{font-size:.9375rem}.mockup-header{padding:.5rem .75rem}.mockup-button{width:10px;height:10px}.mockup-title{font-size:.75rem}}@media (max-width: 480px){.feature-unified-card{padding:1rem;gap:1.25rem}.feature-unified-card .feature-content-row{gap:1.25rem}.feature-description-unified .feature-description-title{font-size:1.25rem}.feature-description-unified .feature-description-text{font-size:.875rem}.feature-nav-pills{gap:.375rem}.feature-pill{padding:.4rem .625rem}.feature-pill-icon{width:16px;height:16px}.feature-pill-icon svg{width:14px;height:14px}.feature-pill-label{font-size:.6875rem}.feature-description-seamless .feature-description-title{font-size:1.125rem}.feature-description-seamless .feature-description-text{font-size:.875rem}.feature-tabs-compact{gap:.375rem;padding:.5rem}.feature-tab-compact{padding:.5rem .75rem;min-width:70px}.feature-tab-icon-wrap{width:36px;height:36px}.feature-tab-icon-wrap svg{width:18px;height:18px}.feature-tab-name{font-size:.6875rem}.mockup-header{padding:.5rem .625rem}.mockup-title{font-size:.6875rem}.feature-description-panel{padding:1.25rem}.feature-description-title{font-size:1.125rem}.feature-description-text{font-size:.875rem}}.features-carousel-container{position:relative;padding:2rem 0}.features-carousel-container:before,.features-carousel-container:after{content:"";position:absolute;top:0;bottom:0;width:120px;z-index:10;pointer-events:none}.features-carousel-container:before{left:0;background:linear-gradient(to right,var(--bg-primary),transparent)}.features-carousel-container:after{right:0;background:linear-gradient(to left,var(--bg-primary),transparent)}.features-swiper{padding:2rem 1rem 4rem;overflow:hidden}.features-swiper .swiper-wrapper{align-items:center}.features-swiper .swiper-slide{opacity:.35;transform:scale(.88);filter:blur(2px);transition:all .5s cubic-bezier(.4,0,.2,1)}.features-swiper .swiper-slide-active{opacity:1;transform:scale(1);filter:blur(0)}.features-swiper .swiper-slide-prev,.features-swiper .swiper-slide-next{opacity:.5;transform:scale(.9);filter:blur(1px)}.feature-slide{padding:1rem}.feature-slide-content{display:grid;grid-template-columns:1.5fr 1fr;gap:2rem;align-items:center;padding:1.5rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:24px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-xl);transition:all .4s ease}.feature-slide-content:hover{border-color:#6366f14d;box-shadow:var(--shadow-xl),var(--glow-primary)}.feature-slide-screenshot{position:relative}.screenshot-mockup-carousel{background:var(--bg-tertiary);border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #0000004d;border:1px solid rgba(255,255,255,.05);transition:transform .4s ease,box-shadow .4s ease}.feature-slide-content:hover .screenshot-mockup-carousel{transform:translateY(-4px);box-shadow:0 12px 40px #0006}.feature-slide-info{display:flex;flex-direction:column;gap:1rem;padding:.5rem 0}.feature-slide-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));border-radius:14px;box-shadow:var(--glow-primary);transition:transform .3s ease}.feature-slide-content:hover .feature-slide-icon{transform:scale(1.05) rotate(3deg)}.feature-slide-icon svg{width:26px;height:26px;stroke-width:2;color:#fff}.feature-slide-title{font-size:1.5rem;font-weight:800;margin:0;background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}.feature-slide-description{font-size:.95rem;line-height:1.6;color:var(--text-secondary);margin:0}.features-swiper .swiper-button-prev,.features-swiper .swiper-button-next{width:48px;height:48px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:50%;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.features-swiper .swiper-button-prev:hover,.features-swiper .swiper-button-next:hover{background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));border-color:transparent;transform:scale(1.1);box-shadow:var(--glow-primary)}.features-swiper .swiper-button-prev:after,.features-swiper .swiper-button-next:after{font-size:18px;font-weight:700;color:var(--text-primary)}.features-swiper .swiper-button-prev:hover:after,.features-swiper .swiper-button-next:hover:after{color:#fff}.features-swiper .swiper-button-prev{left:0}.features-swiper .swiper-button-next{right:0}.features-swiper .swiper-pagination{bottom:0}.features-swiper .swiper-pagination-bullet{width:12px;height:12px;background:var(--glass-border);opacity:1;transition:all .3s ease}.features-swiper .swiper-pagination-bullet-active{background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));transform:scale(1.2);box-shadow:0 0 12px #6366f180}.carousel-status{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1.5rem;font-size:.8125rem;color:var(--text-muted);transition:all .3s ease}.carousel-status .status-dot{width:8px;height:8px;border-radius:50%;background:var(--brand-primary);animation:pulse-status 2s ease-in-out infinite}.carousel-status.paused .status-dot{background:var(--text-muted);animation:none}.carousel-status .status-text{font-weight:500}@keyframes pulse-status{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}@media (max-width: 1024px){.feature-slide-content{grid-template-columns:1fr;gap:2rem;padding:1.5rem}.feature-slide-info{text-align:center;align-items:center}.features-swiper{padding:1.5rem 2.5rem 3.5rem}.features-carousel-container:before,.features-carousel-container:after{width:80px}}@media (max-width: 768px){.features-swiper{padding:1rem 2rem 3rem}.feature-slide{padding:.5rem}.feature-slide-content{padding:1.25rem;gap:1.5rem}.feature-slide-icon{width:56px;height:56px}.feature-slide-icon svg{width:28px;height:28px}.feature-slide-title{font-size:1.5rem}.feature-slide-description{font-size:1rem}.features-swiper .swiper-button-prev,.features-swiper .swiper-button-next{width:40px;height:40px}.features-swiper .swiper-button-prev:after,.features-swiper .swiper-button-next:after{font-size:14px}}@media (max-width: 768px){.features-carousel-container:before,.features-carousel-container:after{width:60px}}@media (max-width: 480px){.features-swiper{padding:.5rem 1rem 2.5rem}.feature-slide-content{padding:1rem;gap:1.25rem;border-radius:16px}.feature-slide-icon{width:48px;height:48px}.feature-slide-icon svg{width:24px;height:24px}.feature-slide-title{font-size:1.25rem}.feature-slide-description{font-size:.875rem}.features-swiper .swiper-button-prev,.features-swiper .swiper-button-next{display:none}.features-swiper .swiper-pagination-bullet{width:10px;height:10px}.carousel-status{margin-top:1rem}.features-carousel-container:before,.features-carousel-container:after{width:40px}}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:2rem;animation:lightboxFadeIn .3s ease;cursor:zoom-out}@keyframes lightboxFadeIn{0%{opacity:0}to{opacity:1}}.lightbox-close{position:absolute;top:1.5rem;right:1.5rem;width:48px;height:48px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;z-index:1001}.lightbox-close:hover{background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));border-color:transparent;transform:scale(1.1)}.lightbox-close svg{width:24px;height:24px;color:var(--text-primary)}.lightbox-close:hover svg{color:#fff}.lightbox-content{max-width:95vw;max-height:90vh;animation:lightboxZoomIn .3s ease;cursor:default}@keyframes lightboxZoomIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.lightbox-image{max-width:100%;max-height:90vh;border-radius:12px;box-shadow:0 20px 60px #00000080}.feature-slide-screenshot{position:relative;cursor:zoom-in}.screenshot-zoom-hint{position:absolute;bottom:1rem;right:1rem;display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;font-size:.75rem;color:var(--text-secondary);opacity:0;transform:translateY(4px);transition:all .3s ease;pointer-events:none}.screenshot-zoom-hint svg{width:16px;height:16px}.feature-slide-screenshot:hover .screenshot-zoom-hint{opacity:1;transform:translateY(0)}@media (max-width: 768px){.lightbox-overlay{padding:1rem}.lightbox-close{top:1rem;right:1rem;width:40px;height:40px}.lightbox-close svg{width:20px;height:20px}.screenshot-zoom-hint{display:none}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--nav-bg);padding:2rem;position:relative;overflow:hidden}.login-bg{position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;background-size:cover;background-position:center;filter:brightness(.4) saturate(1.2);z-index:0}.login-gradient{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 120% 80% at 50% 0%,rgba(34,197,94,.15),transparent 50%),linear-gradient(180deg,#0b122099,#0b1220f2);z-index:1}.login-card{background:var(--card-bg);border-radius:12px;padding:3rem;width:100%;max-width:440px;box-shadow:0 20px 60px #0006;border:1px solid rgba(255,255,255,.1);position:relative;z-index:2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:auto;height:60px;max-width:200px;margin-bottom:1.5rem;object-fit:contain}.login-header h1{font-size:1.75rem;font-weight:800;margin-bottom:.5rem;color:var(--text)}.login-header p{color:var(--text-muted);font-size:.95rem}.login-form{margin-bottom:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text);font-size:.875rem}.form-group input{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:8px;font-size:1rem;transition:all .2s;background:var(--input-bg);color:var(--text)}.form-group input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #22c55e1a}.form-group small{display:block;margin-top:.375rem;color:var(--text-muted);font-size:.8125rem}.error-message{background:#ef44441a;color:var(--danger);padding:.75rem 1rem;border-radius:8px;border:1px solid rgba(239,68,68,.2);margin-bottom:1rem;font-size:.875rem;font-weight:500}.success-message{background:#22c55e1a;color:var(--brand);padding:.75rem 1rem;border-radius:8px;border:1px solid rgba(34,197,94,.2);margin-bottom:1rem;font-size:.875rem;font-weight:500}.spinner{width:40px;height:40px;border:4px solid rgba(34,197,94,.2);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite}.login-form button[type=submit]{width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:700;margin-top:.5rem}.login-footer{text-align:center;padding-top:1.5rem;border-top:1px solid var(--border)}.link-button{background:none;border:none;color:var(--text-muted);font-size:.9375rem;cursor:pointer;padding:.5rem;transition:color .2s;text-decoration:none;font-family:inherit}.link-button strong{color:var(--brand);font-weight:600}.login-back{text-align:center;margin-top:1.5rem}.login-back .link-button{color:var(--brand);font-weight:500}.login-back .link-button:hover{color:var(--brand-600)}@media (max-width: 640px){.login-container{padding:1rem}.login-card{padding:2rem 1.5rem}.login-logo{height:50px}.login-header h1{font-size:1.5rem}.login-header p{font-size:.875rem}}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172abf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-dialog{background:var(--panel-bg, #ffffff);border:1px solid var(--line, #e6eaf2);border-radius:var(--radius, 0px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:500px;width:90%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .2s ease-out}.modal-dialog-sm{max-width:420px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--line, #e6eaf2);flex-shrink:0}.modal-title{margin:0;font-size:1.125rem;font-weight:600;color:var(--text, #0f172a)}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-message{margin:0;font-size:.9375rem;line-height:1.6;color:var(--text, #0f172a)}.modal-input{width:100%;padding:.625rem .875rem;margin-top:1rem;font-size:.9375rem;border:1px solid var(--line, #e6eaf2);border-radius:var(--radius-sm, 0px);background:var(--panel-bg, #ffffff);color:var(--text, #0f172a);transition:all .2s}.modal-input:focus{outline:none;border-color:var(--brand, #22c55e);box-shadow:0 0 0 3px #22c55e1a}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--line, #e6eaf2);display:flex;gap:.75rem;justify-content:flex-end;flex-shrink:0}.btn{padding:.625rem 1.25rem;font-size:.9375rem;font-weight:500;border:none;border-radius:var(--radius-sm, 0px);cursor:pointer;transition:all .2s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand, #22c55e);color:#fff}.btn-primary:hover:not(:disabled){background:var(--brand-600, #16a34a);transform:translateY(-1px);box-shadow:0 4px 12px #22c55e4d}.btn-danger{background:var(--danger, #ef4444);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.btn-secondary{background:transparent;color:var(--muted, #64748b);border:1px solid var(--line, #e6eaf2)}.btn-secondary:hover:not(:disabled){background:var(--panel-subtle, #f3f6fb);color:var(--text, #0f172a)}@media (max-width: 640px){.modal-dialog{width:95%;max-width:none}.modal-header,.modal-body,.modal-footer{padding:1rem}.modal-footer{flex-direction:column-reverse}.btn{width:100%}}.modal-dialog-md{max-width:540px}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;margin-bottom:6px;color:var(--text);font-size:.95rem}.form-hint{margin:0 0 10px;font-size:.85rem;color:var(--muted);line-height:1.4}.file-upload-area{position:relative}.file-input{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden}.file-upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;border:2px dashed var(--line);background:var(--panel-bg);cursor:pointer;transition:all .2s ease;text-align:center;gap:8px}.file-upload-label:hover{border-color:var(--brand);background:color-mix(in oklab,var(--brand) 5%,var(--panel-bg) 95%)}.upload-icon{color:var(--muted);transition:color .2s ease}.file-upload-label:hover .upload-icon{color:var(--brand)}.upload-text{font-weight:600;color:var(--text);font-size:.95rem}.upload-subtext{font-size:.85rem;color:var(--muted)}.file-selected{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--panel-bg);border:1px solid var(--line);gap:12px}.file-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.file-icon{color:var(--brand);flex-shrink:0}.file-details{flex:1;min-width:0}.file-name{font-weight:600;color:var(--text);font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{font-size:.8rem;color:var(--muted);margin-top:2px}.btn-remove{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);background:transparent;color:var(--muted);cursor:pointer;transition:all .2s ease;padding:0}.btn-remove:hover{background:#fee2e2;border-color:#fca5a5;color:#b91c1c}.btn-remove svg{pointer-events:none}.settings-page{min-height:100vh;background:var(--bg);padding:2rem 1rem}.settings-container{max-width:800px;margin:0 auto}.settings-title{font-size:2rem;font-weight:800;color:var(--text);margin:0 0 2rem}.settings-section{margin-bottom:2rem}.section-title{font-size:1.25rem;font-weight:700;color:var(--text);margin:0 0 1rem;display:flex;align-items:center;gap:1rem}.save-indicator{font-size:.8125rem;font-weight:500;color:var(--brand);opacity:.8}.settings-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;overflow:hidden}.settings-item{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;transition:background .15s}.settings-item:hover{background:var(--hover-bg)}.settings-item-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#7bc8a41a;color:var(--brand);border-radius:10px;flex-shrink:0}.settings-item-content{flex:1;min-width:0}.settings-item-label{font-size:.8125rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.settings-item-value{font-size:1rem;color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-select{padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font-size:1rem;font-family:inherit;cursor:pointer;transition:border-color .15s;min-width:200px}.settings-select:hover{border-color:var(--brand)}.settings-select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #7bc8a41a}.settings-select:disabled{opacity:.5;cursor:not-allowed}.settings-divider{height:1px;background:var(--border);margin:0 1.5rem}.settings-info{padding:1.25rem 1.5rem}.settings-info p{margin:0;font-size:.9375rem;color:var(--text-muted)}.settings-info strong{color:var(--text);font-weight:600}.settings-note{padding:1rem 1.25rem;background:#7bc8a40d;border:1px solid rgba(123,200,164,.2);border-radius:8px;font-size:.875rem;color:var(--text-muted);line-height:1.5}@media (max-width: 640px){.settings-page{padding:1.5rem .75rem}.settings-title{font-size:1.5rem;margin-bottom:1.5rem}.settings-item{padding:1rem}.settings-item-icon{width:36px;height:36px}.settings-divider{margin:0 1rem}.settings-info{padding:1rem}}.text-context-menu{position:fixed;background:#fff;border:1px solid var(--line, #e2e8f0);box-shadow:0 8px 24px #00000026;border-radius:6px;z-index:10000;min-width:220px;overflow:hidden}.context-menu-header{padding:10px 12px;border-bottom:1px solid var(--line, #e2e8f0);background:var(--panel-bg, #f8fafc)}.selected-text-preview{font-size:.85rem;color:var(--muted, #64748b);font-style:italic;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.context-menu-items{padding:4px}.context-menu-item{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;background:transparent;border:none;text-align:left;cursor:pointer;transition:background .15s ease;color:var(--text);font-size:.9rem;border-radius:4px}.context-menu-item:hover{background:var(--panel-bg, #f1f5f9)}.context-menu-icon{font-size:18px;color:var(--brand, #3b82f6);flex-shrink:0}.text-context-menu{animation:contextMenuFadeIn .15s ease-out}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.scene-status-dropdown{display:block;position:relative}.scene-status-select{display:flex;align-items:center;justify-content:flex-start;gap:10px;margin:0;padding:8px 12px 8px 16px;border:1px solid var(--line);border-radius:0;font-weight:500;cursor:pointer;outline:none;min-width:120px;transition:background .2s ease;height:40px;box-sizing:border-box;font-size:14px;font-family:inherit;background:#fff;color:var(--text);-webkit-appearance:none;-moz-appearance:none;appearance:none}.scene-status-select:hover{background:#f8fafc}.scene-status-select:focus{outline:2px solid var(--brand);outline-offset:-2px}.status-dropdown-menu{position:absolute;top:100%;left:0;margin-top:4px;background:#fff;border:1px solid var(--line);box-shadow:0 4px 12px #0208171a;z-index:1000;max-height:300px;overflow-y:auto;overflow-x:visible;min-width:100%;width:max-content}.status-option{position:relative;padding:10px 12px 10px 16px;font-weight:500;font-size:14px;cursor:pointer;transition:background .2s ease;min-height:40px;display:flex;align-items:center;justify-content:flex-start;gap:10px;background:#fff;color:var(--text)}.status-icon{font-size:16px;flex-shrink:0}.status-option:hover{background:#f8fafc}.status-option.active{font-weight:700}.status-tooltip{position:absolute;right:100%;margin-right:12px;padding:12px 14px;background:#fff;color:var(--text);border:1px solid var(--line);border-radius:0;font-size:13px;line-height:1.4;width:max-content;max-width:320px;z-index:10001;box-shadow:0 2px 8px #0208171a;animation:fadeIn .2s ease;pointer-events:none}.status-tooltip strong{font-weight:700;color:var(--text)}@keyframes fadeIn{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}.epigram-block{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-left:4px solid #6c757d;border-radius:4px;padding:20px 24px;margin:24px 0;position:relative;font-family:Georgia,Times New Roman,serif;transition:all .2s ease}.epigram-block:hover{background:linear-gradient(135deg,#e9ecef,#dee2e6);box-shadow:0 2px 8px #0000001a}.epigram-block:before{content:"📜 Epigram";position:absolute;top:-10px;left:12px;background:#fff;padding:2px 10px;font-size:11px;color:#6c757d;font-style:normal;font-weight:600;border-radius:3px;box-shadow:0 1px 3px #0000001a;letter-spacing:.5px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.epigram-text{font-style:italic;color:#495057;line-height:1.7;font-size:.95em;white-space:pre-wrap;margin-bottom:12px}.epigram-source{text-align:right;color:#6c757d;font-size:.85em;font-style:normal;margin-top:12px;font-weight:500}.epigram-preview{max-width:600px;margin:40px auto;padding:30px 50px;text-align:center;position:relative}.epigram-preview:before,.epigram-preview:after{content:'"';font-size:3em;color:#dee2e6;position:absolute;font-family:Georgia,serif}.epigram-preview:before{top:0;left:10px}.epigram-preview:after{bottom:-20px;right:10px}.epigram-preview .epigram-text{font-style:italic;color:#495057;font-size:1em;line-height:1.8;margin-bottom:16px;position:relative;z-index:1}.epigram-preview .epigram-source{text-align:right;font-size:.9em;color:#6c757d;font-style:normal;margin-top:16px;font-weight:500}@media print{.epigram-preview{page-break-inside:avoid;margin:30px auto;padding:20px 40px}.epigram-preview:before,.epigram-preview:after{color:#bbb}}.epigram-highlight-marker{background:#6c757d1a;border-left:3px solid rgba(108,117,125,.3);padding-left:4px;display:inline-block;min-width:100%}.epigram-highlight-overlay{z-index:1}.epigram-editor-wrapper{position:relative;flex:1 1 auto;min-height:0;display:flex;flex-direction:column}.epigram-editor-wrapper textarea{position:relative;z-index:2;flex:1 1 auto;min-height:0}@media (prefers-color-scheme: dark){.epigram-block{background:linear-gradient(135deg,#2d3748,#1a202c);border-left-color:#4a5568}.epigram-block:before{background:#1a202c;color:#a0aec0}.epigram-text{color:#e2e8f0}.epigram-source{color:#a0aec0}.epigram-highlight-marker{background:#a0aec026;border-left-color:#a0aec04d}}.dynamic-fields-tab{padding:20px;display:flex;flex-direction:column;gap:24px}.fields-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;max-width:100%}@media (min-width: 1200px){.fields-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 768px) and (max-width: 1199px){.fields-grid{grid-template-columns:repeat(2,1fr)}}.dynamic-field{display:flex;flex-direction:column;gap:8px}.dynamic-field-label{display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:600;color:var(--text)}.field-icon{font-size:16px;color:var(--brand, #3b82f6);flex-shrink:0}.dynamic-field-input-wrapper{position:relative;display:flex;align-items:start;gap:8px}.dynamic-field-input-wrapper .input,.dynamic-field-input-wrapper .textarea{flex:1}.remove-field-btn{flex-shrink:0;width:32px;height:38px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line, #e2e8f0);background:transparent;color:var(--muted, #64748b);cursor:pointer;transition:all .2s ease;border-radius:0;padding:0}.remove-field-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#b91c1c}.remove-field-btn svg{font-size:20px}.add-field-section{position:relative;margin-top:8px}.add-field-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:var(--panel-bg, #f8fafc);border:1px dashed var(--line, #cbd5e1);color:var(--text);cursor:pointer;transition:all .2s ease;font-weight:500;font-size:.95rem}.add-field-btn:hover{background:var(--brand, #3b82f6);border-color:var(--brand, #3b82f6);color:#fff}.add-icon{font-size:20px}.add-field-menu{position:absolute;top:calc(100% + 8px);left:0;background:#fff;border:1px solid var(--line, #e2e8f0);box-shadow:0 8px 24px #0000001f;z-index:100;min-width:350px;max-width:500px;max-height:400px;display:flex;flex-direction:column;border-radius:4px}.add-field-menu-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--line, #e2e8f0);font-weight:600;font-size:.95rem;color:var(--text)}.close-menu-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--muted, #64748b);cursor:pointer;transition:color .2s ease;padding:0}.close-menu-btn:hover{color:var(--text)}.close-menu-btn svg{font-size:24px}.add-field-menu-list{overflow-y:auto;padding:8px}.add-field-menu-item{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;background:transparent;border:none;text-align:left;cursor:pointer;transition:background .2s ease;color:var(--text);font-size:.9rem;border-radius:4px}.add-field-menu-item:hover{background:var(--panel-bg, #f8fafc)}.menu-item-icon{font-size:18px;color:var(--brand, #3b82f6);flex-shrink:0}@media (max-width: 768px){.fields-grid{grid-template-columns:1fr}.add-field-menu{min-width:300px;max-width:calc(100vw - 32px)}}.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.map-page .side{overflow-y:auto}.map-page .panel-title{font-size:14px;font-weight:600;margin-bottom:12px;color:#333}.map-page .form-group{margin-bottom:12px}.map-page .label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:#555}.map-page .hint{display:block;margin-top:4px;font-size:12px;color:#888;font-style:italic}.map-page .error-message{padding:8px;background:#fee;border:1px solid #fcc;border-radius:4px;color:#c33;font-size:12px}.biome-legend{display:flex;flex-direction:column;gap:8px}.biome-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#555}.biome-color{width:20px;height:20px;border-radius:3px;border:1px solid #ddd;flex-shrink:0}.biome-label{flex:1}.map-canvas-container{height:100%;display:flex;align-items:stretch;justify-content:stretch;background:#e8e8e8;overflow:hidden;padding:0}.map-placeholder{text-align:center;color:#888;padding:2rem;margin:auto}.map-placeholder p{margin:10px 0;font-size:15px}.spinner{width:40px;height:40px;margin:0 auto 20px;border:4px solid #f0f0f0;border-top-color:#4a90e2;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.map-canvas{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;background:#e8e8e8;overflow:hidden;-webkit-user-select:none;user-select:none}.map-controls{position:absolute;top:16px;right:16px;display:flex;flex-direction:column;gap:4px;z-index:10;background:#fff;border-radius:6px;box-shadow:0 2px 8px #00000026;padding:4px}.map-controls button{width:36px;height:36px;border:none;background:#fff;color:#333;font-size:20px;font-weight:600;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background .2s}.map-controls button:hover{background:#f0f0f0}.map-controls button:active{background:#e0e0e0}.map-controls .zoom-level{font-size:11px;color:#666;text-align:center;padding:4px 0;font-weight:500}.fantasy-map{min-width:100%;min-height:100%;width:auto;height:auto;display:block;transform-origin:center center}@media (max-width: 768px){.biome-legend{flex-direction:row;flex-wrap:wrap}.biome-item{width:calc(50% - 4px)}}.book-reader{display:flex;height:calc(100dvh - var(--header-h) - var(--topnav-h));background:#2d2d2d;overflow:hidden}.book-sidebar{width:320px;height:100%;background:#1a1a1a;color:#e5e5e5;display:flex;flex-direction:column;border-right:1px solid #3a3a3a;overflow:hidden}.book-sidebar-header{padding:1.5rem;border-bottom:1px solid #3a3a3a;flex-shrink:0}.book-sidebar-header h2{font-size:1.25rem;font-weight:700;color:#fff;margin-bottom:.25rem}.book-meta{font-size:.875rem;color:#999}.chapters-nav{flex:1;padding:1rem 0;overflow-y:auto;overflow-x:hidden;min-height:0}.chapters-nav h3{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#999;padding:0 1.5rem;margin-bottom:.75rem}.chapters-list{list-style:none;margin:0;padding:0}.chapter-item{margin:0}.chapter-link{width:100%;display:flex;align-items:center;gap:.75rem;padding:.625rem 1.5rem;background:transparent;border:none;color:#e5e5e5;text-align:left;cursor:pointer;transition:all .2s;border-left:3px solid transparent}.chapter-link:hover{background:#2a2a2a;border-left-color:#06c}.chapter-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#333;color:#999;border-radius:50%;font-size:.875rem;font-weight:600;flex-shrink:0}.chapter-link:hover .chapter-number{background:#06c;color:#fff}.chapter-title-text{flex:1;font-size:.9375rem;line-height:1.4}.export-actions{padding:1rem 1.5rem;border-top:1px solid #3a3a3a;flex-shrink:0}.btn-export{width:100%;padding:.625rem 1rem;background:#06c;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-export:hover{background:#0052a3;transform:translateY(-1px);box-shadow:0 4px 12px #06c6}.book-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#f5f5f5}.zoom-controls-sidebar{padding:1rem 1.5rem;border-bottom:1px solid #3a3a3a;margin-bottom:1rem}.zoom-controls-sidebar h3{font-size:.875rem;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem}.zoom-controls-flex{display:flex;gap:.5rem;align-items:center}.zoom-btn-sidebar{width:36px;height:36px;border:1px solid #3a3a3a;background:#2a2a2a;color:#e5e5e5;font-size:18px;font-weight:600;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.zoom-btn-sidebar:hover{background:#3a3a3a;border-color:#4a4a4a}.zoom-btn-sidebar:active{background:#1a1a1a;transform:scale(.95)}.zoom-level-sidebar{flex:1;font-size:14px;color:#e5e5e5;font-weight:500;text-align:center;min-width:50px}.preview-stage{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:0;overflow-y:scroll;overflow-x:hidden;background:linear-gradient(135deg,#e8e8e8,#f5f5f5);position:relative}.preview-stage::-webkit-scrollbar{width:0;height:0;display:none}.preview-stage{scrollbar-width:none;-ms-overflow-style:none}.preview-container{width:100%;max-width:1400px;padding:3rem 2rem;box-sizing:border-box;background:transparent}.preview-frame{width:100%;height:20000px;border:none;background:transparent;display:block}.preview-frame::-webkit-scrollbar{display:none}.book-viewport{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;overflow:auto}.book-page{width:148mm;height:210mm;background:#fff;box-shadow:0 8px 32px #00000080;position:relative;border-radius:2px}.page-content{width:100%;height:100%;padding:2.2cm;box-sizing:border-box;overflow:hidden;font-family:Crimson Text,Libre Baskerville,Georgia,Times New Roman,serif;font-size:12pt;line-height:1.5;color:#2d2d2d}.chapter-page{display:flex;align-items:center;justify-content:center}.chapter-header{text-align:center}.chapter-ornament{font-size:2rem;color:#999;margin-bottom:2rem}.chapter-title-display{font-size:2rem;font-weight:700;color:#000;line-height:1.3}.text-page{position:relative}.page-text{height:calc(100% - 2rem);overflow:hidden;text-align:justify;hyphens:auto;-webkit-hyphens:auto;-moz-hyphens:auto}.page-text p{margin-bottom:0;text-indent:1.2em}.page-text p.no-indent{text-indent:0}.scene-divider{text-align:center;margin:1.5rem 0;color:#999;font-size:1rem;letter-spacing:.5em}.scene-title{font-size:1.1rem;font-weight:600;color:#333;margin:1.5rem 0 1rem;text-align:center}.page-number{position:absolute;bottom:1.5cm;left:0;right:0;text-align:center;font-size:10pt;color:#999}.book-controls{display:flex;align-items:center;justify-content:center;gap:2rem;padding:1.5rem;background:#1a1a1a;border-top:1px solid #3a3a3a}.btn-nav{padding:.75rem 1.5rem;background:#333;color:#e5e5e5;border:none;border-radius:6px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-nav:hover:not(:disabled){background:#444;transform:translateY(-1px)}.btn-nav:disabled{opacity:.3;cursor:not-allowed}.page-indicator{font-size:.9375rem;color:#999;font-weight:500;min-width:160px;text-align:center}@media (max-width: 1200px){.book-page{width:120mm;height:170mm}.page-content{font-size:11pt;padding:1.5cm}}@media (max-width: 768px){.book-reader{flex-direction:column}.book-sidebar{width:100%;max-height:30vh}.book-page{width:100mm;height:140mm}.page-content{font-size:10pt;padding:1cm}}.notfound-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--nav-bg);padding:2rem;position:relative;overflow:hidden}.notfound-bg{position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;background-size:cover;background-position:center;filter:brightness(.4) saturate(1.2);z-index:0}.notfound-gradient{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 120% 80% at 50% 0%,rgba(34,197,94,.15),transparent 50%),linear-gradient(180deg,#0b122099,#0b1220f2);z-index:1}.notfound-card{background:var(--card-bg);border-radius:12px;padding:3rem;width:100%;max-width:500px;box-shadow:0 20px 60px #0006;border:1px solid rgba(255,255,255,.1);position:relative;z-index:2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.notfound-header{text-align:center;margin-bottom:2rem}.notfound-logo{width:auto;height:50px;max-width:180px;margin-bottom:1rem;object-fit:contain;opacity:.9}.notfound-error-code{font-size:6rem;font-weight:900;color:var(--brand);line-height:1;margin-bottom:1rem;text-shadow:0 0 40px rgba(34,197,94,.3);letter-spacing:-.05em}.notfound-header h1{font-size:1.75rem;font-weight:800;margin-bottom:.75rem;color:var(--text)}.notfound-header p{color:var(--text-muted);font-size:1rem;line-height:1.6}.notfound-actions{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.notfound-actions .btn{width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:700;text-align:center;text-decoration:none}.notfound-actions .link-button{text-align:center;padding:.5rem;font-size:.9375rem}.notfound-suggestions{padding-top:2rem;border-top:1px solid var(--border)}.suggestions-title{font-weight:600;color:var(--text);margin-bottom:1rem;font-size:.9375rem}.notfound-suggestions ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.notfound-suggestions li{color:var(--text-muted);font-size:.875rem;padding-left:1.5rem;position:relative}.notfound-suggestions li:before{content:"→";position:absolute;left:0;color:var(--brand);font-weight:700}.link-button{background:none;border:none;color:var(--text-muted);cursor:pointer;transition:color .2s;text-decoration:none;font-family:inherit}.link-button:hover{color:var(--brand)}@media (max-width: 640px){.notfound-container{padding:1rem}.notfound-card{padding:2rem 1.5rem}.notfound-logo{height:40px}.notfound-error-code{font-size:4.5rem}.notfound-header h1{font-size:1.5rem}.notfound-header p{font-size:.9375rem}}:root{--header-h: 56px;--radius: 0px;--radius-sm: 0px;--radius-lg: 0px;--brand: #22c55e;--brand-600: #16a34a;--nav-bg: #0b1220;--nav-text: #e7edf7;--nav-muted: #9aa6c1;--line-dark: color-mix(in oklab, var(--nav-bg) 20%, white 80%);--page-bg: #f8fafc;--panel-bg: #ffffff;--panel-subtle: #f3f6fb;--line: #e6eaf2;--shadow-1: 0 1px 2px rgba(16, 24, 40, .06), 0 4px 12px rgba(16, 24, 40, .06);--text: #0f172a;--muted: #64748b;--text-muted: #64748b;--danger:#ef4444;--bg: #f8fafc;--card-bg: #ffffff;--border: #e6eaf2;--hover-bg: #f1f5f9;--input-bg: #ffffff}*{box-sizing:border-box}html,body{height:100%}body{margin:0;background:var(--page-bg);color:var(--text);font-family:system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif}input,textarea{width:100%;background:var(--panel-bg);color:var(--text);border:1px solid var(--line);border-radius:0;padding:10px 12px;outline:none}input::placeholder,textarea::placeholder{color:var(--muted)}.btn{display:inline-flex;align-items:center;justify-content:center;background:#fff;color:var(--text);border:1px solid var(--line);border-radius:0;padding:.5rem .7rem;cursor:pointer;box-shadow:var(--shadow-1);transition:background .18s ease,border-color .18s ease,transform .05s}.btn:hover{background:#f1f5f9}.btn:active{transform:translateY(1px)}.btn.small{padding:.35rem .55rem;font-size:.9rem}.btn.ghost{background:transparent;box-shadow:none}.btn.primary{background:var(--brand);border-color:transparent;color:#052e12;box-shadow:none}.btn.primary:hover{background:var(--brand-600);color:#eafff1}.btn-cta{height:36px;padding:0 .9rem;border:1px solid #c9efd9;background:#f3fbf7;color:#0b6b3e;font-weight:700;border-radius:0;box-shadow:0 1px #10b98114;transition:background .18s ease,border-color .18s ease,transform .02s ease}.btn-cta:hover{background:#e8f8f0;border-color:#a9e5c4}.btn-cta:active{transform:translateY(1px)}.btn-cta .icon{margin-right:.35rem}.grid-2{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));gap:12px 20px}.form-field label{display:block;margin-bottom:6px;color:var(--muted);font-size:12px;font-weight:500}.form-field .input,.form-field .textarea{width:100%}.form-wrap{display:grid;gap:14px}.tabs.tabs--panel{display:flex;align-items:center;gap:1.2rem;padding:0;border-bottom:1px solid var(--border);margin:0 0 .75rem}.tabs--panel .tab{position:relative;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;padding:.35rem .1rem;font-weight:600;color:var(--muted);cursor:pointer}.tabs--panel .tab:hover{color:var(--text)}.tabs--panel .tab:after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;background:var(--brand, var(--acc, #22c55e));transform:scaleX(0);transform-origin:left;transition:transform .45s ease}.tabs--panel .tab.active{color:var(--text)}.tabs--panel .tab.active:after{transform:scaleX(1)}.tabs--panel .tabs-spacer{flex:1 1 auto}.tabs--panel .saved-indicator{font-size:12px;color:var(--muted)}.page-wrap{height:calc(100dvh - var(--header-h));display:grid;grid-template-columns:minmax(220px,1fr) minmax(500px,3fr) minmax(220px,1fr);gap:0;padding:0;background:var(--page-bg);overflow:hidden}.page-wrap:has(.tools-panel.closed){grid-template-columns:minmax(220px,1fr) minmax(500px,3fr) 48px}.side{position:relative;z-index:2;background:var(--panel-bg);border:none;border-right:1px solid var(--line);border-radius:0;padding:.9rem;box-shadow:none;overflow:auto}.main{position:relative;z-index:1;display:flex;flex-direction:column;gap:1rem;min-width:0;min-height:0;overflow:auto}.panel{background:var(--panel-bg);border:none;border-radius:0;padding:.9rem;box-shadow:none;height:100%;display:flex;flex-direction:column}.tree{display:flex;flex-direction:column;gap:.5rem}.tree-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:.4rem;margin-bottom:.4rem;border-bottom:1px solid var(--line)}.tree-title{font-weight:800;font-size:1rem}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid transparent;border-radius:0;background:transparent;color:var(--text);cursor:pointer;transition:background .16s ease,border-color .16s ease,color .16s ease}.icon-btn:hover{background:#f1f5f9;border-color:#e2e8f0}.icon-btn.danger{color:#b91c1c}.icon-btn.danger:hover{background:#fee2e2;border-color:#fca5a5}.icon-btn.caret{width:24px;height:24px;margin-right:.25rem}.tree-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.35rem}.tree-scenes{list-style:none;padding-left:22px;margin:.35rem 0 .25rem;display:flex;flex-direction:column;gap:.25rem}.tree-empty{color:var(--muted);font-size:.9rem;padding:.15rem 0 .35rem}.tree-row{display:flex;align-items:center;gap:.5rem;border:1px solid var(--line);background:var(--panel-bg);cursor:pointer;padding:.35rem .45rem}.scene-row{padding-left:.65rem}.scene-status-icon{font-size:14px;flex-shrink:0;margin-right:4px}.tree-row:hover{background:#f8fafc}.chapter-row{font-weight:700}.scene-row{font-weight:600}.tree-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-actions{display:flex;align-items:center;gap:.25rem}.tree-chapter.active>.chapter-row{border-color:var(--brand)}.tree-scene.active>.scene-row{border-color:var(--brand)}.scene-title{flex:1;height:40px;border:1px solid var(--line);background:#fff;color:var(--text);padding:8px 10px;box-sizing:border-box;font-weight:700;transform:translateY(-4px)}.scene-editor{flex:1 1 auto;min-height:0;width:100%;resize:none;border:1px solid var(--line);background:#fbfbf8;color:#111827;padding:18px 22px 22px;box-sizing:border-box;font-family:Georgia,Times New Roman,serif;font-size:16px;line-height:1.7;letter-spacing:.01em}.empty-state{height:100%;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.6rem;padding-top:clamp(8vh,14%,22vh);color:var(--muted)}.empty-title{font-weight:800;font-size:1.1rem;letter-spacing:.2px;color:var(--text)}.empty-sub{font-size:.95rem}.chapter-overview{display:flex;flex-direction:column;gap:14px;height:100%;min-height:0}.chapter-head{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center}.chapter-title-input{height:40px;border:1px solid var(--line);background:#fff;color:var(--text);padding:8px 10px;font-weight:800}.chapter-meta{color:var(--muted);font-size:12px;white-space:nowrap}.scene-grid{display:grid;grid-auto-flow:row;grid-template-columns:repeat(auto-fill,340px);justify-content:start;gap:18px}.scene-card{position:relative;display:flex;flex-direction:column;gap:.5rem;text-align:left;width:340px;height:190px;background:#fff;border:1px solid var(--line);border-radius:0;padding:16px 14px 18px;cursor:pointer;box-shadow:var(--shadow-1);transition:transform .06s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease,color .18s ease}.scene-card:hover{transform:translateY(-1px);box-shadow:0 3px 12px #0208170f,0 1px 2px #02081714;border-color:#dbe4ee}.scene-card-delete{position:absolute;top:6px;right:6px;opacity:.92}.scene-card-delete .icon-btn{width:26px;height:26px;box-shadow:none}.scene-card-delete .icon-btn:hover{background:#fee2e2;border-color:#fecaca}.scene-card-title{font-weight:800;font-size:1rem;color:var(--text);flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;padding-right:28px}.scene-card-preview{color:var(--muted);font-size:.95rem;line-height:1.45;flex:1 1 auto;overflow:hidden;text-overflow:ellipsis}.scene-card.add-card{align-items:center;justify-content:center;color:var(--brand);background:#f7fffa;border:2px dashed color-mix(in oklab,var(--brand) 35%,#86efac 65%)}.scene-card.add-card:hover{background:#effcf3;border-color:color-mix(in oklab,var(--brand) 55%,#86efac 45%)}.overview-empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center;gap:.6rem;padding-top:clamp(10vh,18%,26vh);color:var(--muted)}.overview-empty .empty-title{font-weight:800;font-size:1.1rem;color:var(--text)}.overview-empty .empty-sub{font-size:.95rem}.tools-panel{position:relative;z-index:2;background:#fff;border:none;border-left:1px solid var(--line);border-radius:0;padding:0;box-shadow:none;display:flex;flex-direction:column;overflow:hidden}.tools-panel.closed{width:60px;min-width:60px}.tools-header{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1rem;border-bottom:1px solid var(--line);min-height:48px}.tools-title{font-weight:800;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tools-toggle{margin-left:auto}.tools-content{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1.5rem}.tools-collapsed-view{display:flex;flex-direction:column;align-items:center;padding:1rem 0;height:100%}.tools-collapsed-toggle{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1rem .5rem;background:transparent;border:none;cursor:pointer;color:var(--text);transition:background .2s ease,color .2s ease;border-radius:0}.tools-collapsed-toggle:hover{background:#f8fafc;color:var(--brand)}.tools-icon{font-size:20px;flex-shrink:0}.tools-badges{display:flex;flex-direction:column;align-items:center;gap:.4rem}.tool-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:20px;padding:0 .4rem;border-radius:10px;font-size:11px;font-weight:700;color:#fff;line-height:1}.notes-badge{background:#3b82f6}.tasks-badge{background:#10b981}.tool-section{display:flex;flex-direction:column;gap:.75rem}.tool-section-title{font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin:0}.btn-analyze-entities{width:100%;padding:.65rem 1rem;background:var(--brand);color:#fff;border:none;border-radius:0;font-weight:600;font-size:.9rem;cursor:pointer;transition:background .2s ease,transform .1s ease}.btn-analyze-entities:hover{background:var(--brand-dark, #2563eb);transform:translateY(-1px)}.btn-analyze-entities:active{transform:translateY(0)}.notes-panel,.tasks-panel{margin-bottom:1rem}.panel-head{display:flex;align-items:center;gap:.35rem;padding:.4rem 0;border-bottom:1px solid var(--line);cursor:pointer;-webkit-user-select:none;user-select:none}.panel-title{flex:1;font-weight:700;font-size:.85rem;letter-spacing:.3px}.panel-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:18px;padding:0 .4rem;border-radius:9px;font-size:11px;font-weight:700;color:#fff;line-height:1;margin-right:.25rem}.panel-count.notes-count{background:#3b82f6}.panel-count.tasks-count{background:#10b981}.panel-content{margin-top:.5rem}.panel-empty{padding:.75rem 0;text-align:center;color:var(--muted);font-size:.85rem}.notes-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.3rem}.note-item{list-style:none}.note-row{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;background:#fff;border:1px solid var(--line);cursor:pointer;transition:background .12s ease,border-color .12s ease}.note-row:hover{background:#f8fafc;border-color:#cbd5e1}.note-info{flex:1;min-width:0;display:flex;align-items:baseline;gap:.5rem}.note-title{font-weight:600;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex-shrink:1}.note-preview{font-size:.8rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.note-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .15s}.note-row:hover .note-actions{opacity:1}.note-edit{display:flex;flex-direction:column;gap:.5rem;padding:.5rem;background:#fff;border:1px solid var(--line)}.note-title-edit{width:100%;padding:.35rem .5rem;border:1px solid var(--line);background:#fff!important;color:var(--text);font-weight:600;font-size:.85rem}.note-title-edit:focus{outline:none;border-color:var(--brand);background:#fff!important}.note-content-edit{width:100%;padding:.35rem .5rem;border:1px solid var(--line);background:#fff!important;color:var(--text);font-family:inherit;font-size:.8rem;line-height:1.5;resize:vertical;min-height:80px}.note-content-edit:focus{outline:none;border-color:var(--brand);background:#fff!important}.note-edit-actions{display:flex;gap:.4rem;justify-content:flex-end}.task-new{display:flex;gap:.35rem;margin-bottom:.75rem}.task-new-input{flex:1;padding:.3rem .5rem;border:1px solid var(--line);background:#fff;color:var(--text);font-size:.8rem}.task-new-input:focus{outline:none;border-color:var(--brand)}.tasks-section{margin-bottom:.75rem}.tasks-section-header{display:flex;align-items:center;gap:.35rem;padding:.3rem 0;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.8rem;font-weight:600;color:var(--muted);transition:color .12s ease}.tasks-section-header:hover{color:var(--text)}.tasks-list{display:flex;flex-direction:column;gap:.3rem}.task-item{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;background:#fff;border:1px solid var(--line);transition:background .12s ease,border-color .12s ease}.task-item:hover{background:#f8fafc;border-color:#cbd5e1}.task-item.completed{opacity:.6}.task-checkbox{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center}.checkbox-box{width:16px;height:16px;border:2px solid var(--line);display:flex;align-items:center;justify-content:center;transition:all .12s ease}.task-checkbox:hover .checkbox-box{border-color:var(--brand)}.checkbox-box.checked{background:var(--brand);border-color:var(--brand);color:#fff}.task-title{flex:1;font-size:.8rem;line-height:1.3;cursor:pointer}.task-item.completed .task-title{text-decoration:line-through;color:var(--muted)}.task-edit-input{flex:1;padding:.2rem .4rem;border:1px solid var(--brand);background:#fff;color:var(--text);font-size:.8rem}.task-edit-input:focus{outline:none}.task-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .15s}.task-item:hover .task-actions{opacity:1}:root{--header-h: 56px}.site-header{position:sticky;top:0;z-index:50;height:var(--header-h);display:flex;align-items:center;justify-content:space-between;gap:.75rem;background:var(--nav-bg)!important;background-image:none!important;border-bottom:0!important;box-shadow:none!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;padding-inline:.9rem;padding-block:0}.brand{display:flex;align-items:center;gap:.55rem;font-weight:800;color:var(--nav-text);text-decoration:none}.brand:focus-visible{outline:2px solid var(--brand);outline-offset:3px}.brand-icon{display:inline-flex;align-items:center;justify-content:center}.brand-icon.natural{width:auto;height:auto;padding:0;background:transparent;border:0;box-shadow:none;overflow:visible}.brand-icon.natural .brand-logo{display:block;width:auto;height:auto;max-height:calc(var(--header-h) - 18px);object-fit:contain;border-radius:0}.brand-name{letter-spacing:.3px;font-size:15px;color:var(--nav-text)}.header-actions{display:flex;align-items:center;gap:.45rem}.site-header .btn{color:var(--nav-text);border-color:color-mix(in oklab,var(--nav-bg) 70%,white 30%);background:transparent}.site-header .btn:hover{background:#ffffff0f;border-color:color-mix(in oklab,var(--nav-bg) 55%,white 45%)}.site-header .btn.primary{background:var(--brand);color:#04110a;border-color:transparent}.site-header .btn.primary:hover{background:var(--brand-600);color:#eafff1}.header-nav{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex:1;height:100%}.header-tab{position:relative;display:inline-flex;align-items:center;gap:6px;height:100%;padding:8px 2px;color:#ffffffb3;text-decoration:none;font-size:14px;font-weight:500;border:0;background:transparent;transition:color .2s ease}.header-tab svg{width:16px;height:16px}.header-tab:hover{color:#fff}.header-tab:after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--brand);transform:scaleX(0);transform-origin:50% 50%;transition:transform .5s cubic-bezier(.4,0,.2,1)}.header-tab:hover:after,.header-tab:focus-visible:after{transform:scaleX(1)}.header-tab.active{color:#fff}.header-tab.active:after{transform:scaleX(1)}@media (prefers-reduced-motion: reduce){.header-tab:after{transition-duration:0ms}}:root{--topnav-h: 52px;--tab-indicator-h: 3px}.tabs{position:relative;z-index:1;height:var(--topnav-h);display:flex;align-items:center;padding-inline:1rem;padding-block:0;color:var(--text);border:0!important;border-radius:0!important;box-shadow:none!important;margin-top:0;border-bottom:1px solid var(--line);overflow-x:visible}.tabs-center{display:flex;justify-content:center;align-items:center;gap:1.6rem;flex:1}.tabs .settings-btn{position:absolute;right:1rem;top:50%;transform:translateY(-50%);width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--muted);cursor:pointer;border-radius:6px;transition:all .2s ease;padding:0}.tabs .settings-btn:hover{background:var(--panel-bg, #f8fafc);color:var(--text)}.tabs .settings-btn svg{font-size:20px}.tabs .tab{position:relative;display:inline-flex;align-items:center;height:100%;padding:8px 2px;color:var(--muted);text-decoration:none;border:0!important;background:transparent!important;border-radius:0!important;transition:color .2s ease}.tabs .tab:hover{color:var(--text)}.tabs .tab:after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--brand);transform:scaleX(0);transform-origin:50% 50%;transition:transform .5s cubic-bezier(.4,0,.2,1)}.tabs .tab:hover:after,.tabs .tab:focus-visible:after{transform:scaleX(1)}.tabs .tab.active{color:var(--text)}.tabs .tab.active:after{transform:scaleX(1)}@media (prefers-reduced-motion: reduce){.tabs .tab:after{transition-duration:0ms}}.dash-wrap{padding:32px 16px;max-width:1800px;margin:0 auto}.dash-loading{opacity:.7;margin-top:12px;text-align:center}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:20px;justify-content:center;max-width:1400px;margin:0 auto}@media (min-width: 1400px){.project-grid{grid-template-columns:repeat(3,1fr)}}.project-card{display:flex;background:var(--panel-bg);border:1px solid var(--line);box-shadow:var(--shadow-1);border-radius:0;overflow:hidden;transition:transform .12s ease,box-shadow .12s ease}.project-card:hover{transform:translateY(-2px)}.project-card-add{cursor:pointer;border:2px dashed var(--line);background:transparent;display:flex;align-items:center;justify-content:center;min-height:240px;transition:all .2s ease}.project-card-add:hover{border-color:var(--brand);background:color-mix(in oklab,var(--brand) 5%,transparent 95%);transform:translateY(-2px)}.add-card-content{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--muted);transition:color .2s ease}.project-card-add:hover .add-card-content{color:var(--brand)}.add-icon{font-size:48px;opacity:.6}.add-text{font-size:1rem;font-weight:600}.project-cover{flex:0 0 160px;display:block}.cover-art{width:160px;aspect-ratio:2 / 3;background:radial-gradient(120% 60% at 100% 0%,rgba(34,197,94,.22),transparent 60%),linear-gradient(135deg,#dbeafe,#e9eafc 45%,#f8fafc);border-right:1px solid var(--line);display:flex;align-items:center;justify-content:center;position:relative}.cover-art:after{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border:2px solid rgba(0,0,0,.06);pointer-events:none}.cover-letter{font-weight:800;font-size:56px;line-height:1;color:#0f172a;opacity:.15}.project-body{flex:1 1 auto;display:flex;flex-direction:column;padding:16px;gap:12px;min-width:0}.project-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.project-title{margin:0;font-size:1.2rem;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.project-title a{color:var(--text);text-decoration:none}.project-title a:hover{text-decoration:underline}.project-description{margin:0;font-size:.95rem;line-height:1.6;color:var(--text);overflow:hidden;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;text-overflow:ellipsis;flex:1}.project-description.placeholder{color:var(--muted);font-style:italic;opacity:.7}.project-actions{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:6px;flex-wrap:wrap}.actions-left{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.actions-right{display:flex;align-items:center}.project-actions .btn{--h: 32px;height:var(--h);padding:0 8px;border-radius:0;font-size:.85rem;line-height:var(--h);display:inline-flex;align-items:center;gap:6px;border:1px solid transparent!important;background:transparent!important;color:var(--text);box-shadow:none!important;transition:background .16s ease,border-color .16s ease,color .16s ease;white-space:nowrap;flex-shrink:0}.project-actions .btn .icon{font-size:.95rem;line-height:1;flex-shrink:0}.project-actions .btn span{overflow:hidden;text-overflow:ellipsis}.project-actions .btn-quiet{color:var(--text)}.project-actions .btn-quiet:hover{background:#f1f5f9;border-color:#e2e8f0}.project-actions .btn-primary-quiet{color:var(--brand)}.project-actions .btn-primary-quiet:hover{background:color-mix(in oklab,var(--brand) 10%,#ffffff 90%);border-color:color-mix(in oklab,var(--brand) 35%,#e2e8f0 65%)}.project-actions .btn-danger-quiet{color:#b91c1c}.project-actions .btn-danger-quiet:hover{background:#fee2e2;border-color:#fca5a5}.project-menu-container{position:relative;flex-shrink:0}.project-menu-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:4px;color:var(--muted);cursor:pointer;transition:all .15s ease;font-size:18px}.project-menu-btn:hover{background:var(--panel-bg, #f1f5f9);border-color:var(--line, #e2e8f0);color:var(--text)}.project-dropdown-menu{position:absolute;top:calc(100% + 4px);right:0;background:#fff;border:1px solid var(--line, #e2e8f0);box-shadow:0 8px 24px #00000026;border-radius:6px;z-index:1000;min-width:180px;overflow:hidden;padding:4px;animation:dropdownFadeIn .15s ease-out}.dropdown-menu-item{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;background:transparent;border:none;text-align:left;cursor:pointer;transition:background .15s ease;color:var(--text);font-size:.9rem;border-radius:4px}.dropdown-menu-item:hover{background:var(--panel-bg, #f1f5f9)}.dropdown-menu-item.danger{color:#b91c1c}.dropdown-menu-item.danger:hover{background:#fee2e2}.dropdown-menu-item .icon{font-size:16px;flex-shrink:0}.dropdown-menu-separator{height:1px;background:var(--line, #e2e8f0);margin:4px 0}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 600px){.project-grid{grid-template-columns:1fr}.project-card{flex-direction:column}.project-cover,.cover-art{width:100%}.cover-art{border-right:0;border-bottom:1px solid var(--line)}.project-actions{flex-direction:column;align-items:stretch;gap:8px}.actions-left{justify-content:space-between}.actions-right{justify-content:flex-end}}.tabs.tabs-inline{display:flex;align-items:center;gap:16px;border-bottom:1px solid var(--border, #e7ecf2);margin-bottom:12px;height:48px}.tabs.tabs-inline .tab{position:relative;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:none;padding:8px 2px;font:inherit;color:var(--muted, #64748b);cursor:pointer;height:100%;display:inline-flex;align-items:center;transition:color .2s ease}.tabs.tabs-inline .tab:hover,.tabs.tabs-inline .tab.active{color:var(--text, #0f172a)}.tabs.tabs-inline .tab:after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--brand, #22c55e);transform:scaleX(0);transform-origin:50% 50%;transition:transform .5s cubic-bezier(.4,0,.2,1)}.tabs.tabs-inline .tab:hover:after,.tabs.tabs-inline .tab:focus-visible:after{transform:scaleX(1)}.tabs.tabs-inline .tab.active:after{transform:scaleX(1)}@media (prefers-reduced-motion: reduce){.tabs.tabs-inline .tab:after{transition-duration:0ms}}.tabs.tabs-inline .tabs-meta{margin-left:auto;font-size:12px;color:var(--muted, #8a94a6)}.form-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:12px 16px}.form-row{grid-column:span 6;display:grid;gap:6px}.form-field .input,.form-field .textarea{border:1px solid #e1e7ef;border-radius:8px;padding:8px 10px;background:#fbfdff;font:inherit}.form-field .input:focus,.form-field .textarea:focus{outline:none;border-color:#bcd7ff;background:#fff}.form-field .textarea{resize:vertical;min-height:84px}.small.muted{font-size:12px;color:#64748b}.characters-page{position:fixed;top:var(--header-h, 56px);left:0;right:0;bottom:0;overflow:hidden;display:grid;grid-template-columns:minmax(220px,1fr) minmax(500px,3fr) minmax(220px,1fr);gap:0;padding:0}.characters-page:has(.tools-panel.closed){grid-template-columns:minmax(220px,1fr) minmax(500px,3fr) 48px}.characters-page .tools-panel{height:100%;overflow:auto;border:none;border-left:1px solid var(--line);box-shadow:none}.characters-page .side{height:100%;overflow:auto;border:none;border-right:1px solid var(--line);box-shadow:none}.characters-page .main{height:100%;display:flex;flex-direction:column;overflow:hidden}.characters-page .main .panel{flex:1 1 auto;height:100%;min-height:0;overflow:auto;border:none;box-shadow:none}.characters-page .tabs.tabs-inline{position:sticky;top:0;z-index:1;background:var(--panel-bg, #fff)}
