.hanzi-writer-container{align-items:center;border:none;box-shadow:none;display:flex;flex-direction:column;gap:4px;padding:4px}.hanzi-writer-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px;width:100%}.hanzi-writer-header h4{color:#f8f8f2;font-size:16px;font-weight:600;margin:0}.hanzi-writer-footer{align-items:center;display:flex;flex-direction:column;gap:4px;margin-top:2px;width:100%}.hanzi-writer-footer h4{color:#f8f8f2;font-size:16px;font-weight:600;margin:0}.hanzi-writer-controls{align-items:center;display:flex;gap:8px}.control-btn{align-items:center;background:#f0f0f0;background:var(--theme-button-bg,#f0f0f0);border:1px solid #ccc;border:1px solid var(--theme-button-border,#ccc);border-radius:6px;color:#333;color:var(--theme-button-text,#333);cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:500;gap:6px;height:36px;justify-content:center;min-width:36px;padding:6px 12px;transition:all .3s ease}.control-btn:hover:not(:disabled){background:#e0e0e0;background:var(--theme-button-hover,#e0e0e0);box-shadow:0 2px 8px #0003;transform:translateY(-1px)}.control-btn:active:not(:disabled){transform:translateY(0)}.control-btn:disabled{cursor:not-allowed;opacity:.6}.hanzi-writer-canvas{border:none;border-radius:8px;box-shadow:none;max-width:100%;overflow:hidden;position:relative;width:-webkit-fit-content;width:fit-content}.hanzi-writer-loading-overlay{align-items:center;background:#0000;display:flex;height:100%;justify-content:center;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:100%;z-index:10}.hanzi-writer-progress-circle{animation:spin 1s linear infinite;border:3px solid #fff3;border-radius:50%;border-top-color:#4a9eff;border-top:3px solid var(--theme-accent,#4a9eff);height:40px;width:40px}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}20%{opacity:1;transform:translate(-50%,-50%) scale(1)}80%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.8)}}.hanzi-writer-error{align-items:center;background:#3d3e384d;border:1px dashed #3d3e38;border-radius:6px;color:#f8f8f2;display:flex;font-size:14px;height:100%;justify-content:center;padding:20px}@media (max-width:768px){.hanzi-writer-container{padding:12px}.hanzi-writer-controls{gap:6px}.control-btn{font-size:12px;height:32px;min-width:32px;padding:6px 10px}}.hanzi-writer-canvas,.hanzi-writer-container{background:#0000}[data-theme=light] .hanzi-writer-progress-circle{border:3px solid #0003;border-top-color:#4a9eff;border-top:3px solid var(--theme-accent,#4a9eff)}.glyph-origin-section{margin-bottom:1.5rem}.glyph-origin-section h3{color:#fff;color:var(--theme-text-primary,#fff);font-size:1.1rem;font-weight:500;margin:0 0 1rem}.glyph-origin-section h4{color:#ccc;color:var(--theme-text-secondary,#ccc);font-size:.9rem;font-weight:600;margin:0 0 1rem;text-align:center}.historical-forms-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.historical-form-item{align-items:center;background:#2a2a2a;border:1px solid #333;border-radius:8px;padding:1rem}.glyph-origin-section,.historical-form-item{display:flex;flex-direction:column;gap:.5rem;transition:all .2s ease}.glyph-origin-section{background-color:#ffffff0d!important;border:1px solid #ffffff26!important;border-radius:12px!important;margin-bottom:1.5rem!important;padding:1.5rem!important}.glyph-origin-content{display:flex;flex-direction:column}.historical-form-item:hover{background:#333;border-color:#444;box-shadow:0 2px 8px #0003;transform:translateY(-1px)}.historical-form-header{border-bottom:1px solid #444;padding-bottom:.5rem;text-align:center;width:100%}.historical-form-period{color:#fff;color:var(--theme-text-primary,#fff);display:block;font-size:.9rem;font-weight:600}.historical-form-content{align-items:center;display:flex;flex-direction:column;gap:.5rem;width:100%}.historical-form-image{align-items:center;display:flex;justify-content:center}.character-image{border-radius:4px;max-height:80px;max-width:80px;padding:.25rem;transition:all .2s ease}.character-image.tone1{filter:brightness(0) saturate(100%) invert(27%) sepia(51%) saturate(2878%) hue-rotate(90deg) brightness(120%) contrast(110%)}.character-image.tone2{filter:brightness(0) saturate(100%) invert(27%) sepia(51%) saturate(2878%) hue-rotate(247deg) brightness(90%) contrast(97%)}.character-image.tone3{filter:brightness(0) saturate(100%) invert(27%) sepia(51%) saturate(2878%) hue-rotate(346deg) brightness(104%) contrast(97%)}.character-image.tone4{filter:brightness(0) saturate(100%) invert(47%) sepia(71%) saturate(2878%) hue-rotate(438deg) brightness(504%) contrast(37%)}.character-image:hover{box-shadow:0 2px 8px #0000004d;transform:scale(1.05)}.image-error{background:#444;border:1px solid #666;border-radius:4px;color:#ff6b6b;cursor:help;font-size:1.5rem;height:80px;width:80px}.image-error,.no-historical-forms{align-items:center;display:flex;justify-content:center}.no-historical-forms{color:#ccc;color:var(--theme-text-secondary,#ccc);flex-direction:column;font-style:italic;grid-column:1/-1;padding:2rem;text-align:center}.no-historical-forms p{font-size:.9rem;margin:.5rem 0}.glyph-origin-loading{align-items:center;color:#ccc;color:var(--theme-text-secondary,#ccc);display:flex;justify-content:center;padding:2rem}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #444;border-radius:50%;border-top-color:#66d9ef;height:20px;margin-right:.5rem;width:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.glyph-origin-error{align-items:center;color:#ff6b6b;display:flex;padding:1rem}.error-content{margin-left:.5rem}.error-content p{margin:0 0 .5rem}.retry-button{background:#66d9ef;border:none;border-radius:4px;color:#2a2a2a;cursor:pointer;font-size:.9em;font-weight:500;padding:.4rem .8rem}.retry-button:hover{background:#4ecdc4}.glyph-origin-bottom-text{border-top:1px solid #ffffff1a;margin-top:1rem;padding-top:1rem}.glyph-origin-bottom-text p{color:#fff;color:var(--theme-text-primary,#fff);font-size:.9rem;font-style:italic;line-height:1.5;margin:0}@media (max-width:768px){.historical-forms-list{gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.historical-form-item{padding:.75rem}.character-image{max-height:60px;max-width:60px}.historical-form-period{font-size:.8rem}.show-more-button{font-size:.8rem;padding:.4rem .8rem}.etymology-subpanel{padding:.75rem}.etymology-title{font-size:.9rem}.etymology-content{font-size:.8rem}.glyph-origin-section{margin-bottom:.75rem;padding:1rem}}.marketing-modal-overlay{align-items:center;animation:overlayFadeIn .3s ease-out;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}@keyframes overlayFadeIn{0%{backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0);opacity:0}to{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:1}}@keyframes bannerFadeIn{0%{border-color:#ffd70000;box-shadow:0 0 0 #ffd70000,inset 0 0 0 #ffd70000;opacity:0;transform:translateY(10px) scale(.95)}to{border-color:gold;box-shadow:0 4px 12px #ffd70033,inset 0 1px 0 #ffd7001a;opacity:1;transform:translateY(0) scale(1)}}.marketing-modal{animation:marketingModalSlideIn .3s ease-out;background:#2a2a2a;background:var(--theme-background-secondary,#2a2a2a);border:1px solid #555;border-radius:12px;box-shadow:0 8px 24px #0006;max-height:90vh;max-width:450px;overflow-y:auto;width:90%}@keyframes marketingModalSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.9)}60%{opacity:.8;transform:translateY(5px) scale(1.02)}to{opacity:1;transform:translateY(0) scale(1)}}.marketing-modal-header{align-items:center;border-bottom:1px solid #555;display:flex;justify-content:space-between;padding:16px 20px 12px}.marketing-modal-title{color:var(--theme-text-primary);font-size:1.5rem;font-weight:600;margin:0}.marketing-modal-close{align-items:center;background:none;border:none;border-radius:4px;color:var(--theme-text-secondary);cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;padding:4px;transition:all .2s ease;width:32px}.marketing-modal-close:hover{background-color:#555;color:#fff}.marketing-modal-content{padding:20px}.marketing-banner{animation:bannerFadeIn .5s ease-out .2s both,bannerShimmer 8s ease-in-out .7s infinite;background:linear-gradient(135deg,var(--background-color) 0,var(--background-color-secondary) 50%,var(--background-color) 100%);border:1px solid gold;border-radius:8px;box-shadow:0 4px 12px #ffd70033,inset 0 1px 0 #ffd7001a;margin-bottom:20px;overflow:hidden;padding:16px;position:relative}.marketing-banner:before{animation:bannerShine 3s ease-in-out infinite;background:linear-gradient(45deg,#0000,#3b82f61a,#8b5cf61a,#ffffff1a,#0000);content:"";height:200%;left:-50%;pointer-events:none;position:absolute;top:-50%;width:200%}.marketing-banner-content{align-items:center;display:flex;gap:16px}.marketing-banner-icon-inline{align-items:center;animation:coinSpin 4s ease-in-out infinite,coinGlow 3s ease-in-out infinite alternate,coinPulse 2s ease-in-out infinite;display:inline-flex;filter:drop-shadow(0 0 8px rgba(255,215,0,.6));margin-right:8px;vertical-align:middle}@keyframes coinSpin{0%{transform:rotateY(0deg)}15%{transform:rotateY(180deg)}50%{transform:rotateY(180deg)}65%{transform:rotateY(0deg)}to{transform:rotateY(0deg)}}@keyframes coinGlow{0%{filter:drop-shadow(0 0 8px rgba(255,215,0,.6)) drop-shadow(0 0 12px rgba(59,130,246,.3))}50%{filter:drop-shadow(0 0 12px rgba(255,215,0,.8)) drop-shadow(0 0 18px rgba(139,92,246,.4))}to{filter:drop-shadow(0 0 16px rgba(255,215,0,.9)) drop-shadow(0 0 24px rgba(255,165,0,.4)) drop-shadow(0 0 20px rgba(59,130,246,.3))}}@keyframes coinPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes bannerShimmer{0%,to{box-shadow:0 4px 12px #ffd7002e,inset 0 1px 0 #ffd7001a,0 0 20px #3b82f614}50%{box-shadow:0 4px 12px #ffd70038,inset 0 1px 0 #ffd7001f,0 0 20px #3b82f61a}}@keyframes bannerShine{0%{transform:translateX(-100%) translateY(-100%) rotate(45deg)}to{transform:translateX(100%) translateY(100%) rotate(45deg)}}.marketing-banner-text h3{color:gold;font-size:1.1rem;font-weight:700;line-height:1.3;margin:0 0 8px;text-align:left;text-shadow:0 1px 2px #0000004d}.marketing-banner-text p{color:var(--text-color);font-size:.9rem;line-height:1.4;margin:0;opacity:.9;text-align:left;text-shadow:0 1px 2px #0000001a}.marketing-text-mobile{display:none}.marketing-text-desktop{display:inline}@media (max-width:768px){.marketing-text-mobile{display:inline}.marketing-text-desktop{display:none}}.marketing-form{display:flex;flex-direction:column;gap:18px}.marketing-form-group{display:flex;flex-direction:column;gap:8px}.marketing-form-group label{color:var(--theme-text-primary);font-size:.875rem;font-weight:500;text-align:left}.marketing-input{background-color:#1a1a1a;background-color:var(--theme-background,#1a1a1a);border:1px solid #555;border-radius:8px;color:#fff;color:var(--theme-text-primary,#fff);font-size:1rem;outline:none;padding:14px 18px;transition:all .2s ease}.marketing-input:focus{border-color:gold;box-shadow:0 0 0 3px #ffd7001a}.marketing-input::placeholder{color:var(--theme-text-tertiary)}.marketing-button{animation:buttonGlow 2s ease-in-out infinite alternate;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;outline:none;padding:14px 24px;text-align:center;transition:all .3s ease}.marketing-button:disabled{cursor:not-allowed;opacity:.6}.marketing-button-primary{animation:shimmer 3s ease-in-out infinite;background:linear-gradient(135deg,#ff6b35,#f7931e 25%,#fdc830 50%,#f7931e 75%,#ff6b35);background-size:200% 100%;border:2px solid orange;color:#1a1a1a;font-weight:600;overflow:hidden;position:relative;text-shadow:0 1px 2px #ffffff4d}@keyframes shimmer{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.marketing-button-primary:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.marketing-button-primary:hover:not(:disabled):before{left:100%}.marketing-button-primary:hover:not(:disabled){background:linear-gradient(135deg,orange,gold 25%,#fff4cc 50%,gold 75%,orange);background-size:200% 100%;border-color:gold;box-shadow:0 8px 24px #ffa50080,0 0 20px #ffd7004d;transform:translateY(-2px) scale(1.02)}.marketing-button-primary:active:not(:disabled){box-shadow:0 4px 12px #ffa50066;transform:translateY(0) scale(1)}.button-coin{margin-left:4px;transform:translateY(-1px);vertical-align:middle}.marketing-form-links{display:flex;flex-direction:column;gap:8px;margin-top:12px}.marketing-link{background:none;border:none;color:gold;cursor:pointer;font-size:.875rem;font-weight:500;padding:6px 0;text-align:left;transition:color .2s ease}.marketing-link:hover{color:orange;text-decoration:underline}.marketing-error{background-color:#f8717126;border:1px solid #f871714d;border-radius:8px;color:#f87171}.marketing-error,.marketing-success{font-size:.875rem;margin-bottom:16px;padding:12px 16px}.marketing-success{background-color:#22c55e1a;border:1px solid #22c55e33;border-radius:8px;color:#22c55e}@media (max-width:768px){.marketing-modal-overlay{align-items:flex-start;padding:20px 10px 10px}.marketing-modal{border-radius:8px;margin:0;max-height:calc(100vh - 40px);max-width:100%;width:100%}.marketing-input{-webkit-text-size-adjust:100%;-webkit-appearance:none;border-radius:8px;font-size:16px!important}.marketing-modal{margin-bottom:20px;position:relative;top:0;transform:none}.marketing-modal-overlay{-webkit-overflow-scrolling:touch;overflow-y:auto;position:fixed}.marketing-modal-header{padding:12px 16px 8px}.marketing-modal-content{padding:16px}.marketing-modal-title{font-size:1.125rem}.marketing-banner{margin-bottom:16px;padding:12px}.marketing-banner-content{flex-direction:column;gap:8px;text-align:left}.marketing-banner-text h3{font-size:.95rem;margin-bottom:4px}.marketing-banner-text p{font-size:.8rem}.marketing-form{gap:14px}.marketing-form-group label{font-size:.8rem}.marketing-input{font-size:16px;padding:12px 14px}.marketing-button{font-size:.9rem;padding:12px 20px}.marketing-form-links{gap:6px;margin-top:10px}.marketing-link{font-size:.8rem;padding:4px 0}.marketing-error,.marketing-success{font-size:.8rem;margin-bottom:12px;padding:10px 12px}}@media (max-width:480px){.marketing-modal-overlay{padding:10px 5px 5px}.marketing-modal{border-radius:6px;max-height:calc(100vh - 20px)}.marketing-modal-header{padding:10px 12px 6px}.marketing-modal-content{padding:12px}.marketing-modal-title{font-size:1rem}.marketing-banner{margin-bottom:12px;padding:10px}.marketing-banner-text h3{font-size:.9rem}.marketing-banner-text p{font-size:.75rem}.marketing-form{gap:12px}.marketing-form-group label{font-size:.75rem}.marketing-input{font-size:16px;padding:10px 12px}.marketing-button{font-size:.85rem;padding:10px 16px}.marketing-form-links{gap:4px;margin-top:8px}.marketing-link{font-size:.75rem;padding:3px 0}.marketing-error,.marketing-success{font-size:.75rem;margin-bottom:10px;padding:8px 10px}}[data-theme=dark] .marketing-input:focus{box-shadow:0 0 0 3px #ffd70033}.marketing-form{animation:marketingFormFadeIn .4s ease-out .1s both}@keyframes marketingFormFadeIn{0%{opacity:0;transform:translateX(20px) translateY(10px)}60%{opacity:.7;transform:translateX(-2px) translateY(-2px)}to{opacity:1;transform:translateX(0) translateY(0)}}@keyframes buttonGlow{0%{box-shadow:0 4px 12px #3b82f633}to{box-shadow:0 6px 20px #3b82f64d,0 0 15px #8b5cf633}}.auth-modal-overlay{align-items:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.auth-modal{animation:authModalSlideIn .3s ease-out;background:#2a2a2a;background:var(--theme-background-secondary,#2a2a2a);border:1px solid #555;border-radius:8px;box-shadow:0 4px 12px #0000004d;max-height:90vh;max-width:400px;overflow-y:auto;width:90%}@keyframes authModalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-modal-header{align-items:center;border-bottom:1px solid #555;display:flex;justify-content:space-between;padding:16px 20px 12px}.auth-modal-title{color:var(--theme-text-primary);font-size:1.5rem;font-weight:600;margin:0}.auth-modal-close{align-items:center;background:none;border:none;border-radius:4px;color:var(--theme-text-secondary);cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;padding:4px;transition:all .2s ease;width:32px}.auth-modal-close:hover{background-color:#555;color:#fff}.auth-modal-content{padding:20px}.auth-form{gap:16px}.auth-form,.auth-form-group{display:flex;flex-direction:column}.auth-form-group{gap:6px}.auth-form-group label{color:var(--theme-text-primary);font-size:.875rem;font-weight:500}.auth-input{background-color:#1a1a1a;background-color:var(--theme-background,#1a1a1a);border:1px solid #555;border-radius:4px;color:#fff;color:var(--theme-text-primary,#fff);font-size:1rem;outline:none;padding:12px 16px;transition:all .2s ease}.auth-input:focus{border-color:var(--theme-accent);box-shadow:0 0 0 3px #3b82f61a}.auth-input::placeholder{color:var(--theme-text-tertiary)}.auth-button{border:none;border-radius:8px;font-size:1rem;padding:12px 24px;text-align:center}.auth-button:disabled{cursor:not-allowed;opacity:.6}.auth-button-primary:hover:not(:disabled){background-color:var(--theme-accent-hover);box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.auth-button-primary:active:not(:disabled){transform:translateY(0)}.auth-form-links{display:flex;flex-direction:column;gap:8px;margin-top:8px}.auth-link{background:none;border:none;color:var(--theme-accent);cursor:pointer;font-size:.875rem;padding:4px 0;text-align:left;transition:color .2s ease}.auth-link:hover{color:var(--theme-accent-hover);text-decoration:underline}.auth-error{background-color:#ef44441a;border:1px solid #ef444433;border-radius:8px;color:#ef4444}.auth-error,.auth-success{font-size:.875rem;margin-bottom:16px;padding:12px 16px}.auth-success{background-color:#22c55e1a;border:1px solid #22c55e33;border-radius:8px;color:#22c55e}@media (max-width:480px){.auth-modal{margin:20px;width:95%}.auth-modal-header{padding:16px 20px 12px}.auth-modal-content{padding:20px}.auth-modal-title{font-size:1.25rem}}[data-theme=dark] .auth-input:focus{box-shadow:0 0 0 3px #3b82f633}.auth-form{animation:authFormFadeIn .3s ease-out}@keyframes authFormFadeIn{0%{opacity:0;transform:translateX(10px)}to{opacity:1;transform:translateX(0)}}.auth-button-container{align-items:center;display:flex;gap:1rem}.auth-button{align-items:center;background-color:var(--theme-background-secondary);border:1px solid var(--theme-border);border-radius:6px;color:var(--theme-text-primary);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;justify-content:center;line-height:1;outline:none;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.auth-button:hover{background-color:var(--theme-background-tertiary);border-color:var(--theme-accent);transform:translateY(-1px)}.auth-button:active{transform:translateY(0)}.auth-button-primary{background-color:var(--theme-accent);border-color:var(--theme-accent);color:#fff}.auth-button-primary:hover{background-color:var(--theme-accent-hover);border-color:var(--theme-accent-hover)}.auth-button-signout{border-color:var(--theme-border);color:var(--theme-text-secondary)}.auth-button-signout:hover{background-color:#ef44441a;border-color:#ef4444;color:#ef4444}.auth-signout-button:hover{background-color:#ef44441a!important;border-color:#ef4444!important;color:#ef4444!important}.auth-user-info{align-items:flex-end;display:flex;flex-direction:column;gap:4px}.auth-status-line,.auth-user-line{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.auth-username{color:var(--theme-text-primary);font-size:.875rem;font-weight:500;line-height:1}.auth-email{color:var(--theme-text-secondary);font-size:.75rem;line-height:1}.auth-user-type{border-radius:12px;display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.5px;line-height:1;margin-top:2px;padding:4px 10px;text-transform:uppercase}.auth-user-type.intro{background:linear-gradient(135deg,#e3f2fd,#90caf9);border:1px solid #64b5f6;box-shadow:0 2px 4px #2196f333;color:#0d47a1}.auth-user-type.subscriber{background:linear-gradient(135deg,#4caf50,#2196f3);border:1px solid #4caf50;box-shadow:0 2px 6px #2196f34d;color:#fff;text-shadow:0 1px 2px #0003}.auth-user-type.lifetime{background:linear-gradient(135deg,gold,orange);border:1px solid gold;box-shadow:0 2px 6px #ffd7004d;color:#fff;font-weight:700;text-shadow:0 1px 2px #0003}.auth-subscribed-badge{background:linear-gradient(135deg,#4caf50,#2196f3);border:1px solid #4caf50;border-radius:12px;box-shadow:0 2px 6px #2196f34d;color:#fff;display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.5px;line-height:1;margin-top:2px;padding:4px 10px;text-shadow:0 1px 2px #0003;text-transform:uppercase}.auth-coin-display{align-items:center;background-color:#0000001a;border:1px solid #ffd7004d;border-radius:12px;display:flex;gap:4px;padding:4px 8px}.auth-coin-count{color:var(--theme-text-primary);font-size:.75rem;font-weight:600;line-height:1}@media (max-width:768px){.auth-user-type{font-size:.65rem;padding:1px 4px}.auth-user-info{gap:2px}.auth-status-line,.auth-user-line{gap:6px}.auth-coin-display{padding:3px 6px}.auth-email,.auth-username{display:none}.auth-user-info{align-items:center;flex-direction:column;gap:4px}.auth-user-line{display:none}.auth-status-line{align-items:center;flex-direction:column;gap:4px}}.auth-loading{align-items:center;display:flex;justify-content:center;padding:8px 16px}.auth-spinner{animation:authSpinner 1s linear infinite;border-top:2px solid var(--theme-border);border:2px solid var(--theme-border);border-radius:50%;border-top-color:var(--theme-accent);height:16px;width:16px}@keyframes authSpinner{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.auth-button-container{gap:.5rem}.auth-button{padding:6px 12px}.auth-button,.auth-username{font-size:.8rem}.auth-email{font-size:.7rem}.auth-signout-button,.auth-subscribed-badge{display:none}}@media (max-width:480px){.auth-button-container{align-items:stretch;flex-direction:column;gap:.5rem}.auth-button{font-size:.8rem;padding:8px 12px;text-align:center}.auth-user-info{align-items:center}.auth-status-line,.auth-user-line{gap:4px;justify-content:center}}[data-theme=dark] .auth-button{box-shadow:0 1px 3px #0003}[data-theme=dark] .auth-button:hover{box-shadow:0 2px 6px #0000004d}.auth-button:focus-visible{outline:2px solid var(--theme-accent);outline-offset:2px}.auth-user-info{animation:authUserInfoSlideIn .3s ease-out}@keyframes authUserInfoSlideIn{0%{opacity:0;transform:translateX(10px)}to{opacity:1;transform:translateX(0)}}.hamburger-menu-container{display:inline-block;position:relative;z-index:9999!important}.hamburger-menu-button{align-items:center;display:flex;justify-content:center;line-height:1;padding:8px 16px}.hamburger-icon{display:flex;flex-direction:column;height:14px;justify-content:space-between;width:20px}.hamburger-icon span{background-color:currentColor;border-radius:2px;display:block;height:2px;transition:all .3s ease;width:100%}.hamburger-menu-dropdown{animation:slideDown .2s ease-out!important;background:#2d2d2d!important;border:1px solid #444!important;border-radius:6px!important;box-shadow:0 4px 12px #0000004d!important;min-width:180px!important;overflow:hidden!important}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.hamburger-menu-item{align-items:center;background:none;border:none;color:#ccc;cursor:pointer;display:flex;font-size:14px;gap:10px;padding:12px 16px;text-align:left;transition:all .2s ease;width:100%}.hamburger-menu-item:hover{background-color:#3a3a3a;color:#fff}.hamburger-menu-item:active{background-color:#444}.hamburger-menu-item .menu-icon{display:inline-block;font-size:18px;text-align:center;width:20px}.hamburger-menu-item:not(:last-child){border-bottom:1px solid #444}.hamburger-menu-divider{background-color:#555;border:none;height:1px;margin:4px 0}.mobile-only-menu-item{display:none}.hamburger-menu-user-info{background-color:#1a1a1a;border-bottom:1px solid #444;padding:12px 16px;text-align:center}.user-display-name{color:#fff;font-size:16px;font-weight:600;margin-bottom:4px}.user-subscription-status{color:#888;font-size:12px;letter-spacing:.5px;text-transform:uppercase}.user-subscription-status.subscribed{background:linear-gradient(135deg,#4caf50,#2196f3);border:1px solid #4caf50;border-radius:12px;box-shadow:0 2px 6px #2196f34d;color:#fff;display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.5px;line-height:1;margin-top:2px;padding:4px 10px;text-shadow:0 1px 2px #0003;text-transform:uppercase}@media (max-width:768px){.hamburger-menu-button{padding:.5rem .75rem}.hamburger-icon{height:13px;width:18px}.hamburger-icon span{height:2px}.mobile-only-menu-item{display:flex}.hamburger-menu-user-info.mobile-only-menu-item,.mobile-only-menu-item.hamburger-menu-divider{display:block}}.feedback-page{background:#0000;flex:1 1;overflow-y:auto;padding:2rem 1rem}.feedback-container{background:#ffffff0d;background:var(--theme-background-secondary,#ffffff0d);border:1px solid #ffffff1a;border:1px solid var(--theme-border-color,#ffffff1a);border-radius:8px;box-shadow:0 8px 32px #0000004d;margin:0 auto;max-width:700px}.feedback-header{align-items:center;border-bottom:1px solid #ffffff1a;border-bottom:1px solid var(--theme-border-color,#ffffff1a);display:flex;justify-content:space-between;padding:2rem 2rem 1rem}.feedback-header h1{color:#fff;color:var(--theme-text-primary,#fff);font-size:1.75rem;font-weight:600;margin:0}.feedback-close-button{background:none;border:none;border-radius:4px;color:#ccc;color:var(--theme-text-secondary,#ccc);cursor:pointer;font-size:1.5rem;line-height:1;padding:.5rem;transition:all .2s}.feedback-close-button:hover{background:#ffffff1a;background:var(--theme-background-hover,#ffffff1a);color:#fff;color:var(--theme-text-primary,#fff)}.feedback-form{padding:2rem}.feedback-form-group{margin-bottom:1.5rem}.feedback-form-group label{color:#ccc;color:var(--theme-text-primary,#ccc);display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.feedback-input,.feedback-textarea{background:#0000004d;background:var(--theme-background-secondary,#0000004d);border:1px solid #ffffff1a;border:1px solid var(--theme-border-color,#ffffff1a);border-radius:6px;box-sizing:border-box;color:#fff;color:var(--theme-text-primary,#fff);font-family:inherit;font-size:1rem;padding:.75rem;transition:all .2s;width:100%}.feedback-input:focus,.feedback-textarea:focus{background:#0006;border-color:#4a9eff;outline:none}.feedback-input:disabled{background:#0003;cursor:not-allowed;opacity:.6}.feedback-textarea{min-height:150px;resize:vertical}.feedback-form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.feedback-button{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.feedback-button:disabled{cursor:not-allowed;opacity:.5}.feedback-button-primary{background:linear-gradient(135deg,#4a9eff,#3a7ed8);color:#fff}.feedback-button-primary:hover:not(:disabled){background:linear-gradient(135deg,#5aafff,#4a8ee8);box-shadow:0 4px 12px #4a9eff4d;transform:translateY(-1px)}.feedback-button-secondary{background:#0000;border:1px solid #ffffff1a;border:1px solid var(--theme-border-color,#ffffff1a);color:#ccc;color:var(--theme-text-primary,#ccc)}.feedback-button-secondary:hover:not(:disabled){background:#3a3a3a;background:var(--theme-background-hover,#3a3a3a);border-color:#555;border-color:var(--theme-border-color,#555);color:#fff;color:var(--theme-text-primary,#fff)}.feedback-error{background:#ff4d4d1a;border:1px solid #ff4d4d4d;border-radius:6px;color:#f99;font-size:.9rem;margin-bottom:1rem;padding:1rem}.feedback-success{padding:3rem 2rem;text-align:center}.success-icon{align-items:center;background:linear-gradient(135deg,#4caf50,#45a049);border-radius:50%;color:#fff;display:flex;font-size:3rem;font-weight:700;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.feedback-success h2{color:#fff;color:var(--theme-text-primary,#fff);font-size:1.5rem;margin:0 0 1rem}.feedback-success p{color:#ccc;color:var(--theme-text-primary,#ccc);line-height:1.6;margin:.5rem 0}.feedback-success .feedback-button{margin-top:2rem}.feedback-footer{border-top:1px solid #ffffff1a;border-top:1px solid var(--theme-border-color,#ffffff1a);padding:1.5rem 2rem;text-align:center}.feedback-footer p{color:#999;color:var(--theme-text-secondary,#999);font-size:.9rem;margin:0}.feedback-footer a{color:#4a9eff;text-decoration:none}.feedback-footer a:hover{text-decoration:underline}[data-theme=light] .feedback-container{background:#ffffffe6;border:1px solid #0000001a;box-shadow:0 8px 32px #0000001a}[data-theme=light] .feedback-header{border-bottom:1px solid #0000001a}[data-theme=light] .feedback-header h1{color:#333}[data-theme=light] .feedback-close-button{color:#666}[data-theme=light] .feedback-close-button:hover{background:#0000001a;color:#333}[data-theme=light] .feedback-form-group label{color:#555}[data-theme=light] .feedback-input,[data-theme=light] .feedback-textarea{background:#fffc;border:1px solid #0003;color:#333}[data-theme=light] .feedback-input:focus,[data-theme=light] .feedback-textarea:focus{background:#fffffff2;border-color:#06c;border-width:2px;outline:none}[data-theme=light] .feedback-input:disabled{background:#0000000d;border:1px solid #0000001a}[data-theme=light] .feedback-button-secondary{border:1px solid #0000001a;color:#555}[data-theme=light] .feedback-button-secondary:hover:not(:disabled){background:#0000000d;border-color:#666;color:#333}[data-theme=light] .feedback-success h2{color:#333}[data-theme=light] .feedback-success p{color:#555}[data-theme=light] .feedback-footer{border-top:1px solid #0000001a}[data-theme=light] .feedback-footer p{color:#666}[data-theme=light] .feedback-footer a{color:#06c}[data-theme=light] .account-info-label{color:#666!important}[data-theme=light] .account-info-value{background:#fffc!important;border:1px solid #0000004d!important;color:#333!important}[data-theme=light] .verification-badge.verified{background:#22c55e1a!important;border:1px solid #22c55e33!important;color:#16a34a!important}[data-theme=light] .verification-badge.unverified{background:#ef44441a!important;border:1px solid #ef444433!important;color:#dc2626!important}[data-theme=light] .user-type-badge.intro,[data-theme=light] .user-type-badge.reader{background:#3b82f61a!important;border:1px solid #3b82f633!important;color:#2563eb!important}[data-theme=light] .user-type-badge.subscriber{background:#a855f71a!important;border:1px solid #a855f733!important;color:#9333ea!important}[data-theme=light] .coin-count{color:#d97706!important}[data-theme=light] .account-actions{border-top:1px solid #0000001a!important}@media (max-width:768px){.feedback-page{padding:.5rem}.feedback-container{border-radius:6px;margin:0;max-width:100%}.feedback-header{padding:1rem 1rem .75rem}.feedback-header h1{font-size:1.25rem}.feedback-form{padding:1rem}.feedback-form-group{margin-bottom:1rem}.feedback-form-group label{font-size:.85rem;margin-bottom:.375rem}.feedback-input,.feedback-textarea{font-size:.9rem;padding:.625rem}.feedback-textarea{min-height:120px}.feedback-form-actions{flex-direction:column-reverse;gap:.75rem;margin-top:1.5rem}.feedback-button{font-size:.9rem;padding:.625rem 1.25rem;width:100%}.feedback-success{padding:1.5rem 1rem}.success-icon{font-size:2.25rem;height:60px;margin-bottom:1rem;width:60px}.feedback-success h2{font-size:1.25rem}.feedback-success p{font-size:.9rem}.feedback-footer{padding:1rem}.feedback-footer p{font-size:.8rem}}@media (max-width:480px){.feedback-page{padding:.25rem}.feedback-header{padding:.75rem .75rem .5rem}.feedback-header h1{font-size:1.125rem}.feedback-form{padding:.75rem}.feedback-form-group{margin-bottom:.75rem}.feedback-input,.feedback-textarea{font-size:.85rem;padding:.5rem}.feedback-textarea{min-height:100px}.feedback-form-actions{gap:.5rem;margin-top:1rem}.feedback-button{font-size:.85rem;padding:.5rem 1rem}.feedback-success{padding:1rem .75rem}.success-icon{font-size:1.875rem;height:50px;margin-bottom:.75rem;width:50px}.feedback-success h2{font-size:1.125rem}.feedback-success p{font-size:.85rem}.feedback-footer{padding:.75rem}}.about-page{background:#0000;flex:1 1;overflow-y:auto;padding:2rem 1rem}.about-container{background:#ffffff0d;background:var(--theme-background-secondary,#ffffff0d);border:1px solid #ffffff1a;border:1px solid var(--theme-border,#ffffff1a);border-radius:8px;box-shadow:0 8px 32px #0000004d;box-shadow:0 8px 32px var(--theme-shadow,#0000004d);margin:0 auto;max-width:800px}.about-header{align-items:center;border-bottom:1px solid #ffffff1a;border-bottom:1px solid var(--theme-border,#ffffff1a);display:flex;justify-content:space-between;padding:2rem 2rem 1rem}.about-title{font-size:1.5rem;font-weight:300;letter-spacing:-.02em;line-height:1.2;margin:0}.about-title .about-prefix{color:#fff;color:var(--theme-text-primary,#fff)}.about-title .tone-1{color:#ff6b6b}.about-title .tone-2{color:#4ecdc4}.about-title .tone-3{color:#95e1d3}.about-title .tone-4{color:#f7dc6f}.about-close-button{background:none;border:none;border-radius:4px;color:#ccc;color:var(--theme-text-secondary,#ccc);cursor:pointer;font-size:1.5rem;line-height:1;padding:.5rem;transition:all .2s}.about-close-button:hover{background:#ffffff1a;background:var(--theme-background-hover,#ffffff1a);color:#fff;color:var(--theme-text-primary,#fff)}.about-content{padding:2rem}.about-section{margin-bottom:2.5rem}.about-section:last-child{margin-bottom:0}.about-section h2{color:#fff;color:var(--theme-text-primary,#fff);font-size:1.25rem;font-weight:600;margin:0 0 1rem}.about-section h3{color:#4a9eff;color:var(--theme-accent,#4a9eff);font-size:1.1rem;font-weight:600;margin:0 0 .75rem}.about-section p{color:#ccc;color:var(--theme-text-secondary,#ccc);line-height:1.7;margin:0 0 1rem}.about-section p:last-child{margin-bottom:0}.about-section ul{list-style:none;margin:0;padding:0}.about-section li{color:#ccc;color:var(--theme-text-secondary,#ccc);line-height:1.7;margin-bottom:.875rem;padding-left:1.5rem;position:relative}.about-section li:before{color:#4a9eff;color:var(--theme-accent,#4a9eff);content:"•";font-size:1.5rem;left:0;line-height:1.4;position:absolute}.about-section li strong{color:#fff;color:var(--theme-text-primary,#fff)}.about-section a{color:#4a9eff;color:var(--theme-accent,#4a9eff);text-decoration:none;transition:color .2s}.about-section a:hover{color:#5aafff;color:var(--theme-accent-hover,#5aafff);text-decoration:underline}[data-theme=light] .about-container{background:#ffffffe6;border:1px solid #0000001a;box-shadow:0 8px 32px #0000001a}[data-theme=light] .about-header{border-bottom:1px solid #0000001a}[data-theme=light] .about-title .about-prefix{color:#333}[data-theme=light] .about-close-button{color:#666}[data-theme=light] .about-close-button:hover{background:#0000001a;color:#333}[data-theme=light] .about-section h2{color:#333}[data-theme=light] .about-section h3{color:#06c}[data-theme=light] .about-section li,[data-theme=light] .about-section p{color:#555}[data-theme=light] .about-section li:before{color:#06c}[data-theme=light] .about-section li strong{color:#333}[data-theme=light] .about-section a{color:#06c}[data-theme=light] .about-section a:hover{color:#0052a3}@media (max-width:768px){.about-page{padding:1rem .5rem}.about-header{padding:1.5rem 1.5rem 1rem}.about-title{font-size:1.25rem}.about-content{padding:1.5rem}.about-section h2{font-size:1.125rem}.about-section h3{font-size:1rem}.about-section{margin-bottom:2rem}}.blog-page{background:#0000;flex:1 1;overflow-y:auto;padding:2rem 1rem}.blog-container{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;box-shadow:0 8px 32px #0000004d;margin:0 auto;max-width:800px}.blog-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:2rem 2rem 1rem}.blog-header h1{color:#fff;font-size:1.75rem;font-weight:600;margin:0}.blog-close-button{background:none;border:none;border-radius:4px;color:#ccc;cursor:pointer;font-size:1.5rem;line-height:1;padding:.5rem;transition:all .2s}.blog-close-button:hover{background:#ffffff1a;color:#fff}.blog-content{padding:2rem}.blog-post{border-bottom:1px solid #ffffff1a;margin-bottom:3rem;padding-bottom:3rem}.blog-post:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.blog-post-title{color:#fff;font-size:1.5rem;font-weight:600;line-height:1.3;margin:0 0 .5rem}.blog-post-meta{color:#999;font-size:.875rem;font-style:italic;margin-bottom:1.5rem}.blog-post-content{color:#ccc;font-size:1rem;line-height:1.8}.blog-post-content p{margin:0 0 1.25rem}.blog-post-content p:last-child{margin-bottom:0}@media (max-width:768px){.blog-page{padding:1rem .5rem}.blog-header{padding:1.5rem 1.5rem 1rem}.blog-header h1{font-size:1.5rem}.blog-content{padding:1.5rem}.blog-post{margin-bottom:2.5rem;padding-bottom:2.5rem}.blog-post-title{font-size:1.25rem}.blog-post-content{font-size:.9375rem;line-height:1.7}}.site-footer{background:#ffffff05;border-top:1px solid #ffffff14;color:#999;margin-top:auto;padding:2rem 0 1rem}.footer-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:700px;padding:0 2rem}.footer-section h4{color:#ccc;font-size:.8125rem;font-weight:600;letter-spacing:.5px;margin:0 0 .75rem;text-align:center;text-transform:uppercase}.footer-section ul{list-style:none;margin:0;padding:0}.footer-section li{margin-bottom:.5rem;text-align:center}.footer-link-button,.footer-section a{color:#999;display:inline-block;font-size:.875rem;text-decoration:none;transition:color .2s}.footer-link-button{background:none;border:none;cursor:pointer;font-family:inherit;padding:0;text-align:center}.footer-link-button:hover,.footer-section a:hover{color:#4a9eff}.footer-bottom{border-top:1px solid #ffffff0d;margin:1.5rem auto 0;max-width:700px;padding:1rem 2rem 0;text-align:center}.footer-bottom p{color:#666;font-size:.8125rem;margin:0}@media (max-width:768px){.site-footer{padding:1.5rem 0 1rem}.footer-content{gap:2rem;grid-template-columns:repeat(3,1fr);padding:0 1.5rem}}@media (max-width:480px){.footer-content{gap:1rem;grid-template-columns:repeat(3,1fr);padding:0 1rem}.footer-link-button,.footer-section a,.footer-section h4{font-size:.75rem}.footer-bottom{padding:1rem 1rem 0}.footer-bottom p{font-size:.75rem}}
/*# sourceMappingURL=main-2e90501a.b241dfbb.css.map*/