﻿@import"https://fonts.googleapis.com/css2?family=Jost:ital,wght@0,100..900;1,100..900&display=swap";.markdown p{line-height:1.6em;margin-top:0;margin-bottom:1rem}.markdown h1{font-size:2.5rem;margin-top:2rem;margin-bottom:1rem;font-weight:bold}.markdown h1:first-child{margin-top:0}.markdown h2{font-size:2rem;margin-top:2rem;margin-bottom:1rem;font-weight:bold}.markdown h2:first-child{margin-top:0}.markdown h3{font-size:1.5rem;margin-top:2rem;margin-bottom:1rem;font-weight:bold}.markdown h3:first-child{margin-top:0}.markdown h4,.markdown h5,.markdown h6{font-size:1.25rem;margin-top:2rem;margin-bottom:1rem;font-weight:bold}.markdown h4:first-child,.markdown h5:first-child,.markdown h6:first-child{margin-top:0}.markdown code{padding:.2rem .4rem;border-radius:.1rem;color:var(--fg-code);background:var(--bg-code);font-size:.9rem}.markdown a{color:var(--fg-link);text-decoration:none}.markdown a:hover{text-decoration:underline}.markdown blockquote{padding-left:1rem;margin:1rem 0;border-left:2px solid var(--fg-link);font-style:italic}.markdown .codeblock{margin:1rem 0;display:flex;flex-direction:column;border:1px solid var(--border-color);border-radius:.25rem;overflow:hidden}.markdown .codeblock-header{display:flex;align-items:center;justify-content:flex-end;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.markdown .codeblock-header .badge{display:block;width:100%;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em;padding:.25rem .5rem;color:var(--foreground);text-align:right}.markdown pre{margin:0;padding:.75rem;overflow-x:auto;font-size:.8rem;line-height:1.5}.markdown pre code{padding:0;background:rgba(0,0,0,0);font-size:inherit}.markdown .codeblock-highlight{background:var(--bg-code-light)}.markdown table{border-collapse:collapse;width:100%;margin:1rem 0;border:1px solid var(--border-color)}.markdown th,.markdown td{padding:.75rem;text-align:left;border:1px solid var(--border-color)}.markdown th{background:var(--bg-secondary);font-weight:600}.markdown tr:nth-child(even){background:var(--bg-code-light)}@media(prefers-color-scheme: light){.app{--background: #FFFFFF;--foreground: #000000;--color-primary: #b8d939;--color-secondary: #999999;--fg-menu-selected: #FFFFFF;--bg-menu-selected: #2a2a2a;--color-header: #FFFFFF;--color-header-border: #E5E7EB;--color-title-dimmed: #999999;--color-title: #1a1a1a;--color-shadow: rgba(0, 0, 0, 0.08);--bg-code: #F5F5F5;--bg-code-light: #FAFAFA;--fg-code: #2a2a2a;--fg-page: #666666;--color-toc-hover: #b8d939;--color-toc-hover-bg: rgba(184, 217, 57, 0.1);--color-toc-completed: #999999;--color-toc-unread: #F5F5F5;--color-toc-chapter-fg: #4a4a4a;--color-toc-section-fg: #888888;--fg-link: #b8d939;--bg-progress: #E5E7EB;--fg-progress: #b8d939;--switch-fg: #000000;--switch-bg: #b8d939;--prompt-header-bg: #b8d939;--prompt-content-bg: #F5F5F5;--prompt-text: #000000;--prompt-content-text: #2a2a2a;--file-header-bg: #F5F5F5;--file-content-bg: #FAFAFA;--file-text: #666666;--shell-header-bg: #F5F5F5;--shell-content-bg: #FAFAFA;--border-color: #E5E7EB;--bg-secondary: #F5F5F5;--bg-badge: #2a2a2a;--fg-badge: #FFFFFF}}@media(prefers-color-scheme: dark){.app{--background: #0f0f0f;--foreground: #FFFFFF;--color-primary: #CEFF44;--color-secondary: #999999;--fg-menu-selected: #FFFFFF;--bg-menu-selected: #2a2a2a;--color-header: #000000;--color-header-border: #2a2a2a;--color-title-dimmed: #999999;--color-title: #FFFFFF;--color-shadow: rgba(0, 0, 0, 0.5);--bg-code: #1a1a1a;--bg-code-light: #0f0f0f;--fg-code: #FFFFFF;--fg-page: #999999;--color-toc-hover: #CEFF44;--color-toc-hover-bg: rgba(206, 255, 68, 0.1);--color-toc-completed: #999999;--color-toc-unread: #1a1a1a;--color-toc-chapter-fg: #CCCCCC;--color-toc-section-fg: #999999;--fg-link: #CEFF44;--bg-progress: #2a2a2a;--fg-progress: #CEFF44;--switch-fg: #FFFFFF;--switch-bg: #CEFF44;--prompt-header-bg: #b8d939;--prompt-content-bg: #1a1a1a;--prompt-text: #000000;--prompt-content-text: #FFFFFF;--file-header-bg: #1a1a1a;--file-content-bg: #0f0f0f;--file-text: #999999;--shell-header-bg: #1a1a1a;--shell-content-bg: #0f0f0f;--border-color: #2a2a2a;--bg-secondary: #1a1a1a;--bg-badge: #666666;--fg-badge: #FFFFFF}}.app.theme-light{--background: #FFFFFF;--foreground: #000000;--color-primary: #b8d939;--color-secondary: #999999;--fg-menu-selected: #FFFFFF;--bg-menu-selected: #2a2a2a;--color-header: #FFFFFF;--color-header-border: #E5E7EB;--color-title-dimmed: #999999;--color-title: #1a1a1a;--color-shadow: rgba(0, 0, 0, 0.08);--bg-code: #F5F5F5;--bg-code-light: #FAFAFA;--fg-code: #2a2a2a;--fg-page: #666666;--color-toc-hover: #b8d939;--color-toc-hover-bg: rgba(184, 217, 57, 0.1);--color-toc-completed: #999999;--color-toc-unread: #F5F5F5;--color-toc-chapter-fg: #4a4a4a;--color-toc-section-fg: #888888;--fg-link: #b8d939;--bg-progress: #E5E7EB;--fg-progress: #b8d939;--switch-fg: #000000;--switch-bg: #b8d939;--prompt-header-bg: #b8d939;--prompt-content-bg: #F5F5F5;--prompt-text: #000000;--prompt-content-text: #2a2a2a;--file-header-bg: #F5F5F5;--file-content-bg: #FAFAFA;--file-text: #666666;--shell-header-bg: #F5F5F5;--shell-content-bg: #FAFAFA;--border-color: #E5E7EB;--bg-secondary: #F5F5F5;--bg-badge: #2a2a2a;--fg-badge: #FFFFFF}.app.theme-dark{--background: #0f0f0f;--foreground: #FFFFFF;--color-primary: #CEFF44;--color-secondary: #999999;--fg-menu-selected: #FFFFFF;--bg-menu-selected: #2a2a2a;--color-header: #000000;--color-header-border: #2a2a2a;--color-title-dimmed: #999999;--color-title: #FFFFFF;--color-shadow: rgba(0, 0, 0, 0.5);--bg-code: #1a1a1a;--bg-code-light: #0f0f0f;--fg-code: #FFFFFF;--fg-page: #999999;--color-toc-hover: #CEFF44;--color-toc-hover-bg: rgba(206, 255, 68, 0.1);--color-toc-completed: #999999;--color-toc-unread: #1a1a1a;--color-toc-chapter-fg: #CCCCCC;--color-toc-section-fg: #999999;--fg-link: #CEFF44;--bg-progress: #2a2a2a;--fg-progress: #CEFF44;--switch-fg: #FFFFFF;--switch-bg: #CEFF44;--prompt-header-bg: #b8d939;--prompt-content-bg: #1a1a1a;--prompt-text: #000000;--prompt-content-text: #FFFFFF;--file-header-bg: #1a1a1a;--file-content-bg: #0f0f0f;--file-text: #999999;--shell-header-bg: #1a1a1a;--shell-content-bg: #0f0f0f;--border-color: #2a2a2a;--bg-secondary: #1a1a1a;--bg-badge: #666666;--fg-badge: #FFFFFF}.app .smooth{transition:color .3s ease,background-color .3s ease,border-color .3s ease}.menu-button,.header-menu-button{display:flex;flex-direction:row;justify-content:center;align-items:center;font-size:.9rem;font-weight:500;padding:0 1rem;color:var(--color-secondary);background:rgba(0,0,0,0);cursor:pointer;border:none;font-family:inherit;height:100%}.menu-button.selected,.selected.header-menu-button{background:var(--bg-menu-selected);color:var(--fg-menu-selected)}.menu-button:hover,.header-menu-button:hover{background:var(--bg-menu-selected);color:var(--fg-menu-selected)}.menu-button svg,.header-menu-button svg{width:16px;height:16px;margin-right:.5rem}.menu-button.footer-variant,.footer-variant.header-menu-button{height:32px;transition:all .2s ease}.menu-button.stack,.stack.header-menu-button{text-transform:capitalize}.app{height:100vh;background:var(--background);color:var(--foreground);display:flex;flex-direction:column;overflow:hidden}.app-header{flex-shrink:0;background:var(--color-header);border-bottom:.5px solid var(--color-header-border);box-shadow:0px 3px 10px 0px var(--color-shadow);z-index:100}.app-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.app-footer{flex-shrink:0;background:var(--color-header);border-top:.5px solid var(--color-header-border);box-shadow:0px -3px 10px 0px var(--color-shadow);z-index:100}.header{display:flex;flex-direction:row;justify-content:space-between;align-items:center;height:32px}.header-logo{width:32px;height:32px;margin-right:.6rem}.header-left{display:flex;flex-direction:row;align-items:center;height:100%}.header-menu{display:flex;flex-direction:row;align-items:stretch;height:100%;gap:.5rem}.header-right{display:flex;align-items:center;height:100%}.read-button,.dev-button,.ride-button{position:relative;transition:all .2s ease;text-decoration:none}.read-button svg,.dev-button svg,.ride-button svg{width:16px;height:16px;margin-right:.4rem}.read-button.active,.dev-button.active,.ride-button.active{background:var(--color-primary);color:var(--background)}.read-button.active:hover,.dev-button.active:hover,.ride-button.active:hover{background:var(--color-primary);color:var(--background);opacity:.9}.footer{display:flex;flex-direction:row;justify-content:space-between;align-items:center;height:32px;padding:0 1rem;gap:1rem}.footer-left{display:flex;align-items:center;height:100%}.footer-menu{display:flex;flex-direction:row;align-items:center;height:100%}.footer-tier{display:flex;align-items:center;margin-left:auto;margin-right:.5rem;height:100%}.app .tier-badge{display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:500;padding:0 1rem;height:32px;color:var(--color-secondary);background:rgba(0,0,0,0);text-decoration:none;transition:all .2s ease;cursor:pointer}.app .tier-badge:hover{background:var(--bg-menu-selected);color:var(--fg-menu-selected)}.app .lesson{height:100%;padding:1.5rem 3rem;display:flex;flex-direction:row;gap:3rem;font-size:1.25rem;overflow:hidden}.app .lesson-layout-main{flex:1;display:flex;flex-direction:row;min-height:0;overflow:hidden;padding:1.5rem 3rem;gap:3rem}.app .lesson-layout-container{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.app .lesson-content{display:flex;flex-direction:row;gap:3rem;flex:1;min-height:0;overflow:hidden;font-size:1.25rem}.app .lesson-bottom-controls{flex-shrink:0}.app .lesson-left{display:flex;flex-direction:column;gap:.4rem;width:20%;min-width:300px}.app .lesson-left .lesson-header{display:flex;flex-direction:column;gap:.4rem}.app .lesson-left .lesson-header .lesson-header-chapter{font-size:1rem;color:var(--color-title-dimmed)}.app .lesson-left .lesson-header .lesson-header-section{font-size:1.6rem;font-weight:bold;color:var(--color-title)}.app .lesson-left .lesson-text{flex-grow:1;font-size:1.25rem;overflow:hidden;text-align:justify}.app .lesson-center{flex-grow:1;display:flex;flex-direction:column;align-items:center;overflow-y:auto}.app .lesson-center .lesson-content-blocks{display:flex;flex-direction:column;gap:2rem;padding:1rem 0}.app .lesson-content-wrapper{width:100%;max-width:1200px;padding:0 2rem;margin:0 auto}.app .lesson-multicolumn{column-count:3;column-gap:3rem}@media(max-width: 1024px){.app .lesson-multicolumn{column-count:2;column-gap:2rem}}@media(max-width: 767px){.app .lesson-multicolumn{column-count:1;column-gap:0}}.app .lesson-multicolumn h1,.app .lesson-multicolumn h2,.app .lesson-multicolumn h3,.app .lesson-multicolumn h4,.app .lesson-multicolumn h5,.app .lesson-multicolumn h6{break-after:avoid;break-inside:avoid}.app .lesson-multicolumn p{text-align:justify}.app .lesson-multicolumn ul{list-style:none;padding:0;margin:0 0 2rem 0;break-inside:avoid}.app .lesson-multicolumn ul li{padding:.5rem 0;padding-left:1.5rem;position:relative}.app .lesson-multicolumn ul li::before{position:absolute;left:0;color:var(--color-accent)}.app .lesson-twocolumn{min-height:100%;column-count:2;column-gap:3rem;column-fill:balance}@media(max-width: 1024px){.app .lesson-twocolumn{column-count:2;column-gap:2rem}}@media(max-width: 767px){.app .lesson-twocolumn{column-count:1;column-gap:0}}.app .lesson-twocolumn h1,.app .lesson-twocolumn h2,.app .lesson-twocolumn h3,.app .lesson-twocolumn h4,.app .lesson-twocolumn h5,.app .lesson-twocolumn h6{break-after:avoid;break-inside:avoid}.app .lesson-twocolumn p{text-align:justify}.app .lesson-twocolumn ul{list-style:none;padding:0;margin:0 0 2rem 0;break-inside:avoid}.app .lesson-twocolumn ul li{padding:.5rem 0;padding-left:1.5rem;position:relative}.app .lesson-twocolumn ul li::before{position:absolute;left:0;color:var(--color-accent)}.app .lesson-right{width:15%;min-width:300px;padding:1.5rem 3rem 0 0}.app .lesson-file-block{display:flex;flex-direction:column;border-radius:.5rem;overflow:hidden}.app .lesson-file-header{background:var(--file-header-bg);padding:.75rem 1rem}.app .lesson-file-header .lesson-file-title{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.app .lesson-file-header .lesson-file-title .lesson-file-path{font-weight:600;font-size:1.1rem;user-select:all;color:var(--file-text)}.app .lesson-file-header .lesson-file-title .lesson-file-type{opacity:.5;font-size:1rem;color:var(--file-text)}.app .lesson-file-content{background:var(--file-content-bg);font-family:monospace;font-size:1rem;color:var(--file-text)}.app .lesson-chunk{padding:.75rem 1.25rem}.app .lesson-chunk .lesson-line{display:flex;flex-direction:row;gap:.5rem;margin-bottom:.25rem}.app .lesson-chunk .lesson-line .lesson-line-number{width:1.2rem;opacity:.2;flex-shrink:0}.app .lesson-chunk .lesson-line .lesson-line-content{white-space:pre-wrap;word-break:break-word}.app .lesson-chunk .lesson-line-skip{opacity:.1;font-size:50%}.app .lesson-chunk .lesson-line-path{padding-bottom:.5rem;opacity:.7;font-size:80%;white-space:pre-wrap}.app .lesson-shell-block .lesson-file-header{background:var(--shell-header-bg)}.app .lesson-shell-block .lesson-file-content{background:var(--shell-content-bg)}.app .lesson-shell-chunk .lesson-line .lesson-shell-prompt{width:1.2rem;opacity:.5;color:#4ade80;font-weight:bold;flex-shrink:0}.app .lesson-shell-chunk .lesson-line .lesson-line-content{opacity:1;white-space:pre-wrap;word-break:break-word}.app .lesson-prompt-block{border:1px solid var(--prompt-header-bg);border-radius:.5rem;overflow:hidden}.app .lesson-prompt-block .lesson-prompt-container{display:flex;flex-direction:row}.app .lesson-prompt-block .lesson-prompt-icon{width:3rem;min-width:3rem;background:var(--prompt-header-bg);display:flex;align-items:center;justify-content:center;padding:1rem .5rem}.app .lesson-prompt-block .lesson-prompt-icon .lesson-prompt-symbol{color:var(--prompt-text);font-size:1.2rem;font-weight:bold;opacity:.8}.app .lesson-prompt-block .lesson-prompt-content{flex:1;background:var(--prompt-content-bg);padding:1rem 1.5rem}.app .lesson-prompt-block .lesson-prompt-content .lesson-prompt-text{color:var(--prompt-content-text);font-size:1.25rem;font-style:italic;line-height:1.6}.app .lesson-prompt-block .lesson-prompt-content .lesson-prompt-text p{margin:0}.app .lesson-line-content span{background:rgba(0,0,0,0) !important}.app .diff-normal{opacity:.6}.app .lesson-shell-chunk .diff-normal{opacity:1}.app .diff-inserted{position:relative;display:inline-block}.app .diff-inserted .diff-content{opacity:1}.app .diff-inserted::after{content:"";position:absolute;top:100%;left:0;width:100%;height:2px;background-color:#22c55e}.app .diff-deleted{position:relative;display:inline-block}.app .diff-deleted .diff-content{opacity:.4}.app .diff-deleted::after{content:"";position:absolute;top:50%;left:0;width:100%;height:2px;background-color:#e20000}.app .lesson{display:flex;flex-direction:column;padding:0}.app .lesson-content .lesson-left{width:25%;min-width:300px;display:flex;flex-direction:column;gap:.4rem;overflow-y:auto;min-height:0}.app .lesson-content .lesson-left .lesson-header{flex-shrink:0}.app .lesson-content .lesson-left .lesson-text{flex:1;overflow-y:auto;min-height:0}.app .lesson-content .lesson-center{flex:1;display:flex;flex-direction:column;overflow-y:auto;min-height:0;align-items:stretch}.app .lesson-content .lesson-center .lesson-content-blocks{width:100%;max-width:100%;padding:1rem 0}.app .lesson-content .lesson-center .lesson-file-block,.app .lesson-content .lesson-center .lesson-prompt-block{width:100%}.app .lesson-phase{display:flex;flex-direction:column;padding:0}.app .lesson-phase .lesson-center{justify-content:center}.app .lesson-phase .lesson-phase-content{display:flex;flex-direction:column;gap:2rem;width:100%}.app .lesson-phase .lesson-phase-description{text-align:center}.app .lesson-phase .lesson-phase-description h2{font-weight:bold;margin-bottom:1rem}.app .lesson-phase .lesson-phase-description:has(p) h2{font-size:2.5rem}.app .lesson-phase .lesson-phase-description:not(:has(p)) h2{font-size:2rem;font-style:italic}.app .lesson-phase .lesson-phase-description p{line-height:1.6}.app .lesson-phase .lesson-phase-prompt{width:100%}.app .lesson-intro{display:flex;flex-direction:column;padding:0}.app .lesson-intro .lesson-center{display:flex;flex-direction:column}.app .lesson-intro .lesson-content-wrapper{flex:1;display:flex;flex-direction:column}.app .lesson-intro .lesson-intro-content{flex:1;display:flex;flex-direction:column;gap:0}.app .lesson-intro .lesson-intro-header{text-align:center;margin-bottom:1rem}.app .lesson-intro .lesson-intro-header h1{font-weight:bold;margin-bottom:1rem}.app .lesson-intro .lesson-intro-columns ul li::before{content:"•"}.app .lesson-outro{display:flex;flex-direction:column;padding:0}.app .lesson-outro .lesson-center{display:flex;flex-direction:column}.app .lesson-outro .lesson-content-wrapper{flex:1;display:flex;flex-direction:column}.app .lesson-outro .lesson-outro-content{flex:1;display:flex;flex-direction:column;gap:0}.app .lesson-outro .lesson-outro-header{text-align:center;margin-bottom:1rem}.app .lesson-outro .lesson-outro-header h1{font-weight:bold;margin-bottom:1rem}.app .lesson-outro .lesson-outro-header .lesson-outro-book-title{font-style:italic;font-weight:500}.app .lesson-outro .lesson-outro-columns ul li::before{content:"✓";font-weight:bold}.app .lesson-read{display:flex;flex-direction:column;padding:0;height:100%}.app .lesson-read .lesson-content{flex:1;min-height:0}.app .lesson-read .lesson-center{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.app .lesson-read .lesson-content-wrapper{flex:1;display:flex;flex-direction:column;min-height:0}.app .lesson-read .lesson-read-content{flex:1;min-height:0;overflow-y:auto;position:relative}.app .lesson-read .lesson-read-columns ul li::before{content:"•"}.app .lesson-premium{display:flex;flex-direction:column;padding:0}.app .lesson-premium .lesson-center{justify-content:center}.app .lesson-premium .lesson-premium-content{display:flex;flex-direction:column;align-items:center;gap:2rem;text-align:center;width:100%}.app .lesson-premium h1{font-weight:bold;margin:0;font-size:2rem;display:flex;align-items:center;gap:1rem}.app .lesson-premium .lesson-premium-icon{display:inline-flex;align-items:center}.app .lesson-premium .lesson-premium-icon svg{width:40px;height:40px;stroke:var(--color-accent)}.app .lesson-premium .lesson-premium-description{line-height:1.6;font-size:1rem;font-style:italic;margin:0;color:var(--text-secondary)}.app .lesson-premium .lesson-premium-next{line-height:1.6;font-size:1.25rem;margin:0;width:100%}.app .lesson-premium .lesson-premium-cta{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:1rem}.app .lesson-premium .lesson-premium-button{background:var(--color-accent);color:#fff;border:none;padding:1rem 3rem;font-weight:bold;font-size:1.1rem;border-radius:8px;cursor:pointer;text-decoration:none;display:inline-block;transition:transform .2s,opacity .2s}.app .lesson-premium .lesson-premium-button:hover{transform:scale(1.05);opacity:.9}.app .lesson-premium .lesson-premium-button:active{transform:scale(0.98)}@media(max-width: 767px){.app .lesson-premium h1{font-size:1.5rem}.app .lesson-premium .lesson-premium-description{font-size:1rem}.app .lesson-premium .lesson-premium-button{padding:.875rem 2rem;font-size:1rem}}.app .lesson-bottom-controls .lesson-controls{display:flex;flex-direction:column;gap:.5rem}.app .lesson-bottom-controls .lesson-controls .lesson-controls-progress{height:3px;background:var(--bg-progress)}.app .lesson-bottom-controls .lesson-controls .lesson-controls-progress .lesson-controls-progress-bar{transition:width .5s;height:3px;background:var(--fg-progress)}.app .lesson-bottom-controls .lesson-controls .lesson-controls-buttons{display:flex;flex-direction:row;justify-content:space-between}.app .lesson-bottom-controls .lesson-controls .lesson-controls-buttons .lesson-controls-button{cursor:pointer;color:var(--fg-link);user-select:none;font-size:1.25rem}.app .lesson-bottom-controls .lesson-controls .lesson-controls-buttons .lesson-controls-button.lesson-controls-button-disabled{opacity:.3;cursor:not-allowed;pointer-events:none}.app .lesson-bottom-controls .lesson-controls .lesson-controls-pages{display:flex;flex-direction:row;justify-content:space-between}.app .lesson-bottom-controls .lesson-controls .lesson-controls-pages .lesson-controls-page{color:var(--fg-page);font-size:1.1rem}.lesson-mobile-header{display:none;position:sticky;top:0;z-index:100;background:var(--color-header);border-bottom:1px solid var(--color-header-border);padding:.875rem 1rem;align-items:center;justify-content:space-between;box-shadow:0 2px 8px var(--color-shadow)}.lesson-mobile-header .lesson-mobile-header-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.lesson-mobile-header .lesson-header-chapter{font-size:.75rem;font-weight:500;color:var(--color-secondary);text-transform:uppercase;letter-spacing:.05em}.lesson-mobile-header .lesson-header-section{font-size:1rem;font-weight:600;color:var(--color-title)}.lesson-mobile-header .lesson-mobile-toc-toggle{background:none;border:none;color:var(--color-title);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:background .2s ease;border-radius:8px}.lesson-mobile-header .lesson-mobile-toc-toggle:hover{background:var(--bg-code)}.lesson-mobile-header .lesson-mobile-toc-toggle svg{width:24px;height:24px}.lesson-mobile-toc-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:200;opacity:0;pointer-events:none;transition:opacity .3s ease}.lesson-mobile-toc-overlay.open{opacity:1;pointer-events:auto}.lesson-mobile-toc{display:none;position:fixed;top:0;right:-300px;width:300px;height:100%;background:var(--color-header);z-index:300;flex-direction:column;transition:right .3s ease;box-shadow:-4px 0 16px var(--color-shadow)}.lesson-mobile-toc.open{right:0}.lesson-mobile-toc .lesson-mobile-toc-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1rem;border-bottom:1px solid var(--color-header-border)}.lesson-mobile-toc .lesson-mobile-toc-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-title)}.lesson-mobile-toc .lesson-mobile-toc-header .lesson-mobile-toc-close{background:none;border:none;font-size:2rem;line-height:1;color:var(--color-title);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .2s ease}.lesson-mobile-toc .lesson-mobile-toc-header .lesson-mobile-toc-close:hover{background:var(--bg-code)}.lesson-mobile-toc .lesson-mobile-toc-content{flex:1;overflow:hidden}.lesson-mobile-toc .lesson-mobile-toc-content .viewport{padding:1.5rem}@media(max-width: 1200px){.lesson-mobile-header{display:flex}.lesson-mobile-toc-overlay{display:block}.lesson-mobile-toc{display:flex}.app .lesson-right{display:none}.app .lesson-content .lesson-left .lesson-header{display:none}.app .lesson{gap:0}}@media(max-width: 767px){.app .lesson{flex-direction:column;padding:0;gap:0;overflow-y:auto;overflow-x:hidden}.app .lesson-layout-main{padding:1.5rem 1rem}.app .lesson-content-wrapper{padding:0;max-width:none}.app .lesson-content .lesson-center{padding:0 1rem}.app .lesson-page-main{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:1.5rem 1rem}.app .lesson-page-container{overflow:hidden}.app .lesson-content{flex-direction:column;gap:1.5rem;overflow-y:auto}.app .lesson-content .lesson-left{width:100%;min-width:0;padding:0;flex-shrink:0;overflow:visible}.app .lesson-content .lesson-left .lesson-header{display:none}.app .lesson-content .lesson-left .lesson-text .markdown{line-height:1.7}.app .lesson-content .lesson-left .lesson-text .markdown p{margin:0 0 1rem 0}.app .lesson-content .lesson-left .lesson-text .markdown p:last-child{margin-bottom:0}.app .lesson-content .lesson-left .lesson-text .markdown strong{font-weight:600}.app .lesson-content .lesson-center{width:100%;flex:none;overflow:visible}.app .lesson-content-blocks{gap:1.5rem}.app .lesson-file-header{padding:.625rem .875rem}.app .lesson-file-header .lesson-file-title .lesson-file-path{word-break:break-all}.app .lesson-file-header .lesson-file-title .lesson-file-type{white-space:nowrap}.app .lesson-file-content{overflow-x:auto}.app .lesson-chunk{padding:.625rem .875rem}.app .lesson-chunk .lesson-line{white-space:pre-wrap;word-break:break-word}.app .lesson-chunk .lesson-line .lesson-line-content{flex:1;min-width:0}.app .lesson-prompt-block .lesson-prompt-icon{width:2.5rem;min-width:2.5rem;padding:.875rem .5rem}.app .lesson-prompt-block .lesson-prompt-content{padding:1.125rem 1.25rem;min-width:0}.app .lesson-prompt-block .lesson-prompt-content .lesson-prompt-text{line-height:1.7}.app .lesson.lesson-intro .lesson-intro-header{margin-bottom:1.5rem}.app .lesson.lesson-intro .lesson-intro-columns{column-count:1}.app .lesson.lesson-outro .lesson-outro-header{margin-bottom:1.5rem}.app .lesson.lesson-outro .lesson-outro-columns{column-count:1}.app .lesson.lesson-premium .lesson-premium-button{padding:.875rem 2rem}}.lesson-file .diff-normal{opacity:.7}.switch{display:flex;flex-direction:row;align-items:center;padding:1px;height:32px}.switch .switch-button{cursor:pointer;display:flex;align-items:center;justify-content:center;padding:6px;opacity:.5}.switch .switch-button:hover{opacity:1}.switch .switch-button.selected{opacity:1}.switch svg{color:var(--switch-fg);height:16px;width:16px}.toc-chapter-group.collapsed .toc-sections{display:none}.toc-chapter-group.expanded .toc-sections{display:block}.toc-chapter{cursor:pointer;padding:.4rem;padding-left:1.5rem;font-size:1.125rem;color:var(--color-toc-chapter-fg);border-left:2px solid var(--color-toc-unread);transition:color .2s ease,background .2s ease,border-color .2s ease}.toc-chapter:hover{color:var(--foreground);background:var(--color-toc-hover-bg);border-left-color:var(--color-toc-hover)}.toc-chapter.toc-completed{border-color:var(--color-toc-completed)}.toc-chapter.toc-completed:hover{background:var(--color-toc-hover-bg);border-left-color:var(--color-toc-hover)}.toc-sections{margin-left:0}.toc-section{cursor:pointer;padding:.2rem;padding-left:2.5rem;border-left:2px solid var(--color-toc-unread);font-size:1.125rem;color:var(--color-toc-section-fg);transition:color .2s ease,background .2s ease,border-color .2s ease}.toc-section:hover{background:var(--color-toc-hover-bg);color:var(--color-toc-chapter-fg);border-left-color:var(--color-toc-hover)}.toc-section.toc-completed{border-color:var(--color-toc-completed)}.toc-section.toc-completed:hover{background:var(--color-toc-hover-bg);border-left-color:var(--color-toc-hover)}.toc-section.toc-reading{border-color:var(--color-primary);background:var(--bg-secondary);font-weight:500;color:var(--color-toc-chapter-fg)}.toc-section.toc-reading:hover{background:var(--color-toc-hover-bg);border-left-color:var(--color-toc-hover)}.has-viewport{position:relative}.has-viewport .viewport,.has-viewport .curtain{text-align:justify;position:absolute;inset:0;padding-right:1rem;overflow-y:scroll}.unlock-container{height:100%;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--background)}.unlock-box{width:100%;max-width:400px;padding:3rem;background:var(--color-header);border:1px solid var(--color-header-border);border-radius:12px;box-shadow:0 4px 20px var(--color-shadow)}.unlock-header{text-align:center;margin-bottom:2rem}.unlock-logo{width:48px;height:48px;margin-bottom:1.5rem}.unlock-title{font-size:1.75rem;font-weight:600;color:var(--color-title);margin:0 0 .5rem 0}.unlock-subtitle{font-size:1rem;color:var(--color-title-dimmed);margin:0}.unlock-form{margin-bottom:2rem}.unlock-input-group{display:flex;flex-direction:column;gap:1rem}.unlock-input{width:100%;padding:.875rem 1rem;font-size:1rem;font-family:inherit;background:var(--background);color:var(--foreground);border:2px solid var(--color-header-border);border-radius:8px;outline:none;transition:border-color .2s ease}.unlock-input:focus{border-color:var(--color-primary)}.unlock-input.error{border-color:var(--color-primary)}.unlock-input::placeholder{color:var(--color-title-dimmed)}.unlock-button{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:500;font-family:inherit;color:var(--fg-menu-selected);background:var(--bg-menu-selected);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.unlock-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(20,96,104,.2)}.unlock-button:active{transform:translateY(0)}.unlock-button svg{width:16px;height:16px}.unlock-error{display:none;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem 1rem;font-size:.875rem;color:var(--color-primary);background:var(--bg-progress);border-radius:6px}.unlock-error.show{display:flex}.unlock-error svg{flex-shrink:0}.unlock-footer{text-align:center;font-size:.875rem;color:var(--color-title-dimmed)}.unlock-footer p{margin:0}.unlock-link{color:var(--fg-link);text-decoration:none}.unlock-link:hover{text-decoration:underline}.no-book-message{text-align:center;padding:2rem 0;color:var(--text-secondary)}.no-book-message svg{margin-bottom:1rem;color:var(--text-tertiary)}.no-book-message p{margin:0;line-height:1.6}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;background:var(--background);color:var(--foreground);overflow:hidden;position:relative}.loading-container::before{content:"";position:absolute;top:-100%;left:-100%;width:300%;height:300%;background:radial-gradient(ellipse at center, var(--bg-progress) 0%, var(--bg-code) 25%, var(--bg-progress) 50%, var(--bg-code) 75%, transparent 100%);opacity:.6}.loading-caption{font-size:26px;font-weight:500;color:var(--color-primary);opacity:0;animation:fadeInText 2s ease-in-out .5s forwards;margin-bottom:8px}.loading-subtitle{font-size:14px;font-weight:400;color:var(--color-secondary);opacity:0;animation:fadeInText 2s ease-in-out 1.5s forwards}@keyframes fadeInText{to{opacity:1}}.app .loading-spinner-container{display:flex;justify-content:center;align-items:center;margin:2rem 0}.app .loading-spinner{width:48px;height:48px;border:4px solid var(--color-header-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app .unpacking-progress-group{margin-bottom:2rem;display:flex;flex-direction:column;align-items:stretch;gap:.5rem}.app .progress-bar-container{flex-grow:1;height:20px;background-color:var(--bg-progress);border-radius:0;overflow:hidden}.app .progress-bar-fill{height:100%;width:0%;background:var(--color-primary);border-radius:0;transition:width .1s linear}.app .progress-text{font-size:.875rem;font-weight:500;color:var(--color-secondary);text-align:center}.demo-container{height:100%;overflow-y:auto;padding:3rem;background:var(--background)}.demo-header{text-align:center;margin-bottom:3rem}.demo-header h1{font-size:2.5rem;font-weight:600;color:var(--color-title);margin:1rem 0 .5rem 0}.demo-logo{width:64px;height:64px}.demo-subtitle{font-size:1.5rem;color:var(--color-title-dimmed);margin:0}.demo-sections{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:3rem}.demo-section h2{font-size:2rem;font-weight:600;color:var(--color-title);margin:0 0 1.5rem 0}.demo-cards{display:grid;grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));gap:1.5rem}.demo-card{display:flex;flex-direction:column;padding:2rem;background:var(--color-header);border:1px solid var(--color-header-border);border-radius:12px;text-decoration:none;color:inherit;transition:all .2s ease}.demo-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--color-shadow);border-color:var(--color-primary)}.demo-card:hover .demo-card-icon{background:var(--color-primary);color:#fff}.demo-card:hover .demo-card-action{color:var(--color-primary)}.demo-card h3{font-size:1.5rem;font-weight:600;color:var(--color-title);margin:1rem 0 .5rem 0}.demo-card p{flex-grow:1;font-size:1.25rem;color:var(--color-title-dimmed);line-height:1.5;margin:0 0 1rem 0}.demo-card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-code);color:var(--fg-code);border-radius:12px;transition:all .2s ease}.demo-card-icon svg{width:24px;height:24px}.demo-card-action{font-size:1.125rem;font-weight:500;color:var(--color-secondary);transition:color .2s ease}.demo-theme-info{background:var(--color-header);border:1px solid var(--color-header-border);border-radius:12px;padding:2rem}.demo-theme-info p{font-size:1.25rem;line-height:1.6;color:var(--foreground);margin:0 0 1rem 0}.demo-theme-info p:last-child{margin-bottom:0}.demo-theme-info ul{margin:1rem 0;padding-left:2rem}.demo-theme-info ul li{margin-bottom:.5rem;color:var(--foreground);font-size:1.25rem}.demo-theme-info ul li strong{color:var(--color-title)}.demo-features{display:grid;grid-template-columns:repeat(auto-fit, minmax(250px, 1fr));gap:1.5rem}.demo-feature{background:var(--color-header);border:1px solid var(--color-header-border);border-radius:8px;padding:1.5rem}.demo-feature h4{font-size:1.375rem;font-weight:600;color:var(--color-title);margin:0 0 .5rem 0}.demo-feature p{font-size:1.125rem;line-height:1.5;color:var(--color-title-dimmed);margin:0}.app .dev-view{display:flex;height:calc(100vh - 60px - 40px);width:100%;overflow:hidden}.app .dev-sidebar{width:280px;min-width:280px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.app .dev-sidebar-header{padding:12px 16px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.app .dev-sidebar-header h3{margin:0;font-size:11px;font-weight:600;letter-spacing:.5px;color:var(--color-secondary)}.app .dev-sidebar-actions{display:flex;gap:4px}.app .dev-icon-btn{background:rgba(0,0,0,0);border:none;cursor:pointer;padding:4px;border-radius:4px;color:var(--foreground);opacity:.6;transition:opacity .2s ease,background .2s ease}.app .dev-icon-btn:hover{opacity:1;background:var(--bg-menu-selected)}.app .dev-icon-btn svg{display:block}.app .dev-tree{overflow-y:auto;overflow-x:hidden;padding:8px 0;flex:1}.app .dev-tree-item{user-select:none}.app .dev-tree-item.dev-folder>.dev-tree-children{display:none}.app .dev-tree-item.dev-folder.dev-folder-open>.dev-tree-label .dev-folder-icon{transform:rotate(90deg)}.app .dev-tree-item.dev-folder.dev-folder-open>.dev-tree-children{display:block}.app .dev-tree-label{display:flex;align-items:center;gap:6px;padding:4px 12px;cursor:pointer;color:var(--foreground);font-size:13px;transition:background .15s ease}.app .dev-tree-label:hover{background:var(--color-toc-hover-bg)}.app .dev-tree-label svg{flex-shrink:0;color:var(--color-secondary);transition:transform .2s ease}.app .dev-tree-label .dev-folder-icon{width:16px;height:16px}.app .dev-tree-label span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app .dev-tree-children{padding-left:16px}.app .dev-file{display:flex;align-items:center;gap:6px;padding:4px 12px;cursor:pointer;color:var(--foreground);font-size:13px;transition:background .15s ease}.app .dev-file:hover{background:var(--color-toc-hover-bg)}.app .dev-file.dev-file-active{background:var(--bg-menu-selected);color:var(--fg-menu-selected)}.app .dev-file .dev-file-icon{flex-shrink:0;color:var(--color-secondary);width:16px;height:16px}.app .dev-file span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app .dev-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--background)}.app .dev-tabs{display:flex;gap:0;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);overflow-x:auto;overflow-y:hidden;flex-shrink:0}.app .dev-tab{display:flex;align-items:center;gap:8px;padding:8px 12px;background:rgba(0,0,0,0);border-right:1px solid var(--border-color);cursor:pointer;font-size:13px;color:var(--foreground);opacity:.7;transition:opacity .2s ease,background .2s ease;white-space:nowrap}.app .dev-tab:hover{opacity:1;background:rgba(255,255,255,.05)}.app .dev-tab.dev-tab-active{opacity:1;background:var(--background);border-bottom:2px solid var(--color-primary)}.app .dev-tab span{user-select:none}.app .dev-tab-close{background:rgba(0,0,0,0);border:none;color:var(--foreground);cursor:pointer;font-size:18px;line-height:1;padding:0 4px;opacity:.5;transition:opacity .2s ease}.app .dev-tab-close:hover{opacity:1}.app .dev-editor{flex:1;display:flex;flex-direction:column;overflow:hidden}.app .dev-file-header{padding:8px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);font-size:12px;color:var(--color-secondary)}.app .dev-file-path{font-family:"Courier New",monospace}.app .dev-code-container{flex:1;display:flex;overflow:auto;background:var(--background);font-family:"Courier New",Monaco,monospace;font-size:13px;line-height:1.6}.app .dev-line-numbers{margin:0;padding:16px 12px;background:var(--bg-secondary);border-right:1px solid var(--border-color);color:var(--color-secondary);text-align:right;user-select:none;flex-shrink:0}.app .dev-line-numbers code{display:block;font-family:inherit;font-size:inherit;line-height:inherit}.app .dev-code{margin:0;padding:16px;flex:1;overflow:auto;color:var(--fg-code)}.app .dev-code code{display:block;font-family:inherit;font-size:inherit;line-height:inherit;color:inherit}.app .dev-tree::-webkit-scrollbar,.app .dev-tabs::-webkit-scrollbar,.app .dev-code-container::-webkit-scrollbar{width:8px;height:8px}.app .dev-tree::-webkit-scrollbar-track,.app .dev-tabs::-webkit-scrollbar-track,.app .dev-code-container::-webkit-scrollbar-track{background:var(--bg-secondary)}.app .dev-tree::-webkit-scrollbar-thumb,.app .dev-tabs::-webkit-scrollbar-thumb,.app .dev-code-container::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.app .dev-tree::-webkit-scrollbar-thumb:hover,.app .dev-tabs::-webkit-scrollbar-thumb:hover,.app .dev-code-container::-webkit-scrollbar-thumb:hover{background:var(--color-secondary)}@media(max-width: 767px){.app .dev-view{flex-direction:column}.app .dev-sidebar{width:100%;height:200px;border-right:none;border-bottom:1px solid var(--border-color)}}.app .ride-view{display:flex;height:calc(100vh - 60px - 40px);width:100%;overflow:hidden}.app .ride-sidebar{width:300px;min-width:300px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.app .ride-sidebar-header{padding:12px 16px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.app .ride-sidebar-header h3{margin:0;font-size:11px;font-weight:600;letter-spacing:.5px;color:var(--color-secondary)}.app .ride-sidebar-actions{display:flex;gap:4px}.app .ride-icon-btn{background:rgba(0,0,0,0);border:none;cursor:pointer;padding:4px;border-radius:4px;color:var(--foreground);opacity:.6;transition:opacity .2s ease,background .2s ease}.app .ride-icon-btn:hover{opacity:1;background:var(--bg-menu-selected)}.app .ride-icon-btn svg{display:block}.app .ride-resources-list{flex:1;overflow-y:auto;padding:8px 0}.app .ride-resource-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background .15s ease}.app .ride-resource-item:hover{background:var(--color-toc-hover-bg)}.app .ride-resource-item.active{background:var(--bg-menu-selected)}.app .ride-resource-icon{flex-shrink:0;width:20px;height:20px;color:var(--color-primary)}.app .ride-resource-info{flex:1;min-width:0}.app .ride-resource-name{font-size:13px;font-weight:500;color:var(--foreground);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app .ride-resource-path{font-size:11px;color:var(--color-secondary);font-family:"Courier New",monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app .ride-resource-stats{display:flex;align-items:center;gap:8px;margin-top:4px;font-size:11px;color:var(--color-secondary)}.app .ride-status-online{width:6px;height:6px;border-radius:50%;background:#10b981;flex-shrink:0}.app .ride-sidebar-footer{padding:12px 16px;border-top:1px solid var(--border-color);background:var(--background)}.app .ride-connection-status{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--foreground)}.app .ride-status-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.app .ride-status-indicator.online{background:#10b981;box-shadow:0 0 0 2px rgba(16,185,129,.2)}.app .ride-status-indicator.offline{background:#6b7280}.app .ride-connection-text{font-weight:500}.app .ride-main{flex:1;display:flex;flex-direction:column;overflow-y:auto;background:var(--background);padding:24px;gap:24px}.app .ride-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.app .ride-section-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color);background:var(--background)}.app .ride-section-header h3{margin:0;font-size:11px;font-weight:600;letter-spacing:.5px;color:var(--color-secondary)}.app .ride-add-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;background:rgba(0,0,0,0);border:1px solid var(--border-color);border-radius:4px;color:var(--foreground);cursor:pointer;transition:all .2s ease;font-family:inherit}.app .ride-add-btn:hover{background:var(--bg-menu-selected);border-color:var(--color-primary)}.app .ride-add-btn svg{width:14px;height:14px}.app .ride-connectors-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:16px;padding:20px}.app .ride-connector-card{background:var(--background);border:1px solid var(--border-color);border-radius:6px;overflow:hidden;transition:border-color .2s ease}.app .ride-connector-card:hover{border-color:var(--color-primary)}.app .ride-connector-card.disabled{opacity:.6}.app .ride-connector-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border-color)}.app .ride-connector-title{display:flex;align-items:center;gap:10px}.app .ride-connector-title svg{color:var(--color-primary);flex-shrink:0}.app .ride-connector-title span{font-size:14px;font-weight:600;color:var(--foreground)}.app .ride-toggle-switch{position:relative;width:40px;height:22px}.app .ride-toggle-switch input{opacity:0;width:0;height:0}.app .ride-toggle-switch input:checked+.ride-toggle-slider{background:var(--color-primary)}.app .ride-toggle-switch input:checked+.ride-toggle-slider:before{transform:translateX(18px)}.app .ride-toggle-switch input:disabled+.ride-toggle-slider{opacity:.5;cursor:not-allowed}.app .ride-toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--border-color);transition:.3s;border-radius:22px}.app .ride-toggle-slider:before{position:absolute;content:"";height:16px;width:16px;left:3px;bottom:3px;background:#fff;transition:.3s;border-radius:50%}.app .ride-connector-body{padding:16px;display:flex;flex-direction:column;gap:12px}.app .ride-field{display:flex;flex-direction:column;gap:6px}.app .ride-field label{font-size:12px;font-weight:500;color:var(--foreground)}.app .ride-input,.app .ride-select,.app .ride-textarea{width:100%;padding:8px 10px;font-size:13px;font-family:inherit;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;color:var(--foreground);transition:border-color .2s ease}.app .ride-input:focus,.app .ride-select:focus,.app .ride-textarea:focus{outline:none;border-color:var(--color-primary)}.app .ride-input:disabled,.app .ride-select:disabled,.app .ride-textarea:disabled{opacity:.5;cursor:not-allowed}.app .ride-textarea{resize:vertical;min-height:60px;font-family:"Courier New",monospace;line-height:1.5}.app .ride-connector-status{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;margin-top:4px}.app .ride-connector-status.active{color:#10b981}.app .ride-connector-status.inactive{color:var(--color-secondary)}.app .ride-status-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.app .ride-characters-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));gap:16px;padding:20px}.app .ride-character-card{background:var(--background);border:1px solid var(--border-color);border-radius:6px;overflow:hidden;transition:border-color .2s ease}.app .ride-character-card:hover{border-color:var(--color-primary)}.app .ride-character-card.active{border-color:var(--color-primary)}.app .ride-character-header{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--border-color)}.app .ride-character-icon{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.app .ride-character-icon.engineer{background:linear-gradient(135deg, #667eea 0%, #764ba2 100%);color:#fff}.app .ride-character-icon.teacher{background:linear-gradient(135deg, #f093fb 0%, #f5576c 100%);color:#fff}.app .ride-character-icon.architect{background:linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);color:#fff}.app .ride-character-info{flex:1}.app .ride-character-name{font-size:15px;font-weight:600;color:var(--foreground);margin-bottom:2px}.app .ride-character-desc{font-size:12px;color:var(--color-secondary)}.app .ride-character-body{padding:16px;display:flex;flex-direction:column;gap:12px}.app .ride-character-traits{display:flex;flex-wrap:wrap;gap:6px}.app .ride-trait{padding:4px 10px;font-size:11px;font-weight:500;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;color:var(--foreground)}.app .ride-range{width:100%;height:4px;border-radius:2px;background:var(--border-color);outline:none;-webkit-appearance:none}.app .ride-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--color-primary);cursor:pointer}.app .ride-range::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:none}.app .ride-range-value{font-size:11px;font-weight:500;color:var(--color-secondary);margin-left:8px}.app .ride-resources-list::-webkit-scrollbar,.app .ride-main::-webkit-scrollbar{width:8px}.app .ride-resources-list::-webkit-scrollbar-track,.app .ride-main::-webkit-scrollbar-track{background:var(--bg-secondary)}.app .ride-resources-list::-webkit-scrollbar-thumb,.app .ride-main::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.app .ride-resources-list::-webkit-scrollbar-thumb:hover,.app .ride-main::-webkit-scrollbar-thumb:hover{background:var(--color-secondary)}@media(max-width: 767px){.app .ride-view{flex-direction:column}.app .ride-sidebar{width:100%;height:200px;border-right:none;border-bottom:1px solid var(--border-color)}.app .ride-connectors-grid,.app .ride-characters-grid{grid-template-columns:1fr}}.welcome-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:1000;opacity:0;transition:opacity .3s ease}.welcome-modal-overlay.visible{opacity:1}.welcome-modal-overlay.hiding{opacity:0}.welcome-modal{background:var(--background);border:1px solid var(--color-header-border);border-radius:12px;width:90%;max-width:700px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.3);transform:translateY(20px);transition:transform .3s ease}.welcome-modal-overlay.visible .welcome-modal{transform:translateY(0)}.welcome-modal-header{display:flex;align-items:center;justify-content:space-between;padding:2rem;border-bottom:1px solid var(--color-header-border)}.welcome-modal-header h2{margin:0;font-size:1.75rem;font-weight:600;color:var(--color-title)}.welcome-modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:rgba(0,0,0,0);color:var(--color-title-dimmed);cursor:pointer;border-radius:8px;transition:all .2s ease}.welcome-modal-close:hover{background:var(--color-header);color:var(--color-title)}.welcome-modal-close svg{width:20px;height:20px}.welcome-modal-content{flex:1;overflow-y:auto;padding:2rem}.welcome-section{margin-bottom:2rem}.welcome-section:last-child{margin-bottom:0}.welcome-section h3{font-size:1.25rem;font-weight:600;color:var(--color-title);margin:0 0 .75rem 0}.welcome-section p{font-size:1rem;line-height:1.6;color:var(--foreground);margin:0 0 .75rem 0}.welcome-section ul,.welcome-section ol{margin:0;padding-left:1.5rem}.welcome-section ul li,.welcome-section ol li{margin-bottom:.5rem;line-height:1.6;color:var(--foreground)}.welcome-section ul li strong,.welcome-section ol li strong{color:var(--color-title)}.welcome-tips{background:var(--color-header);border:1px solid var(--color-header-border);border-radius:8px;padding:1.5rem}.welcome-tips h3{margin-bottom:1rem}.welcome-tip{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.welcome-tip:last-child{margin-bottom:0}.welcome-tip-icon{font-size:1.25rem;flex-shrink:0}.welcome-modal-footer{padding:1.5rem 2rem;border-top:1px solid var(--color-header-border);display:flex;justify-content:flex-end}.welcome-modal-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;font-family:inherit;color:var(--fg-menu-selected);background:var(--bg-menu-selected);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.welcome-modal-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(20,96,104,.2)}.welcome-modal-button:active{transform:translateY(0)}.welcome-modal-button svg{width:16px;height:16px}@media(max-width: 768px){.welcome-modal{width:95%;max-height:90vh}.welcome-modal-header{padding:1.5rem}.welcome-modal-header h2{font-size:1.5rem}.welcome-modal-content{padding:1.5rem}.welcome-section h3{font-size:1.125rem}}.app .intro-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:1000;opacity:0;transition:opacity .3s ease}.app .intro-modal-overlay.visible{display:flex;opacity:1}.app .intro-modal-overlay.hiding{opacity:0}.app .intro-modal{background:var(--background);border:1px solid var(--color-header-border);border-radius:12px;width:90%;max-width:800px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.3);transform:translateY(20px);transition:transform .3s ease}.intro-modal-overlay.visible .app .intro-modal{transform:translateY(0)}.app .intro-modal-header{display:flex;align-items:center;justify-content:space-between;padding:2rem;border-bottom:1px solid var(--color-header-border)}.app .intro-modal-header h2{margin:0;font-size:1.75rem;font-weight:600;color:var(--color-title)}.app .intro-modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:rgba(0,0,0,0);color:var(--color-title-dimmed);cursor:pointer;border-radius:8px;transition:all .2s ease}.app .intro-modal-close:hover{background:var(--color-header);color:var(--color-title)}.app .intro-modal-close svg{width:20px;height:20px}.app .intro-modal-content{flex:1;overflow-y:auto;padding:2rem;font-size:1.25rem}.app .intro-modal-content .markdown h1,.app .intro-modal-content .markdown h2,.app .intro-modal-content .markdown h3,.app .intro-modal-content .markdown h4,.app .intro-modal-content .markdown h5,.app .intro-modal-content .markdown h6{color:var(--color-title);margin-top:1.5rem;margin-bottom:.75rem}.app .intro-modal-content .markdown h1:first-child,.app .intro-modal-content .markdown h2:first-child,.app .intro-modal-content .markdown h3:first-child,.app .intro-modal-content .markdown h4:first-child,.app .intro-modal-content .markdown h5:first-child,.app .intro-modal-content .markdown h6:first-child{margin-top:0}.app .intro-modal-content .markdown h3{font-size:1.25rem;font-weight:600}.app .intro-modal-content .markdown p{line-height:1.6;color:var(--foreground);margin:0 0 1rem 0}.app .intro-modal-content .markdown ul,.app .intro-modal-content .markdown ol{margin:0 0 1rem 0;padding-left:1.5rem}.app .intro-modal-content .markdown ul li,.app .intro-modal-content .markdown ol li{margin-bottom:.5rem;line-height:1.6;color:var(--foreground)}.app .intro-modal-content .markdown code{padding:.2em .4em;background:var(--color-header);border:1px solid var(--color-header-border);border-radius:3px;font-size:.9em;font-family:"Consolas","Monaco","Courier New",monospace}.app .intro-modal-content .markdown pre{background:var(--color-header);border:none;border-radius:6px;padding:1rem;overflow-x:auto;margin:0}.app .intro-modal-content .markdown pre code{padding:0;background:rgba(0,0,0,0);border:none}.app .intro-modal-content .markdown strong{color:var(--color-title);font-weight:600}.app .intro-modal-footer{padding:1.5rem 2rem;border-top:1px solid var(--color-header-border);display:flex;justify-content:flex-end}.app .intro-modal-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;font-family:inherit;color:var(--fg-menu-selected);background:var(--bg-menu-selected);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.app .intro-modal-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(20,96,104,.2)}.app .intro-modal-button:active{transform:translateY(0)}.app .intro-modal-button svg{width:16px;height:16px}@media(max-width: 768px){.app .intro-modal{width:95%;max-height:90vh}.app .intro-modal-header{padding:1.5rem}.app .intro-modal-header h2{font-size:1.5rem}.app .intro-modal-content{padding:1.5rem}}.language-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:1000;opacity:0;transition:opacity .3s ease}.language-modal-overlay.visible{opacity:1}.language-modal-overlay.hiding{opacity:0}.language-modal{background:var(--background);border:1px solid var(--color-header-border);border-radius:12px;width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.3);transform:translateY(20px);transition:transform .3s ease}.language-modal-overlay.visible .language-modal{transform:translateY(0)}.language-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--color-header-border);background:var(--background);border-radius:12px 12px 0 0}.language-modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--color-title)}.language-modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:rgba(0,0,0,0);color:var(--color-title-dimmed);cursor:pointer;border-radius:8px;transition:all .2s ease}.language-modal-close:hover{background:var(--color-header);color:var(--color-title)}.language-modal-close svg{width:20px;height:20px}.language-modal-content{flex:1;overflow-y:auto;padding:1rem;background:var(--background);border-radius:0 0 12px 12px}.language-list{display:flex;flex-direction:column;gap:.25rem}.language-item{display:flex;align-items:center;gap:1rem;width:100%;padding:.75rem 1rem;border:none;background:rgba(0,0,0,0);border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;font-family:inherit;font-size:1rem;color:var(--foreground)}.language-item:hover{background:var(--color-header)}.language-item.active{background:var(--bg-code)}.language-item.active .language-check{opacity:1}.language-flag{font-size:1.5rem;width:2rem;text-align:center}.language-name{flex:1;font-weight:500;color:var(--color-title)}.language-native{color:var(--color-title-dimmed);font-size:.875rem}.language-check{width:20px;height:20px;color:var(--color-primary);opacity:0;transition:opacity .2s ease}@media(max-width: 768px){.language-modal{width:95%;max-height:85vh}.language-modal-header{padding:1.25rem}.language-modal-header h2{font-size:1.25rem}.language-item{padding:.625rem .75rem}.language-item .language-flag{font-size:1.25rem}}.app .help-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:1000;opacity:0;transition:opacity .3s ease}.app .help-modal-overlay.visible{display:flex;opacity:1}.app .help-modal-overlay.hiding{opacity:0}.app .help-modal{background:var(--background);border:1px solid var(--color-header-border);border-radius:12px;width:90%;max-width:1200px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.3);transform:translateY(20px);transition:transform .3s ease}.help-modal-overlay.visible .app .help-modal{transform:translateY(0)}.app .help-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid var(--color-header-border)}.app .help-modal-header h2{margin:0;font-size:1.75rem;font-weight:600;color:var(--color-title)}.app .help-modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:rgba(0,0,0,0);color:var(--color-title-dimmed);cursor:pointer;border-radius:8px;transition:all .2s ease}.app .help-modal-close:hover{background:var(--color-header);color:var(--color-title)}.app .help-modal-close svg{width:20px;height:20px}.app .help-modal-tabs{display:flex;gap:.5rem;padding:0 2rem;border-bottom:1px solid var(--color-header-border);background:var(--color-header)}.app .help-tab{padding:1rem 1.5rem;font-size:1rem;font-weight:500;font-family:inherit;color:var(--color-text-dimmed);background:rgba(0,0,0,0);border:none;border-bottom:2px solid rgba(0,0,0,0);cursor:pointer;transition:all .2s ease;position:relative;top:1px}.app .help-tab:hover{color:var(--color-title);background:var(--background)}.app .help-tab.active{color:var(--color-title);background:var(--background);border-bottom-color:var(--color-accent)}.app .help-modal-content{flex:1;overflow-y:auto;padding:2rem;font-size:1.25rem;position:relative}.app .help-tab-content{display:none}.app .help-tab-content.active{display:block}.app .help-tab-content .markdown h1,.app .help-tab-content .markdown h2,.app .help-tab-content .markdown h3,.app .help-tab-content .markdown h4,.app .help-tab-content .markdown h5,.app .help-tab-content .markdown h6{color:var(--color-title);margin-top:1.5rem;margin-bottom:.75rem}.app .help-tab-content .markdown h1:first-child,.app .help-tab-content .markdown h2:first-child,.app .help-tab-content .markdown h3:first-child,.app .help-tab-content .markdown h4:first-child,.app .help-tab-content .markdown h5:first-child,.app .help-tab-content .markdown h6:first-child{margin-top:0}.app .help-tab-content .markdown h3{font-size:1.5rem;font-weight:600}.app .help-tab-content .markdown h4{font-size:1.25rem;font-weight:600}.app .help-tab-content .markdown p{line-height:1.6;color:var(--foreground);margin:0 0 1rem 0}.app .help-tab-content .markdown ul,.app .help-tab-content .markdown ol{margin:0 0 1rem 0;padding-left:1.5rem}.app .help-tab-content .markdown ul li,.app .help-tab-content .markdown ol li{margin-bottom:.5rem;line-height:1.6;color:var(--foreground)}.app .help-tab-content .markdown code{padding:.2em .4em;background:var(--color-header);border:1px solid var(--color-header-border);border-radius:3px;font-size:.9em;font-family:"Consolas","Monaco","Courier New",monospace}.app .help-tab-content .markdown pre{background:var(--color-header);border:none;border-radius:6px;padding:1rem;overflow-x:auto;margin:0 0 1rem 0}.app .help-tab-content .markdown pre code{padding:0;background:rgba(0,0,0,0);border:none}.app .help-tab-content .markdown strong{color:var(--color-title);font-weight:600}.app .help-tab-content .markdown em{font-style:italic}.app .help-modal-footer{padding:1.5rem 2rem;border-top:1px solid var(--color-header-border);display:flex;justify-content:flex-end}.app .help-modal-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;font-family:inherit;color:var(--fg-menu-selected);background:var(--bg-menu-selected);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.app .help-modal-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(20,96,104,.2)}.app .help-modal-button:active{transform:translateY(0)}.app .help-modal-button svg{width:16px;height:16px}@media(max-width: 768px){.app .help-modal{width:95%;max-width:100%;max-height:90vh}.app .help-modal-header{padding:1.5rem}.app .help-modal-header h2{font-size:1.5rem}.app .help-modal-tabs{padding:0 1rem}.app .help-tab{padding:.875rem 1rem;font-size:.9rem;white-space:nowrap}.app .help-modal-content{padding:1.5rem}}.project-mirror-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:1000;opacity:0;transition:opacity .3s ease}.project-mirror-modal-overlay.visible{display:flex;opacity:1}.project-mirror-modal-overlay.hiding{opacity:0}.project-mirror-modal{background:var(--background);border:1px solid var(--color-header-border);border-radius:12px;width:90%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.3);transform:translateY(20px);transition:transform .3s ease}.project-mirror-modal-overlay.visible .project-mirror-modal{transform:translateY(0)}.project-mirror-modal-header{display:flex;align-items:center;justify-content:space-between;padding:2rem;border-bottom:1px solid var(--color-header-border)}.project-mirror-modal-header h2{margin:0;font-size:1.75rem;font-weight:600;color:var(--color-title)}.project-mirror-modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:rgba(0,0,0,0);color:var(--color-title-dimmed);cursor:pointer;border-radius:8px;transition:all .2s ease}.project-mirror-modal-close:hover{background:var(--color-header);color:var(--color-title)}.project-mirror-modal-close svg{width:20px;height:20px}.project-mirror-modal-content{flex:1;overflow-y:auto;padding:2rem}.project-mirror-section{margin-bottom:2rem}.project-mirror-section:last-child{margin-bottom:0}.project-mirror-section h3{font-size:1.25rem;font-weight:600;color:var(--color-title);margin:0 0 1rem 0}.project-mirror-section p{font-size:1rem;line-height:1.6;color:var(--foreground);margin:0 0 1rem 0}.project-mirror-note{padding-left:1rem;border-left:3px solid #ff3d00;color:var(--foreground);font-size:.875rem;margin-top:1rem}.project-mirror-folder{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem;background:var(--color-header);border:1px solid var(--color-header-border);border-radius:8px}.project-mirror-folder-info{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.project-mirror-folder-info svg{color:var(--color-title-dimmed);flex-shrink:0}.project-mirror-folder-details{min-width:0;flex:1}.project-mirror-folder-name{font-weight:500;color:var(--color-title);margin-bottom:.25rem}.project-mirror-folder-path{font-size:.875rem;color:var(--color-title-dimmed);font-family:"SF Mono",Monaco,"Cascadia Code","Roboto Mono",Consolas,"Courier New",monospace;word-break:break-all}.project-mirror-folder-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;font-family:inherit;color:var(--color-title);background:var(--background);border:1px solid var(--color-header-border);border-radius:6px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.project-mirror-folder-button:hover{background:var(--color-title-dimmed);color:var(--background)}.project-mirror-folder-button svg{width:14px;height:14px}.project-mirror-switch-container{display:flex;align-items:center;justify-content:space-between;gap:1rem}.project-mirror-switch-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;user-select:none}.project-mirror-switch-label input[type=checkbox]{display:none}.project-mirror-switch-label input[type=checkbox]:disabled~.project-mirror-switch{opacity:.5;cursor:not-allowed}.project-mirror-switch-label input[type=checkbox]:disabled~.project-mirror-switch-text{opacity:.5;cursor:not-allowed}.project-mirror-switch{position:relative;width:44px;height:24px;background:var(--color-header-border);border-radius:12px;transition:background .3s ease;flex-shrink:0}input[type=checkbox]:checked~.project-mirror-switch{background:var(--bg-menu-selected)}input[type=checkbox]:disabled~.project-mirror-switch{cursor:not-allowed}.project-mirror-switch-slider{position:absolute;top:2px;left:2px;width:20px;height:20px;background:var(--background);border-radius:50%;transition:transform .3s ease;box-shadow:0 2px 4px rgba(0,0,0,.2)}input[type=checkbox]:checked~.project-mirror-switch .project-mirror-switch-slider{transform:translateX(20px)}.project-mirror-switch-text{font-size:1rem;color:var(--color-title);font-weight:500}.project-mirror-sync-once-button{display:flex;align-items:center;justify-content:center;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;font-family:inherit;color:var(--color-title);background:var(--background);border:1px solid var(--color-header-border);border-radius:6px;cursor:pointer;white-space:nowrap;position:relative;transition:background .2s ease}.project-mirror-sync-once-button:hover:not(:disabled){background:var(--color-header)}.project-mirror-sync-once-button:active:not(:disabled){box-shadow:0 0 8px 1px rgba(255,61,0,.2);transition:none}.project-mirror-sync-once-button:not(:active){box-shadow:none;transition:background .2s ease,box-shadow .5s ease}.project-mirror-sync-once-button:disabled{opacity:.5;cursor:not-allowed}.project-mirror-modal-footer{padding:1.5rem 2rem;border-top:1px solid var(--color-header-border);display:flex;justify-content:center;gap:.75rem}.project-mirror-modal-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;font-family:inherit;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.project-mirror-modal-button.secondary{color:var(--color-title);background:rgba(0,0,0,0);border:1px solid var(--color-header-border)}.project-mirror-modal-button.secondary:hover{background:var(--color-header)}.project-mirror-modal-button.primary{color:var(--fg-menu-selected);background:var(--bg-menu-selected)}.project-mirror-modal-button.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(20,96,104,.2)}.project-mirror-modal-button.primary:active:not(:disabled){transform:translateY(0)}.project-mirror-modal-button.primary:disabled{opacity:.6;cursor:not-allowed}.project-mirror-modal-button svg{width:16px;height:16px}.project-mirror-modal-button svg.spinning{animation:spin 1s linear infinite}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@media(max-width: 768px){.project-mirror-modal{width:95%;max-height:90vh}.project-mirror-modal-header{padding:1.5rem}.project-mirror-modal-header h2{font-size:1.5rem}.project-mirror-modal-content{padding:1.5rem}.project-mirror-folder{flex-direction:column;align-items:stretch;gap:.75rem}.project-mirror-switch-container{flex-direction:column;align-items:stretch;gap:1rem}.project-mirror-sync-once-button{width:100%}.project-mirror-modal-footer{padding:1rem 1.5rem}.project-mirror-modal-footer .project-mirror-modal-button{width:100%;justify-content:center}}.project-premium-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:1000;opacity:0;transition:opacity .3s ease}.project-premium-modal-overlay.visible{display:flex;opacity:1}.project-premium-modal-overlay.hiding{opacity:0}.project-premium-modal{background:var(--background);border:1px solid var(--color-primary);border-radius:16px;width:90%;max-width:640px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.4),0 0 40px var(--color-primary);transform:translateY(20px);transition:transform .3s ease;animation:premiumGlow 3s ease-in-out infinite}.project-premium-modal-overlay.visible .project-premium-modal{transform:translateY(0)}.project-premium-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid var(--color-header-border)}.project-premium-modal-header h2{margin:0;font-size:1.125rem;font-weight:500;color:var(--color-title-dimmed)}.project-premium-modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:rgba(0,0,0,0);color:var(--color-title-dimmed);cursor:pointer;border-radius:8px;transition:all .2s ease}.project-premium-modal-close:hover{background:var(--color-header);color:var(--color-title)}.project-premium-modal-close svg{width:20px;height:20px}.project-premium-modal-content{flex:1;overflow-y:auto;padding:3rem 3rem;display:flex;flex-direction:column;align-items:center;text-align:center}.project-premium-modal-content h3{font-size:2.25rem;font-weight:600;color:var(--color-title);margin:0 0 1rem 0;line-height:1.2}.project-premium-tagline{font-size:1.25rem;line-height:1.5;color:var(--color-title-dimmed);margin:0 0 2.5rem 0;max-width:480px}.project-premium-benefits{display:flex;flex-direction:column;gap:1.25rem;width:100%;max-width:440px}.project-premium-benefit{display:flex;align-items:center;gap:1rem;text-align:left;font-size:1.1875rem;color:var(--foreground)}.project-premium-benefit .benefit-icon{flex-shrink:0;width:30px;height:30px;border-radius:50%;background:var(--color-primary);color:var(--background);display:flex;align-items:center;justify-content:center;font-size:1.0625rem;font-weight:600}.project-premium-modal-footer{padding:2rem 2.5rem;border-top:1px solid var(--color-header-border);display:flex;justify-content:center;gap:1rem}.project-premium-modal-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 2rem;font-size:1.0625rem;font-weight:500;font-family:inherit;border:none;border-radius:10px;cursor:pointer;transition:all .2s ease;text-decoration:none}.project-premium-modal-button.secondary{color:var(--color-title-dimmed);background:rgba(0,0,0,0);border:none;padding:.875rem 1.5rem}.project-premium-modal-button.secondary:hover{color:var(--color-title)}.project-premium-modal-button.primary{color:var(--background);background:var(--color-primary);min-width:180px}.project-premium-modal-button.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px rgba(184,217,57,.4)}.project-premium-modal-button.primary:active:not(:disabled){transform:translateY(0)}.project-premium-modal-button.primary:disabled{opacity:.6;cursor:not-allowed}.project-premium-modal-button svg{width:16px;height:16px}@media(max-width: 768px){.project-premium-modal{width:95%;max-height:90vh}.project-premium-modal-header{padding:1.25rem 1.5rem}.project-premium-modal-header h2{font-size:1rem}.project-premium-modal-content{padding:2.5rem 2rem}.project-premium-modal-content h3{font-size:1.875rem}.project-premium-tagline{font-size:1.125rem}.project-premium-benefit{font-size:1.0625rem}.project-premium-modal-footer{padding:1.5rem 2rem;flex-direction:column;gap:.75rem}.project-premium-modal-footer .project-premium-modal-button{width:100%;justify-content:center}.project-premium-modal-footer .project-premium-modal-button.primary{min-width:auto}}@keyframes premiumGlow{0%,100%{box-shadow:0 20px 60px rgba(0,0,0,.4),0 0 30px rgba(184,217,57,.3)}50%{box-shadow:0 20px 60px rgba(0,0,0,.4),0 0 50px rgba(184,217,57,.6)}}.code-normal{color:#d5d6db;background:#25262b}.code-keyword{color:#7ad1d9;background:#25262b;font-style:italic}.code-control{color:#d42e64;background:#25262b}.code-function{color:#7ad149;background:#25262b}.code-parameter{color:#d68b2f;background:#25262b;font-style:italic}*{box-sizing:border-box}body{margin:0;padding:0;font-family:"Jost";height:100vh;overflow:hidden}
