:root{--color-primary: #6e4a7e;--color-primary-light: #8b6a9e;--color-primary-dark: #4a2d5c;--color-primary-bg: #f5f0f7;--color-bg: #fafafa;--color-surface: #ffffff;--color-text: #1a1a2e;--color-text-secondary: #6b7280;--color-border: #e5e7eb;--color-code-bg: #1a1b26;--color-code-text: #c0caf5;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "Fira Code", "Cascadia Code", "Consolas", "Courier New", monospace;--container-max: 1100px;--nav-height: 60px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:var(--nav-height)}body{font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.container{max-width:var(--container-max);margin:0 auto;padding:0 24px}.section-title{font-size:2rem;font-weight:700;text-align:center;margin-bottom:12px;color:var(--color-text)}.section-desc{text-align:center;color:var(--color-text-secondary);font-size:1.1rem;margin-bottom:40px}.navbar{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-height);background:#4a2d5ceb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.08);transition:background .3s ease}.navbar-inner{display:flex;align-items:center;justify-content:space-between;height:100%}.navbar-logo{display:flex;align-items:center;gap:8px;font-size:1.1rem;font-weight:600;color:#fff;text-decoration:none}.navbar-logo:hover{text-decoration:none;opacity:.9}.navbar-toggle{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:4px}.navbar-toggle span{display:block;width:22px;height:2px;background:#fff;border-radius:1px;transition:transform .2s ease}.navbar-links{display:flex;list-style:none;gap:32px;align-items:center}.navbar-links a{color:#ffffffd9;font-size:.95rem;font-weight:500;text-decoration:none;transition:color .2s ease}.navbar-links a:hover{color:#fff;text-decoration:none}.hero{position:relative;padding:140px 0 80px;background:linear-gradient(135deg,#6e4a7e,#3d2b5a 40%,#1a1b26);color:#fff;text-align:center;overflow:hidden}.hero-bg{position:absolute;top:0;left:0;right:0;bottom:0;z-index:0;overflow:hidden}.hero-bg canvas{width:100%;height:100%;display:block}.hero-inner{position:relative;z-index:1;max-width:800px;margin:0 auto}.hero-title{font-size:3.6rem;font-weight:700;margin-bottom:24px;letter-spacing:-.02em;line-height:1.1;position:relative}.hero-title-line{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}.hero-word{display:inline-block;opacity:0;transform:translateY(30px);animation:hero-word-enter .7s cubic-bezier(.16,1,.3,1) forwards;cursor:default;transition:filter .3s ease,text-shadow .3s ease}.hero-word--elixir{animation-delay:.1s;background:linear-gradient(135deg,#bb9af7,#7aa2f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-word--data{animation-delay:.3s;color:#fff}.hero-word--viewer{animation-delay:.5s;color:#fff}.hero-word:hover{filter:brightness(1.2);text-shadow:0 0 30px rgba(187,154,247,.5)}.hero-word--elixir:hover{filter:brightness(1.3) drop-shadow(0 0 20px rgba(187,154,247,.6))}@keyframes hero-word-enter{to{opacity:1;transform:translateY(0)}}.hero-title:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.06) 50%,transparent 100%);animation:hero-shimmer 4s ease-in-out infinite;pointer-events:none}@keyframes hero-shimmer{0%,to{left:-100%}50%{left:100%}}.hero-subtitle{font-size:1.2rem;line-height:1.7;color:#fffc;margin-bottom:32px;opacity:0;animation:hero-fade-up .8s ease forwards .7s}@keyframes hero-fade-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.hero-subtitle a{color:#bb9af7;text-decoration:underline;text-underline-offset:2px;transition:color .2s ease}.hero-subtitle a:hover{color:#fff}.hero-pills{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:40px;opacity:0;animation:hero-fade-up .8s ease forwards .9s}.hero-pills-row{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.pill{display:inline-block;padding:6px 16px;background:#ffffff0f;border:1px solid rgba(187,154,247,.25);border-radius:100px;font-size:.88rem;font-weight:500;color:#ffffffe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:all .3s ease}.pill:hover{background:#bb9af726;border-color:#bb9af780;transform:translateY(-1px)}.hero-cta{display:flex;justify-content:center;gap:16px;opacity:0;animation:hero-fade-up .8s ease forwards 1.1s}.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 28px;border-radius:8px;font-size:1rem;font-weight:600;text-decoration:none;transition:all .2s ease;cursor:pointer;border:2px solid transparent;font-family:var(--font-sans)}.btn:hover{text-decoration:none}.btn-primary{background:#fff;color:var(--color-primary-dark)}.btn-primary:hover{background:#ffffffe6;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.btn-outline{background:transparent;color:#fff;border-color:#fff6}.btn-outline:hover{background:#ffffff1a;border-color:#fff9}.btn-secondary{background:var(--color-primary);color:#fff;border-color:var(--color-primary);padding:10px 24px;font-size:.95rem}.btn-secondary:hover{background:var(--color-primary-light);border-color:var(--color-primary-light);transform:translateY(-1px);box-shadow:0 4px 12px #6e4a7e4d}.features{padding:80px 0;background:var(--color-bg)}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:16px}.feature-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:32px 24px;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.feature-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #6e4a7e14}.feature-icon{font-size:2rem;margin-bottom:16px}.feature-card h3{font-size:1.1rem;font-weight:600;margin-bottom:8px;color:var(--color-text)}.feature-card p{font-size:.95rem;color:var(--color-text-secondary);line-height:1.5}.demo{padding:80px 0;background:var(--color-primary-bg)}.demo-actions{display:flex;justify-content:center;margin-bottom:20px}.demo-header{border-radius:12px 12px 0 0}.demo-hint{font-size:.8rem;color:#565f89;font-weight:400;letter-spacing:0;text-transform:none}.demo-card{background:var(--color-code-bg);border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #6e4a7e26;border:1px solid rgba(110,74,126,.2)}.demo-viewer{height:460px}.install{padding:80px 0;background:var(--color-bg)}.tabs{display:flex;justify-content:center;gap:8px;margin-bottom:32px}.tab{padding:10px 24px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;font-family:var(--font-sans);font-size:.95rem;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease}.tab:hover{color:var(--color-primary);border-color:var(--color-primary-light)}.tab--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.tab--active:hover{color:#fff;background:var(--color-primary-light);border-color:var(--color-primary-light)}.tab-panel{display:none}.tab-panel--active{display:block}.code-block{background:var(--color-code-bg);border-radius:10px;overflow:hidden;margin-bottom:20px;border:1px solid #2a2b3d}.code-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:#24253a;border-bottom:1px solid #2a2b3d}.code-label{font-size:.82rem;font-weight:500;color:#7a7ea0;text-transform:uppercase;letter-spacing:.04em}.copy-btn{background:transparent;border:1px solid #3b4261;color:#a9b1d6;font-family:var(--font-sans);font-size:.82rem;padding:4px 12px;border-radius:4px;cursor:pointer;transition:all .2s ease}.copy-btn:hover{background:#292e42;border-color:#7aa2f7;color:#7aa2f7}.copy-btn--copied{background:#9ece6a26;border-color:#9ece6a;color:#9ece6a}.code-block pre{padding:16px 20px;overflow-x:auto;font-family:var(--font-mono);font-size:.88rem;line-height:1.65;color:var(--color-code-text)}.code-block code{font-family:inherit}.code-block pre::-webkit-scrollbar{height:6px}.code-block pre::-webkit-scrollbar-track{background:var(--color-code-bg)}.code-block pre::-webkit-scrollbar-thumb{background:#3b4261;border-radius:3px}.hl-keyword{color:#bb9af7}.hl-string{color:#9ece6a}.hl-fn{color:#7aa2f7}.hl-comment{color:#565f89;font-style:italic}.hl-tag{color:#f7768e}.hl-attr{color:#7dcfff}.footer{padding:40px 0;background:var(--color-primary-dark);color:#ffffffbf}.footer-inner{display:flex;flex-direction:column;align-items:center;gap:16px}.footer-links{display:flex;gap:24px;align-items:center}.footer-links a{display:inline-flex;align-items:center;gap:6px;color:#ffffffbf;font-size:.95rem;transition:color .2s ease}.footer-links a:hover{color:#fff;text-decoration:none}.footer-links svg{flex-shrink:0}.footer-copy{font-size:.88rem;color:#ffffff80}.footer-copy a{color:#ffffffb3}.footer-copy a:hover{color:#fff}.modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:200;align-items:center;justify-content:center;padding:24px}.modal-overlay--visible{display:flex;animation:modal-overlay-in .2s ease}@keyframes modal-overlay-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border-radius:16px;box-shadow:0 24px 64px #0000004d;max-width:960px;width:100%;max-height:88vh;display:flex;flex-direction:column;animation:modal-slide-in .3s cubic-bezier(.16,1,.3,1)}@keyframes modal-slide-in{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--color-border)}.modal-title{font-size:1.2rem;font-weight:600;color:var(--color-text)}.modal-close{background:none;border:none;font-size:1.2rem;color:var(--color-text-secondary);cursor:pointer;width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close:hover{background:var(--color-primary-bg);color:var(--color-text)}.modal-body{padding:20px 24px;flex:1;min-height:0;overflow:auto}.modal-textarea{width:100%;min-height:420px;background:var(--color-code-bg);color:var(--color-code-text);border:1px solid #3b4261;border-radius:8px;padding:16px;font-family:var(--font-mono);font-size:.9rem;line-height:1.6;resize:vertical;outline:none;transition:border-color .2s ease}.modal-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #6e4a7e26}.modal-textarea::placeholder{color:#565f89}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px 20px;border-top:1px solid var(--color-border)}.modal-footer .btn-secondary{background:transparent;color:var(--color-text-secondary);border-color:var(--color-border)}.modal-footer .btn-secondary:hover{background:var(--color-primary-bg);color:var(--color-text);border-color:var(--color-primary-light);box-shadow:none}.modal-footer .btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.modal-footer .btn-primary:hover{background:var(--color-primary-light);border-color:var(--color-primary-light);box-shadow:0 4px 12px #6e4a7e4d}@media (max-width: 1023px){.features-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 767px){.navbar-toggle{display:flex}.navbar-links{display:none;position:absolute;top:var(--nav-height);left:0;right:0;flex-direction:column;background:var(--color-primary-dark);padding:16px 24px;gap:16px;border-bottom:1px solid rgba(255,255,255,.1)}.navbar-links--open{display:flex}.hero{padding:120px 0 60px}.hero-title{font-size:2.4rem}.hero-title-line{gap:10px}.hero-subtitle{font-size:1.05rem}.hero-cta{flex-direction:column;align-items:center}.features-grid{grid-template-columns:1fr}.features,.demo{padding:60px 0}.demo-viewer{height:380px}.install{padding:60px 0}.tabs{flex-direction:column;align-items:stretch}.tab{text-align:center}.code-block pre{font-size:.82rem;padding:12px 14px}.section-title{font-size:1.6rem}.footer-links{flex-direction:column;gap:12px}.modal{max-height:90vh}.modal-textarea{min-height:200px}}.edv-container{position:relative;background:#1a1b26;color:#c0caf5;font-family:Cascadia Code,Fira Code,Consolas,Courier New,monospace;font-size:14px;line-height:20px;height:100%;overflow:hidden;display:flex;flex-direction:column;tab-size:2;-moz-tab-size:2}.edv-inner{flex:1;min-height:0;overflow:auto}.edv-scroll{min-width:fit-content;padding-bottom:20px}.edv-line{display:flex;min-height:20px}.edv-line:hover{background:#292e42;outline:1px dashed #3b4261}.edv-gutter{display:flex;align-items:center;flex-shrink:0;padding-right:8px;padding-left:4px;user-select:none;-webkit-user-select:none;gap:2px}.edv-line-number{color:#3b4261;text-align:right;min-width:2.5em;padding-right:4px;font-variant-numeric:tabular-nums}.edv-line:hover .edv-line-number{color:#737aa2}.edv-fold-indicator{width:16px;height:20px;display:inline-flex;align-items:center;justify-content:center;font-size:10px;color:transparent;flex-shrink:0}.edv-fold-indicator.edv-foldable{cursor:pointer;color:#565f89;opacity:0;transition:opacity .15s ease}.edv-line:hover .edv-fold-indicator.edv-foldable,.edv-fold-indicator.edv-foldable[data-folded=true]{opacity:1}.edv-code{flex:1;white-space:pre;padding-left:8px;min-height:20px;border-left:1px solid #292e42}.edv-word-wrap .edv-scroll{min-width:unset}.edv-word-wrap .edv-code{white-space:pre-wrap;word-break:break-all;overflow-wrap:anywhere}.edv-word-wrap .edv-line{align-items:flex-start}.edv-fold-ellipsis{display:inline-block;background:#292e42;color:#7aa2f7;padding:0 5px;margin:0 2px;border-radius:3px;font-size:11px;cursor:pointer;border:1px solid #3b4261;line-height:16px;vertical-align:middle;white-space:nowrap}.edv-fold-ellipsis:hover{background:#33394e;color:#7aa2f7;border-color:#7aa2f7}.tok-atom{color:#2ac3de}.tok-namespace{color:#7dcfff}.tok-bool{color:#ff9e64}.tok-null{color:#2ac3de}.tok-number{color:#ff9e64}.tok-character{color:#9ece6a}.tok-variableName{color:#c0caf5}.tok-function,.tok-definition{color:#7aa2f7}.tok-special{color:#f7768e}.tok-string{color:#9ece6a}.tok-escape,.tok-keyword{color:#bb9af7}.tok-operator{color:#89ddff}.tok-comment{color:#565f89;font-style:italic}.tok-inspect-literal{color:#bb9af7}.tok-underscore{color:#565f89;font-style:italic}.tok-punctuation{color:#a9b1d6}.tok-separator,.tok-angleBracket{color:#89ddff}.tok-attributeName{color:#7dcfff}.tok-docString{color:#e0af68}.edv-inner::-webkit-scrollbar{width:10px;height:10px}.edv-inner::-webkit-scrollbar-track{background:#1a1b26}.edv-inner::-webkit-scrollbar-thumb{background:#3b4261;border-radius:5px}.edv-inner::-webkit-scrollbar-thumb:hover{background:#565f89}.edv-inner::-webkit-scrollbar-corner{background:#1a1b26}.edv-toolbar{position:absolute;top:4px;right:14px;z-index:10;display:flex;gap:2px;background:#1a1b26;border:1px solid #3b4261;border-radius:4px;padding:2px;opacity:0;transition:opacity .2s ease;pointer-events:none}.edv-container:hover .edv-toolbar{opacity:1;pointer-events:auto}.edv-toolbar-btn{background:transparent;border:1px solid transparent;color:#a9b1d6;width:26px;height:24px;border-radius:3px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;font-family:inherit;padding:0;line-height:1}.edv-toolbar-btn:hover{background:#292e42;border-color:#565f89;color:#c0caf5}.edv-toolbar-btn.edv-toolbar-btn--active{background:#292e42;border-color:#7aa2f7;color:#7aa2f7}.edv-search-bar{flex-shrink:0;z-index:20;display:none;align-items:center;gap:6px;padding:4px 8px;background:#1a1b26;border-bottom:1px solid #3b4261;font-size:13px}.edv-search-bar--visible{display:flex}.edv-search-input-wrapper{display:flex;align-items:center;background:#1a1b26;border:1px solid #3b4261;border-radius:3px;overflow:hidden}.edv-search-input-wrapper:focus-within{border-color:#7aa2f7}.edv-search-input{background:transparent;border:none;outline:none;color:#c0caf5;font-family:inherit;font-size:13px;padding:3px 6px;width:180px}.edv-search-input::placeholder{color:#565f89}.edv-search-case-btn{background:transparent;border:1px solid transparent;color:#565f89;cursor:pointer;font-size:12px;font-family:inherit;padding:2px 6px;border-radius:2px;margin-right:2px;line-height:1}.edv-search-case-btn:hover{color:#c0caf5;background:#292e42;border-color:#565f89}.edv-search-case-btn--active{color:#7aa2f7;background:#292e42;border-color:#7aa2f7}.edv-search-case-btn--active:hover{border-color:#c0caf5}.edv-search-info{color:#c0caf5;font-size:12px;min-width:70px;text-align:center;white-space:nowrap}.edv-search-info--no-results{color:#f7768e}.edv-search-nav-btn{background:transparent;border:1px solid transparent;color:#a9b1d6;cursor:pointer;width:24px;height:24px;border-radius:3px;font-size:14px;display:flex;align-items:center;justify-content:center;font-family:inherit;padding:0;line-height:1}.edv-search-nav-btn:hover{background:#292e42;border-color:#565f89}.edv-search-match{background:#e0af6866;border-radius:2px;color:inherit}.edv-search-current{background:#e0af68cc;border-radius:2px;color:#1a1b26}.edv-line--has-match .edv-line-number{color:#e0af68}.edv-code [data-from]{cursor:pointer}.edv-inspect-token{background:#7aa2f733;border-radius:2px;outline:1px solid rgba(122,162,247,.4)}.edv-line.edv-inspect-line{background:#7aa2f70f}.edv-inspect-bracket{background:#7aa2f733;border-radius:2px;outline:1px solid rgba(122,162,247,.35)}@keyframes edv-inspect-flash{0%{background-color:#7aa2f773}to{background-color:#7aa2f733}}.edv-inspect-copied{animation:edv-inspect-flash .4s ease-out}.edv-copied-toast{position:fixed;background:#292e42;color:#7aa2f7;border:1px solid #7aa2f7;border-radius:4px;padding:2px 8px;font-size:12px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;pointer-events:none;z-index:100;animation:edv-toast-fade 1.2s ease-out forwards}@keyframes edv-toast-fade{0%{opacity:1;transform:translateY(0)}70%{opacity:1}to{opacity:0;transform:translateY(-10px)}}.edv-filter-bar{flex-shrink:0;z-index:20;display:none;align-items:center;gap:6px;padding:4px 8px;background:#1a1b26;border-bottom:1px solid #3b4261;font-size:13px;flex-wrap:wrap}.edv-filter-bar--visible{display:flex}.edv-filter-input-wrapper{position:relative;display:flex;align-items:center;background:#1a1b26;border:1px solid #3b4261;border-radius:3px;overflow:visible}.edv-filter-input-wrapper:focus-within{border-color:#7aa2f7}.edv-filter-input{background:transparent;border:none;outline:none;color:#c0caf5;font-family:inherit;font-size:13px;padding:3px 6px;width:140px}.edv-filter-input::placeholder{color:#565f89}.edv-filter-tags{display:flex;gap:4px;flex-wrap:wrap;align-items:center}.edv-filter-tag{display:inline-flex;align-items:center;gap:2px;background:#292e42;border:1px solid #3b4261;border-radius:3px;padding:1px 4px 1px 6px;font-size:12px;color:#7aa2f7;white-space:nowrap;line-height:18px}.edv-filter-tag-label{color:#7aa2f7}.edv-filter-tag-remove{background:transparent;border:none;color:#565f89;cursor:pointer;font-size:10px;padding:0 2px;line-height:1;display:flex;align-items:center;justify-content:center;border-radius:2px}.edv-filter-tag-remove:hover{color:#f7768e;background:#f7768e26}.edv-filter-info{color:#c0caf5;font-size:12px;white-space:nowrap;margin-left:auto}.edv-filter-dropdown{display:none;position:absolute;top:100%;left:-1px;right:-1px;background:#1a1b26;border:1px solid #3b4261;border-top:none;border-radius:0 0 3px 3px;max-height:160px;overflow-y:auto;z-index:30}.edv-filter-dropdown--visible{display:block}.edv-filter-dropdown-item{padding:4px 8px;cursor:pointer;font-size:13px;color:#c0caf5;white-space:nowrap}.edv-filter-dropdown-item:hover,.edv-filter-dropdown-item--active{background:#292e42;color:#7aa2f7}.edv-filter-dropdown::-webkit-scrollbar{width:6px}.edv-filter-dropdown::-webkit-scrollbar-track{background:#1a1b26}.edv-filter-dropdown::-webkit-scrollbar-thumb{background:#3b4261;border-radius:3px}
