:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:16px;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{width:100%;height:100%;margin:0;padding:0;overflow-x:hidden}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideLeft{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes slideRight{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes glow{0%,to{box-shadow:0 2px 12px #00000026}50%{box-shadow:0 4px 20px #00000040}}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:fadeIn .4s cubic-bezier(.16,1,.3,1)}.slide-up{animation:slideUp .5s cubic-bezier(.34,1.56,.64,1)}.scale-in{animation:scaleIn .35s cubic-bezier(.34,1.56,.64,1)}:focus-visible{outline:2px solid var(--primary-color, #e5a83a);outline-offset:2px}:focus:not(:focus-visible){outline:none}.skeleton{background:linear-gradient(90deg,var(--surface-1, #1a1a1a) 0%,var(--surface-2, #222222) 40%,var(--surface-3, #2a2a2a) 50%,var(--surface-2, #222222) 60%,var(--surface-1, #1a1a1a) 100%);background-size:800px 100%;animation:shimmer 1.8s ease-in-out infinite;border-radius:var(--radius-md, 8px)}.skeleton-text{height:.875rem;border-radius:var(--radius-xs, 4px);margin-bottom:.5rem}.skeleton-text.short{width:60%}.skeleton-heading{height:1.5rem;width:40%;border-radius:var(--radius-sm, 6px);margin-bottom:.75rem}.skeleton-card{height:200px;border-radius:var(--radius-lg, 12px)}.skeleton-circle{border-radius:50%}.glow-effect{animation:glow 3s ease-in-out infinite}.loading{animation:pulse 2s ease-in-out infinite}.app-loading{min-height:100svh;color:#fafafa;background:linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(180deg,rgba(255,255,255,.04) 1px,transparent 1px),#050605;background-size:96px 96px}.app-loading-landing{padding:0 max(24px,calc((100vw - 1320px)/2))}.app-loading-nav{min-height:72px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(229,168,58,.18)}.app-loading-nav span{width:min(280px,38vw);height:12px;border-radius:999px;background:#ffffff1a}.app-loading-hero{min-height:calc(100svh - 72px);display:grid;grid-template-columns:minmax(360px,.92fr) minmax(420px,1.08fr);align-items:center;gap:clamp(28px,5vw,72px);padding:32px 0 52px}.app-loading-copy{display:grid;gap:14px}.app-loading-kicker{width:min(360px,76%);height:18px}.app-loading-title{width:min(680px,100%);height:clamp(50px,6vw,78px);border-radius:10px}.app-loading-title-short{width:min(520px,78%)}.app-loading-line{width:min(620px,100%);height:16px}.app-loading-line-short{width:min(430px,70%)}.app-loading-paths{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px}.app-loading-path{min-height:76px}.app-loading-preview{border:1px solid rgba(255,255,255,.12);background:#0d0e0b;box-shadow:inset 0 3px #e5a83a}.app-loading-preview-top{min-height:42px;border-bottom:1px solid rgba(255,255,255,.12);background:#11120e}.app-loading-preview-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:14px}.app-loading-preview-grid span{min-height:180px}.app-loading-app{display:grid;place-content:center;justify-items:center;gap:14px;padding:24px}.app-loading-app .app-loading-line{width:min(280px,72vw)}.app-loading-app .app-loading-line-short{width:min(190px,52vw)}.spinner{animation:spin 1s linear infinite}.appear{animation:fadeIn .3s cubic-bezier(.16,1,.3,1)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary, #111111)}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}@media(max-width:980px){.app-loading-landing{padding:0 16px}.app-loading-hero{min-height:auto;grid-template-columns:1fr;align-items:start;gap:22px;padding-top:28px}}@media(max-width:700px){.app-loading-nav{min-height:64px}.app-loading-nav span{width:38vw}.app-loading-hero{min-height:calc(100svh - 64px);padding-bottom:24px}.app-loading-title{height:clamp(42px,12vw,58px)}.app-loading-paths,.app-loading-preview-grid{grid-template-columns:1fr}.app-loading-preview-grid span{min-height:88px}}*{scrollbar-color:rgba(255,255,255,.08) var(--bg-primary, #111111);scrollbar-width:thin}[data-theme=light] ::-webkit-scrollbar-thumb{background:#0000001a}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#0000002e}[data-theme=light] *{scrollbar-color:rgba(0,0,0,.1) var(--bg-primary)}::selection{background:#e5a83a40;color:var(--text-primary, #ececec)}.drag-to-pan{cursor:grab;touch-action:none;user-select:none;-webkit-user-select:none;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none}.drag-to-pan::-webkit-scrollbar{display:none}.drag-to-pan--active{cursor:grabbing}.toast-stack{position:fixed;top:var(--space-4, 16px);right:var(--space-4, 16px);z-index:3000;display:flex;flex-direction:column;gap:var(--space-2, 8px);max-width:380px;width:calc(100% - 32px);pointer-events:none}.toast{display:flex;align-items:flex-start;gap:var(--space-3, 12px);padding:var(--space-3, 12px) var(--space-4, 16px);background:var(--surface-1, #1b1d22);border:1px solid var(--border-color, #2a2d33);border-left:4px solid #3b82f6;border-radius:var(--radius-md, 8px);box-shadow:0 6px 24px #00000059;pointer-events:auto;animation:toastSlideIn .2s ease-out}@keyframes toastSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast-success{border-left-color:#10b981}.toast-error{border-left-color:#ef4444}.toast-warning{border-left-color:#f59e0b}.toast-info{border-left-color:#3b82f6}.toast-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.toast-success .toast-icon{color:#10b981}.toast-error .toast-icon{color:#ef4444}.toast-warning .toast-icon{color:#f59e0b}.toast-info .toast-icon{color:#3b82f6}.toast-body{flex:1;min-width:0;color:var(--text-primary, #fff);font-size:.88rem;line-height:1.4}.toast-title{font-weight:600;margin-bottom:2px}.toast-message{word-wrap:break-word;overflow-wrap:break-word}.toast-close{background:none;border:none;color:var(--text-muted, #888);cursor:pointer;padding:2px;border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.toast-close:hover{background:#ffffff0f;color:var(--text-primary, #fff)}@media(max-width:540px){.toast-stack{top:auto;bottom:var(--space-4, 16px);left:var(--space-4, 16px);right:var(--space-4, 16px);max-width:none}}.confirm-modal-overlay{position:fixed;inset:0;z-index:2000;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:confirmFadeIn .15s ease}@keyframes confirmFadeIn{0%{opacity:0}to{opacity:1}}.confirm-modal{background:var(--surface-1, #1b1d22);border:1px solid var(--border-color, #2a2d33);border-radius:var(--radius-lg, 12px);width:100%;max-width:480px;max-height:85vh;overflow-y:auto;box-shadow:0 12px 48px #0006;animation:confirmSlideUp .2s ease}@keyframes confirmSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.confirm-modal-danger{border-top:4px solid #ef4444}.confirm-modal-warning{border-top:4px solid #f59e0b}.confirm-modal-primary{border-top:4px solid #3b82f6}.confirm-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6) var(--space-3);border-bottom:1px solid var(--border-color, #2a2d33)}.confirm-modal-header h3{display:flex;align-items:center;gap:var(--space-2);margin:0;font-size:1.05rem;color:var(--text-primary, #fff)}.confirm-modal-danger .confirm-modal-header h3{color:#ef4444}.confirm-modal-warning .confirm-modal-header h3{color:#f59e0b}.confirm-modal-primary .confirm-modal-header h3{color:#3b82f6}.confirm-modal-close{background:none;border:none;color:var(--text-muted, #888);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center}.confirm-modal-close:hover:not(:disabled){background:#ffffff0d;color:var(--text-primary, #fff)}.confirm-modal-close:disabled{opacity:.4;cursor:not-allowed}.confirm-modal-body{padding:var(--space-5) var(--space-6);color:var(--text-secondary, #c5c8cf);font-size:.92rem;line-height:1.55}.confirm-modal-body p{margin:0 0 var(--space-3)}.confirm-modal-body p:last-child{margin-bottom:0}.confirm-modal-body strong{color:var(--text-primary, #fff)}.confirm-modal-body ul{margin:var(--space-2) 0 0 var(--space-4);font-size:.85rem;line-height:1.65}.confirm-modal-typed{padding:0 var(--space-6) var(--space-4)}.confirm-modal-typed label{display:block;font-size:.82rem;color:var(--text-muted, #888);margin-bottom:var(--space-2)}.confirm-modal-typed input{width:100%;padding:10px 12px;background:var(--surface-2, #15171b);border:1px solid var(--border-color, #2a2d33);border-radius:var(--radius-sm, 6px);color:var(--text-primary, #fff);font-size:.95rem;box-sizing:border-box}.confirm-modal-typed input:focus{outline:none;border-color:#ef4444}.confirm-modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;padding:var(--space-4) var(--space-6) var(--space-5);border-top:1px solid var(--border-color, #2a2d33)}.confirm-modal-actions .btn{min-width:100px}@media(max-width:540px){.confirm-modal-actions{flex-direction:column-reverse}.confirm-modal-actions .btn{width:100%}}.upload-toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:9999;display:flex;flex-direction:column;gap:var(--space-2);max-width:360px;width:calc(100vw - 2rem)}.upload-toast{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);background:var(--surface-2);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);animation:toast-slide-in .3s var(--ease-spring)}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.upload-toast-icon{flex-shrink:0;margin-top:2px}.upload-toast-uploading .upload-toast-icon{color:var(--primary-color)}.upload-toast-processing .upload-toast-icon{color:var(--warning-color)}.upload-toast-done .upload-toast-icon{color:var(--success-color)}.upload-toast-error .upload-toast-icon{color:var(--error-color)}.upload-toast-spin{animation:toast-spin 1.5s linear infinite}@keyframes toast-spin{to{transform:rotate(360deg)}}.upload-toast-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.upload-toast-label{font-size:.8125rem;font-weight:600;color:var(--text-primary)}.upload-toast-progress{width:100%;height:3px;border-radius:2px;background:#ffffff0f;overflow:hidden}.upload-toast-bar{height:100%;border-radius:2px;background:var(--accent-color);transition:width var(--transition-base)}.upload-toast-pct,.upload-toast-msg{font-size:.75rem;color:var(--text-secondary)}.upload-toast-err{color:var(--error-color)}.upload-toast-buy-link{display:inline-block;margin-top:.3rem;padding:.25rem .6rem;font-size:.7rem;font-weight:700;color:var(--primary-color);background:#e5a83a1a;border:1px solid rgba(229,168,58,.3);border-radius:var(--radius-sm, 4px);cursor:pointer;transition:all .15s ease}.upload-toast-buy-link:hover{background:#e5a83a33;border-color:var(--primary-color)}.upload-toast-reanalysis.upload-toast-processing{border-left:3px solid #a78bfa}.upload-toast-reanalysis.upload-toast-processing .upload-toast-icon{color:#a78bfa}.upload-toast-reanalysis.upload-toast-done{border-left:3px solid #22c55e}.upload-toast-dismiss{flex-shrink:0;background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:2px;border-radius:var(--radius-xs);transition:background var(--transition-fast)}.upload-toast-dismiss:hover{background:#ffffff0f;color:var(--text-primary)}@media(max-width:480px){.upload-toast-container{bottom:var(--space-4);right:var(--space-2);left:var(--space-2);max-width:none;width:auto}}.social-optin-page{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:var(--space-8) var(--space-4)}.social-optin-card{max-width:520px;width:100%;background:var(--surface-1);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:2.5rem;text-align:center;animation:slideUp .3s ease}.social-optin-icon{color:var(--primary-color);margin-bottom:var(--space-4)}.social-optin-card h2{font-size:1.5rem;margin-bottom:.75rem}.social-optin-desc{color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-6);font-size:.95rem}.social-optin-features{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-6);text-align:left}.social-optin-feature{display:flex;align-items:center;gap:var(--space-3);padding:.75rem 1rem;background:var(--surface-2);border-radius:var(--radius-md);border:1px solid var(--border-color)}.social-optin-feature svg{color:var(--primary-color);flex-shrink:0}.social-optin-feature div{display:flex;flex-direction:column}.social-optin-feature strong{font-size:.9rem;color:var(--text-primary)}.social-optin-feature span{font-size:.8rem;color:var(--text-tertiary)}.social-optin-privacy{font-size:.85rem;color:var(--text-secondary);background:#e5a83a0f;border:1px solid var(--primary-muted);border-radius:var(--radius-md);padding:.75rem;margin-bottom:var(--space-6);line-height:1.5}.social-optin-btn{width:100%;padding:.8rem 1.5rem;font-size:1rem}.social-optin-skip{margin-top:.75rem;font-size:.8rem;color:var(--text-tertiary)}@media(max-width:768px){.social-optin-card{padding:var(--space-6)}}.mobile-bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:220;display:flex;align-items:stretch;justify-content:space-around;min-height:calc(56px + env(safe-area-inset-bottom,0px));padding:4px 8px calc(4px + env(safe-area-inset-bottom,0px));background:#09090bf2;border-top:1px solid rgba(255,255,255,.08);backdrop-filter:blur(16px) saturate(1.5);-webkit-backdrop-filter:blur(16px) saturate(1.5)}.mobile-nav-item{min-width:0;flex:1;max-width:100px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-height:48px;color:#71717a;text-decoration:none;font-size:10px;font-weight:500;letter-spacing:.01em;transition:color .2s ease;position:relative;-webkit-tap-highlight-color:transparent;background:transparent;border:none;border-radius:8px;padding:4px;cursor:pointer;font-family:inherit}.mobile-nav-item svg{width:22px;height:22px;color:currentColor}.mobile-nav-item:hover{color:#a1a1aa}.mobile-nav-item.active,.mobile-nav-item.active svg{color:#fafafa}.mobile-nav-label{line-height:1;overflow:hidden;max-width:100%;text-overflow:ellipsis;white-space:nowrap}.mobile-nav-icon-wrap{position:relative;display:inline-flex}.mobile-nav-badge{position:absolute;top:-4px;right:-8px;display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:#e5a83a;color:#09090b;font-size:10px;font-weight:600;line-height:1}.mobile-nav-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;border:2px solid transparent;transition:border-color .2s ease}.mobile-nav-item.active .mobile-nav-avatar{border-color:#fafafa}.notification-menu{position:absolute;top:calc(100% + 8px);right:0;width:min(420px,calc(100vw - 16px));max-height:420px;overflow-y:auto;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 30px #00000040;z-index:240}.nav-brand .notification-menu{left:0;right:auto}.notification-empty{padding:14px;color:var(--text-tertiary);font-size:.9rem}.notification-item{width:100%;text-align:left;background:transparent;border:0;border-bottom:1px solid var(--border-color);display:flex;gap:8px;align-items:flex-start;justify-content:space-between;padding:12px;color:inherit;cursor:pointer}.notification-item:last-child{border-bottom:0}.notification-item:hover{background:var(--bg-hover)}.notification-copy{flex:1;min-width:0}.notification-title{font-weight:600;color:var(--text-primary);margin-bottom:4px}.notification-count{font-weight:700;color:var(--primary);margin-left:6px}.notification-description{font-size:.86rem;line-height:1.35;color:var(--text-secondary)}.notification-clear{border:0;background:transparent;color:var(--text-tertiary);display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px}.notification-clear:hover{color:var(--text-primary);background:var(--bg-primary)}@media(max-width:768px){.mobile-top-bar .notification-menu,.app--mobile .notification-menu{position:fixed;top:calc(72px + env(safe-area-inset-top,0px));left:max(10px,env(safe-area-inset-left,0px));right:max(10px,env(safe-area-inset-right,0px));width:auto;max-height:min(420px,calc(100dvh - 92px - env(safe-area-inset-bottom,0px)));border-radius:18px;z-index:1200}.notification-item{padding:14px}}.mobile-top-bar{position:sticky;top:0;z-index:150;height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:#09090bcc;border-bottom:1px solid rgba(255,255,255,.08);backdrop-filter:blur(16px) saturate(1.5);-webkit-backdrop-filter:blur(16px) saturate(1.5)}.mobile-top-left{display:flex;align-items:center;gap:12px}.mobile-top-brand{display:flex;align-items:center;justify-content:center;color:#fafafa;text-decoration:none;transition:opacity .2s ease}.mobile-top-brand:hover{opacity:.8}.mobile-top-brand svg{margin-right:0!important}.mobile-top-actions{display:flex;align-items:center;gap:4px}.mobile-top-icon{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:#a1a1aa;text-decoration:none;background:transparent;border:none;border-radius:8px;padding:0;cursor:pointer;transition:all .2s ease}.mobile-top-icon:hover,.mobile-top-icon.active{color:#fafafa;background:#ffffff14}.mobile-top-bell{color:#a1a1aa}.mobile-top-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px;color:#09090b;background:#e5a83a;border-radius:999px;font-size:10px;font-weight:600;line-height:1}@keyframes mobileBellPop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.geb-container{position:fixed;top:var(--space-4);left:50%;transform:translate(-50%);z-index:900;width:100%;max-width:420px;padding:0 var(--space-4);animation:geb-slide-down .5s cubic-bezier(.34,1.56,.64,1);pointer-events:none}@keyframes geb-slide-down{0%{opacity:0;transform:translate(-50%) translateY(-24px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.geb-banner{pointer-events:all;display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:var(--surface-1);border:1px solid rgba(229,168,58,.25);border-radius:var(--radius-xl);box-shadow:0 8px 32px #00000059,0 0 0 1px #e5a83a14,inset 0 1px #ffffff0a;cursor:pointer;transition:all var(--transition-base);font-family:inherit;text-align:left;color:var(--text-primary)}.geb-banner:hover{border-color:#e5a83a66;box-shadow:0 12px 40px #0006,0 0 20px #e5a83a14}.geb-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-lg);background:var(--primary-subtle);color:var(--primary-color);flex-shrink:0}.geb-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--error-color);color:#fff;font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface-1)}.geb-text{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.geb-title{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.geb-subtitle{display:inline-flex;align-items:center;gap:2px;font-size:.72rem;color:var(--primary-color);font-weight:500}.geb-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;flex-shrink:0;transition:all var(--transition-fast)}.geb-close:hover{background:var(--surface-3);color:var(--text-primary)}@media(max-width:768px){.geb-container{top:calc(56px + var(--space-2));max-width:calc(100% - var(--space-4))}}.belt-modal-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:1rem}.belt-modal{position:relative;width:100%;max-width:420px;background:var(--bg-secondary, #1a1a2e);border:1px solid var(--border-color, #2a2a4a);border-radius:20px;padding:2rem 1.75rem;text-align:center;animation:beltModalIn .3s ease-out}@keyframes beltModalIn{0%{opacity:0;transform:scale(.92) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}.belt-modal-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;border-radius:6px;transition:color .15s,background .15s}.belt-modal-close:hover{color:var(--text-primary);background:var(--surface-1, rgba(255,255,255,.05))}.belt-modal-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:var(--primary-muted, rgba(99,102,241,.15));color:var(--primary-light, #f0c05e);margin-bottom:1rem}.belt-modal-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.belt-modal-subtitle{font-size:.85rem;color:var(--text-tertiary);line-height:1.5;margin:0 0 1.5rem}.belt-modal-options{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:1.5rem}.belt-modal-option{display:flex;align-items:center;gap:8px;padding:.55rem 1rem;border-radius:10px;border:2px solid var(--border-color, #2a2a4a);background:var(--bg-primary, #111111);color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.belt-modal-option:hover{border-color:var(--belt-color);background:#ffffff08}.belt-modal-option.selected{border-color:var(--belt-color);background:#ffffff0f;color:var(--text-primary);box-shadow:0 0 0 1px var(--belt-color),0 2px 8px #0003}.belt-modal-swatch{display:inline-block;width:14px;height:14px;border-radius:4px;background:var(--belt-color);border:1px solid rgba(255,255,255,.15);flex-shrink:0}.belt-modal-label{white-space:nowrap}.belt-modal-stripes{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;margin-bottom:1.5rem}.belt-modal-stripe-btn{padding:.35rem .7rem;border-radius:8px;border:1.5px solid var(--border-color, #2a2a4a);background:var(--bg-primary, #111111);color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit;letter-spacing:.05em}.belt-modal-stripe-btn:hover{border-color:var(--belt-color)}.belt-modal-stripe-btn.active{border-color:var(--belt-color);background:#ffffff0f;color:var(--text-primary);font-weight:600;box-shadow:0 0 0 1px var(--belt-color)}.belt-modal-actions{display:flex;flex-direction:column;gap:.5rem;align-items:center}.belt-modal-save{width:100%;padding:.7rem 1.5rem;font-size:.9rem;font-weight:700;border-radius:10px}.belt-modal-skip{background:none;border:none;color:var(--text-tertiary);font-size:.8rem;cursor:pointer;padding:.25rem .5rem;font-family:inherit;transition:color .15s}.belt-modal-skip:hover{color:var(--text-secondary)}.smm-backdrop{position:fixed;inset:0;z-index:1000;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:smmFadeIn .2s ease}@keyframes smmFadeIn{0%{opacity:0}to{opacity:1}}.smm-panel{width:100%;max-width:640px;max-height:80vh;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-xl);animation:smmSlideUp .25s var(--ease-out)}@keyframes smmSlideUp{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.smm-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-color);flex-shrink:0}.smm-header-info h2{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.3}.smm-header-to{font-size:.82rem;color:var(--text-tertiary)}.smm-header-to strong{color:var(--primary-color)}.smm-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast)}.smm-close:hover{background:var(--surface-2);color:var(--text-primary)}.smm-toolbar{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--border-color);flex-shrink:0}.smm-search{display:flex;align-items:center;gap:var(--space-2);background:var(--surface-1);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.45rem .75rem;transition:border-color var(--transition-fast)}.smm-search:focus-within{border-color:var(--primary-dark)}.smm-search svg{color:var(--text-tertiary);flex-shrink:0}.smm-search input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:.85rem;font-family:inherit}.smm-search input::placeholder{color:var(--text-tertiary)}.smm-search-clear{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:2px;display:flex;border-radius:50%;transition:color var(--transition-fast)}.smm-search-clear:hover{color:var(--text-primary)}.smm-message{background:var(--surface-1);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.45rem .75rem;color:var(--text-primary);font-size:.82rem;font-family:inherit;outline:none;transition:border-color var(--transition-fast)}.smm-message:focus{border-color:var(--primary-dark)}.smm-message::placeholder{color:var(--text-tertiary)}.smm-message-section{display:flex;flex-direction:column;gap:4px;padding:var(--space-2) var(--space-5) var(--space-3);border-bottom:1px solid var(--border-color);flex-shrink:0}.smm-message-label{font-size:.72rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.03em}.smm-grid-scroll{flex:1;overflow-y:auto;padding:var(--space-4) var(--space-5);overscroll-behavior:contain}.smm-grid-scroll::-webkit-scrollbar{width:6px}.smm-grid-scroll::-webkit-scrollbar-track{background:transparent}.smm-grid-scroll::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.smm-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.smm-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-8);color:var(--text-tertiary);text-align:center}.smm-empty svg{opacity:.4}.smm-empty p{font-size:.85rem;max-width:280px;margin:0}.smm-card{display:flex;flex-direction:column;background:var(--surface-1);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform .15s}.smm-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.smm-card-sent{opacity:.6;pointer-events:none}.smm-thumb{position:relative;aspect-ratio:16 / 9;background:var(--surface-2);overflow:hidden}.smm-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .25s ease}.smm-card:hover .smm-thumb img{transform:scale(1.03)}.smm-thumb-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);opacity:.5}.smm-badges{position:absolute;top:var(--space-2);right:var(--space-2);display:flex;gap:var(--space-1)}.smm-badge{display:inline-flex;align-items:center;gap:3px;font-size:.65rem;font-weight:700;padding:2px 6px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.03em}.smm-badge-win{background:#34d39933;color:var(--success-color)}.smm-badge-loss{background:#f8717133;color:var(--error-color)}.smm-badge-draw{background:#a8afc226;color:var(--text-secondary)}.smm-badge-instructional{background:#6366f133;color:var(--color-info, #6366f1)}.smm-type-tabs{display:flex;gap:var(--space-1);padding:var(--space-2) var(--space-5);border-bottom:1px solid var(--border-color)}.smm-type-tab{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;font-weight:600;border-radius:var(--radius-full, 999px);border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.smm-type-tab:hover{background:var(--bg-tertiary)}.smm-type-tab.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.smm-type-count{font-size:.68rem;opacity:.75}.smm-card-body{padding:var(--space-2) var(--space-3);display:flex;flex-direction:column;gap:3px;flex:1}.smm-card-title{font-size:.82rem;font-weight:600;color:var(--text-primary);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.smm-card-meta{display:flex;align-items:center;gap:var(--space-1);flex-wrap:wrap}.smm-pill{font-size:.62rem;font-weight:600;color:var(--primary-light);background:var(--primary-subtle);padding:1px 6px;border-radius:var(--radius-sm)}.smm-card-date{font-size:.7rem;color:var(--text-tertiary)}.smm-send-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:.4rem;border:none;border-top:1px solid var(--border-color);background:transparent;color:var(--primary-color);font-size:.78rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.smm-send-btn:hover:not(:disabled){background:var(--primary-subtle)}.smm-send-btn:disabled{cursor:default}.smm-send-done{color:var(--success-color);background:var(--success-subtle)}@media(max-width:600px){.smm-backdrop{align-items:flex-end;padding:0}.smm-panel{max-width:100%;max-height:90vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0;animation:smmSheetUp .3s var(--ease-out)}@keyframes smmSheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.smm-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-2)}.smm-header{padding:var(--space-3) var(--space-4)}.smm-toolbar{padding:var(--space-2) var(--space-4)}.smm-grid-scroll{padding:var(--space-3) var(--space-4)}}@media(max-width:380px){.smm-grid{grid-template-columns:1fr}}.fd-backdrop{position:fixed;inset:0;background:#00000073;z-index:999;animation:fdFadeIn .2s ease-out}@keyframes fdFadeIn{0%{opacity:0}to{opacity:1}}.fd-drawer{position:fixed;bottom:0;left:0;right:0;max-height:85vh;background:var(--bg-primary);border-radius:var(--radius-xl) var(--radius-xl) 0 0;z-index:1000;display:flex;flex-direction:column;animation:fdSlideUp .25s var(--ease-out);box-shadow:0 -4px 32px #00000026}@keyframes fdSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.fd-drawer--desktop{bottom:auto;left:auto;right:auto;max-height:none;border-radius:var(--radius-xl);animation:fdFadeInDesktop .2s var(--ease-out)}.fd-drawer--desktop .fd-handle-bar{display:none}.fd-drawer--desktop .fd-header{touch-action:none;user-select:none;-webkit-user-select:none}.fd-drawer--dragging{transition:none!important;box-shadow:0 8px 40px #00000040}.fd-drawer--resizing{transition:none!important}@keyframes fdFadeInDesktop{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.fd-resize-grip{position:absolute;bottom:0;right:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:nwse-resize;color:var(--text-tertiary);opacity:.5;transition:opacity .15s;touch-action:none;z-index:2;border-radius:0 0 var(--radius-xl) 0}.fd-resize-grip:hover{opacity:1}.fd-handle-bar{display:flex;justify-content:center;padding:var(--space-2) 0 0}.fd-handle{width:36px;height:4px;background:var(--border-color);border-radius:999px}.fd-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4) var(--space-2)}.fd-header-left{display:flex;align-items:center;gap:var(--space-2)}.fd-header-left h2{margin:0;font-size:1.1rem;font-weight:700;color:var(--text-primary)}.fd-friend-count{font-size:.72rem;font-weight:700;background:var(--primary-muted);color:var(--primary-color);padding:1px 7px;border-radius:999px}.fd-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.fd-close:hover{background:var(--surface-2);color:var(--text-primary)}.fd-tabs{display:flex;gap:var(--space-1);padding:0 var(--space-4) var(--space-3)}.fd-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);border:none;border-radius:var(--radius-md);background:var(--surface-1);color:var(--text-tertiary);font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s;font-family:inherit}.fd-tab:hover{background:var(--surface-2);color:var(--text-secondary)}.fd-tab--active{background:var(--primary-muted);color:var(--primary-color)}.fd-tab-count{font-size:.65rem;font-weight:700;background:var(--surface-2);padding:0 5px;border-radius:999px;line-height:1.4}.fd-tab--active .fd-tab-count{background:#ffffff26}.fd-tab-badge{font-size:.6rem;font-weight:700;background:var(--color-danger);color:#fff;padding:0 5px;border-radius:999px;min-width:16px;text-align:center;line-height:1.5}.fd-search{display:flex;align-items:center;gap:var(--space-2);margin:0 0 var(--space-3);padding:var(--space-2) var(--space-3);background:var(--surface-1);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-tertiary);transition:border-color .15s}.fd-search:focus-within{border-color:var(--primary-color)}.fd-search input{flex:1;border:none;background:none;outline:none;font-size:.85rem;color:var(--text-primary);font-family:inherit}.fd-search input::placeholder{color:var(--text-tertiary)}.fd-search-clear{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:2px;display:flex;align-items:center}.fd-search-results{margin:0 0 var(--space-3);background:var(--surface-1);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.fd-search-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-subtle)}.fd-search-item:last-child{border-bottom:none}.fd-search-loading,.fd-search-empty{padding:var(--space-3);text-align:center;color:var(--text-tertiary);font-size:.82rem}.fd-user-info{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;min-width:0;flex:1}.fd-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;flex-shrink:0}.fd-avatar-ph{width:30px;height:30px;border-radius:50%;background:var(--surface-2);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);flex-shrink:0}.fd-user-name{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fd-status-badge{font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:999px;display:flex;align-items:center;gap:3px;flex-shrink:0}.fd-status-friend{background:var(--color-success-subtle);color:var(--color-success)}.fd-status-pending{background:var(--color-warning-subtle);color:var(--color-warning)}.fd-content{flex:1;overflow-y:auto;padding:0 var(--space-4) var(--space-4);overscroll-behavior:contain;padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom,0px))}.fd-loading{text-align:center;color:var(--text-tertiary);font-size:.85rem;padding:var(--space-6) 0}.fd-section{margin-bottom:var(--space-4)}.fd-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:.78rem;font-weight:700;color:var(--primary-color);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-2)}.fd-request-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2);border-radius:var(--radius-sm);transition:background .12s}.fd-request-row:hover{background:var(--surface-1)}.fd-request-actions{display:flex;gap:var(--space-1);flex-shrink:0}.fd-friend-list{display:flex;flex-direction:column}.fd-friend-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-2);border-bottom:1px solid var(--border-subtle);border-radius:var(--radius-sm);transition:background .12s}.fd-friend-row:hover{background:var(--surface-1)}.fd-friend-row:last-child{border-bottom:none}.fd-friend-actions{display:flex;align-items:center;gap:var(--space-1);flex-shrink:0}.fd-action-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.fd-action-btn:hover{background:var(--surface-2);color:var(--text-primary)}.fd-overflow{position:relative}.fd-overflow-menu{position:absolute;right:0;top:100%;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:10;min-width:140px;overflow:hidden}.fd-overflow-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);border:none;background:none;color:var(--text-primary);font-size:.82rem;cursor:pointer;transition:background .15s;font-family:inherit}.fd-overflow-item:hover{background:var(--surface-1)}.fd-overflow-danger{color:var(--color-danger)}.fd-overflow-danger:hover{background:#ef444414}.fd-group-picker{border-top:1px solid var(--border-subtle);padding:var(--space-1) 0}.fd-group-picker-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3) var(--space-2) var(--space-5);border:none;background:none;color:var(--text-secondary);font-size:.78rem;cursor:pointer;transition:background .15s;font-family:inherit}.fd-group-picker-item:hover{background:var(--surface-1);color:var(--text-primary)}.fd-group-picker-item:disabled{opacity:.5;cursor:not-allowed}.fd-empty{text-align:center;padding:var(--space-8) var(--space-4);color:var(--text-tertiary)}.fd-empty p{margin:var(--space-2) 0 0;font-size:.85rem}.fd-pending{margin-top:var(--space-3)}.fd-pending-label{font-size:.72rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em}.fd-pending-chips{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-2)}.fd-pending-chip{font-size:.72rem;font-weight:500;color:var(--text-secondary);background:var(--surface-1);border:1px solid var(--border-color);padding:2px 8px;border-radius:999px;display:flex;align-items:center;gap:3px}.fd-groups-section{margin-top:0;padding-top:0}.fd-group-create{display:flex;gap:var(--space-2);margin:var(--space-2) 0 var(--space-3)}.fd-group-create-input{flex:1;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--surface-1);padding:var(--space-2) var(--space-3);font-size:.82rem;color:var(--text-primary);font-family:inherit;outline:none;transition:border-color .15s}.fd-group-create-input:focus{border-color:var(--primary-color)}.fd-group-create-input::placeholder{color:var(--text-tertiary)}.fd-group-empty{font-size:.8rem;color:var(--text-tertiary);text-align:center;padding:var(--space-3) 0}.fd-group-list{display:flex;flex-direction:column;gap:var(--space-2)}.fd-group-card{border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;transition:border-color .15s}.fd-group-card--expanded{border-color:var(--primary-muted)}.fd-group-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);cursor:pointer;transition:background .15s}.fd-group-header:hover{background:var(--surface-1)}.fd-group-header-left{display:flex;align-items:center;gap:var(--space-2);min-width:0;flex:1;color:var(--text-secondary)}.fd-group-header-info{display:flex;flex-direction:column;min-width:0}.fd-group-name{font-size:.82rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fd-group-meta{font-size:.68rem;color:var(--text-tertiary)}.fd-group-header-right{display:flex;align-items:center;gap:var(--space-1);flex-shrink:0;color:var(--text-tertiary)}.fd-group-body{border-top:1px solid var(--border-subtle)}.fd-group-members-bar{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3)}.fd-group-member-avatars{display:flex;align-items:center}.fd-group-member-avatar{width:22px;height:22px;border-radius:50%;object-fit:cover;border:2px solid var(--bg-primary);margin-left:-6px}.fd-group-member-avatar:first-child{margin-left:0}.fd-group-member-more{font-size:.65rem;font-weight:700;color:var(--text-tertiary);margin-left:var(--space-1)}.fd-group-invite-list{padding:var(--space-1) var(--space-3);border-top:1px solid var(--border-subtle)}.fd-group-invite-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-1) 0}.fd-group-chat{border-top:1px solid var(--border-subtle);max-height:400px;display:flex;flex-direction:column}.fd-group-chat-empty{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4) var(--space-3);color:var(--text-tertiary);font-size:.78rem}.fd-group-chat-messages{flex:1;overflow-y:auto;padding:var(--space-2) var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.fd-chat-msg{display:flex;flex-direction:column;gap:2px;max-width:min(82%,520px);align-self:flex-start}.fd-chat-msg--mine{align-self:flex-end}.fd-chat-msg-header{display:flex;align-items:center;gap:var(--space-2);margin:0 2px}.fd-chat-msg-author{font-size:.72rem;font-weight:700;color:var(--text-secondary)}.fd-chat-msg-author-wrap{display:inline-flex;align-items:center;gap:6px;min-width:0}.fd-chat-msg-avatar,.fd-chat-msg-avatar-ph{width:18px;height:18px;border-radius:999px;flex-shrink:0}.fd-chat-msg-avatar{object-fit:cover;border:1px solid rgba(255,255,255,.18)}.fd-chat-msg-avatar-ph{display:inline-flex;align-items:center;justify-content:center;background:#ffffff14;color:var(--text-tertiary)}.fd-chat-msg--mine .fd-chat-msg-author{color:var(--primary-color)}.fd-chat-msg-time{font-size:.65rem;color:var(--text-tertiary)}.fd-chat-msg--mine .fd-chat-msg-header{justify-content:flex-end}.fd-chat-msg-body{padding:8px 10px;border-radius:12px;border:1px solid var(--chat-border, var(--border-color));background:var(--chat-bg, var(--surface-1));box-shadow:0 2px 8px #0000002e}.fd-chat-msg--mine .fd-chat-msg-body{box-shadow:0 2px 10px #0003}.fd-chat-player{margin-top:var(--space-2);border-radius:var(--radius-sm);overflow:hidden;background:#000}.fd-chat-player video,.fd-chat-player iframe{width:100%;aspect-ratio:16 / 9;display:block;border:none}.fd-chat-player-link{background:var(--surface-1);padding:var(--space-2) var(--space-3);text-align:center}.fd-chat-player-link a{color:var(--primary-color);font-size:.78rem;font-weight:600;text-decoration:none}.fd-chat-player-link a:hover{text-decoration:underline}.fd-chat-play-icon{flex-shrink:0;color:var(--primary-color)}.fd-chat-video-card{display:inline-flex;align-items:center;gap:var(--space-2);background:#00000029;border:1px solid var(--chat-border, var(--border-color));border-radius:var(--radius-sm);padding:4px 8px;cursor:default}.fd-chat-video-title{font-size:.75rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.fd-chat-video-pill{font-size:.62rem;font-weight:600;color:var(--text-tertiary);background:var(--surface-2);padding:1px 6px;border-radius:999px}.fd-chat-msg-text{font-size:.78rem;color:var(--text-secondary);margin:6px 0 0;font-style:italic;line-height:1.4}.fd-chat-msg-text--plain{margin:0;font-style:normal;color:var(--text-primary)}.fd-chat-msg--reply{margin-top:6px}.fd-chat-msg--reply.fd-chat-msg--no-header{margin-top:3px}.fd-chat-reply-count{display:flex;align-items:center;gap:3px;font-size:.65rem;color:var(--text-tertiary);margin-top:2px}.fd-chat-msg--mine .fd-chat-reply-count{justify-content:flex-end}.fd-group-chat-compose{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-top:1px solid var(--border-subtle)}.fd-group-chat-input{flex:1;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--surface-1);padding:var(--space-1) var(--space-2);font-size:.78rem;color:var(--text-primary);font-family:inherit;outline:none}.fd-group-chat-input:focus{border-color:var(--primary-color)}.fd-group-chat-input::placeholder{color:var(--text-tertiary)}.social-fab{position:fixed;z-index:300;width:48px;height:48px;border-radius:50%;border:none;background:#e5a83a;color:#fff;display:flex;align-items:center;justify-content:center;cursor:grab;box-shadow:0 4px 14px #00000059;transition:left .3s ease,top .3s ease,transform .2s ease,opacity .2s ease,box-shadow .2s ease;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.social-fab:hover{transform:scale(1.08);box-shadow:0 6px 20px #00000073}.social-fab--dragging{cursor:grabbing;transform:scale(1.12);box-shadow:0 8px 24px #00000080;transition:transform .1s ease,opacity .1s ease,box-shadow .1s ease}.social-fab--hidden{opacity:0;pointer-events:none;transform:scale(.6)}.social-fab-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;border-radius:9px;background:var(--color-error, #ef4444);color:#fff;font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1;box-shadow:0 1px 4px #0000004d}.social-fab--has-badge:not(.social-fab--dragging):not(.social-fab--hidden){animation:fab-pulse 2.5s ease-in-out infinite}@keyframes fab-pulse{0%,to{box-shadow:0 4px 14px #00000059}50%{box-shadow:0 4px 14px #00000059,0 0 0 6px #ffffff14}}@media(max-width:768px){.social-fab{width:44px;height:44px}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-gradient: #fafafa;--primary-color: #fafafa;--primary-light: #ffffff;--primary-dark: #e5e5e5;--primary-subtle: rgba(255, 255, 255, .05);--primary-muted: rgba(255, 255, 255, .1);--accent-gradient: #e5a83a;--accent-color: #e5a83a;--accent-light: #f0c05e;--accent-dark: #c4880a;--accent-subtle: rgba(229, 168, 58, .1);--accent-glow: rgba(229, 168, 58, .15);--primary: var(--accent-color);--primary-bg: var(--accent-subtle);--success-color: #22c55e;--success-subtle: rgba(34, 197, 94, .1);--warning-color: #f59e0b;--warning-subtle: rgba(245, 158, 11, .1);--error-color: #ef4444;--error-subtle: rgba(239, 68, 68, .1);--bg-primary: #09090b;--bg-secondary: #0f0f12;--bg-tertiary: #18181b;--surface-1: #0f0f12;--surface-2: #18181b;--surface-3: #1c1c1f;--text-primary: #fafafa;--text-secondary: #a1a1aa;--text-tertiary: #52525b;--border-color: rgba(255, 255, 255, .08);--border-subtle: rgba(255, 255, 255, .04);--border-accent: rgba(229, 168, 58, .25);--shadow-0: none;--shadow-1: 0 1px 3px rgba(0, 0, 0, .2);--shadow-2: 0 4px 16px rgba(0, 0, 0, .25);--shadow-xs: var(--shadow-1);--shadow-sm: var(--shadow-1);--shadow-md: var(--shadow-2);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .35);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .45);--shadow-glow: 0 4px 24px rgba(0, 0, 0, .2);--glass-bg: rgba(255, 255, 255, .04);--glass-bg-hover: rgba(255, 255, 255, .07);--glass-bg-strong: rgba(255, 255, 255, .06);--glass-border: rgba(255, 255, 255, .1);--glass-border-hover: rgba(255, 255, 255, .16);--glass-blur: blur(20px);--glass-blur-strong: blur(32px);--glass-shadow: 0 4px 24px rgba(0, 0, 0, .2);--glass-shadow-hover: 0 8px 40px rgba(0, 0, 0, .3);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--spacing-xs: var(--space-1);--spacing-sm: var(--space-2);--spacing-md: var(--space-4);--spacing-lg: var(--space-6);--spacing-xl: var(--space-8);--spacing-2xl: var(--space-12);--text-xs: .75rem;--text-sm: .8125rem;--text-base: .875rem;--text-lg: 1.125rem;--text-xl: 1.5rem;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-full: 9999px;--color-win: #22c55e;--color-win-subtle: rgba(34, 197, 94, .12);--color-loss: #ef4444;--color-loss-subtle: rgba(239, 68, 68, .12);--color-draw: #6b7280;--color-info: #3b82f6;--color-info-subtle: rgba(59, 130, 246, .12);--color-promotion: #f59e0b;--color-competition: #ef4444;--color-seminar: #8b5cf6;--color-social: #3b82f6}[data-theme=light]{--primary-color: #1a1a1a;--primary-light: #333333;--primary-dark: #111111;--primary-subtle: rgba(0, 0, 0, .04);--primary-muted: rgba(0, 0, 0, .08);--primary-gradient: #1a1a1a;--accent-color: #c4880a;--accent-light: #e5a83a;--accent-subtle: rgba(196, 136, 10, .08);--accent-gradient: #c4880a;--success-color: #16a34a;--success-subtle: rgba(22, 163, 74, .08);--warning-color: #d97706;--warning-subtle: rgba(217, 119, 6, .08);--error-color: #dc2626;--error-subtle: rgba(220, 38, 38, .06);--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--surface-1: #ffffff;--surface-2: #f9fafb;--surface-3: #f3f4f6;--text-primary: #111111;--text-secondary: #555555;--text-tertiary: #999999;--border-color: rgba(0, 0, 0, .16);--border-subtle: rgba(0, 0, 0, .08);--border-accent: rgba(196, 136, 10, .35);--shadow-1: 0 1px 3px rgba(0, 0, 0, .1);--shadow-2: 0 4px 16px rgba(0, 0, 0, .12);--shadow-xs: var(--shadow-1);--shadow-sm: var(--shadow-1);--shadow-md: var(--shadow-2);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .14);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .16);--shadow-glow: 0 4px 24px rgba(0, 0, 0, .08);--glass-bg: rgba(255, 255, 255, .7);--glass-bg-hover: rgba(255, 255, 255, .85);--glass-bg-strong: rgba(255, 255, 255, .8);--glass-border: rgba(0, 0, 0, .16);--glass-border-hover: rgba(0, 0, 0, .22);--glass-blur: blur(20px);--glass-blur-strong: blur(32px);--glass-shadow: 0 4px 24px rgba(0, 0, 0, .08);--glass-shadow-hover: 0 8px 40px rgba(0, 0, 0, .12);--color-win: #16a34a;--color-win-subtle: rgba(22, 163, 74, .08);--color-loss: #dc2626;--color-loss-subtle: rgba(220, 38, 38, .06);--color-draw: #64748b;--color-info: #2563eb;--color-info-subtle: rgba(37, 99, 235, .08)}[data-theme=light] .btn-primary{background:var(--accent-color);border:1px solid var(--accent-color);color:#fff}[data-theme=light] .btn-secondary{border:1px solid rgba(0,0,0,.2);color:var(--text-primary);background:#0000000a}[data-theme=light] .btn-secondary:hover:not(:disabled){border-color:#0000004d;background:#00000014}[data-theme=light] .btn-danger{border:1px solid rgba(220,38,38,.35)}[data-theme=light] .btn-logout{border:1px solid rgba(0,0,0,.16)}[data-theme=light] .navbar{border-bottom:1px solid rgba(0,0,0,.1)}[data-theme=light] input,[data-theme=light] textarea,[data-theme=light] select{border:1px solid rgba(0,0,0,.18);background:#00000005}[data-theme=light] input:focus,[data-theme=light] textarea:focus,[data-theme=light] select:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #c4880a1a}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;font-weight:400;letter-spacing:-.011em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{line-height:1.2;font-weight:700;letter-spacing:-.025em;color:var(--text-primary)}h1{font-size:clamp(1.75rem,4vw,2.5rem)}h2{font-size:clamp(1.5rem,3.2vw,2rem)}h3{font-size:clamp(1.125rem,2.5vw,1.5rem)}h4{font-size:1.25rem}h5{font-size:1.0625rem}h6{font-size:.9375rem}p{color:var(--text-secondary);margin-bottom:var(--space-4)}:root{--app-page-title-size: clamp(1.6rem, 2.4vw, 2rem);--app-page-subtitle-size: .92rem;--app-section-title-size: 1.05rem}.page-header,.page-header-left,.page-header-info,.dashboard-welcome,.detail-header,.subscribe-header,.analyze-card,.admin-header-left,.gym-apply-header,.checkin-header{text-align:left!important}.page-header-info h1,.page-header h1,.dashboard-welcome h1,.detail-header h1,.subscribe-header h1,.analyze-card h1,.admin-header-left h1,.gym-apply-header h1,.checkin-header h1{margin-top:0!important;text-align:left!important;font-size:var(--app-page-title-size)!important;line-height:1.05!important;font-weight:900!important;letter-spacing:-.045em!important}.page-subtitle,.page-header-info p,.dashboard-welcome p,.detail-header p,.subscribe-subtitle,.analyze-card .subtitle,.checkin-subtitle{text-align:left!important;font-size:var(--app-page-subtitle-size)!important;line-height:1.45!important;font-weight:500!important}.section-heading,.analytics-section .section-heading,.training-log-page .section-heading{justify-content:flex-start!important;text-align:left!important;font-size:var(--app-section-title-size)!important;line-height:1.2!important;font-weight:900!important;letter-spacing:-.025em!important}@media(max-width:760px){:root{--app-page-title-size: 1.45rem;--app-page-subtitle-size: .86rem;--app-section-title-size: 1rem}}#root{width:100%;min-height:100vh;display:flex;flex-direction:column}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.navbar{position:sticky;top:0;z-index:100;background:#09090bcc;backdrop-filter:blur(16px) saturate(1.5);-webkit-backdrop-filter:blur(16px) saturate(1.5);border-bottom:1px solid rgba(255,255,255,.08);padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:60px;max-width:100%}.nav-brand{display:flex;align-items:center;gap:12px;flex-shrink:0}.nav-brand .logo{text-decoration:none;display:flex;align-items:center;transition:opacity .2s ease}.nav-brand .logo:hover{opacity:.8}.nav-links{display:flex;flex-direction:row;gap:4px;align-items:center;justify-content:flex-end;padding:0;flex:1;min-width:0}.nav-links a{color:#a1a1aa;text-decoration:none;font-weight:500;font-size:14px;transition:all .2s ease;padding:8px 14px;border-radius:8px;position:relative;display:flex;align-items:center;gap:6px;white-space:nowrap;min-height:38px}.nav-links a:hover{color:#fafafa;background:#ffffff0f}.nav-links a.active{color:var(--accent-light);background:var(--accent-subtle);border:1px solid rgba(229,168,58,.18)}.nav-links a.active:after{display:none}.nav-divider{width:1px;height:24px;background:var(--border-color);margin:0 var(--space-1);flex-shrink:0}.nav-bell-wrap{position:relative;z-index:220}.nav-bell{position:relative;display:flex;align-items:center;justify-content:center;background:#ffffff09;border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-md);transition:all var(--transition-fast);margin-left:var(--space-3);margin-right:var(--space-2)}.nav-bell:hover{color:var(--accent-color);border-color:var(--border-accent);background:var(--accent-subtle)}.nav-bell-badge{position:absolute;top:-2px;right:-4px;display:inline-flex;align-items:center;justify-content:center;min-width:17px;height:17px;padding:0 4px;border-radius:var(--radius-full);background:var(--error-color);color:#fff;font-size:.6rem;font-weight:800;line-height:1;animation:bellPop .4s var(--ease-spring)}@keyframes bellPop{0%{transform:scale(0)}50%{transform:scale(1.3)}to{transform:scale(1)}}.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:17px;height:17px;padding:0 5px;border-radius:var(--radius-full);background:var(--error-color);color:#fff;font-size:.6rem;font-weight:700;line-height:1;margin-left:var(--space-1);animation:badgePop .3s var(--ease-spring)}@keyframes badgePop{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.nav-dropdown-trigger .nav-badge{margin-left:.25rem;margin-right:-.15rem}.nav-dropdown-menu .nav-badge{margin-left:auto}.restricted-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-8);background:var(--bg-primary)}.restricted-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-10);max-width:480px;width:100%;text-align:center;box-shadow:var(--shadow-md)}.restricted-icon{font-size:2.5rem;margin-bottom:var(--space-3);color:var(--warning-color)}.restricted-title{font-size:1.5rem;margin:0 0 var(--space-3) 0}.restricted-title-danger{color:var(--error-color)}.restricted-title-warning{color:var(--warning-color)}.restricted-body{color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-4)}.restricted-meta{color:var(--text-tertiary);font-size:.85rem;margin-bottom:var(--space-4)}.restricted-meta-support{margin-bottom:var(--space-6)}.restricted-support-link{color:var(--primary-light)}.restricted-support-link:hover{text-decoration:underline}.restricted-action{width:100%}.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:4px;z-index:110;position:relative}.hamburger-badge{position:absolute;top:-2px;right:-4px;width:9px;height:9px;border-radius:50%;background:var(--error-color);animation:badgePop .3s var(--ease-spring)}.hamburger span{display:block;width:22px;height:2px;background:var(--text-secondary);border-radius:2px;transition:all var(--transition-base)}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.app-main{padding:var(--space-6);width:100%;max-width:1400px;margin:0 auto;overflow-x:hidden;flex:1}@media(min-width:769px){.app-main:has(.admin-layout),.app-main:has(.gym-admin-layout){max-width:none;margin:0;padding:0;overflow:hidden}.app:has(.admin-layout) .app-footer,.app:has(.gym-admin-layout) .app-footer{display:none}}.app-footer{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-top:1px solid var(--glass-border);padding:var(--space-4) var(--space-6);text-align:center;color:var(--text-tertiary);font-size:.8rem}.app-footer p{margin:0;color:var(--text-tertiary)}.footer-link{color:var(--text-tertiary);text-decoration:none;transition:color var(--transition-fast)}.footer-link:hover{color:var(--primary-light);text-decoration:underline}.btn{padding:var(--space-2) var(--space-5);border:none;border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;font-weight:600;transition:all var(--transition-base);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);white-space:nowrap;min-width:0;-webkit-user-select:none;user-select:none;text-decoration:none;letter-spacing:-.01em;line-height:1.4}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px}.btn-primary{background:var(--accent-color);color:#111;border:1px solid rgba(255,255,255,.1);box-shadow:var(--glass-shadow)}.btn-primary:hover:not(:disabled){background:var(--accent-light);box-shadow:var(--glass-shadow-hover);filter:brightness(1.08)}.btn-primary:active:not(:disabled){filter:brightness(.95)}.btn-secondary{background:#ffffff09;color:var(--primary-light);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--accent-subtle);border-color:var(--border-accent)}.btn-danger{background:var(--error-subtle);color:var(--error-color);border:1px solid rgba(248,113,113,.2)}.btn-danger:hover:not(:disabled){background:var(--error-color);color:#fff;border-color:var(--error-color)}.btn-large{padding:var(--space-3) var(--space-8);font-size:.9375rem;border-radius:var(--radius-lg)}.btn-small{padding:var(--space-1) var(--space-3);font-size:.8rem}.btn-sm{padding:.42rem .7rem;font-size:.78rem;border-radius:8px}.btn-success{background:#22c55e1f;color:#86efac;border:1px solid rgba(34,197,94,.35)}.btn-success:hover:not(:disabled){background:#22c55e33;border-color:#22c55e8c}.btn-outline-danger{background:#ef444414;color:#fca5a5;border:1px solid rgba(239,68,68,.28)}.btn-outline-danger:hover:not(:disabled){background:#ef44442e;color:#fecaca;border-color:#ef444480}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid transparent;box-shadow:none}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text-primary);border-color:var(--border-color)}.btn-ghost-danger{background:transparent;color:#fca5a5;border:1px solid transparent;box-shadow:none}.btn-ghost-danger:hover:not(:disabled){background:#ef44441f;color:#fecaca;border-color:#ef444447}.btn-link{display:inline-flex;align-items:center;justify-content:center;gap:.25rem;width:fit-content;min-height:28px;padding:.2rem .35rem;background:transparent;border:1px solid transparent;border-radius:7px;color:var(--accent-color);font:inherit;font-size:.85rem;font-weight:700;cursor:pointer;text-decoration:none}.btn-link:hover:not(:disabled){background:#e5a83a14;border-color:#e5a83a38;text-decoration:none}.login-legal-footer{margin-top:var(--space-6);color:var(--text-tertiary);font-size:var(--text-xs);text-align:center}input,textarea,select{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);color:var(--text-primary);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-family:inherit;font-size:.9375rem;transition:all var(--transition-fast)}select,input{color-scheme:dark}select option{background:var(--surface-2);color:var(--text-primary)}select option:checked{background:var(--surface-3);color:var(--text-primary)}[data-theme=light] select,[data-theme=light] input{color-scheme:light}[data-theme=light] select option{background:#fff;color:#1a1a1a}[data-theme=light] select option:checked{background:#f0f0f0;color:#1a1a1a}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #e5a83a1f;background:var(--glass-bg-hover)}input::placeholder,textarea::placeholder{color:var(--text-tertiary)}.page-container{max-width:1400px;margin:0 auto;padding:var(--space-8) var(--space-4);animation:slideUp .4s var(--ease-out);width:100%}.page-container--wide{max-width:1600px}.page-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6)}.page-header-left{display:flex;align-items:center;gap:var(--space-3);min-width:0}.page-header-left>svg{color:var(--primary-light);flex-shrink:0}.page-header-info{min-width:0}.page-header-info h1{display:flex;align-items:center;gap:var(--space-2);margin:0;font-size:clamp(1.4rem,3vw,1.75rem);line-height:1.2}.page-header-info p{max-width:720px;margin:.25rem 0 0;color:var(--text-secondary);font-size:var(--app-page-subtitle-size, .95rem);line-height:1.5}.page-subtitle{color:var(--text-tertiary);font-size:.85rem;margin:.15rem 0 0}.page-header-actions{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-1);flex-shrink:0;min-width:0}.page-tabs{display:flex;gap:0;margin-bottom:var(--space-6);border-bottom:1px solid var(--border-color);overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}.page-tabs::-webkit-scrollbar{display:none}.segmented-control{display:flex;gap:var(--space-1);background:var(--surface-1);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:.2rem;margin-bottom:var(--space-5)}.segmented-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:transparent;border:none;color:var(--text-tertiary);font-size:.8125rem;font-weight:600;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);font-family:inherit;white-space:nowrap}.segmented-btn:hover{color:var(--text-secondary);background:var(--surface-2)}.segmented-btn.active{background:var(--surface-2);color:var(--text-primary)}.page-tab{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;font-size:.875rem;font-weight:600;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;font-family:inherit}.page-tab:hover{color:var(--text-secondary);background:#e5a83a0a}.page-tab.active{color:var(--accent-light);border-bottom-color:var(--accent-color)}.page-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.4rem;height:1.4rem;padding:0 .35rem;border-radius:10px;background:#78716c1a;color:var(--text-tertiary);font-size:.72rem;font-weight:700}.page-tab.active .page-tab-count{background:var(--accent-subtle);color:var(--accent-light)}.page-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:var(--radius-full);background:var(--error-color);color:#fff;font-size:.65rem;font-weight:700;line-height:1}.page-tab.locked-tab{opacity:.5;cursor:not-allowed}.page-tab.locked-tab:hover{color:var(--text-tertiary);background:none}.page-search-wrapper{position:relative;margin-bottom:var(--space-6)}.page-search-bar{display:flex;align-items:center;gap:var(--space-2);padding:.65rem .85rem;background:var(--surface-1);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.page-search-bar:focus-within{border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-subtle)}.page-search-bar>svg{color:var(--text-tertiary);flex-shrink:0}.page-search-bar input{flex:1;border:none;background:transparent;color:var(--text-primary);font-size:.9rem;outline:none;padding:0;box-shadow:none}.page-search-bar input::placeholder{color:var(--text-tertiary)}.page-search-clear{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:.2rem;border-radius:50%;transition:var(--transition-fast)}.page-search-clear:hover{background:var(--surface-2);color:var(--text-primary)}.page-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-12) var(--space-6);color:var(--text-tertiary)}.page-empty>svg{opacity:.4;margin-bottom:var(--space-4)}.page-empty h3{color:var(--text-secondary);margin:0 0 var(--space-2) 0;font-size:1.1rem}.page-empty p{font-size:.875rem;max-width:320px;margin:0 auto;line-height:1.5;color:var(--text-tertiary)}.page-empty .btn{margin-top:var(--space-4)}.page-card-list{display:flex;flex-direction:column;gap:var(--space-2)}.page-card{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--surface-1);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast);box-shadow:var(--shadow-xs)}.page-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-sm)}.admin-badge{display:inline-flex;align-items:center;margin-left:var(--space-2);padding:2px var(--space-2);border-radius:var(--radius-sm);font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--accent-subtle);color:var(--accent-light);border:1px solid var(--border-accent)}@media(max-width:768px){.page-container{padding:var(--space-4) .75rem}.page-header{flex-wrap:wrap;row-gap:var(--space-3);column-gap:var(--space-2)}.page-header-left{flex:1 1 auto;min-width:0}.page-header-left>svg{width:22px;height:22px}.page-header-info h1{font-size:1.25rem}.page-header-actions{flex:1 1 100%;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:flex-start;gap:var(--space-2)}.page-header-actions .btn,.page-header-actions button{min-width:0;white-space:nowrap}.page-tab{flex:1;justify-content:center;padding:var(--space-2) var(--space-1);font-size:.78rem;gap:.3rem;min-width:0}.page-tab>svg{display:none}.page-tab-count{min-width:1.2rem;height:1.2rem;font-size:.65rem;padding:0 .25rem}.page-card{padding:var(--space-2) var(--space-3)}}.tag{display:inline-flex;align-items:center;gap:var(--space-1);border-radius:var(--radius-sm);font-weight:600;font-size:.75rem;padding:var(--space-1) var(--space-2);background:var(--primary-subtle);color:var(--primary-light);border:1px solid var(--border-accent)}.small-tag{display:inline-block;border-radius:var(--radius-xs);font-weight:500;font-size:.7rem;padding:2px var(--space-2);background:var(--surface-2);color:var(--text-tertiary);border:1px solid var(--border-color)}.type-badge{padding:2px var(--space-2);border-radius:var(--radius-sm);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;background:#a78bfa1a;color:#c4b5fd;border:1px solid rgba(167,139,250,.15)}.difficulty-badge{padding:2px var(--space-2);border-radius:var(--radius-sm);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.difficulty-beginner{background:#34d3991a;color:#6ee7b7;border:1px solid rgba(52,211,153,.15)}.difficulty-intermediate{background:#fbbf241a;color:#fcd34d;border:1px solid rgba(251,191,36,.15)}.difficulty-advanced{background:#f871711a;color:#fca5a5;border:1px solid rgba(248,113,113,.15)}.source-badge{padding:2px var(--space-2);border-radius:var(--radius-sm);font-size:.7rem;font-weight:600;letter-spacing:.03em}.source-ai{background:var(--primary-subtle);color:#f0c05e;border:1px solid var(--border-accent)}.source-ai-whisper{background:var(--success-subtle);color:#6ee7b7;border:1px solid rgba(52,211,153,.15)}.clickable{cursor:pointer}.stat-strip{display:flex;align-items:center;gap:0;flex-wrap:wrap;margin-bottom:var(--space-6)}.stat-strip-item{display:flex;flex-direction:column;align-items:center;padding:var(--space-3) var(--space-6);position:relative}.stat-strip-item:not(:last-child):after{content:"";position:absolute;right:0;top:20%;height:60%;width:1px;background:var(--border-color)}.stat-strip-value{font-size:var(--text-xl);font-weight:800;line-height:1.1;color:var(--text-primary)}.stat-strip-label{font-size:var(--text-xs);font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}.stat-strip-item.stat-win .stat-strip-value{color:var(--color-win)}.stat-strip-item.stat-loss .stat-strip-value{color:var(--color-loss)}.stat-strip-item.stat-draw .stat-strip-value{color:var(--color-draw)}.stat-strip-item.stat-accent .stat-strip-value{color:var(--accent-color)}@media(max-width:640px){.stat-strip-item{padding:var(--space-2) var(--space-4)}.stat-strip-value{font-size:var(--text-lg)}}.section-heading{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin:var(--space-8) 0 var(--space-4) 0;padding-bottom:var(--space-3);border-bottom:1px solid var(--border-color)}.section-heading:first-child{margin-top:0}.section-heading svg{color:var(--accent-color);flex-shrink:0}.section-heading-sm{font-size:var(--text-base);font-weight:700;margin:var(--space-6) 0 var(--space-3) 0;padding-bottom:var(--space-2)}.inline-banner{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) 0;border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);margin-bottom:var(--space-6)}.inline-banner-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-md);flex-shrink:0}.inline-banner-content{flex:1;min-width:0}.inline-banner-content h3{font-size:var(--text-base);font-weight:700;margin:0 0 2px}.inline-banner-content p{font-size:var(--text-sm);color:var(--text-secondary);margin:0;line-height:1.4}@media(max-width:640px){.inline-banner{flex-direction:column;text-align:center;gap:var(--space-3)}.inline-banner .btn{width:100%;justify-content:center}}.inline-banner-vertical{flex-direction:column;text-align:center;gap:var(--space-3);padding:var(--space-5) var(--space-4);border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--card-bg);margin-bottom:0}.inline-banner-vertical .btn{width:100%;justify-content:center}.btn-outline{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.btn-outline:hover:not(:disabled){border-color:var(--text-tertiary);background:var(--surface-2);color:var(--text-primary)}.empty-state{text-align:center;padding:var(--space-12);color:var(--text-tertiary)}@media(max-width:768px){.navbar{padding:0 var(--space-4)}.nav-links{display:none;position:fixed;top:56px;left:0;right:0;background:var(--surface-1);flex-direction:column;padding:var(--space-6);gap:var(--space-1);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-lg);z-index:99}.hamburger,.nav-links.open{display:flex}.nav-links a{width:100%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md)}.nav-links a.active:after{display:none}.nav-links a.active{background:var(--primary-muted)}.nav-divider{width:100%;height:1px;margin:var(--space-1) 0}.app-main{padding:var(--space-4)}h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}}.install-pwa-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--accent-color);color:#1a1a2e;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);font-size:.875rem;font-weight:700;cursor:pointer;transition:all var(--transition-base);white-space:nowrap;box-shadow:var(--glass-shadow)}.nav-links .install-pwa-btn{min-height:38px;padding:0 var(--space-3);color:var(--text-secondary);background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-full);box-shadow:none;font-size:.74rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.nav-links .install-pwa-btn:hover{color:var(--accent-color);background:var(--accent-subtle);border-color:var(--accent-color);filter:none;box-shadow:none}.install-pwa-btn:hover{filter:brightness(1.1);box-shadow:var(--glass-shadow-hover)}.install-pwa-btn:active{filter:brightness(.95)}@keyframes pulse-glow{0%,to{box-shadow:0 2px 8px #00000026}50%{box-shadow:0 4px 16px #00000040}}.install-pwa-wrapper{position:relative}.install-instructions{position:absolute;top:calc(100% + .5rem);right:0;background:var(--surface-2);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);min-width:250px;box-shadow:var(--shadow-lg);z-index:1000;animation:fadeIn .2s var(--ease-out)}.install-instructions.install-instructions--portal{position:fixed;top:auto;right:auto;z-index:2000}.install-instructions p{margin-bottom:.5rem;color:var(--text-primary);font-size:.875rem}.install-instructions ol{margin:0;padding-left:1.25rem;color:var(--text-secondary);font-size:.8rem;line-height:1.6}.install-instructions ol li{margin-bottom:.25rem}.close-instructions{position:absolute;top:.5rem;right:.5rem;background:none;border:none;color:var(--text-tertiary);cursor:pointer;font-size:1rem;padding:.25rem}.close-instructions:hover{color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.nav-user{display:flex;align-items:center;gap:var(--space-2);padding:0 0 0 var(--space-4);border-left:1px solid var(--border-color)}.nav-user-link{display:flex;align-items:center;gap:var(--space-2);text-decoration:none;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer}.nav-user-link:hover{background:var(--primary-subtle)}.nav-user-link:hover .nav-user-name{color:var(--primary-light)}.nav-user-link:hover .nav-avatar{border-color:var(--primary-light)}.nav-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;border:2px solid var(--primary-color)}.nav-user-name{color:var(--text-secondary);font-size:.85rem;font-weight:500;white-space:nowrap;overflow:visible;text-overflow:unset;display:inline-flex;align-items:center;gap:var(--space-2);flex:1}.nav-admin-badge{display:inline-flex;align-items:center;gap:.2rem;margin-left:0;padding:3px 8px;background:transparent;color:var(--accent-color);border:1px solid color-mix(in srgb,var(--accent-color) 45%,transparent);font-size:.6rem;font-weight:850;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;vertical-align:middle;white-space:nowrap;flex-shrink:0}.btn-logout{background:none;border:1px solid var(--border-color);color:var(--text-tertiary);padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:.8rem;cursor:pointer;transition:var(--transition-fast);white-space:nowrap;text-align:center}.btn-logout:hover{color:var(--error-color);border-color:var(--error-color);background:var(--error-subtle)}@media(max-width:768px){.nav-user{margin-top:0;padding:var(--space-2) 0;border-left:none;border-top:1px solid var(--border-color);justify-content:center}}.nav-subscribe{font-weight:600!important;display:inline-flex!important;align-items:center;gap:var(--space-2);font-size:.875rem!important;line-height:1;color:var(--accent-color)!important;border:1px solid rgba(229,168,58,.18);background:#e5a83a0f}.nav-subscribe svg{color:inherit!important;stroke:currentColor!important;flex-shrink:0}.nav-subscribe svg *{stroke:currentColor}.nav-subscribe.active{color:var(--accent-light)!important;-webkit-text-fill-color:unset!important;background:var(--accent-subtle)!important}.nav-subscribe.active svg{color:var(--accent-color)}.admin-mode-toggle{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .65rem;border-radius:var(--radius-full);border:1px solid var(--border-color);background:var(--surface-1);color:var(--text-secondary);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;transition:all .2s ease;font-family:inherit;white-space:nowrap;flex-shrink:0}.admin-mode-toggle:hover{border-color:var(--accent-color);color:var(--accent-color)}.admin-mode-toggle.active{background:var(--accent-color);color:#111;border-color:var(--accent-color)}.admin-mode-toggle.active:hover{background:var(--accent-light);border-color:var(--accent-light)}.admin-mode-toggle svg{flex-shrink:0}.app--mobile .navbar{display:none}.app:has(.lp-overview-page)>.navbar,.app:has(.lp-onepage)>.navbar,.app:has(.login-container)>.navbar{display:none!important;visibility:hidden!important;opacity:0!important;pointer-events:none!important}.app--mobile .app-footer{display:none}.app-main--mobile{padding:var(--space-4);padding-bottom:calc(76px + env(safe-area-inset-bottom,0px) + var(--space-4))}.mobile-legal-footer{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:var(--space-6) var(--space-4) var(--space-2);margin-top:var(--space-6)}.mobile-legal-footer a{color:var(--text-tertiary);text-decoration:none;font-size:.7rem;font-weight:500;transition:color var(--transition-fast)}.mobile-legal-footer a:hover,.mobile-legal-footer a.active{color:var(--primary-light)}.mobile-legal-sep{color:var(--text-tertiary);font-size:.7rem;opacity:.5}.impersonation-banner{position:sticky;top:0;z-index:9999;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;background:var(--warning-color, #f59e0b);color:#1a1a1a;font-size:.85rem;font-weight:600;text-align:center}.impersonation-banner strong{font-weight:700}.impersonation-banner button{margin-left:.75rem;padding:.25rem .75rem;border:1.5px solid #1a1a1a;border-radius:6px;background:transparent;color:#1a1a1a;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.impersonation-banner button:hover:not(:disabled){background:#1a1a1a;color:var(--warning-color, #f59e0b)}.impersonation-banner button:disabled{opacity:.6;cursor:not-allowed}.impersonation-readonly-badge{display:inline-flex;align-items:center;padding:.15rem .5rem;font-size:.68rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;background:#1a1a1a;color:var(--warning-color, #f59e0b);border-radius:4px}
