.dialog{border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:0;max-width:500px;width:90%;background:var(--bg-primary);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 0 60px #0f172a;animation:popFromBelow .4s cubic-bezier(.22,1,.36,1);position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);margin:0}.dialog::backdrop{background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .3s ease-out}@keyframes popFromBelow{0%{opacity:0;transform:translate(-50%,-40%) scale(.85)}60%{opacity:1;transform:translate(-50%,-52%) scale(1.05)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.dialog-content{padding:40px;text-align:center;overflow-y:clip;position:relative}.icon-container{width:80px;height:80px;margin:0 auto 24px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 0 30px #6366f180;transform:scale(0);opacity:0;transition:all .3s ease 2s}.icon-container.show{transform:scale(1);opacity:1}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.checkmark{width:40px;height:40px;stroke:#fff;stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round}.checkmark path{stroke-dasharray:100;stroke-dashoffset:100;animation:drawCheck .5s ease-out .4s forwards}@keyframes drawCheck{to{stroke-dashoffset:0}}.dialog-button{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;padding:14px 40px;font-size:16px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s;box-shadow:0 0 20px #6366f166}.dialog-button:hover{transform:translateY(-2px);box-shadow:0 0 30px #6366f199}.dialog-button:active{transform:translateY(0)}@font-face{font-family:rockie;src:url(/rockie.woff2) format("woff2"),url(/rockie.woff) format("woff");font-weight:400;font-style:normal;font-display:swap}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--transition-speed: .3s}[data-theme=dark]{--bg-primary: #191919;--bg-secondary: #1a1a1a;--bg-tertiary: #1e1e1e;--bg-elevated: #252525;--bg-hover: #2d2d2d;--border-primary: #2a2a2a;--border-secondary: #3a3a3a;--text-primary: #ffffff;--text-secondary: #e3e3e3;--text-tertiary: #b3b3b3;--text-muted: #888;--text-subtle: #666;--accent-primary: #4a9eff;--accent-hover: #3d8de6;--accent-glow: rgba(74, 158, 255, .4);--code-bg: #0d0d0d;--code-inline-bg: #262626;--code-text: #ff6b6b;--gradient-start: #1e3a5f;--gradient-end: #2d1e3f;--shadow: rgba(0, 0, 0, .4)}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-tertiary: #f1f3f5;--bg-elevated: #ffffff;--bg-hover: #e9ecef;--border-primary: #dee2e6;--border-secondary: #ced4da;--text-primary: #212529;--text-secondary: #343a40;--text-tertiary: #495057;--text-muted: #6c757d;--text-subtle: #adb5bd;--accent-primary: #0066cc;--accent-hover: #0052a3;--accent-glow: rgba(0, 102, 204, .2);--code-bg: #f8f9fa;--code-inline-bg: #e9ecef;--code-text: #d63384;--gradient-start: #4a90e2;--gradient-end: #7b68ee;--shadow: rgba(0, 0, 0, .1)}html{width:100vw;height:100vh;height:100dvh;font-size:100%}@media (width < 1024px) or (height < 700px){html{font-size:90%}}@media (width < 768px) or (height < 500px){html{font-size:80%}}@media (height < 500px){.hide_short{display:none}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background-color:var(--bg-primary);color:var(--text-secondary);line-height:1.6;transition:background-color var(--transition-speed),color var(--transition-speed);width:100%;height:100%;font-size:100%}#app{width:100%;height:100%;display:flex;overflow:clip}.sidebar{width:280px;background-color:var(--bg-secondary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;overflow-y:auto;transition:background-color var(--transition-speed),border-color var(--transition-speed)}.sidebar-header{display:flex;flex-direction:column;justify-content:center;padding-top:12px;padding-left:24px;border-bottom:1px solid var(--border-primary);transition:border-color var(--transition-speed)}.top-bar-left .sidebar-header{transform:translate(-100%)}@media (width < 768px){.sidebar{width:0}.top-bar-left .sidebar-header{padding-left:6px;transform:translate(0)}.hero .hero-title{display:none}}.site-title{font-size:20px;font-weight:600;color:var(--text-primary);transition:color var(--transition-speed)}.site-slogan{font-size:14px;color:var(--text-muted);font-style:italic;transition:color var(--transition-speed)}.handwritten{font-family:rockie,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.nav{padding:16px 8px;flex:1}.nav-item{position:relative;width:100%;display:flex;align-items:center;gap:10px;padding:8px 12px;margin-bottom:2px;background:none;border:none;color:var(--text-tertiary);font-size:14px;text-align:left;cursor:pointer;border-radius:6px;transition:all var(--transition-speed)}.nav-item.soon .nav-icon,.nav-item.soon .nav-description{opacity:.4}.nav-item:hover{background-color:var(--bg-elevated);color:var(--text-primary)}.nav-item.active{background-color:var(--bg-hover);color:var(--text-primary)}.nav-icon{font-size:16px}.nav-description{line-height:1.7}.love{color:var(--text-primary);position:absolute;right:0;top:0;padding:1px 5px}.nav-section-title{padding:8px 12px;font-size:12px;color:var(--text-subtle);text-transform:uppercase;letter-spacing:.5px;font-weight:600;transition:color var(--transition-speed)}.main-content{flex:1;overflow-y:auto;background-color:var(--bg-primary);display:flex;flex-direction:column;transition:background-color var(--transition-speed)}.top-bar,.sidebar-header{height:73px;flex-shrink:0}.top-bar{display:flex;justify-content:space-between;align-items:center;padding:16px 40px;border-bottom:1px solid var(--border-primary);background-color:var(--bg-secondary);z-index:100;transition:all var(--transition-speed)}.top-bar-left{flex:1;overflow:clip}.top-bar-right{display:flex;align-items:center;gap:16px}.btn,.home-button{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--text-tertiary);font-size:14px;cursor:pointer;padding:8px 12px;border-radius:6px;transition:all var(--transition-speed);font-weight:500}.home-button:hover{background-color:var(--bg-elevated);color:var(--text-primary)}.home-icon{font-size:16px}.home-text{display:inline}@media (max-width: 768px){.home-text{display:none}}.btn{display:flex;justify-content:center;align-items:center;gap:5px}.icon{font-size:24px;display:flex;justify-content:center;align-items:center}.theme-toggle{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background-color var(--transition-speed)}.theme-toggle:hover{background-color:var(--bg-elevated)}.theme-toggle-icon{width:24px;height:24px;position:relative}.theme-toggle-icon svg{width:24px;height:24px;position:absolute;top:0;left:0;transition:all .4s cubic-bezier(.4,0,.2,1)}.theme-toggle-icon .sun{color:#ff8c42;stroke:#ff8c42}.theme-toggle-icon .moon{color:#e8e8e8;stroke:#e8e8e8}.theme-toggle-icon.dark .sun{opacity:0;transform:rotate(90deg) scale(.8)}.theme-toggle-icon.dark .moon,.theme-toggle-icon.light .sun{opacity:1;transform:rotate(0) scale(1)}.theme-toggle-icon.light .moon{opacity:0;transform:rotate(-90deg) scale(.8)}.sign-in-btn{background-color:var(--accent-primary);color:#fff;border:none;padding:8px 20px;font-size:14px;font-weight:500;border-radius:6px;cursor:pointer;transition:all var(--transition-speed)}.sign-in-btn:hover{background-color:var(--accent-hover);transform:translateY(-1px)}.user-menu{display:flex;align-items:center;gap:12px}.user-name{font-size:14px;color:var(--text-secondary);font-weight:500;transition:color var(--transition-speed)}.sign-out-btn{background:none;border:1px solid var(--border-secondary);color:var(--text-tertiary);padding:6px 16px;font-size:14px;border-radius:6px;cursor:pointer;transition:all var(--transition-speed)}.sign-out-btn:hover{background-color:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-secondary)}.home{max-width:900px;margin:0 auto;padding:60px 40px;width:100%}.hero{margin-bottom:60px}.hero-title{font-size:3rem;font-weight:700;color:var(--text-primary);margin-bottom:16px;line-height:1.2;transition:color var(--transition-speed)}.hero-description{font-size:18px;color:var(--text-muted);line-height:1.7;max-width:700px;transition:color var(--transition-speed)}.articles-grid{display:grid;gap:24px}.article-card{position:relative;background-color:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:12px;padding:28px;cursor:pointer;transition:all var(--transition-speed)}.article-card.soon .article-card-header,.article-card.soon .article-description,.article-card.soon .read-more{opacity:.3}.article-card:hover{border-color:var(--border-secondary);transform:translateY(-2px);box-shadow:0 8px 24px var(--shadow)}.article-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:16px}.article-author-date{display:flex;flex-direction:column;align-items:flex-end;height:1em}.article-card h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);line-height:1.3;transition:color var(--transition-speed)}.article-date,.article-author{font-size:13px;color:var(--text-subtle);white-space:nowrap;margin-top:4px;transition:color var(--transition-speed)}.article-description{font-size:15px;color:var(--text-muted);margin-bottom:16px;line-height:1.6;transition:color var(--transition-speed)}.read-more{background:none;border:none;color:var(--accent-primary);font-size:14px;font-weight:500;cursor:pointer;padding:0;transition:color var(--transition-speed)}.read-more:hover{color:var(--accent-hover)}.article-detail{max-width:800px;margin:0 auto;padding:20px 40px;width:100%;display:flex;flex-direction:column;gap:30px}.back-button{background:none;border:none;color:var(--text-muted);font-size:14px;cursor:pointer;padding:8px 0;margin-bottom:24px;transition:color var(--transition-speed);display:inline-block}.back-button:hover{color:var(--text-primary)}.article-title{font-size:2.5rem;font-weight:700;color:var(--text-primary);margin-bottom:16px;line-height:1.2;transition:color var(--transition-speed)}.article-meta{font-size:14px;color:var(--text-subtle);display:flex;align-items:center;gap:8px;transition:color var(--transition-speed)}.separator{color:var(--text-subtle);transition:color var(--transition-speed)}.article-content h1{font-size:36px;font-weight:700;color:var(--text-primary);margin:48px 0 20px;line-height:1.3;transition:color var(--transition-speed)}.article-content h1:first-child{margin-top:0}.article-content h2,.h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:40px 0 16px;line-height:1.3;transition:color var(--transition-speed)}.article-content h3{font-size:1.3rem;font-weight:600;color:var(--text-primary);margin:32px 0 12px;line-height:1.4;transition:color var(--transition-speed)}.article-content p{font-size:16px;color:var(--text-tertiary);margin-bottom:16px;line-height:1.7;transition:color var(--transition-speed)}.article-content ul{margin:16px 0 16px 24px}.article-content li{font-size:16px;color:var(--text-tertiary);margin-bottom:8px;line-height:1.7;transition:color var(--transition-speed)}.article-content code{background-color:var(--code-inline-bg);color:var(--text-secondary);padding:3px 8px;border-radius:4px;font-family:Courier New,monospace;font-size:14px;transition:all var(--transition-speed)}.article-content pre{background-color:var(--code-bg);border:1px solid var(--border-primary);border-radius:8px;padding:20px;overflow-x:auto;margin:24px 0;transition:all var(--transition-speed)}.article-content pre code{background:none;color:var(--text-secondary);padding:0;font-size:14px;line-height:1.6}.article-footer{margin-top:60px;padding-top:40px;border-top:1px solid var(--border-primary);transition:border-color var(--transition-speed)}.join-section{background:linear-gradient(135deg,var(--gradient-start) 0%,var(--gradient-end) 100%);border-radius:12px;padding:40px;transition:all var(--transition-speed);display:flex;flex-direction:column;align-items:center;text-align:center}.join-section h3{font-size:1.3rem;font-weight:600;color:#fff;margin-bottom:12px}.join-description{font-size:15px;color:#ffffffe6;line-height:1.6;margin-bottom:28px;max-width:600px}.inline-download-form{display:flex;flex-direction:column;gap:12px;width:100%;max-width:400px}.inline-email-input{flex:1;padding:14px 16px;font-size:15px;border:2px solid rgba(255,255,255,.3);border-radius:8px;background-color:#fffffff2;color:#1a1a1a;transition:all var(--transition-speed)}.inline-email-input:focus{outline:none;border-color:#fff;background-color:#fff;box-shadow:0 0 0 3px #fff3}.inline-email-input::placeholder{color:#6c757d}.inline-submit-btn{background-color:#fff;color:var(--gradient-start);border:none;padding:14px 24px;font-size:15px;font-weight:600;border-radius:8px;cursor:pointer;transition:all var(--transition-speed);white-space:nowrap}.inline-submit-btn:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0003}.download-ready{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:400px}.download-button{background-color:#fff;color:var(--gradient-start);border:none;padding:14px 32px;font-size:16px;font-weight:600;border-radius:8px;cursor:pointer;transition:all var(--transition-speed);display:inline-block}.download-button:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0003}.download-ready-text{font-size:14px;color:#fffc;margin:0}.inline-email-sent{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:400px;padding:20px;background-color:#ffffff1a;border-radius:8px}.email-check{width:48px;height:48px;background-color:#ffffffe6;color:#22c55e;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700}.inline-email-sent p{font-size:15px;color:#fff;margin:0;text-align:center}.loading-dots{display:flex;gap:6px;margin-top:8px}.loading-dots span{width:8px;height:8px;background-color:#fff9;border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:16px;padding:40px;max-width:480px;width:90%;position:relative;animation:slideUp .3s ease-out;transition:background-color var(--transition-speed),border-color var(--transition-speed)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:28px;color:var(--text-muted);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all var(--transition-speed);z-index:2}.modal-close:hover{background-color:var(--bg-hover);color:var(--text-primary)}.modal-title{font-size:28px;font-weight:600;color:var(--text-primary);margin-bottom:12px;transition:color var(--transition-speed);text-align:center}.modal-description{font-size:15px;color:var(--text-muted);margin-bottom:32px;line-height:1.6;transition:color var(--transition-speed);text-align:center}.auth-form{display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.form-group{display:flex;flex-direction:column;gap:2px}.form-group label{font-size:14px;font-weight:500;color:var(--text-secondary);transition:color var(--transition-speed)}.form-group input{padding:12px 16px;font-size:15px;border:1px solid var(--border-secondary);border-radius:8px;background-color:var(--bg-tertiary);color:var(--text-primary);transition:all var(--transition-speed)}.form-group input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 1px 1px 1px var(--accent-primary)}.auth-submit-btn{background-color:var(--accent-primary);color:#fff;border:none;padding:14px 24px;font-size:16px;font-weight:500;border-radius:8px;cursor:pointer;transition:all var(--transition-speed);display:flex;gap:10px;justify-content:center;align-items:center}.auth-submit-btn:hover{background-color:var(--accent-hover);transform:translateY(-1px);min-width:300px}button[disabled]{background-color:var(--bg-elevated);color:var(--text-muted)}.auth-note{text-align:center;font-size:12px;color:var(--text-subtle);line-height:1.5;padding:5px 10px;border-radius:8px;transition:all var(--transition-speed)}.access-confirm{position:absolute;background:var(--bg-primary);left:0;top:100%;transform:translate(0);transition:transform .3s ease}.access-confirm.submitted{transform:translateY(-100%)}.email-sent{text-align:center;padding:20px 50px}.email-icon{font-size:64px;margin-bottom:24px}.email-sent h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:16px;transition:color var(--transition-speed)}.email-sent p{font-size:15px;color:var(--text-tertiary);margin-bottom:12px;transition:color var(--transition-speed)}.email-sent strong{color:var(--text-primary);transition:color var(--transition-speed)}.email-note{color:var(--text-muted);font-size:14px;margin-top:16px!important}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;margin:32px auto 0;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary);transition:background-color var(--transition-speed)}::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:4px;transition:background-color var(--transition-speed)}::-webkit-scrollbar-thumb:hover{background:var(--text-subtle)}@media (max-width: 768px){.app-container{flex-direction:column}.sidebar{display:none}.main-content{height:100vh}.top-bar{padding:12px 20px;position:relative}.home{padding:32px 24px}.hero-title{font-size:36px}.article-detail{padding:32px 24px 60px}.modal-content,.join-section{padding:32px 24px}.join-section h3{font-size:1.3rem}.inline-download-form,.inline-email-sent,.download-ready{max-width:100%}}.avatar{width:20px;height:20px;border-radius:50%;overflow:hidden;display:inline-block;vertical-align:middle;background-color:#ddd}.avatar img{width:100%;height:100%;display:block;object-fit:cover}.avatar--initials{display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#fff;background-color:#6a9955;-webkit-user-select:none;user-select:none}.avatar--with-border{box-shadow:0 0 0 1px #00000014 inset}.avatar:focus{outline:2px solid #268bd2;outline-offset:2px}.join{background:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:16px;padding:30px;max-width:1200px;width:100%}.join-title{color:var(--text-secondary);font-size:2.5rem;font-weight:700;margin-bottom:16px;line-height:1.2}.join-description{color:var(--text-muted);font-size:1.125rem;margin-bottom:32px;line-height:1.6}.join-form{display:flex;gap:12px;align-items:stretch}input:placeholder-shown{border:1px solid var(--accent-primary)}.email{flex:1;background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:8px;padding:16px 20px;color:#fff;font-size:1rem;outline:none;transition:border-color .2s}.email::placeholder{color:#666}.email:focus,.email:hover{border-color:#6366f1b3}.join-button{background:#6366f1b3;color:#fff;border:3px solid transparent;border-radius:8px;padding:16px 32px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}.join-button:hover{background:#6366f180;border-color:#6366f1e6}.join-button:active{transform:scale(.98)}@media (max-width: 768px){.join{padding:32px 24px}.join-title{font-size:2rem}.join-description{font-size:1rem}.join-form{flex-direction:column}.join-button{width:100%}}.block.code{font-family:Menlo,Consolas,monospace;font-size:.9em;color:var(--text-secondary)}.block .line{color:var(--text-secondary)}.line .number{color:#b5cea8}.line .unknown{color:var(--text-secondary)}.line .operator{color:#d4d4d4}.line .bracket{color:gold}.line .identifier{color:#4fc1ff}.line .symbol{color:#ccc}.line .comment{color:#6a9955}.line .constant-language{color:#569cd6}.line .string{color:#ce9178}.line .entity-name-tag{color:#569cd6}.line .entity-other-attribute-name{color:#9cdcfe}.line .keyword{color:#569cd6;font-weight:500}.line .storage{color:#569cd6}.line .variable{color:#9cdcfe}.line .entity-name-function{color:#dcdcaa}.line .support-class{color:#4ec9b0}.line .markup-bold{color:#569cd6;font-weight:700}.line .markup-italic{font-style:italic}.line .markup-underline{text-decoration:underline}.line .invalid{color:#f44747}a{color:var(--text-tertiary);text-decoration:underline;transition:color .2s ease,text-decoration .2s ease}a:hover{color:var(--accent-hover);text-decoration:underline}a:visited{color:var(--text-tertiary);opacity:.85}a:visited:hover{color:var(--text-secondary);text-decoration:underline;opacity:1}a:active{color:var(--accent-hover)}a:focus{outline:2px solid var(--accent-primary);outline-offset:2px;border-radius:2px}a:focus:not(:focus-visible){outline:none}a:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px;border-radius:2px}a.link-enhanced{position:relative;font-weight:500}a.link-enhanced:hover{text-shadow:0 0 8px var(--accent-glow)}a.link-underlined{text-decoration:underline;text-decoration-color:var(--accent-primary);text-decoration-thickness:1px;text-underline-offset:3px}a.link-underlined:hover{text-decoration-thickness:2px}label.label-hint{font-size:.9em;color:var(--text-muted)}
