@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";*{margin:0;padding:0;box-sizing:border-box}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px}:root{--radius-sm: 6px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 0 rgba(27, 31, 36, .04);--shadow-md: 0 3px 6px rgba(140, 149, 159, .15);--shadow-lg: 0 8px 24px rgba(140, 149, 159, .2);--shadow-xl: 0 12px 28px rgba(140, 149, 159, .3);--shadow-2xl: 0 16px 32px rgba(27, 31, 36, .15);--transition-fast: 80ms cubic-bezier(.33, 1, .68, 1);--transition-base: .2s cubic-bezier(.33, 1, .68, 1);--transition-slow: .3s cubic-bezier(.33, 1, .68, 1)}:root[data-theme=light]{--body-bg: #ffffff;--surface-bg: #f6f8fa;--surface-secondary: #ffffff;--surface-tertiary: #f6f8fa;--text-primary: #1f2328;--text-secondary: #59636e;--text-tertiary: #818b98;--text-inverse: #ffffff;--primary: #0969da;--primary-hover: #0860ca;--primary-light: #ddf4ff;--primary-dark: #0550ae;--accent: #0969da;--accent-hover: #0860ca;--accent-light: #ddf4ff;--border-color: #d1d9e0;--border-hover: #0969da;--divider: #d1d9e0;--success: #1f883d;--success-bg: #dafbe1;--success-text: #0f5323;--success-border: #1f883d;--warning: #bf8700;--warning-bg: #fff8c5;--warning-text: #7d4e00;--warning-border: #bf8700;--error: #d1242f;--error-bg: #ffebe9;--error-text: #86061d;--error-border: #d1242f;--info: #0969da;--info-bg: #ddf4ff;--info-text: #0349b4;--info-border: #0969da;--card-bg: #ffffff;--hover-bg: #f3f4f6;--active-bg: #ddf4ff;--disabled-bg: #f6f8fa;--disabled-text: #818b98;--button-default-bg: #f6f8fa;--button-default-hover: #f3f4f6;--button-default-active: #e6eaef;--button-default-border: #d1d9e0;--button-default-text: #1f2328;--button-primary-bg: #1f883d;--button-primary-hover: #1c8139;--button-primary-active: #197935;--button-primary-text: #ffffff;--button-danger-bg: #d1242f;--button-danger-hover: #b62324;--button-danger-active: #a0161e;--button-danger-text: #ffffff;--shadow-colored: 0 0 0 4px rgba(9, 105, 218, .12)}:root[data-theme=dark]{--body-bg: #0d1117;--surface-bg: #161b22;--surface-secondary: #0d1117;--surface-tertiary: #010409;--text-primary: #e6edf3;--text-secondary: #8d96a0;--text-tertiary: #6e7681;--text-inverse: #0d1117;--primary: #539bf5;--primary-hover: #6cb6ff;--primary-light: #1c2d41;--primary-dark: #4184e4;--accent: #539bf5;--accent-hover: #6cb6ff;--accent-light: #1c2d41;--border-color: #30363d;--border-hover: #539bf5;--divider: #21262d;--success: #3fb950;--success-bg: #0f3a1a;--success-text: #7ee787;--success-border: #3fb950;--warning: #d29922;--warning-bg: #4a3c0f;--warning-text: #e3b341;--warning-border: #d29922;--error: #f85149;--error-bg: #490b0d;--error-text: #ff8182;--error-border: #f85149;--info: #539bf5;--info-bg: #0c2d6b;--info-text: #79c0ff;--info-border: #539bf5;--card-bg: #161b22;--hover-bg: #21262d;--active-bg: #1c2d41;--disabled-bg: #21262d;--disabled-text: #6e7681;--button-default-bg: #21262d;--button-default-hover: #30363d;--button-default-active: #292e33;--button-default-border: #30363d;--button-default-text: #e6edf3;--button-primary-bg: #238636;--button-primary-hover: #2ea043;--button-primary-active: #26a148;--button-primary-text: #ffffff;--button-danger-bg: #da3633;--button-danger-hover: #e5534b;--button-danger-active: #f47067;--button-danger-text: #ffffff;--shadow-sm: 0 0 transparent;--shadow-md: 0 3px 6px rgba(1, 4, 9, .12);--shadow-lg: 0 8px 24px rgba(1, 4, 9, .2);--shadow-xl: 0 12px 28px rgba(1, 4, 9, .3);--shadow-2xl: 0 16px 32px rgba(1, 4, 9, .4);--shadow-colored: 0 0 0 4px rgba(83, 155, 245, .12)}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:"liga";-webkit-font-smoothing:antialiased;vertical-align:middle}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--body-bg);color:var(--text-primary);transition:background-color var(--transition-slow),color var(--transition-slow);overflow-x:hidden;max-width:100vw}code{font-family:JetBrains Mono,Fira Code,source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh;overflow-x:hidden;max-width:100vw}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.card{background:var(--card-bg);border-radius:var(--radius-md);box-shadow:var(--shadow-md);border:1px solid var(--border-color)}.btn-primary{background:var(--button-primary-bg);color:var(--button-primary-text);border:1px solid rgba(27,31,36,.15);border-radius:var(--radius-md);transition:all var(--transition-base);font-weight:600;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--button-primary-hover);box-shadow:var(--shadow-md)}.btn-primary:active:not(:disabled){background:var(--button-primary-active)}.btn-secondary{background:var(--button-default-bg);color:var(--button-default-text);border:1px solid var(--button-default-border);border-radius:var(--radius-md);transition:all var(--transition-base);font-weight:600;box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background:var(--button-default-hover);border-color:var(--border-hover)}.btn-secondary:active:not(:disabled){background:var(--button-default-active)}input[type=checkbox]{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:20px;height:20px;border:2px solid var(--border-color);border-radius:5px;background-color:transparent;cursor:pointer;position:relative;transition:all var(--transition-base);flex-shrink:0}input[type=checkbox]:hover{border-color:var(--primary);background-color:var(--primary-light)}input[type=checkbox]:focus{outline:none;box-shadow:0 0 0 3px var(--shadow-colored)}input[type=checkbox]:checked{background-color:var(--primary);border-color:var(--primary);animation:checkboxBounce .3s ease-in-out}input[type=checkbox]:checked:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(45deg) scale(0);width:5px;height:10px;border:solid white;border-width:0 2px 2px 0;animation:checkmarkSlide .3s ease-in-out forwards;animation-delay:.1s}input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed;background-color:var(--disabled-bg);border-color:var(--border-color)}input[type=checkbox]:disabled:hover{border-color:var(--border-color);background-color:var(--disabled-bg)}@keyframes checkboxBounce{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes checkmarkSlide{0%{transform:translate(-50%,-50%) rotate(45deg) scale(0)}50%{transform:translate(-50%,-50%) rotate(45deg) scale(1.2)}to{transform:translate(-50%,-50%) rotate(45deg) scale(1)}}input[type=radio]{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:20px;height:20px;border:2px solid var(--border-color);border-radius:50%;background-color:transparent;cursor:pointer;position:relative;transition:all var(--transition-base);flex-shrink:0}input[type=radio]:hover{border-color:var(--primary);background-color:var(--primary-light)}input[type=radio]:focus{outline:none;box-shadow:0 0 0 3px var(--shadow-colored)}input[type=radio]:checked{background-color:var(--primary);border-color:var(--primary);animation:radioBounce .3s ease-in-out}input[type=radio]:checked:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);width:8px;height:8px;border-radius:50%;background-color:#fff;animation:radioDotSlide .3s ease-in-out forwards;animation-delay:.1s}input[type=radio]:disabled{opacity:.5;cursor:not-allowed;background-color:var(--disabled-bg);border-color:var(--border-color)}input[type=radio]:disabled:hover{border-color:var(--border-color);background-color:var(--disabled-bg)}@keyframes radioBounce{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes radioDotSlide{0%{transform:translate(-50%,-50%) scale(0)}50%{transform:translate(-50%,-50%) scale(1.3)}to{transform:translate(-50%,-50%) scale(1)}}.app-logo{display:inline-block;vertical-align:middle;-webkit-user-select:none;user-select:none;object-fit:contain}.app-logo-xs{max-height:20px}.app-logo-sm{max-height:32px}.app-logo-md{max-height:48px}.app-logo-lg{max-height:64px}.app-logo-xl{max-height:96px}.top-bar{position:fixed;top:0;left:0;right:0;height:60px;background:var(--surface-bg);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 20px;z-index:1000;box-shadow:var(--shadow-md)}.top-bar-left{display:flex;align-items:center}.logo-button{display:flex;align-items:center;gap:12px;background:transparent;border:none;padding:0;cursor:pointer;transition:opacity .2s}.logo-button:hover{opacity:.8}.app-title{font-size:1.5rem;font-weight:700;margin:0;color:var(--text-primary);-webkit-user-select:none;user-select:none}.game-info-topbar{display:flex;align-items:center;gap:16px;margin-left:24px;padding-left:24px;border-left:1px solid var(--border-color)}.game-info-item-topbar{display:flex;flex-direction:column;gap:2px}.game-info-label-topbar{font-size:.75rem;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.game-info-value-topbar{font-size:.95rem;color:var(--text-primary);font-weight:600;font-family:Courier New,monospace}.game-info-value-topbar.clickable-game-id{cursor:pointer;transition:color var(--transition-base),transform var(--transition-base);padding:2px 6px;border-radius:var(--radius-sm);background:var(--surface-secondary)}.game-info-value-topbar.clickable-game-id:hover{color:var(--primary);transform:scale(1.05);background:var(--hover-bg)}.top-bar-right{display:flex;align-items:center;gap:12px;color:var(--text-primary)}.theme-selector{display:flex;gap:4px;background:var(--surface-secondary);padding:4px;border-radius:var(--radius-md);border:1px solid var(--border-color)}.theme-btn{background:transparent;border:none;padding:6px 12px;border-radius:var(--radius-sm);font-size:1.2rem;cursor:pointer;transition:all var(--transition-base);opacity:.6;color:var(--text-primary)}.theme-btn:hover{opacity:1;background:var(--hover-bg)}.theme-btn.active{opacity:1;background:var(--active-bg);box-shadow:var(--shadow-sm)}.icon-btn{background:var(--surface-secondary);border:1px solid var(--border-color);padding:8px 12px;border-radius:var(--radius-md);font-size:1.2rem;cursor:pointer;transition:all var(--transition-base);opacity:.8;color:var(--text-primary)}.icon-btn:hover{opacity:1;background:var(--hover-bg);transform:scale(1.05)}.user-menu-container{position:relative}.user-avatar-wrapper{position:relative;display:inline-flex;align-items:center;gap:8px}.user-avatar{width:40px;height:40px;border-radius:var(--radius-full);border:2px solid var(--border-color);cursor:pointer;background:var(--surface-secondary);overflow:hidden;transition:transform var(--transition-base);padding:0}.user-avatar:hover{transform:scale(1.05);border-color:var(--primary)}.user-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-weight:600;background:var(--primary);color:var(--text-inverse)}.wins-badge{display:flex;align-items:center;gap:4px;background:var(--warning);color:#242424;padding:4px 10px;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;box-shadow:var(--shadow-md);white-space:nowrap;border:1px solid var(--warning-border);transition:transform var(--transition-base),box-shadow var(--transition-base)}.wins-badge:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:200px;background-color:#242832;background-image:linear-gradient(139deg,#242832 0% 0%,#251c28);border-radius:10px;padding:15px 0;box-shadow:0 10px 30px #0000004d;overflow:hidden;animation:dropdownSlideIn .2s ease-out;display:flex;flex-direction:column;gap:10px}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.user-info{padding:0 10px}.user-name{font-weight:600;color:#fff}.user-dropdown hr{margin:0;border:none;border-top:1.5px solid #42434a}.dropdown-item{width:100%;padding:4px 7px;margin:0 10px;width:calc(100% - 20px);background:transparent;border:none;text-align:left;cursor:pointer;font-size:.95rem;color:#7e8590;font-weight:600;transition:all .3s ease-out;display:flex;align-items:center;gap:10px;border-radius:6px}.dropdown-item svg{width:19px;height:19px;transition:all .3s ease-out}.dropdown-item:hover{background-color:#5353ff;color:#fff;transform:translate(1px,-1px)}.dropdown-item:active{transform:scale(.99)}.logout-btn{color:#bd89ff}.logout-btn svg{stroke:#bd89ff}.logout-btn:hover{background-color:#382d47d5;color:#bd89ff}.overlay{position:fixed;inset:0;background:#00000080;z-index:999;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.preferences-panel{position:fixed;top:60px;right:20px;width:360px;max-height:calc(100vh - 100px);background:var(--surface-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-2xl);z-index:1001;overflow:hidden;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.preferences-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border-color);background:var(--surface-secondary)}.preferences-header h2{margin:0;font-size:1.25rem;color:var(--text-primary)}.close-btn{background:transparent;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-tertiary);padding:4px 8px;border-radius:var(--radius-sm);transition:all var(--transition-base);line-height:1}.close-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.preferences-content{padding:20px;max-height:calc(100vh - 200px);overflow-y:auto}.preference-group{margin-bottom:16px}.preference-group:last-child{margin-bottom:0}.preference-group h3{margin:0 0 12px;font-size:1rem;font-weight:600;color:var(--text-primary)}.preference-item{margin-bottom:4px}.preference-item:last-child{margin-bottom:0}.preference-item label{display:flex;align-items:center;cursor:pointer;padding:4px;border-radius:var(--radius-md);transition:background var(--transition-base)}.preference-item label:hover{background:var(--hover-bg)}.preference-item input[type=checkbox],.preference-item input[type=radio]{margin-right:10px;cursor:pointer;width:18px;height:18px}.preference-item span{color:var(--text-primary);font-size:.95rem}.preference-item select{margin-left:auto;padding:4px 8px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--surface-secondary);color:var(--text-primary);font-size:.9rem;cursor:pointer;outline:none}.preference-item select:focus{border-color:var(--primary)}@media(max-width:768px){.top-bar{padding:0 12px;height:56px}.top-bar-left{flex:1;min-width:0;overflow:hidden}.top-bar-right{gap:8px;flex-shrink:0}.logo-button{gap:8px;min-width:0}.app-title{font-size:1.1rem}.theme-selector{display:none}.icon-btn{padding:6px 10px;font-size:1.1rem}.user-avatar{width:36px;height:36px}.wins-badge{font-size:.75rem;padding:3px 8px}.preferences-panel{right:0;left:0;width:auto;margin:0 12px;top:56px}.game-info-topbar{display:none}}@media(max-width:480px){.top-bar{padding:0 8px;height:52px}.top-bar-left{gap:0}.top-bar-right,.logo-button{gap:6px}.topbar-logo{width:28px;height:28px}.app-title{font-size:1rem}.icon-btn{padding:6px 8px;font-size:1rem}.user-avatar{width:32px;height:32px}.user-avatar-wrapper{gap:6px;position:relative}.wins-badge{position:static;font-size:.65rem;padding:2px 5px;min-width:20px;text-align:center;gap:2px}.game-info-topbar{margin-left:8px;padding-left:8px;gap:6px}.game-info-label-topbar{font-size:.6rem}.game-info-value-topbar{font-size:.8rem}.game-info-value-topbar.clickable-game-id{padding:1px 3px}.preferences-panel{margin:0 8px;top:52px;max-height:calc(100vh - 80px)}.user-dropdown{min-width:200px}}@media(max-width:360px){.top-bar{padding:0 6px}.app-title{display:none}.logo-button{gap:0}.game-info-topbar{margin-left:6px;padding-left:6px;gap:4px}.game-info-item-topbar:last-child{display:none}.icon-btn{padding:5px 7px}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--surface-bg);padding:20px}.login-card{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);border:1px solid var(--border-color);max-width:500px;width:100%;overflow:hidden}.login-header{background:var(--primary);color:#fff;padding:40px 30px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:15px}.login-header h1{margin:0;font-size:3rem;font-weight:700}.login-subtitle{margin:0;font-size:1.1rem;opacity:.95}.login-content{padding:40px 30px}.login-description{text-align:center;color:var(--text-secondary);margin:0 0 30px;font-size:1rem;line-height:1.6}.google-signin-button{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 24px;background:var(--button-default-bg);border:1px solid var(--button-default-border);border-radius:var(--radius-md);font-size:1rem;font-weight:600;color:var(--button-default-text);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.google-signin-button:hover:not(:disabled){background:var(--button-default-hover);border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.google-signin-button:active:not(:disabled){background:var(--button-default-active);transform:translateY(0)}.google-signin-button:disabled{opacity:.6;cursor:not-allowed}.google-logo{width:20px;height:20px}.loading-spinner{font-size:1.2rem;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.guest-button{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 24px;background:var(--button-primary-bg);border:1px solid rgba(27,31,36,.15);border-radius:var(--radius-md);font-size:1rem;font-weight:600;color:var(--button-primary-text);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-md);margin-bottom:20px}.guest-button:hover:not(:disabled){background:var(--button-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.guest-button:active:not(:disabled){background:var(--button-primary-active);transform:translateY(0)}.guest-button:disabled{opacity:.6;cursor:not-allowed}.divider{display:flex;align-items:center;text-align:center;margin:20px 0;color:var(--text-tertiary);font-size:.9rem}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid var(--border-color)}.divider span{padding:0 15px}.email-form{display:flex;flex-direction:column;gap:12px;margin-top:20px}.email-form input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;background:var(--surface-bg);color:var(--text-primary);transition:all var(--transition-base)}.email-form input:focus{outline:none;border-color:var(--primary);box-shadow:var(--shadow-colored)}.email-form input:disabled{background:var(--disabled-bg);cursor:not-allowed}.email-button{width:100%;padding:14px 24px;background:var(--button-primary-bg);border:1px solid rgba(27,31,36,.15);border-radius:var(--radius-md);font-size:1rem;font-weight:600;color:var(--button-primary-text);cursor:pointer;transition:all var(--transition-base);margin-top:8px;box-shadow:var(--shadow-sm)}.email-button:hover:not(:disabled){background:var(--button-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.email-button:active:not(:disabled){background:var(--button-primary-active);transform:translateY(0)}.email-button:disabled{opacity:.6;cursor:not-allowed}.auth-links{display:flex;justify-content:space-between;margin-top:12px;gap:10px}.link-button{background:none;border:none;color:var(--primary);font-size:.9rem;cursor:pointer;padding:4px 8px;text-decoration:underline;transition:color var(--transition-base)}.link-button:hover{color:var(--primary-hover)}.error-message{margin-top:20px;padding:12px 16px;background:var(--error-bg);border:1px solid var(--error-border);border-radius:var(--radius-md);color:var(--error-text);display:flex;align-items:center;gap:10px;font-size:.95rem}.error-icon{font-size:1.2rem}.success-message{margin-top:20px;padding:12px 16px;background:var(--success-bg);border:1px solid var(--success-border);border-radius:var(--radius-md);color:var(--success-text);display:flex;align-items:center;gap:10px;font-size:.95rem}.success-icon{font-size:1.2rem}.login-features{margin-top:40px;padding-top:30px;border-top:1px solid var(--border-color)}.login-features h3{margin:0 0 20px;color:var(--text-primary);font-size:1.1rem;text-align:center}.login-features ul{list-style:none;padding:0;margin:0}.login-features li{display:flex;align-items:center;gap:12px;padding:10px 0;color:var(--text-secondary);font-size:.95rem;line-height:1.5}.feature-icon{font-size:1.5rem;flex-shrink:0}.login-footer{background:var(--surface-bg);padding:20px 30px;text-align:center;border-top:1px solid var(--border-color)}.privacy-note{margin:0;color:var(--text-tertiary);font-size:.85rem;line-height:1.5}@media(max-width:600px){.login-header h1{font-size:2.5rem}.login-content{padding:30px 20px}.login-features{margin-top:30px;padding-top:20px}}.app-footer{padding:1rem;padding-bottom:70px;text-align:center;background-color:#0000000d;border-top:1px solid rgba(0,0,0,.1);margin-top:auto}.app-footer p{margin:0;font-size:.875rem;color:#666}.footer-link{color:#007bff;text-decoration:none;font-weight:500;transition:color .2s ease}.footer-link:hover{color:#0056b3;text-decoration:underline}@media(prefers-color-scheme:dark){.app-footer{background-color:#ffffff0d;border-top-color:#ffffff1a}.app-footer p{color:#aaa}.footer-link{color:#4da3ff}.footer-link:hover{color:#66b3ff}}*{box-sizing:border-box}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--body-bg);color:var(--text-primary);transition:background-color var(--transition-slow),color var(--transition-slow)}.app-content{padding-top:60px;min-height:100vh;display:flex;flex-direction:column}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 60px);background:var(--primary);color:var(--text-inverse)}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:var(--text-inverse);border-radius:var(--radius-full);animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{to{transform:rotate(360deg)}}.app-loading p{font-size:1.25rem;margin:0}.app-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 60px);background:var(--error-bg);padding:20px;text-align:center}.app-error h2{color:var(--error-text);margin:0 0 16px;font-size:2rem}.app-error p{color:var(--error-text);margin:0 0 24px;font-size:1.1rem;max-width:600px}.app-error button{background:var(--button-danger-bg);color:var(--button-danger-text);border:1px solid rgba(27,31,36,.15);padding:12px 24px;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-md)}.app-error button:hover{background:var(--button-danger-hover);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.app-error button:active{background:var(--button-danger-active);transform:translateY(0)}
