@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap";.navbar{height:var(--navbar-height);background:var(--bg-navbar);border-bottom:1px solid var(--border);z-index:200;transition:background var(--transition-base), border-color var(--transition-base);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:0 20px;display:flex;position:fixed;top:0;left:0;right:0}.navbar-brand{width:var(--sidebar-width);align-items:center;display:flex}.navbar-logo{align-items:center;text-decoration:none;display:flex}.navbar-logo-img{width:auto;height:100px;display:block}.navbar-logo-name{font-family:var(--font-heading);letter-spacing:-.01em;gap:1px;font-size:20px;font-weight:800;display:flex}.logo-ani{color:var(--text-primary)}.logo-lang{color:var(--accent)}.navbar-note{color:var(--text-muted);text-align:center;flex:1;margin:0 20px;font-size:12px;line-height:1.4}.navbar-note-label{color:var(--text-secondary);font-weight:600}.navbar-note-link{color:var(--accent);transition:color var(--transition-fast);font-weight:600;text-decoration:none}.navbar-note-link:hover{color:var(--accent-hover);text-decoration:underline}.navbar-actions{align-items:center;gap:8px;display:flex}.theme-toggle{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-hover);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.theme-toggle:hover{background:var(--accent-light);border-color:var(--accent-border);color:var(--accent)}.mobile-menu-toggle{border-radius:var(--radius-md);border:1px solid var(--border);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;margin-right:12px;display:none}.mobile-menu-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.mobile-menu-toggle--active{background:var(--accent-light);border-color:var(--accent-border);color:var(--accent)}@media (width<=900px){.navbar-note{display:none}}@media (width<=768px){.navbar-brand{width:auto}.mobile-menu-toggle{display:flex}}@media (width<=480px){.navbar{padding:0 12px}.navbar-username{max-width:70px}.navbar-user{gap:8px;margin-right:6px;padding-right:6px}.btn-navbar-logout,.btn-navbar-login{padding:5px 8px;font-size:12px}}.navbar-user{border-right:1px solid var(--border);align-items:center;gap:12px;margin-right:12px;padding-right:12px;display:flex}.navbar-username{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:120px;font-size:13px;font-weight:500;overflow:hidden}.btn-navbar-logout,.btn-navbar-login{color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:6px 12px;font-size:13px;font-weight:600;text-decoration:none}.btn-navbar-logout:hover{color:#ef4444;background:#ef44441a;border-color:#ef4444}.btn-navbar-login:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent-border)}.btn-navbar-edit-profile{color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;width:30px;height:30px;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex}.btn-navbar-edit-profile:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent-border)}.sidebar{top:var(--navbar-height);width:var(--sidebar-width);height:calc(100vh - var(--navbar-height));background:var(--bg-sidebar);border-right:1px solid var(--border);z-index:100;transition:background var(--transition-base), border-color var(--transition-base);flex-direction:column;justify-content:space-between;padding:16px 12px;display:flex;position:fixed;left:0;overflow-y:auto}.sidebar-nav{flex-direction:column;gap:2px;display:flex}.sidebar-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);letter-spacing:.01em;align-items:center;gap:10px;padding:9px 12px;font-size:13px;font-weight:500;text-decoration:none;display:flex}.sidebar-link:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-link--active{background:var(--accent-light);color:var(--accent);font-weight:600}.sidebar-link--active .sidebar-link-icon{color:var(--accent)}.sidebar-link-icon{color:inherit;flex-shrink:0;align-items:center;display:flex}.sidebar-link-label{text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:600}.sidebar-footer{display:none}@media (width<=768px){.sidebar{transition:transform var(--transition-base), background var(--transition-base), border-color var(--transition-base);z-index:110;box-shadow:var(--shadow-lg);transform:translate(-100%)}.sidebar.sidebar--open{transform:translate(0,0)}.sidebar-footer{border-top:1px solid var(--border);margin-top:24px;padding-top:16px;padding-bottom:28px;display:block}.sidebar-note{color:var(--text-secondary);text-align:center;padding:0 4px;font-size:11px;line-height:1.45}.sidebar-note-label{color:var(--text-primary);font-weight:700}.sidebar-note-link{color:var(--accent);font-weight:600;text-decoration:none}.sidebar-note-link:hover{text-decoration:underline}}.sidebar-user{flex-direction:column;gap:8px;padding:4px 12px;display:flex}.sidebar-username{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.btn-sidebar-logout{border:1px solid var(--border);color:#ef4444;border-radius:var(--radius-sm);cursor:pointer;text-align:center;width:100%;transition:all var(--transition-fast);background:0 0;padding:6px 10px;font-size:11px;font-weight:600}.btn-sidebar-logout:hover{background:#ef44440d;border-color:#ef4444}.acard{border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;min-height:380px;transition:border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base);outline:none;flex-direction:column;justify-content:flex-end;animation:.4s ease-out both cardIn;display:flex;position:relative;overflow:hidden}@keyframes cardIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.acard:hover,.acard:focus-visible{border-color:var(--accent-border);box-shadow:var(--shadow-lg), 0 0 0 1px var(--accent-border);transform:translateY(-3px)}.acard-bg-img{object-fit:cover;z-index:0;width:100%;height:100%;transition:transform .5s;display:block;position:absolute;inset:0}.acard:hover .acard-bg-img{transform:scale(1.05)}.acard-gradient{z-index:1;transition:background var(--transition-base);background:linear-gradient(#0000 28%,#00000059 48%,#000000bf 72%,#000000eb 100%);position:absolute;inset:0}.acard:hover .acard-gradient{background:linear-gradient(#0000 28%,#00000061 48%,#000000c7 72%,#000000f2 100%)}.acard-genre-tag{z-index:2;text-transform:uppercase;letter-spacing:.08em;color:#ffffffe6;-webkit-backdrop-filter:blur(6px);border-radius:var(--radius-full);background:#0006;border:1px solid #ffffff26;padding:4px 10px;font-size:10px;font-weight:600;position:absolute;top:12px;left:12px}.acard-body{z-index:2;background:0 0;border-top:none;flex-direction:column;gap:10px;padding:16px;display:flex;position:relative}.acard-name{font-family:var(--font-heading);color:#fff;font-size:18px;font-weight:700;line-height:1.2}.acard-fullname{color:#ffffff8c;margin-top:3px;font-size:11px}.acard-desc{color:#ffffffb3;font-size:12.5px;line-height:1.6}.acard-symbols{flex-wrap:wrap;gap:5px;display:flex}.acard-symbol{border-radius:var(--radius-sm);width:32px;height:32px;transition:border-color var(--transition-fast), background var(--transition-fast);background:#ffffff1a;border:1px solid #ffffff26;justify-content:center;align-items:center;display:flex;overflow:hidden}.acard:hover .acard-symbol{background:#ffffff26;border-color:#ffffff40}.acard-symbol-img{object-fit:contain;filter:invert();mix-blend-mode:screen;width:22px;height:22px}.acard-footer{border-top:1px solid #ffffff1f;justify-content:space-between;align-items:center;margin-top:auto;padding-top:10px;display:flex}.acard-count{color:#ffffff73;font-size:11px}.acard-cta{color:var(--accent);transition:letter-spacing var(--transition-fast);font-size:12px;font-weight:600}.acard:hover .acard-cta{letter-spacing:.04em;text-decoration:underline}.home{padding:28px 28px 48px}.home-header{margin-bottom:20px}.home-title{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:-.01em;text-transform:uppercase;font-size:22px;font-weight:700}.home-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;display:grid}@media (width<=640px){.home{padding:20px 16px 40px}.home-grid{grid-template-columns:1fr;gap:12px}}.acard--add{border:2px dashed var(--border);background:var(--bg-surface);min-height:380px;transition:border-color var(--transition-base), background var(--transition-base), transform var(--transition-base), box-shadow var(--transition-base);justify-content:center;align-items:center;text-decoration:none;display:flex}.acard--add:hover,.acard--add:focus-visible{border-color:var(--accent);background:var(--bg-hover);box-shadow:var(--shadow-lg), 0 0 0 1px var(--accent-border);transform:translateY(-3px)}.acard-add-content{color:var(--text-secondary);text-align:center;flex-direction:column;align-items:center;gap:10px;padding:24px;display:flex}.acard-add-icon{color:var(--accent);transition:transform var(--transition-base);font-size:54px;font-weight:300;line-height:1}.acard--add:hover .acard-add-icon{transform:scale(1.1)}.acard-add-title{font-family:var(--font-heading);color:var(--text-primary);font-size:17px;font-weight:600}.acard-add-subtitle{color:var(--text-muted);max-width:200px;font-size:12.5px;line-height:1.4}.key-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;min-width:50px;height:62px;color:var(--text-primary);transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;max-width:66px;box-shadow:var(--shadow-sm);outline:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:6px 4px;display:flex;position:relative;overflow:hidden}.key-btn:hover,.key-btn:focus-visible{border-color:var(--accent);background:var(--accent-light);box-shadow:0 0 0 2px var(--accent-light), var(--shadow-sm);transform:translateY(-2px)scale(1.03)}.key-btn:active{box-shadow:var(--shadow-sm);transition:all 80ms;transform:translateY(0)scale(.97)}.key-btn--missing{opacity:.35;cursor:not-allowed}.key-btn--missing:hover{box-shadow:var(--shadow-sm);border-color:var(--border);background:var(--bg-card);transform:none}.key-symbol-wrap{flex:1;justify-content:center;align-items:center;width:100%;display:flex}.key-symbol-img{object-fit:contain;mix-blend-mode:multiply;width:32px;height:32px;transition:filter var(--transition-fast), transform var(--transition-fast)}[data-theme=dark] .key-symbol-img{filter:invert();mix-blend-mode:screen}.key-btn:hover .key-symbol-img{transform:scale(1.1)}.key-btn--symbol-only{padding:4px 2px}.key-btn--symbol-only .key-symbol-wrap{width:100%;height:100%}.key-btn--symbol-only .key-symbol-img{width:100%;max-width:48px;height:100%;max-height:48px}.key-btn--symbol-only:hover .key-symbol-img{transform:scale(1.06)}.key-symbol-placeholder{color:var(--text-muted);font-size:18px}.key-latin{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:.04em;font-size:16px;font-weight:700;line-height:1}.key-latin--small{font-size:10px;font-family:var(--font-body);color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;font-weight:600}.key-latin--hiragana{color:var(--text-primary);letter-spacing:0;font-family:Noto Sans JP,Hiragino Sans,Yu Gothic,sans-serif;font-size:18px;font-weight:700;line-height:1}.key-btn--special{border-radius:var(--radius-md);flex-direction:row;flex:none;gap:5px;min-width:auto;max-width:none;height:50px;padding:8px 14px}.key-special-icon{font-size:15px}.key-special-label{color:var(--text-secondary);white-space:nowrap;letter-spacing:.04em;font-size:11px;font-weight:600}.key-btn--special.key-btn--active{background:var(--theme-gradient)!important;border-color:var(--theme-primary)!important;box-shadow:0 0 10px var(--theme-glow), var(--shadow-sm)!important}.key-btn--special.key-btn--active .key-special-icon,.key-btn--special.key-btn--active .key-special-label{color:#fff!important}.keyboard{background:var(--bg-surface);border-radius:var(--radius-xl);border:1px solid var(--border);width:100%;padding:20px}.keyboard-ambient{display:none}.keyboard-rows{flex-direction:column;gap:7px;display:flex}.keyboard-row{padding-left:var(--row-offset,0);justify-content:center;gap:5px;display:flex}.keyboard-row--bottom{gap:8px;padding-left:0}.keyboard-row--bottom .key-btn--special:first-child{flex-shrink:0}@media (width<=640px){.keyboard{padding:12px 8px}.keyboard-rows{gap:5px}.keyboard-row{padding-left:calc(var(--row-offset,0) * .5);gap:3px}.key-btn{min-width:28px;height:50px;padding:4px 2px}.key-symbol-img{width:22px;height:22px}.key-latin{font-size:12px}.key-latin--small{font-size:9px}.key-btn--special{height:42px;padding:5px 7px}}.text-output{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);overflow:hidden}.text-output:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.text-output-header{border-bottom:1px solid var(--border);background:var(--bg-muted);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.text-output-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:7px;font-size:12px;font-weight:600;display:flex}.text-output-icon{color:var(--text-secondary);align-items:center;display:flex}.text-output-mode-toggle{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);gap:2px;padding:3px;display:flex}.text-output-mode-btn{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;align-items:center;gap:5px;padding:6px 10px;font-size:11px;font-weight:500;display:flex}.text-output-mode-btn--active{background:var(--bg-muted);color:var(--text-primary);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.text-output-mode-btn:not(.text-output-mode-btn--active):hover{color:var(--text-primary);background:var(--bg-hover)}.text-output-mode-icon{align-items:center;display:flex}.text-output-mode-label{display:none}@media (width>=480px){.text-output-mode-label{display:inline}}.text-output-stats{align-items:center;gap:5px;display:flex}.text-stat{color:var(--text-muted);font-size:11px}.text-stat-divider{color:var(--text-muted);opacity:.5}.text-output-display{min-height:120px;color:var(--text-primary);word-break:break-all;white-space:pre-wrap;background:var(--bg-surface);padding:14px;line-height:1.7;position:relative}.text-display-symbols{flex-wrap:wrap;align-items:flex-end;gap:6px;display:flex}.text-output-placeholder{color:var(--text-muted);font-size:14px;font-style:italic;font-weight:400}.text-cursor{background:var(--accent);vertical-align:text-bottom;border-radius:1px;width:2px;height:1.1em;margin-left:2px;animation:1.1s ease-in-out infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.text-symbol-row{border-top:1px solid var(--border);background:var(--bg-muted);align-items:center;gap:10px;padding:8px 14px 10px;display:flex;overflow-x:auto}.text-symbol-label{color:var(--accent);text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;font-size:10px;font-weight:700}.text-symbol-chars{flex-wrap:wrap;align-items:center;gap:2px;display:flex}.text-symbol-char{flex-direction:column;justify-content:center;align-items:center;gap:2px;min-width:26px;height:auto;padding-bottom:2px;display:flex}.text-symbol-char--hiragana{min-width:30px}.text-symbol-char--large{gap:4px;min-width:44px;padding-bottom:4px}.text-symbol-char--large .text-symbol-char-img{width:40px;height:40px}.text-symbol-char--large .text-symbol-hiragana-label{font-size:16px}.text-symbol-char--large .text-symbol-latin{font-size:11px}.text-symbol-char-img{object-fit:contain;mix-blend-mode:multiply;width:22px;height:22px}[data-theme=dark] .text-symbol-char-img{filter:invert();mix-blend-mode:screen}.text-symbol-hiragana-label{color:var(--accent);letter-spacing:0;font-family:Noto Sans JP,Hiragino Sans,Yu Gothic,sans-serif;font-size:13px;font-weight:700;line-height:1}.text-symbol-latin{color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;font-size:9px;font-weight:600;line-height:1}.text-symbol-space{background:var(--border);border-radius:1px;width:10px;height:2px;display:inline-block}.text-symbol-space--large{width:20px;height:3px}.text-symbol-newline{color:var(--text-muted);font-size:11px}.text-symbol-other{color:var(--text-secondary);font-size:12px}.text-output-actions{border-top:1px solid var(--border);background:var(--bg-muted);justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.text-output-actions-btns{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.text-output-hint{color:var(--text-muted);white-space:nowrap;align-items:center;gap:6px;margin:0;padding-left:4px;font-size:11px;display:flex}.hint-text-mobile{display:none}.text-action-btn{border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;align-items:center;gap:6px;padding:7px 16px;font-size:12px;font-weight:600;display:flex}.text-action-btn:disabled{opacity:.35;cursor:not-allowed}.text-action-btn--copy{background:var(--accent);color:#fff;border-color:var(--accent)}.text-action-btn--copy:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.text-action-btn--clear{color:var(--text-secondary);border-color:var(--border);background:0 0}.text-action-btn--clear:hover:not(:disabled){color:#ef4444;background:#ef44441a;border-color:#ef44444d}@media (width<=640px){.text-output-header{flex-wrap:wrap;gap:8px}.text-output-mode-toggle{justify-content:center;width:100%}.text-output-actions{flex-wrap:wrap;gap:8px}.text-output-actions-btns{flex-wrap:wrap;gap:6px}.text-output-hint{white-space:normal;flex:100%;margin-top:4px;padding-left:0}.hint-text-desktop{display:none}.hint-text-mobile{display:inline}.text-output-stats{margin-left:auto}}.gallery{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.gallery-header{border-bottom:1px solid var(--border);background:var(--bg-muted);padding:14px 18px 12px}.gallery-title{font-family:var(--font-heading);color:var(--text-primary);align-items:center;gap:7px;margin-bottom:2px;font-size:14px;font-weight:600;display:flex}.gallery-subtitle{color:var(--text-muted);font-size:12px}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(68px,1fr));gap:6px;padding:14px;display:grid}.gallery-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:default;transition:all var(--transition-fast);flex-direction:column;align-items:center;gap:5px;padding:10px 6px;display:flex;position:relative}.gallery-item:hover{border-color:var(--accent-border);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.gallery-item--missing{opacity:.3}.gallery-item--missing:hover{box-shadow:none;border-color:var(--border);transform:none}.gallery-symbol{justify-content:center;align-items:center;width:40px;height:40px;display:flex}.gallery-symbol-img{object-fit:contain;mix-blend-mode:multiply;width:36px;height:36px;transition:filter var(--transition-fast)}[data-theme=dark] .gallery-symbol-img{filter:invert();mix-blend-mode:screen}.gallery-missing{color:var(--text-muted);font-size:20px}.gallery-letter{font-family:var(--font-heading);color:var(--text-secondary);letter-spacing:.06em;font-size:12px;font-weight:700}.gallery-dot{background:var(--accent);border-radius:50%;width:5px;height:5px;position:absolute;top:5px;right:5px}.kb-page{padding:24px 28px 48px}.kb-page--has-examples{align-items:flex-start;gap:32px;display:flex}.kb-layout{flex-direction:column;flex-grow:1;gap:16px;width:100%;max-width:780px;margin-left:auto;margin-right:auto;display:flex}.kb-toast{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-primary);box-shadow:var(--shadow-md);z-index:1000;align-items:center;gap:8px;padding:9px 18px;font-size:13px;font-weight:500;animation:.25s ease-out toastIn;display:flex;position:fixed;top:72px;left:50%;transform:translate(-50%)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(-8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.kb-tabs{background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-lg);gap:2px;width:fit-content;padding:3px;display:flex}.kb-tab{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;display:flex}.kb-tab--active{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border);box-shadow:var(--shadow-sm);font-weight:600}.kb-tab:not(.kb-tab--active):hover{color:var(--text-primary);background:var(--bg-hover)}.kb-tab-icon{color:inherit;align-items:center;display:flex}.kb-panel{animation:.3s ease-out slideIn}@keyframes slideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.kb-keyboard-wrap{flex-direction:column;display:flex}.kb-info-bar{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);flex-wrap:wrap;align-items:center;gap:16px;padding:12px 16px;display:flex}.kb-info-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.kb-info-icon{color:var(--text-muted);align-items:center;display:flex}.kb-info-item--japanese{color:var(--text-muted);margin-left:auto;font-size:11px;font-style:italic}@media (width<=960px){.kb-layout{margin-left:auto;margin-right:auto}}@media (width<=640px){.kb-page{padding:16px 14px 40px}.kb-layout{margin-left:auto;margin-right:auto}.kb-info-item--japanese{margin-left:0}.keyboard-row{padding-left:0!important}.key-btn--special{height:42px;padding:4px 6px;min-width:38px!important}}.kb-delete-btn{color:#ef4444;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);background:#ef444414;border:1px solid #ef444433;align-items:center;gap:5px;padding:4px 10px;font-size:11px;font-weight:600;line-height:1;display:flex}.kb-delete-btn:hover{color:#fff;background:#ef4444;border-color:#ef4444;box-shadow:0 0 10px #ef444459}.kb-examples-sidebar{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);min-width:220px;max-height:calc(100vh - 120px);box-shadow:var(--shadow-sm);flex-direction:column;flex:1;gap:16px;padding:16px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:sticky;top:96px;overflow-y:auto}.kb-examples-sidebar--mobile{display:none}.kb-examples-sidebar--collapsed{flex:0 0 52px;align-items:center;width:52px;min-width:52px;padding:12px 8px;overflow:hidden}.kb-examples-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding-bottom:8px;display:flex}.kb-examples-sidebar--collapsed .kb-examples-header{border-bottom:none;padding-bottom:0}.kb-examples-title{color:var(--text-primary);margin:0;font-size:14px;font-weight:600}.kb-examples-toggle-btn{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}.kb-examples-toggle-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.kb-examples-list{flex-direction:column;gap:16px;display:flex}.kb-example-item{cursor:pointer;flex-direction:column;gap:6px;display:flex}.kb-example-img{aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--border);width:100%;transition:all var(--transition-fast)}.kb-example-item:hover .kb-example-img{border-color:var(--theme-primary,var(--border));box-shadow:0 4px 12px var(--theme-glow,#0000001a);transform:translateY(-2px)}.kb-example-label{color:var(--text-muted);text-align:center;transition:color var(--transition-fast);font-size:11px}.kb-example-item:hover .kb-example-label{color:var(--text-primary)}.kb-lightbox-overlay{z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000d9;justify-content:center;align-items:center;animation:.2s ease-out kb-fadeIn;display:flex;position:fixed;inset:0}.kb-lightbox-content{justify-content:center;align-items:center;max-width:90%;max-height:90%;display:flex;position:relative}.kb-lightbox-img{border-radius:var(--radius-lg);object-fit:contain;border:1px solid #ffffff26;max-width:100%;max-height:85vh;animation:.25s cubic-bezier(.34,1.56,.64,1) kb-zoomIn;box-shadow:0 12px 40px #0009}.kb-lightbox-close{color:#fff;cursor:pointer;transition:opacity var(--transition-fast);background:0 0;border:none;font-size:36px;line-height:1;position:absolute;top:-45px;right:0}.kb-lightbox-close:hover{opacity:.7}@keyframes kb-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes kb-zoomIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (width<=960px){.kb-page--has-examples{flex-direction:column;align-items:stretch;gap:24px}.kb-examples-sidebar--desktop{display:none}.kb-examples-sidebar--mobile{width:100%;max-height:none;display:flex;position:static}.kb-examples-sidebar--collapsed{align-items:stretch;width:100%;padding:8px}.kb-examples-list{flex-flow:wrap;gap:12px}.kb-example-item{flex:calc(33.333% - 8px);min-width:150px;max-width:calc(33.333% - 8px)}}@media (width<=640px){.kb-example-item{flex:calc(50% - 6px);max-width:calc(50% - 6px)}}@media (width<=480px){.kb-page{padding:12px 8px 32px}.key-btn{height:46px;min-width:22px!important}.key-special-label{display:none}.key-btn--special{padding:4px;min-width:32px!important}}.kb-guide-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);flex-direction:column;gap:16px;padding:24px;animation:.3s ease-out slideIn;display:flex}.kb-guide-title{font-family:var(--font-heading);color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);align-items:center;gap:8px;margin:0;padding-bottom:12px;font-size:16px;font-weight:700;display:flex}.kb-guide-list{flex-direction:column;gap:12px;display:flex}.kb-guide-item{background:var(--bg-page);border-radius:var(--radius-md);border:1px solid var(--border);transition:all var(--transition-fast);align-items:flex-start;gap:12px;padding:12px 14px;display:flex}.kb-guide-item:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.kb-guide-item-icon{background:var(--accent-light);border-radius:var(--radius-full);width:22px;height:22px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.kb-guide-item-content{flex-direction:column;flex-grow:1;gap:3px;display:flex}.kb-guide-item-title{color:var(--text-primary);font-size:13px;font-weight:600}.kb-guide-item-text{color:var(--text-secondary);font-size:11.5px;line-height:1.45}.kb-guide-item-text code{background:var(--bg-hover);border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--accent);padding:2px 5px;font-family:monospace;font-size:11px}@media (width<=480px){.kb-guide-panel{padding:16px 12px}.kb-guide-item{gap:8px;padding:10px 8px}}.source-page{padding:28px 28px 48px}.source-header{margin-bottom:24px}.source-title{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:-.01em;font-size:22px;font-weight:700}.source-subtitle{color:var(--text-muted);max-width:560px;margin-top:6px;font-size:13px;line-height:1.5}.source-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;margin:0;padding:0;list-style:none;display:grid}.source-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);height:100%;color:inherit;transition:border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-base);flex-direction:column;text-decoration:none;display:flex;overflow:hidden}.source-card:hover{border-color:var(--accent-border);box-shadow:var(--shadow-lg);transform:translateY(-3px)}.source-card-thumb{aspect-ratio:16/9;background:var(--bg-muted);border-bottom:1px solid var(--border);overflow:hidden}.source-card-img{object-fit:cover;object-position:center top;width:100%;height:100%;transition:transform var(--transition-base);display:block}.source-card:hover .source-card-img{transform:scale(1.03)}.source-card-thumb-fallback{width:100%;height:100%;color:var(--accent);background:var(--bg-muted);justify-content:center;align-items:center;display:flex}.source-card-body{flex-direction:column;flex:1;gap:4px;padding:14px 16px 16px;display:flex}.source-card-anime{color:var(--accent);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:600}.source-card-title{color:var(--text-primary);flex:1;font-size:14px;font-weight:600;line-height:1.35}.source-card-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px;margin-top:8px;padding-top:10px;display:flex}.source-card-site{color:var(--text-muted);font-size:12px}.source-card-arrow{color:var(--text-muted);transition:color var(--transition-fast);flex-shrink:0;align-items:center;display:flex}.source-card:hover .source-card-arrow{color:var(--accent)}@media (width<=640px){.source-page{padding:20px 16px 40px}.source-grid{grid-template-columns:1fr;gap:12px}}.login-container{min-height:calc(100vh - var(--navbar-height) - 40px);justify-content:center;align-items:center;padding:20px;display:flex}.login-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:440px;transition:transform var(--transition-base), box-shadow var(--transition-base);flex-direction:column;padding:40px 32px;display:flex}.login-card--google{text-align:center;max-width:400px}.login-logo-wrap{justify-content:center;align-items:center;margin:0 auto 20px;display:flex}.login-logo-img{width:auto;height:30px;display:block}.login-header{margin-bottom:32px}.login-header h2{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:12px;font-size:26px;font-weight:800}.login-subtitle{color:var(--text-secondary);font-size:14px;line-height:1.5}.auth-alert{border-radius:var(--radius-md);text-align:left;margin-bottom:24px;padding:12px 16px;font-size:13px;line-height:1.4}.auth-alert--error{color:#ef4444;background:#ef44441a;border:1px solid #ef444433}.auth-action-box{margin-bottom:24px}.btn-google-login{background:var(--bg-surface);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;gap:12px;padding:14px;font-size:14px;font-weight:600;display:flex}.btn-google-login:hover{background:var(--bg-hover);border-color:var(--text-muted);transform:translateY(-1px)}.btn-google-login:active{transform:translateY(0)}.btn-google-login:disabled{opacity:.6;cursor:not-allowed}.google-icon{flex-shrink:0}.spinner{border:2px solid #0000001a;border-top-color:var(--text-primary);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}.spinner--dark,[data-theme=dark] .spinner--dark{border-color:#fff3;border-top-color:var(--text-primary)}@keyframes spin{to{transform:rotate(360deg)}}.auth-footer-simple{color:var(--text-muted);border-top:1px solid var(--border);padding-top:20px;font-size:12px;line-height:1.4}.forum-page{width:100%;max-width:900px;margin:0 auto;padding:24px}.forum-header{justify-content:space-between;align-items:center;gap:20px;margin-bottom:32px;display:flex}.forum-title{font-family:var(--font-heading);color:var(--text-primary);font-size:32px;font-weight:800}.forum-subtitle{color:var(--text-secondary);margin-top:4px;font-size:15px}.btn-create-discussion{background:var(--accent);color:var(--text-inverse);border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;transition:background var(--transition-fast), transform var(--transition-fast);border:none;padding:12px 24px;font-size:15px;font-weight:600}.btn-create-discussion:hover{background:var(--accent-hover)}.btn-create-discussion:active{transform:scale(.98)}.discussions-list{flex-direction:column;gap:16px;display:flex}.discussion-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);color:inherit;transition:transform var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base);justify-content:space-between;gap:24px;padding:24px;text-decoration:none;display:flex}.discussion-card:hover{border-color:var(--accent-border);box-shadow:var(--shadow-md);transform:translateY(-2px)}.discussion-card-body{flex-direction:column;flex:1;justify-content:center;display:flex}.discussion-meta{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:10px;font-size:12px;display:flex}.discussion-author{color:var(--text-primary);font-weight:600}.discussion-dot{opacity:.6}.discussion-card-title{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:8px;font-size:20px;font-weight:700;line-height:1.3}.discussion-card-excerpt{color:var(--text-secondary);font-size:14px;line-height:1.5}.discussion-card-image{border-radius:var(--radius-md);border:1px solid var(--border);flex-shrink:0;width:120px;height:120px;overflow:hidden}.discussion-card-image img{object-fit:cover;width:100%;height:100%}.forum-loading{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:80px 0;display:flex}.spinner-large{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.forum-empty{text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:80px 40px}.empty-icon{margin-bottom:16px;font-size:48px}.forum-empty h3{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:8px;font-size:20px}.forum-empty p{color:var(--text-secondary);font-size:14px}.image-upload-zone{flex-direction:column;align-items:flex-start;gap:12px;display:flex}.btn-upload-trigger{background:var(--bg-input);border:1px dashed var(--border);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);padding:12px 20px;font-size:13px;font-weight:500}.btn-upload-trigger:hover{border-color:var(--accent);color:var(--text-primary);background:var(--bg-hover)}.upload-preview-container{align-items:center;gap:16px;width:100%;display:flex}.upload-preview-container img{object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border);width:80px;height:80px}.btn-remove-preview{border:1px solid var(--border);color:#ef4444;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:6px 12px;font-size:12px;font-weight:500}.btn-remove-preview:hover{background:#ef44440d;border-color:#ef4444}@media (width<=600px){.forum-header{flex-direction:column;align-items:flex-start}.btn-create-discussion{text-align:center;width:100%}.discussion-card{flex-direction:column-reverse;gap:16px}.discussion-card-image{width:100%;height:180px}}.nsfw-warning{color:#ef4444;border-radius:var(--radius-md);background:#ef444414;border-left:3px solid #ef4444;margin-bottom:16px;padding:10px 14px;font-size:12px;font-weight:500;line-height:1.5}.btn-delete-discussion{color:#ef4444;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #ef444480;padding:6px 14px;font-size:13px;font-weight:600}.btn-delete-discussion:hover{color:#fff;background:#ef4444;border-color:#ef4444;box-shadow:0 4px 12px #ef44444d}.discussion-card-actions{align-items:center;gap:12px;margin-top:16px;display:flex}.btn-upvote{background:var(--bg-hover);border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:600;display:flex}.btn-upvote:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent-border)}.btn-upvote--active{background:var(--accent)!important;color:var(--text-inverse)!important;border-color:var(--accent)!important}.forum-load-more-container{justify-content:center;width:100%;margin-top:32px;display:flex}.btn-load-more-discussions{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);padding:12px 28px;font-size:14px;font-weight:600}.btn-load-more-discussions:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent-border);color:var(--accent)}.btn-load-more-discussions:disabled{opacity:.6;cursor:not-allowed}.discussion-detail-page{width:100%;max-width:1100px;margin:0 auto;padding:24px}.back-link{color:var(--text-secondary);transition:color var(--transition-fast);align-items:center;gap:8px;margin-bottom:24px;font-size:14px;font-weight:500;text-decoration:none;display:inline-flex}.back-link:hover{color:var(--accent)}.discussion-detail-layout{grid-template-columns:1fr 320px;align-items:start;gap:32px;display:grid}.discussion-right-pane{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;position:sticky;top:24px}.discussion-right-pane h3{font-family:var(--font-heading);color:var(--text-primary);border-bottom:1px solid var(--border);margin-bottom:16px;padding-bottom:12px;font-size:18px}.other-discussions-list{flex-direction:column;gap:16px;display:flex}.other-discussion-card{border-radius:var(--radius-md);background:var(--bg-muted);transition:all var(--transition-fast);border:1px solid #0000;padding:16px;text-decoration:none;display:block}.other-discussion-card:hover{background:var(--bg-card);border-color:var(--accent);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.other-discussion-card h4{color:var(--text-primary);margin-bottom:8px;font-size:15px;font-weight:600;line-height:1.4}.other-discussion-meta{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.no-other-discussions{color:var(--text-secondary);text-align:center;padding:16px 0;font-size:14px}.main-discussion{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:32px;padding:32px}.discussion-detail-header{margin-bottom:20px}.discussion-detail-meta{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:12px;font-size:12px;display:flex}.author-name{color:var(--text-primary);font-weight:600}.discussion-detail-title{font-family:var(--font-heading);color:var(--text-primary);font-size:28px;font-weight:800;line-height:1.3}.discussion-detail-image{border-radius:var(--radius-md);border:1px solid var(--border);width:100%;max-height:480px;margin-bottom:24px;overflow:hidden}.discussion-detail-image img{object-fit:contain;background:#000;width:100%;height:100%;display:block}.discussion-detail-content{color:var(--text-primary);font-size:16px;line-height:1.6}.discussion-detail-content p{margin-bottom:16px}.discussion-detail-content p:last-child{margin-bottom:0}.comments-section{margin-top:40px}.comments-section h3{font-family:var(--font-heading);color:var(--text-primary);border-bottom:1px solid var(--border);margin-bottom:20px;padding-bottom:8px;font-size:20px}.comment-form,.reply-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;gap:12px;margin-bottom:24px;padding:16px;display:flex}.comment-form textarea,.reply-form textarea{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-body);resize:vertical;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:12px 16px}.comment-form textarea:focus,.reply-form textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-light);background:var(--bg-surface)}.comment-form-actions,.reply-form-actions{justify-content:flex-end;gap:8px;display:flex}.btn-send-comment,.btn-send-reply{background:var(--accent);color:var(--text-inverse);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);border:none;align-items:center;gap:6px;padding:10px 18px;font-size:13px;font-weight:600;display:flex}.btn-send-comment:hover,.btn-send-reply:hover{background:var(--accent-hover)}.btn-send-comment:disabled,.btn-send-reply:disabled{opacity:.6;cursor:not-allowed}.btn-cancel-reply{border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:10px 18px;font-size:13px;font-weight:500}.btn-cancel-reply:hover{background:var(--bg-hover);color:var(--text-primary)}.login-prompt{background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-md);text-align:center;color:var(--text-secondary);margin-bottom:24px;padding:16px;font-size:14px}.login-prompt a{color:var(--accent);font-weight:600;text-decoration:none}.login-prompt a:hover{text-decoration:underline}.comments-list{flex-direction:column;gap:20px;display:flex}.comment-thread{flex-direction:column;gap:12px;display:flex}.comment-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:18px}.comment-card-header,.reply-card-header{color:var(--text-secondary);align-items:center;gap:8px;margin-bottom:8px;font-size:12px;display:flex}.comment-author,.reply-author{color:var(--text-primary);font-weight:600}.comment-text,.reply-text{color:var(--text-primary);white-space:pre-line;font-size:14px;line-height:1.5}.comment-actions{margin-top:10px;display:flex}.btn-reply-toggle{color:var(--accent);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;padding:0;font-size:12px;font-weight:500}.btn-reply-toggle:hover{color:var(--accent-hover);text-decoration:underline}.replies-list{border-left:2px solid var(--border);flex-direction:column;gap:12px;margin-left:32px;padding-left:16px;display:flex}.reply-card{background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 16px}.discussion-detail-loading{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:120px 0;display:flex}.discussion-detail-error{text-align:center;padding:80px 40px}.discussion-detail-error h2{font-family:var(--font-heading);margin-bottom:8px;font-size:24px}.discussion-detail-error p{color:var(--text-secondary);margin-bottom:24px}.btn-back{background:var(--accent);color:var(--text-inverse);border-radius:var(--radius-md);border:none;padding:12px 24px;font-weight:600;text-decoration:none}.no-comments{text-align:center;color:var(--text-secondary);padding:32px 0;font-size:14px}@media (width<=900px){.discussion-detail-layout{grid-template-columns:1fr}}@media (width<=600px){.main-discussion{padding:20px}.discussion-detail-title{font-size:22px}.replies-list{margin-left:16px;padding-left:10px}}.btn-report-small{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:4px;padding:4px 8px;font-size:12px;font-weight:500;display:inline-flex}.btn-report-small:hover{color:#dc2626;background:#dc26261a}.ml-auto{margin-left:auto}.report-select{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-md);font-size:14px;font-family:var(--font-body);width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:12px 16px}.report-select:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-light);background:var(--bg-surface)}.btn-submit-danger{background:#dc2626!important}.btn-detail-upvote{background:var(--bg-hover);border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:6px;margin-left:12px;padding:4px 12px;font-size:12px;font-weight:600;display:flex}.btn-detail-upvote:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent-border)}.btn-detail-upvote--active{background:var(--accent)!important;color:var(--text-inverse)!important;border-color:var(--accent)!important}.btn-toggle-replies{color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;margin-left:12px;padding:0;font-size:12px;font-weight:600}.btn-toggle-replies:hover{color:var(--accent);text-decoration:underline}.discussion-detail-actions{border-top:1px solid var(--border);align-items:center;margin-top:24px;padding-top:20px;display:flex}.discussion-detail-actions .btn-detail-upvote{border-radius:var(--radius-md);margin-left:0;padding:8px 16px;font-size:14px}.btn-show-more-comments{color:var(--accent);border:1px solid var(--accent-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:0 0;margin:24px auto 0;padding:10px 24px;font-size:14px;font-weight:600;display:block}.btn-show-more-comments:hover{background:var(--accent-light);border-color:var(--accent);transform:translateY(-1px)}.btn-show-more-comments:active{transform:translateY(0)}.discussion-avatar{object-fit:cover;border:1px solid var(--border);border-radius:50%;width:28px;height:28px}.discussion-avatar-placeholder{background:var(--accent);width:28px;height:28px;color:var(--text-inverse);border:1px solid var(--accent);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.comment-avatar,.reply-avatar{object-fit:cover;border:1px solid var(--border);border-radius:50%;width:28px;height:28px}.comment-avatar-placeholder,.reply-avatar-placeholder{background:var(--accent);width:28px;height:28px;color:var(--text-inverse);border:1px solid var(--accent);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.btn-edit-discussion-small,.btn-delete-discussion-small{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:4px;padding:4px 8px;font-size:12px;font-weight:500;display:inline-flex}.btn-edit-discussion-small:hover{background:var(--bg-hover);color:var(--accent)}.btn-delete-discussion-small:hover{color:#dc2626;background:#dc26261a}.gallery-page{width:100%;max-width:1200px;margin:0 auto;padding:24px}.gallery-page-header{margin-bottom:32px}.gallery-page-title{font-family:var(--font-heading);color:var(--text-primary);font-size:32px;font-weight:800}.gallery-page-subtitle{color:var(--text-secondary);margin-top:4px;font-size:15px}.gallery-masonry-grid{gap:16px;width:100%;display:flex}.gallery-masonry-column{flex-direction:column;flex:1;gap:16px;display:flex}.gallery-masonry-item{cursor:pointer;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card);transition:transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);position:relative;overflow:hidden}.gallery-masonry-item:hover{border-color:var(--accent-border);box-shadow:var(--shadow-md);transform:translateY(-4px)}.gallery-masonry-image-wrapper{width:100%;display:block;position:relative}.gallery-masonry-image{object-fit:cover;width:100%;height:auto;transition:transform .5s;display:block}.gallery-masonry-item:hover .gallery-masonry-image{transform:scale(1.03)}.gallery-masonry-overlay{opacity:0;transition:opacity var(--transition-base);z-index:2;background:linear-gradient(#0000 40%,#000000b3 100%);flex-direction:column;justify-content:space-between;padding:16px;display:flex;position:absolute;inset:0}.gallery-masonry-item:hover .gallery-masonry-overlay{opacity:1}.gallery-anime-badge{background:var(--accent);color:var(--text-inverse);border-radius:var(--radius-full);box-shadow:var(--shadow-sm);text-transform:uppercase;letter-spacing:.05em;align-self:flex-start;padding:4px 10px;font-size:11px;font-weight:700}.gallery-zoom-icon{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);width:32px;height:32px;transition:background var(--transition-fast), transform var(--transition-fast);background:#ffffff40;border:1px solid #fff3;border-radius:50%;justify-content:center;align-self:flex-end;align-items:center;display:flex}.gallery-zoom-icon:hover{background:#fff6;transform:scale(1.1)}.lightbox-overlay{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1000;background:#000000d9;justify-content:center;align-items:center;padding:40px;animation:.3s ease-out lightboxFadeIn;display:flex;position:fixed;inset:0}@keyframes lightboxFadeIn{0%{opacity:0}to{opacity:1}}.lightbox-close{color:#fff;cursor:pointer;z-index:1010;opacity:.7;transition:opacity var(--transition-fast), transform var(--transition-fast);background:0 0;border:none;font-size:44px;line-height:1;position:absolute;top:24px;right:24px}.lightbox-close:hover{opacity:1;transform:scale(1.05)}.lightbox-nav{color:#fff;cursor:pointer;z-index:1010;width:50px;height:50px;transition:all var(--transition-fast);background:#ffffff1a;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.lightbox-nav:hover{background:#ffffff40;transform:translateY(-50%)scale(1.05)}.lightbox-nav--prev{left:32px}.lightbox-nav--next{right:32px}.lightbox-content{border-radius:var(--radius-lg);background:#161b22;border:1px solid #ffffff1a;flex-direction:column;max-width:800px;max-height:80vh;animation:.35s cubic-bezier(.16,1,.3,1) lightboxZoomIn;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #000c}@keyframes lightboxZoomIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.lightbox-content img{object-fit:contain;background:#0d1117;max-width:100%;max-height:60vh;margin:0 auto;display:block}.lightbox-caption{color:#fff;padding:20px 24px}.lightbox-caption h3{font-family:var(--font-heading);color:#fff;margin-bottom:4px;font-size:18px;font-weight:700}.lightbox-caption p{color:#8b949e;font-size:13px;line-height:1.4}@media (width<=992px){.lightbox-nav{width:40px;height:40px}.lightbox-nav--prev{left:16px}.lightbox-nav--next{right:16px}}@media (width<=768px){.lightbox-overlay{padding:20px}.lightbox-content{max-width:100%}}@media (width<=480px){.lightbox-nav{display:none}}.alphabet-page{width:100%;max-width:1000px;margin:0;padding:24px 24px 24px 50px}.alphabet-header{margin-bottom:36px}.alphabet-title{font-family:var(--font-heading);color:var(--text-primary);font-size:32px;font-weight:500}.alphabet-subtitle{color:var(--text-secondary);margin-top:4px;font-size:12px}.alphabet-list{flex-direction:column;gap:32px;display:flex}.alphabet-item{background:0 0;border:none;padding:0}.alphabet-anime-title{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:12px;font-size:18px;font-weight:700}.alphabet-row-content{justify-content:space-between;align-items:center;gap:24px;width:100%;display:flex}.alphabet-left-group{align-items:center;gap:16px;display:flex}.alphabet-symbols-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);align-items:center;gap:12px;height:82px;padding:16px 24px;display:flex}.alphabet-preview-symbol{border-radius:var(--radius-md);width:38px;height:38px;box-shadow:var(--shadow-sm);background:#fff;border:1px solid #00000014;justify-content:center;align-items:center;padding:6px;display:flex}.alphabet-preview-symbol img{object-fit:contain;max-width:100%;max-height:100%;display:block}.alphabet-dots{color:var(--text-secondary);letter-spacing:2px;-webkit-user-select:none;user-select:none;margin-left:4px;font-size:28px;font-weight:800}.alphabet-right-group{align-items:center;display:flex}.alphabet-button-box{border-radius:var(--radius-lg);justify-content:center;align-items:center;height:82px;padding:16px 24px;display:flex}.btn-show-full{color:var(--accent);border:1px solid var(--accent-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;padding:10px 20px;font-size:14px;font-weight:600}.btn-show-full:hover{background:var(--accent-light);border-color:var(--accent)}@media (width<=768px){.alphabet-row-content{flex-direction:column;align-items:flex-start;gap:16px}.alphabet-left-group{justify-content:space-between;width:100%}.alphabet-symbols-box{flex:1;justify-content:center;padding:16px}.alphabet-right-group{width:100%}.alphabet-button-box{width:100%;height:auto;padding:12px}.btn-show-full{text-align:center;width:100%}}.alphabet-detail-page{width:100%;max-width:900px;margin:0 auto;padding:24px}.alphabet-detail-error{text-align:center;padding:80px 40px}.alphabet-detail-error h2{font-family:var(--font-heading);margin-bottom:8px;font-size:24px}.alphabet-detail-error p{color:var(--text-secondary);margin-bottom:24px}.alphabet-detail-header-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:32px;padding:28px}.alphabet-detail-genre-tag{background:var(--accent-light);color:var(--accent);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--accent-border);margin-bottom:12px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-block}.alphabet-detail-title{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:8px;font-size:28px;font-weight:800}.alphabet-detail-desc{color:var(--text-secondary);font-size:14px;line-height:1.5}.alphabet-detail-body{margin-top:16px}.support-page{max-width:840px;margin:0 auto;padding:40px 28px 60px}.support-header{text-align:center;flex-direction:column;align-items:center;margin-bottom:48px;display:flex}.support-heart-icon-wrap{color:#ef4444;filter:drop-shadow(0 4px 12px #ef444433);margin-bottom:18px;animation:3s ease-in-out infinite heartFloat;display:inline-flex}@keyframes heartFloat{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-8px)scale(1.05)}}.support-title{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:-.02em;font-size:28px;font-weight:800}.support-subtitle{color:var(--text-secondary);max-width:580px;margin-top:12px;font-size:14px;line-height:1.6}.support-cards-grid{grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:48px;display:grid}.support-card{border-radius:var(--radius-xl);background:var(--bg-surface);border:1px solid var(--border);transition:transform var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base);flex-direction:column;padding:28px;text-decoration:none;display:flex;position:relative;overflow:hidden}.support-card-bg-glow{opacity:0;transition:opacity var(--transition-base);z-index:1;pointer-events:none;position:absolute;inset:0}.kofi-card .support-card-bg-glow{background:radial-gradient(circle at 100% 0,#ff5e5b14,#0000 70%)}.teer-card .support-card-bg-glow{background:radial-gradient(circle at 100% 0,#0ea5e914,#0000 70%)}.support-card:hover .support-card-bg-glow{opacity:1}.support-card-content{z-index:2;flex-direction:column;flex:1;height:100%;display:flex;position:relative}.support-platform-badge{text-transform:uppercase;letter-spacing:.08em;border-radius:var(--radius-full);width:fit-content;transition:background var(--transition-fast), color var(--transition-fast);margin-bottom:20px;padding:4px 12px;font-size:11px;font-weight:700}.kofi-card .support-platform-badge{color:#ff5e5b;background:#ff5e5b1a}.teer-card .support-platform-badge{color:#0ea5e9;background:#0ea5e91a}.support-platform-title{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:12px;font-size:20px;font-weight:700}.support-platform-desc{color:var(--text-secondary);flex:1;margin-bottom:28px;font-size:13.5px;line-height:1.6}.support-card-footer{border-top:1px solid var(--border);color:var(--text-secondary);transition:color var(--transition-fast), border-color var(--transition-fast);justify-content:space-between;align-items:center;padding-top:16px;font-size:14px;font-weight:600;display:flex}.kofi-card:hover{border-color:#ff5e5b66;transform:translateY(-4px);box-shadow:0 12px 32px #ff5e5b1a}.kofi-card:hover .support-card-footer{color:#ff5e5b;border-color:#ff5e5b33}.teer-card:hover{border-color:#0ea5e966;transform:translateY(-4px);box-shadow:0 12px 32px #0ea5e91a}.teer-card:hover .support-card-footer{color:#0ea5e9;border-color:#0ea5e933}.support-action-text{align-items:center;gap:6px;display:flex}.support-footer-note{text-align:center;color:var(--text-muted);margin-top:16px;font-size:13px}@media (width<=768px){.support-page{padding:30px 16px 48px}.support-cards-grid{grid-template-columns:1fr;gap:20px}.support-title{font-size:24px}.support-card{padding:24px}}.guidelines-page{max-width:960px;margin:0 auto;padding:40px 28px 60px}.guidelines-header{text-align:center;flex-direction:column;align-items:center;margin-bottom:40px;display:flex}.guidelines-shield-badge{filter:drop-shadow(0 4px 10px #0000001a);margin-bottom:16px;font-size:44px}.guidelines-title{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:-.02em;font-size:28px;font-weight:800}.guidelines-subtitle{color:var(--text-secondary);max-width:580px;margin-top:10px;font-size:14px;line-height:1.6}.guidelines-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-bottom:40px;display:grid}.guidelines-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base);gap:16px;padding:24px;display:flex;position:relative;overflow:hidden}.guidelines-card-glow{background:radial-gradient(circle at 0% 0%, var(--rule-accent), transparent 70%);opacity:.03;pointer-events:none;z-index:1;width:120px;height:120px;transition:opacity var(--transition-base);position:absolute;top:0;left:0}.guidelines-card:hover .guidelines-card-glow{opacity:.08}.guidelines-card:hover{border-color:var(--rule-accent);box-shadow:var(--shadow-md);transform:translateY(-3px)}.guidelines-card-num{font-family:var(--font-heading);color:var(--rule-accent);opacity:.85;-webkit-user-select:none;user-select:none;font-size:22px;font-weight:800;line-height:1}.guidelines-card-body{z-index:2;flex-direction:column;gap:6px;display:flex;position:relative}.guidelines-card-title{font-family:var(--font-heading);color:var(--text-primary);font-size:16px;font-weight:700}.guidelines-card-desc{color:var(--text-secondary);font-size:13px;line-height:1.6}.guidelines-warning-box{background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-md);border-left:4px solid #ef4444;flex-direction:column;gap:8px;padding:20px 24px;display:flex}.guidelines-warning-title{font-family:var(--font-heading);color:var(--text-primary);font-size:15px;font-weight:700}.guidelines-warning-text{color:var(--text-secondary);font-size:13px;line-height:1.6}@media (width<=768px){.guidelines-page{padding:30px 16px 48px}.guidelines-grid{grid-template-columns:1fr;gap:16px}.guidelines-title{font-size:24px}.guidelines-card{padding:20px}}.footer{background:var(--bg-surface);border-top:1px solid var(--border);transition:background var(--transition-base), border-color var(--transition-base);margin-top:auto;padding:48px 28px 24px}.footer-content{grid-template-columns:1.5fr repeat(3,1fr);gap:40px;max-width:1200px;margin:0 auto 40px;display:grid}.footer-brand-section{flex-direction:column;gap:16px;display:flex}.footer-logo{text-decoration:none;display:inline-block}.footer-logo-img{width:auto;height:80px;display:block}.footer-description{color:var(--text-secondary);max-width:320px;font-size:13.5px;line-height:1.6}.footer-links-column{flex-direction:column;gap:16px;display:flex}.footer-column-title{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.05em;color:var(--text-primary);font-size:15px;font-weight:700}.footer-links-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.footer-links-list a{color:var(--text-secondary);transition:color var(--transition-fast), transform var(--transition-fast);font-size:13.5px;text-decoration:none;display:inline-block}.footer-links-list a:hover{color:var(--accent);transform:translate(4px)}.footer-disclaimer-text{color:var(--text-secondary);font-size:12.5px;line-height:1.6}.footer-bottom{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;max-width:1200px;margin:0 auto;padding-top:24px;display:flex}.footer-copy{color:var(--text-muted);font-size:12.5px}@media (width<=992px){.footer-content{grid-template-columns:1fr 1fr;gap:32px}.footer-brand-section,.footer-links-column.text-muted-column{grid-column:span 2}}@media (width<=768px){.footer{padding:36px 20px 20px}}@media (width<=576px){.footer-content{grid-template-columns:1fr;gap:28px}.footer-brand-section,.footer-links-column.text-muted-column{grid-column:span 1}.footer-links-list a:hover{transform:none}}.app-body{padding-top:var(--navbar-height);flex:1;min-height:100vh;display:flex}.app-main{margin-left:var(--sidebar-width);min-height:calc(100vh - var(--navbar-height));background:var(--bg-page);transition:margin-left var(--transition-base), background var(--transition-base);flex-direction:column;flex:1;display:flex}.sidebar-overlay{display:none}@media (width<=768px){.app-main{margin-left:0}.sidebar-overlay.active{top:var(--navbar-height);-webkit-backdrop-filter:blur(4px);z-index:105;animation:fadeIn var(--transition-fast) ease-out;background:#0f172a59;display:block;position:fixed;bottom:0;left:0;right:0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}:root{--accent:#0ea5e9;--accent-hover:#0284c7;--accent-light:#0ea5e91f;--accent-border:#0ea5e94d;--bg-page:#f4f6f9;--bg-surface:#fff;--bg-card:#fff;--bg-sidebar:#fff;--bg-navbar:#fff;--bg-input:#f8fafc;--bg-hover:#f1f5f9;--bg-muted:#f8fafc;--border:#e2e8f0;--border-focus:var(--accent);--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-inverse:#fff;--sidebar-width:220px;--navbar-height:56px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:18px;--radius-full:999px;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 16px #00000014, 0 2px 4px #0000000a;--shadow-lg:0 8px 30px #0000001a, 0 4px 8px #0000000a;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--font-heading:"Outfit", sans-serif;--font-body:"Inter", sans-serif}[data-theme=dark]{--bg-page:#0d1117;--bg-surface:#161b22;--bg-card:#1c2128;--bg-sidebar:#161b22;--bg-navbar:#161b22;--bg-input:#21262d;--bg-hover:#21262d;--bg-muted:#21262d;--border:#30363d;--border-focus:var(--accent);--text-primary:#e6edf3;--text-secondary:#8b949e;--text-muted:#484f58;--text-inverse:#0d1117;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 30px #00000080}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg-page);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;transition:background var(--transition-base), color var(--transition-base);line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);line-height:1.2}button{font-family:var(--font-body)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}#root,.app-shell{flex-direction:column;min-height:100vh;display:flex}.page-enter{animation:.3s ease-out pageEnter}@keyframes pageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:linear-gradient(145deg, var(--bg-surface), var(--bg-card));border:1px solid #ffffff14;border-radius:20px;width:100%;max-width:600px;max-height:90vh;padding:36px;animation:.4s cubic-bezier(.16,1,.3,1) modalEnter;overflow-y:auto;box-shadow:0 25px 50px -12px #00000080,inset 0 1px #ffffff0d}@keyframes modalEnter{0%{opacity:0;transform:scale(.95)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:28px;padding-bottom:16px;display:flex}.modal-header h2{font-family:var(--font-heading);color:var(--text-primary);font-size:24px;font-weight:700}.btn-close-modal{color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;padding:0 4px;font-size:28px;line-height:1}.btn-close-modal:hover{color:var(--text-primary)}.modal-form{flex-direction:column;gap:24px;display:flex}.modal-form input[type=text],.modal-form textarea{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-md);font-size:15px;font-family:var(--font-body);outline:none;padding:14px 18px;transition:all .3s}.modal-form textarea{resize:vertical}.modal-form input[type=text]:focus,.modal-form textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-light);background:var(--bg-surface);transform:translateY(-1px)}.modal-actions{justify-content:flex-end;gap:12px;margin-top:12px;display:flex}.btn-cancel{border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:12px 20px;font-size:14px;font-weight:500}.btn-cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-submit{background:var(--accent);color:var(--text-inverse);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);border:none;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:600;display:flex}.btn-submit:hover{background:var(--accent-hover)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.btn-submit-danger{color:#fff!important;background:#ef4444!important}.btn-submit-danger:hover{background:#dc2626!important}
