*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.multiplayer-status,.status-trigger{position:relative}.status-trigger{align-items:center;background:#ffffff1a;border:2px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-family:Arial,sans-serif;font-size:18px;font-weight:700;gap:12px;padding:12px 20px;transition:all .2s}.status-trigger:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-1px)}.status-trigger.open .dropdown-arrow{transform:rotate(180deg)}.status-icon{font-size:24px;line-height:1}.status-text{font-size:18px;line-height:1}.dropdown-arrow{font-size:14px;margin-left:4px;opacity:.8;transition:transform .3s ease}.notification-dot{animation:pulse 2s infinite;background:#f44;border:2px solid #fff;border-radius:50%;height:16px;position:absolute;right:-4px;top:-4px;width:16px}.status-overlay{background:#0003;bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.status-menu{animation:slideDown .2s ease;background:#fff;border-radius:12px;box-shadow:0 8px 24px #0003;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:320px;z-index:1000}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.status-menu-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px 20px}.status-menu-header h4{font-size:18px;font-weight:600;margin:0}.status-menu-item{align-items:center;background:#fff;border:none;border-left:3px solid #0000;cursor:pointer;display:flex;gap:12px;padding:14px 20px;text-align:left;transition:background .2s;width:100%}.status-menu-item:hover{background:#f5f5f5}.status-menu-item.active{background:#e3f2fd;border-left-color:#2196f3}.status-menu-item.game-active{background:#fff3e0;border-left-color:#ff9800}.status-menu-item.invite-pending{background:#fce4ec;border-left-color:#e91e63}.item-icon{flex-shrink:0;font-size:24px;line-height:1}.item-content{flex:1 1}.item-title{color:#333;font-size:15px;font-weight:600;margin-bottom:2px}.item-desc{color:#666;font-size:13px}.item-action{background:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:6px 16px;transition:all .2s}.item-action:hover{background:#45a049;transform:scale(1.05)}.status-menu-divider{background:#e0e0e0;height:1px;margin:8px 0}@media (max-width:768px){.status-menu{width:280px}.status-text{display:none}.dropdown-arrow{margin-left:0}.status-trigger{padding:10px 16px}.footer-content{padding:0 10px}.footer-links{flex-direction:column;gap:5px}.footer-separator{display:none}}.app-layout{background:#f5f4f4;display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(135deg,#b094cd 100%,#f5f9f5 0);box-shadow:0 2px 8px #d05c5c26;color:#8e6cc1;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-top{border-bottom:1px solid #ffffff1a;justify-content:space-between;padding:8px 20px}.header-brand,.header-top{align-items:center;display:flex}.header-brand{gap:12px}.app-logo{//border-radius:50%;background:#ffffff0d;border:0 solid #fff3;height:90px;object-fit:contain;padding:3px;width:105px}.app-title{-webkit-text-fill-color:#0000;background:linear-gradient(90deg,#fff 100%,#a8dadc 0);-webkit-background-clip:text;background-clip:text;font-size:32px;font-weight:750;letter-spacing:1.5px;margin:0}.header-info{align-items:center;display:flex;gap:20px}.datetime-display{align-items:flex-end;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:6px;display:flex;flex-direction:column;gap:2px;padding:4px 12px}.date-text,.time-text{color:#fafcfa;font-family:Arial,monospace;font-size:18px;font-weight:750}.user-section{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:6px;gap:10px;padding:4px 12px}.user-section,.user-welcome{align-items:center;display:flex}.user-welcome{color:#fafcfa;font-family:Arial,monospace;font-size:18px;font-weight:700;gap:6px}.user-icon{font-size:20px}.logout-btn-compact{align-items:center;background:#8273e3;border:2px solid #0c0c0c;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-family:Arial,monospace;font-size:16px;font-weight:700;gap:6px;padding:6px 12px;transition:all .2s}.logout-btn-compact:hover{background:#76d479;border-color:#b71c1c;transform:scale(1.05)}.logout-icon{font-size:22px}.header-nav{background:#0000;padding:0 10px}.nav-tabs{display:flex;gap:2px;overflow-x:auto;scrollbar-color:#ffffff4d #0000;scrollbar-width:thin}.nav-tabs::-webkit-scrollbar{height:3px}.nav-tabs::-webkit-scrollbar-track{background:#0000}.nav-tabs::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.nav-tab{align-items:center;background:#0000;border:none;border-bottom:3px solid #0000;color:#f9fafc;cursor:pointer;display:flex;font-family:Arial,monospace;font-size:20px;font-weight:750;gap:6px;padding:8px 14px;position:relative;transition:all .2s;white-space:nowrap}.nav-tab:hover{background:#ffffff26;color:#1a202c}.nav-tab.active{background:#ffffff0d;border-bottom-color:#2ecc71;color:#2ecc71;font-weight:800}.tab-icon{font-size:20px}.tab-label{font-size:18px}.app-main{background:#f5f5f5;flex:1 1;padding:0}.app-footer{background:linear-gradient(135deg,#1a1a2e,#16213e);border-top:1px solid #ffffff1a;color:#fffffff2;margin-top:auto;padding:20px}.footer-content{margin:0 auto;max-width:1400px;text-align:center}.copyright{color:#fffffff2;font-size:18px;font-weight:700;margin:0 0 10px}.footer-links{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:10px}.footer-link{color:#fffffff2;font-size:16px;text-decoration:none;transition:color .2s}.footer-link:hover{color:#4caf50;text-decoration:underline}.footer-separator{color:#ffffff4d;font-size:16px}.footer-tagline{color:#fffffff2;font-size:16px;font-style:italic;margin:10px 0 0}@media (max-width:1024px){.app-title{font-size:18px}.app-logo{height:38px;width:38px}.nav-tab{font-size:12px;padding:8px 10px}.tab-label{display:none}.tab-icon{font-size:20px}}@media (max-width:768px){.header-top{flex-direction:column;gap:10px;padding:10px}.header-brand{justify-content:center;width:100%}.header-info{justify-content:space-between;width:100%}.datetime-display{flex-direction:row;gap:10px}.date-text,.time-text{font-size:11px}.app-title{font-size:16px}.nav-tabs{justify-content:flex-start}.nav-tab{padding:8px 12px}.footer-content{padding:0 10px}.footer-links{flex-direction:column;gap:5px}.footer-separator{display:none}}@media (max-width:480px){.app-logo{height:32px;width:32px}.app-title{font-size:14px;letter-spacing:1px}.user-welcome{font-size:18px}.user-icon{font-size:20px}.nav-tab{padding:6px 8px}.tab-icon{font-size:20px}}.app-header{animation:fadeIn .3s ease-in}@keyframes slideIn{0%{transform:translateX(-100%)}to{transform:translateX(0)}}.nav-tab{animation:fadeIn .3s ease-in}.auth-form{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;margin:0 auto;max-width:400px;padding:32px}.auth-form h2{color:#333;font-size:28px;font-weight:700;margin:0 0 8px;text-align:center}.auth-subtitle{color:#666;margin:0 0 24px}.auth-error,.auth-subtitle{font-size:14px;text-align:center}.auth-error{background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;margin-bottom:16px;padding:12px}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:6px}.form-group input[type=date],.form-group input[type=email],.form-group input[type=password],.form-group input[type=text]{border:2px solid #e0e0e0;border-radius:6px;box-sizing:border-box;font-size:15px;padding:12px;transition:border-color .2s;width:100%}.form-group input:focus{border-color:#4caf50;outline:none}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.password-input{position:relative}.password-input input{padding-right:45px}.toggle-password{align-items:center;background:none;border:none;cursor:pointer;display:flex;font-size:20px;justify-content:center;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.field-error{color:#d32f2f;font-size:13px}.field-error,.field-hint{display:block;margin-top:4px}.field-hint{color:#666;font-size:12px}.form-options{font-size:14px;justify-content:space-between;margin-bottom:20px}.checkbox-label,.form-options{align-items:center;display:flex}.checkbox-label{cursor:pointer;gap:6px;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{accent-color:#4caf50;cursor:pointer;height:16px;width:16px}.link-btn{background:none;border:none;color:#4caf50;cursor:pointer;font-size:14px;font-weight:600;padding:0;text-decoration:none}.link-btn:hover{text-decoration:underline}.auth-submit-btn{background:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px;transition:background .2s;width:100%}.auth-submit-btn:hover:not(:disabled){background:#45a049}.auth-submit-btn:disabled{background:#ccc;cursor:not-allowed}.auth-footer{color:#666;font-size:14px;margin-top:20px;text-align:center}.legal-acceptance-section{border-top:1px solid #e0e0e0;margin-top:20px;padding-top:16px}.checkbox-group{margin-bottom:12px}.checkbox-group .checkbox-label{align-items:flex-start;cursor:pointer;display:flex;font-size:14px;font-weight:400;gap:10px;line-height:1.4}.checkbox-group .checkbox-label input[type=checkbox]{accent-color:#4caf50;cursor:pointer;flex-shrink:0;height:18px;margin-top:1px;width:18px}.checkbox-text{color:#555}.checkbox-text a{color:#4caf50;font-weight:500;text-decoration:none}.checkbox-text a:hover{color:#388e3c;text-decoration:underline}.checkbox-group .field-error{margin-left:28px;margin-top:4px}input[type=date]{background-color:#fff;color:#333;cursor:pointer}input[type=date]::-webkit-calendar-picker-indicator{border-radius:4px;cursor:pointer;padding:4px}input[type=date]::-webkit-calendar-picker-indicator:hover{background-color:#4caf501a}input[type=date]:invalid::-webkit-datetime-edit{color:#999}.page-header{align-items:center;background-color:#fff;border:2px solid #000;border-radius:10px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;margin-bottom:15px;margin-left:auto;margin-right:auto;max-width:1600px;padding:10px 20px}.page-header .header-content{align-items:center;display:flex;gap:15px}.page-header .page-title{color:#333;font-size:32px;margin:0}.page-header .page-description{color:#666;font-size:16px;font-weight:700;margin:0}.page-header .header-actions{align-items:center;display:flex;gap:10px}.page-header .action-btn{border:2px solid #0000;border-radius:8px;cursor:pointer;font-size:16px;font-weight:700;padding:8px 20px;transition:all .2s;white-space:nowrap}.page-header .action-btn-primary{background-color:#4caf50;color:#fff}.page-header .action-btn-primary:hover{background-color:#45a049;box-shadow:0 4px 12px #4caf504d;transform:translateY(-2px)}.page-header .action-btn-secondary{background-color:#2196f3;color:#fff}.page-header .action-btn-secondary:hover{background-color:#1976d2;box-shadow:0 4px 12px #2196f34d;transform:translateY(-2px)}.page-header .action-btn-danger{background-color:#f44336;color:#fff}.page-header .action-btn-danger:hover{background-color:#d32f2f;box-shadow:0 4px 12px #f443364d;transform:translateY(-2px)}.page-header .action-btn:disabled{cursor:not-allowed;opacity:.6}.page-header .action-select{background:#fff;border:2px solid #ddd;border-radius:8px;color:#333;cursor:pointer;font-size:16px;font-weight:700;padding:8px 15px;transition:all .3s ease}.page-header .action-select:hover{border-color:#4caf50}.page-header .action-select:focus{border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a;outline:none}@media (max-width:768px){.page-header{gap:10px}.page-header,.page-header .header-content{align-items:flex-start;flex-direction:column}.page-header .header-content{gap:5px}.page-header .header-actions{flex-wrap:wrap;width:100%}.page-header .action-btn,.page-header .action-select{width:100%}}.home-page{background:#a16cd6;display:flex;flex-direction:column;min-height:100vh}.home-main{flex:1 1;padding:40px 20px}.home-page .page-header{margin-bottom:40px}.home-content{grid-gap:40px;align-items:stretch;display:grid;gap:40px;grid-template-columns:1fr auto 1fr;margin:0 auto;max-width:1400px}@media (max-width:1200px){.home-content{gap:32px;grid-template-columns:1fr}.home-logo-section{order:-1}}.features-section{background:#fffffff2;border-radius:12px;box-shadow:0 8px 16px #0000001a;padding:32px}.features-section h2{color:#333;font-size:28px;margin:0 0 24px}.feature-list{display:flex;flex-direction:column;gap:20px}.feature-item{align-items:flex-start;display:flex;gap:16px}.feature-icon{flex-shrink:0;font-size:32px}.feature-item h3{color:#333;font-size:18px;margin:0 0 4px}.feature-item p{color:#666;font-size:14px;line-height:1.5;margin:0}.auth-section{background:#fffffff2;border-radius:12px;box-shadow:0 8px 16px #0000001a;display:flex;flex-direction:column;overflow:hidden}.auth-tabs{background:#f5f5f5;border-bottom:2px solid #e0e0e0;display:flex;flex-shrink:0}.tab-button{background:#0000;border:none;color:#666;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:16px;position:relative;transition:all .2s}.tab-button:hover{background:#0000000d}.tab-button.active{background:#fff;color:#4caf50}.tab-button.active:after{background:#4caf50;bottom:-2px;content:"";height:2px;left:0;position:absolute;right:0}.auth-tab-content{display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:8px}.auth-tab-content>*{margin-bottom:auto;margin-top:auto}.home-logo-section{align-items:flex-start;display:flex;justify-content:center;padding-top:20px}.home-logo{border-radius:12px;box-shadow:0 8px 24px #0003;height:auto;max-width:300px}.dashboard-page{background:#f5f5f5;min-height:100vh;padding-top:10px}.dashboard-content{margin:0 auto;max-width:1200px;padding:20px 20px 48px}.action-cards{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.action-card{background:#fff;border:2px solid #0c0c0c;border-radius:12px;box-shadow:0 2px 8px #0000001a;color:inherit;display:block;padding:32px;text-align:center;text-decoration:none;transition:transform .2s,box-shadow .2s}.action-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-4px)}.card-icon{display:block;font-size:48px;margin-bottom:16px}.action-card h3{color:#333;font-size:22px;margin:0 0 8px}.action-card p{color:#666;font-size:14px;line-height:1.5;margin:0}.documents-page{background:#f5f5f5;min-height:100vh;padding-top:10px}.documents-content{margin:0 auto;max-width:1200px;padding:20px 20px 48px}.document-card{background:#fff;border:2px solid #0c0c0c;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.document-header{align-items:center;background-color:#f8f9fa;border-bottom:2px solid #ddd;display:flex;justify-content:space-between;padding:20px}.document-info{align-items:center;display:flex;gap:15px}.document-icon{font-size:48px}.document-title{color:#333;font-size:24px;margin:0}.document-subtitle{color:#666;font-size:14px;margin:5px 0 0}.download-btn{align-items:center;background-color:#4caf50;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:700;gap:8px;padding:12px 24px;transition:all .2s}.download-btn:hover{background-color:#45a049;box-shadow:0 4px 12px #4caf504d;transform:translateY(-2px)}.pdf-viewer{height:calc(100vh - 400px);min-height:600px;width:100%}.pdf-iframe{border:none;height:100%;width:100%}@media (max-width:768px){.document-header{align-items:flex-start;flex-direction:column;gap:15px}.download-btn{justify-content:center;width:100%}.document-title{font-size:20px}.pdf-viewer{min-height:400px}}.online-users-panel-container{display:flex;flex-direction:column;height:100%;overflow:hidden}.online-users-header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:15px;padding:10px 0}.user-count{align-items:center;display:flex;gap:8px}.count-icon{font-size:18px}.count-text{color:#2196f3;font-size:14px;font-weight:700}.refresh-btn{background:linear-gradient(135deg,#4caf50,#388e3c);border:2px solid #388e3c;border-radius:50%;color:#fff;height:36px;justify-content:center;width:36px}.refresh-btn:hover:not(:disabled){background:linear-gradient(135deg,#66bb6a,#4caf50);border-color:#4caf50;transform:scale(1.05)}.refresh-icon{font-size:18px}.online-users-content{flex:1 1;overflow-y:auto;padding:5px}.empty-message{margin:0}.users-list{gap:10px}.user-card,.users-list{display:flex;flex-direction:column}.user-card{background:#fff;border:2px solid #e0e0e0;border-radius:8px;gap:12px;padding:12px;transition:all .2s}.user-card:hover{border-color:#2196f3;box-shadow:0 2px 8px #2196f326}.user-card.current-user{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-color:#2196f3;border-width:3px}.user-card.current-user:hover{box-shadow:0 2px 12px #2196f340}.user-avatar{align-items:center;background:linear-gradient(135deg,#2196f3,#1976d2);border-radius:50%;display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.user-card.current-user .user-avatar{background:linear-gradient(135deg,#ff9800,#f57c00);box-shadow:0 2px 8px #ff98004d}.avatar-icon{filter:brightness(0) invert(1);font-size:24px}.user-info{display:flex;flex:1 1;flex-direction:column;gap:6px;min-width:0}.user-name-row{align-items:center;display:flex;gap:8px}.user-name{color:#333;font-size:15px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.you-badge{background:#ff9800;border-radius:10px;color:#fff;display:inline-block;font-size:11px;font-weight:700;margin-left:6px;padding:2px 8px}.user-meta{flex-wrap:wrap;gap:10px}.status-badge,.user-meta{align-items:center;display:flex}.status-badge{border-radius:10px;font-size:11px;font-weight:700;gap:4px;letter-spacing:.5px;padding:3px 8px;text-transform:uppercase}.status-badge.status-available{background:#e8f5e9;color:#2e7d32}.status-badge.status-hosting{background:#fff3e0;color:#e65100}.status-badge.status-in-game{background:#fce4ec;color:#c2185b}.status-icon{font-size:12px}.status-label{font-size:10px}.connected-time{color:#999;font-size:11px;font-style:italic}.user-stats{grid-gap:10px;background:#f9f9f9;border:1px solid #e0e0e0;border-radius:6px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);padding:10px}.stat-item{flex-direction:column;text-align:center}.stat-label{font-size:11px;letter-spacing:.5px}.user-actions{display:flex;gap:6px}.challenge-btn{align-items:center;background:linear-gradient(135deg,#4caf50,#388e3c);border:none;border-radius:50%;box-shadow:0 2px 6px #4caf504d;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.challenge-btn:hover{background:linear-gradient(135deg,#66bb6a,#4caf50);box-shadow:0 3px 10px #4caf5066;transform:scale(1.1)}.challenge-btn:active{transform:scale(.95)}.challenge-icon{filter:brightness(0) invert(1);font-size:18px}.online-users-content::-webkit-scrollbar{width:6px}.online-users-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.online-users-content::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.online-users-content::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width:768px){.online-users-header{padding:8px 0}.count-text{font-size:13px}.user-card{gap:10px;padding:10px}.user-avatar{height:38px;width:38px}.avatar-icon{font-size:20px}.user-name{font-size:14px}.status-badge,.you-badge{font-size:10px;padding:2px 6px}.challenge-btn{height:32px;width:32px}.challenge-icon{font-size:16px}.user-stats{gap:8px;padding:8px}.stat-label{font-size:10px}.stat-value{font-size:13px}}@media (max-width:480px){.empty-icon{font-size:48px}.empty-title{font-size:18px}.empty-message{font-size:14px}.user-card{padding:8px}.user-avatar{height:34px;width:34px}.avatar-icon{font-size:18px}.user-name{font-size:13px}.user-meta{gap:8px}.status-badge{padding:2px 6px}.connected-time{font-size:10px}.user-stats{gap:8px;grid-template-columns:repeat(2,1fr);padding:8px}.stat-label{font-size:9px}.stat-value{font-size:12px}}.user-card{animation:fadeIn .3s ease-in-out}.user-card:first-child{animation-delay:0s}.user-card:nth-child(2){animation-delay:.05s}.user-card:nth-child(3){animation-delay:.1s}.user-card:nth-child(4){animation-delay:.15s}.user-card:nth-child(5){animation-delay:.2s}.user-card:nth-child(6){animation-delay:.25s}.user-card:nth-child(7){animation-delay:.3s}.user-card:nth-child(8){animation-delay:.35s}.user-card.current-user{animation:fadeIn .3s ease-in-out,pulse 2s ease-in-out infinite}.create-game-panel-container{display:flex;flex-direction:column;gap:16px;margin:0 auto;max-width:700px;padding:0 10px}.create-game-notice{align-items:center;background:linear-gradient(135deg,#ff9800,#f57c00);border:2px solid #ff9800;border-radius:8px;box-shadow:0 2px 4px #ff980033;color:#fff;display:flex;gap:10px;padding:12px 16px}.notice-icon{flex-shrink:0;font-size:20px}.notice-text{font-size:14px;font-weight:600;line-height:1.4}.create-game-form{display:flex;flex-direction:column;gap:14px}.form-row{grid-gap:12px;gap:12px}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{margin:0}.mode-selector-compact{background:#f5f5f5;border:2px solid #ddd;border-radius:6px;display:flex;gap:6px;padding:4px}.mode-btn{background:#fff;border:2px solid #0000;border-radius:4px;color:#666;cursor:pointer;flex:1 1;font-family:inherit;font-size:14px;font-weight:600;padding:8px 12px;transition:all .2s}.mode-btn:hover:not(:disabled){background:#fafafa;color:#333}.mode-btn.active{background:#ff9800;border-color:#f57c00;box-shadow:0 2px 4px #ff98004d;color:#fff}.mode-btn:disabled{cursor:not-allowed;opacity:.5}.form-select{background:#fff;border:2px solid #80cd93;border-radius:6px;color:#333;font-family:inherit;font-size:14px;font-weight:600;padding:10px 12px;transition:all .2s;width:100%}.form-select:hover:not(:disabled){border-color:#63cf97}.form-select:focus{border-color:#66ce65;box-shadow:0 0 0 3px #4c955a1a;outline:none}.form-select:disabled{background:#f5f5f5;border-color:#66ce65;color:#68c777;cursor:not-allowed}.config-summary-compact{background:linear-gradient(#fff 100%);border:2px solid #ff9800;border-radius:6px;display:flex;flex-wrap:wrap;gap:20px;padding:10px 14px}.summary-item{align-items:center;display:flex;font-size:14px;gap:6px}.summary-label{color:#666;font-weight:600}.summary-value{color:#ff9800;font-weight:700}.summary-value em{color:#999;font-style:italic;font-weight:400}.form-actions{margin-top:4px}.create-game-btn,.form-actions{display:flex;justify-content:center}.create-game-btn{align-items:center;background:linear-gradient(135deg,#ff9800,#f57c00);border:2px solid #f57c00;border-radius:8px;box-shadow:0 2px 4px #ff980033;color:#fff;cursor:pointer;font-size:16px;font-weight:600;gap:8px;min-width:200px;padding:12px 32px;transition:all .2s}.create-game-btn:hover:not(:disabled){background:linear-gradient(135deg,#f57c00,#e65100);box-shadow:0 4px 8px #ff98004d;transform:translateY(-1px)}.create-game-btn:active:not(:disabled){box-shadow:0 2px 4px #ff980033;transform:translateY(0)}.create-game-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.create-game-btn.creating{background:#aaa;cursor:wait}.btn-icon{font-size:18px}.btn-text{font-size:15px}.btn-spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@media (max-width:768px){.create-game-panel-container{gap:14px;max-width:100%;padding:0 5px}.form-row{gap:10px}.create-game-btn{min-width:180px;padding:12px 28px}.config-summary-compact{gap:16px}}@media (max-width:520px){.form-row{gap:12px;grid-template-columns:1fr}.create-game-notice{padding:10px 14px}.mode-btn,.notice-text{font-size:13px}.mode-btn{padding:9px 12px}.form-select{font-size:13px}.config-summary-compact{flex-direction:column;gap:8px}.summary-item{font-size:13px}.create-game-btn{font-size:15px;min-width:160px;padding:11px 24px}}.create-game-btn:focus-visible,.form-select:focus-visible,.mode-btn:focus-visible{outline:2px solid #ff9800;outline-offset:2px}.host-lobby-container{display:flex;flex-direction:column;gap:16px;margin:0 auto;max-width:700px;padding:0 10px}.host-lobby-empty{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:200px;padding:40px 20px;text-align:center}.empty-icon{font-size:48px;margin-bottom:12px}.empty-text{color:#333;font-size:20px;font-weight:700;margin:0 0 8px}.empty-subtext{color:#666;font-size:14px;line-height:1.5;margin:0}.empty-subtext strong{color:#9c27b0;font-weight:700}.room-code-section{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px solid #2196f3;border-radius:8px;padding:14px 16px}.room-code-label{color:#1565c0;display:block;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.room-code-display{background:#fff;border:2px solid #64b5f6;border-radius:6px;gap:10px;margin-bottom:8px;padding:10px 14px}.room-code-text{color:#1565c0;flex:1 1;font-family:Courier New,monospace;font-size:20px;font-weight:700;letter-spacing:2px}.copy-btn{align-items:center;background:#2196f3;color:#fff;display:flex;font-size:16px;height:32px;justify-content:center;min-width:40px;padding:6px 12px;transition:all .2s}.copy-btn:hover{background:#1976d2}.copy-btn:active{transform:scale(.95)}.copy-btn.copied{background:#4caf50}.room-code-hint{color:#1976d2;font-size:12px;font-style:italic;margin:0;text-align:center}.opponent-status-section{background:#f5f5f5;border:2px solid #e0e0e0;border-radius:8px;padding:14px 16px}.status-header{gap:10px;margin-bottom:10px}.status-header,.status-icon{align-items:center;display:flex}.status-icon{background:#fff;border:2px solid #e0e0e0;border-radius:50%;font-size:20px;height:28px;justify-content:center;width:28px}.status-text{color:#333;font-size:15px;font-weight:700}.opponent-info{background:#fff;border:2px solid #4caf50;border-radius:6px;display:flex;flex-direction:column;gap:10px;padding:12px 14px}.opponent-name-row{align-items:center;display:flex;gap:8px}.opponent-label{color:#666;font-size:13px;font-weight:600}.opponent-name{color:#4caf50;flex:1 1;font-size:16px;font-weight:700}.opponent-stats{border-top:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:12px;padding-top:8px}.stat-item{align-items:center;display:flex;gap:4px}.stat-label{color:#666;font-size:13px;font-weight:600}.stat-value{color:#4caf50;font-size:14px}.status-subtext{color:#999;font-size:13px;font-style:italic;margin:0;text-align:center}.host-actions{display:flex;gap:10px}.cancel-hosting-btn,.start-game-btn{align-items:center;border:2px solid;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-family:inherit;font-size:15px;font-weight:600;gap:6px;justify-content:center;padding:11px 20px;transition:all .2s}.start-game-btn{background:linear-gradient(135deg,#4caf50,#388e3c);border-color:#388e3c;box-shadow:0 2px 4px #4caf5033;color:#fff}.start-game-btn:hover:not(:disabled){background:linear-gradient(135deg,#66bb6a,#4caf50);box-shadow:0 4px 8px #4caf504d;transform:translateY(-1px)}.start-game-btn:active:not(:disabled){transform:translateY(0)}.start-game-btn:disabled{background:#e0e0e0;border-color:#ccc;box-shadow:none;color:#999;cursor:not-allowed;opacity:.6}.cancel-hosting-btn{background:#fff;border-color:#d32f2f;color:#d32f2f}.cancel-hosting-btn:hover{background:#d32f2f;box-shadow:0 4px 8px #d32f2f33;color:#fff;transform:translateY(-1px)}.cancel-hosting-btn:active{transform:translateY(0)}.btn-icon{font-size:16px}.btn-text{font-size:14px}@media (max-width:768px){.host-lobby-container{gap:14px;max-width:100%;padding:0 5px}.opponent-status-section,.room-code-section{padding:12px 14px}.room-code-text{font-size:18px}.host-actions{gap:8px}.cancel-hosting-btn,.start-game-btn{font-size:14px;padding:10px 16px}}@media (max-width:480px){.host-lobby-empty{padding:30px 15px}.empty-icon{font-size:40px}.empty-text{font-size:18px}.empty-subtext{font-size:13px}.room-code-section{padding:12px}.room-code-text{font-size:16px;letter-spacing:1px}.copy-btn{font-size:14px;height:30px;min-width:36px;padding:6px 10px}.room-code-hint{font-size:11px}.opponent-status-section{padding:12px}.status-icon{font-size:18px;height:26px;width:26px}.status-text{font-size:14px}.opponent-info{padding:9px 12px}.opponent-label{font-size:12px}.opponent-name{font-size:14px}.status-subtext{font-size:12px}.host-actions{flex-direction:column;gap:8px}.cancel-hosting-btn,.start-game-btn{padding:11px 16px}}.cancel-hosting-btn:focus-visible,.copy-btn:focus-visible,.start-game-btn:focus-visible{outline:2px solid #2196f3;outline-offset:2px}.join-game-panel-container{display:flex;flex-direction:column;height:100%;overflow:hidden}.join-game-header{border-bottom:2px solid #e0e0e0;justify-content:space-between;margin-bottom:15px;padding:10px 0}.game-count,.join-game-header{align-items:center;display:flex}.count-badge{background:linear-gradient(135deg,#2196f3,#1976d2);border-radius:12px;color:#fff;font-size:13px;font-weight:700;padding:4px 12px}.refresh-btn{align-items:center;background:#f5f5f5;border:2px solid #ddd;border-radius:6px;color:#333;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;padding:6px 12px;transition:all .2s}.refresh-btn:hover:not(:disabled){background:#e0e0e0;border-color:#2196f3;color:#2196f3}.refresh-btn:disabled{cursor:not-allowed;opacity:.6}.refresh-btn.refreshing .refresh-icon{animation:spin 1s linear infinite}.refresh-icon{display:inline-block;font-size:16px}.refresh-text{font-size:13px}.join-game-content{flex:1 1;overflow-y:auto;padding:5px}.loading-state{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;padding:40px 20px;text-align:center}.loading-spinner{border:4px solid #f3f3f3;border-radius:50%;border-top-color:#2196f3;height:50px;margin-bottom:20px;width:50px}.loading-state p{color:#666;font-size:16px;margin:0}.error-state{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;padding:40px 20px;text-align:center}.error-icon{font-size:48px;margin-bottom:15px}.error-message{color:#d32f2f;font-size:15px;font-weight:600;margin:0 0 20px}.retry-btn{background:#d32f2f;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:background .2s}.retry-btn:hover{background:#b71c1c}.empty-state{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;padding:40px 20px;text-align:center}.empty-icon{font-size:64px;margin-bottom:20px;opacity:.5}.empty-title{color:#333;font-size:20px;font-weight:700;margin:0 0 10px}.empty-message{color:#666;font-size:15px;margin:0 0 15px}.empty-hint{color:#999;font-size:14px;line-height:1.5;margin:0}.empty-hint strong{color:#9c27b0;font-weight:700}.game-cards-list{display:flex;flex-direction:column;gap:12px}.game-card{background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;padding:12px;transition:all .2s}.game-card:hover{border-color:#2196f3;box-shadow:0 4px 12px #2196f333;transform:translateY(-2px)}.game-card-header{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:10px}.room-code{gap:6px}.room-code-label{color:#999;font-size:12px;font-weight:600}.room-code-value{color:#2196f3;font-family:Courier New,monospace;font-size:16px;font-weight:700;letter-spacing:1px}.game-time{color:#999;font-size:11px;font-style:italic}.game-card-body{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.game-info-row{align-items:center;display:flex;font-size:14px;gap:8px}.info-icon{font-size:16px;text-align:center;width:20px}.info-label{color:#666;font-weight:600;min-width:60px}.info-value{color:#333;font-weight:500}.game-info-row.game-name .info-value{color:#666;font-style:italic}.game-card-footer{border-top:1px solid #f0f0f0;display:flex;justify-content:flex-end;padding-top:10px}.join-btn{align-items:center;background:linear-gradient(135deg,#4caf50,#388e3c);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:700;gap:6px;padding:8px 16px;transition:all .2s}.join-btn:hover{background:linear-gradient(135deg,#66bb6a,#4caf50);box-shadow:0 2px 8px #4caf504d;transform:scale(1.05)}.join-btn:active{transform:scale(.98)}.join-btn-icon{font-size:14px}.join-btn-text{font-size:13px}.manage-btn{align-items:center;background:linear-gradient(135deg,#2196f3,#1976d2);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:700;gap:6px;padding:8px 16px;transition:all .2s}.manage-btn:hover{background:linear-gradient(135deg,#42a5f5,#2196f3);box-shadow:0 2px 8px #2196f34d;transform:scale(1.05)}.manage-btn:active{transform:scale(.98)}.join-game-content::-webkit-scrollbar{width:6px}.join-game-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.join-game-content::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.join-game-content::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width:768px){.join-game-header{align-items:stretch;flex-direction:column;gap:10px}.game-count,.refresh-btn{justify-content:center}.refresh-btn{width:100%}.room-code-value{font-size:14px}.game-info-row{font-size:13px}.info-label{min-width:50px}.join-btn{justify-content:center;width:100%}}@media (max-width:480px){.empty-icon{font-size:48px}.empty-title{font-size:18px}.empty-message{font-size:14px}.empty-hint{font-size:13px}.game-card{padding:10px}.room-code-value{font-size:13px}.game-info-row{font-size:12px}}.game-card{animation:fadeIn .3s ease-in-out}.game-card:first-child{animation-delay:0s}.game-card:nth-child(2){animation-delay:.05s}.game-card:nth-child(3){animation-delay:.1s}.game-card:nth-child(4){animation-delay:.15s}.game-card:nth-child(5){animation-delay:.2s}.reset-password-page{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;min-height:100vh}.reset-main{flex:1 1;padding:40px 20px}.reset-password-content{margin:40px auto 0;max-width:500px}.reset-form-container{background:#fffffff2;border-radius:12px;box-shadow:0 8px 16px #0000001a;overflow:hidden}.reset-form{padding:32px}.reset-form h2{color:#333;font-size:28px;font-weight:700;margin:0 0 8px;text-align:center}.reset-subtitle{color:#666;margin:0 0 24px}.reset-error,.reset-subtitle{font-size:14px;text-align:center}.reset-error{background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;margin-bottom:16px;padding:12px}.reset-form .form-group{margin-bottom:20px}.reset-form .form-group label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:6px}.reset-form .form-group input{border:2px solid #e0e0e0;border-radius:6px;box-sizing:border-box;font-size:15px;padding:12px;transition:border-color .2s;width:100%}.reset-form .form-group input:focus{border-color:#4caf50;outline:none}.reset-form .password-input{position:relative}.reset-form .password-input input{padding-right:45px}.reset-form .toggle-password{background:none;border:none;cursor:pointer;font-size:20px;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.reset-form .field-hint{color:#666;display:block;font-size:12px;margin-top:4px}.reset-submit-btn{background:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px;transition:background .2s;width:100%}.reset-submit-btn:hover:not(:disabled){background:#45a049}.reset-submit-btn:disabled{background:#ccc;cursor:not-allowed}.reset-footer{margin-top:20px;text-align:center}.reset-form .link-btn{background:none;border:none;color:#4caf50;cursor:pointer;font-size:14px;font-weight:600;padding:0}.reset-form .link-btn:hover{text-decoration:underline}.error-message,.success-message{padding:40px 32px;text-align:center}.error-icon,.success-icon{font-size:64px;margin-bottom:16px}.error-message h2,.success-message h2{color:#333;font-size:24px;margin:0 0 16px}.error-message p,.success-message p{color:#666;font-size:14px;margin-bottom:12px}.error-message .reset-submit-btn,.success-message .reset-submit-btn{margin-top:24px}.loading-spinner{animation:spin 1s linear infinite;display:inline-block;font-size:48px;margin-bottom:16px}.help-page{background:#f5f5f5;min-height:100vh;padding-top:10px}.help-content{margin:0 auto;max-width:1200px;padding:20px 20px 48px}.section-title{border-bottom:2px solid #e0e0e0;color:#333;font-size:24px;font-weight:700;margin:0 0 20px;padding-bottom:10px}.quick-links-section{margin-bottom:40px}.quick-links-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.quick-link-card{align-items:center;background:#fff;border:2px solid #0c0c0c;border-radius:12px;box-shadow:0 2px 8px #0000001a;color:inherit;display:flex;flex-direction:column;padding:30px 20px;text-align:center;text-decoration:none;transition:transform .2s,box-shadow .2s}.quick-link-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-4px)}.quick-link-icon{font-size:48px;margin-bottom:15px}.quick-link-card h3{color:#333;font-size:20px;margin:0 0 8px}.quick-link-card p{color:#666;font-size:14px;line-height:1.5;margin:0}.faq-section{margin-bottom:40px}.faq-categories{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:25px}.category-btn{align-items:center;background:#fff;border:2px solid #ddd;border-radius:25px;color:#555;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 18px;transition:all .2s}.category-btn:hover{border-color:#4caf50;color:#4caf50}.category-btn.active{background:#4caf50;border-color:#4caf50;color:#fff}.category-icon{font-size:16px}.category-label{font-size:14px}.faq-list{display:flex;flex-direction:column;gap:12px}.faq-item{background:#fff;border:2px solid #e0e0e0;border-radius:10px;overflow:hidden;transition:border-color .2s,box-shadow .2s}.faq-item.expanded,.faq-item:hover{border-color:#4caf50}.faq-item.expanded{box-shadow:0 4px 12px #4caf5026}.faq-question{align-items:center;background:#0000;border:none;color:#333;cursor:pointer;display:flex;font-size:16px;font-weight:600;justify-content:space-between;padding:18px 20px;text-align:left;transition:background-color .2s;width:100%}.faq-question:hover{background:#f9f9f9}.question-text{flex:1 1;padding-right:15px}.expand-icon{align-items:center;background:#e8f5e9;border-radius:50%;color:#4caf50;display:flex;font-size:24px;font-weight:700;height:30px;justify-content:center;width:30px}.faq-answer{animation:fadeIn .3s ease;border-top:1px solid #e0e0e0;padding:0 20px 20px}.faq-answer p{color:#555;font-size:15px;line-height:1.7;margin:15px 0 0}.still-need-help{margin-bottom:40px}.help-cta-card{background:linear-gradient(135deg,#4caf50,#2e7d32);border-radius:12px;box-shadow:0 4px 20px #4caf504d;color:#fff;padding:40px;text-align:center}.help-cta-card h2{font-size:28px;margin:0 0 15px}.help-cta-card p{font-size:16px;margin:0 0 25px;opacity:.95}.cta-buttons{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.cta-btn{border-radius:8px;font-size:16px;font-weight:700;padding:14px 30px;text-decoration:none;transition:all .2s}.cta-btn.primary{background:#fff;color:#4caf50}.cta-btn.primary:hover{background:#f0f0f0;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.cta-btn.secondary{background:#0000;border:2px solid #fff;color:#fff}.cta-btn.secondary:hover{background:#ffffff1a;transform:translateY(-2px)}.legal-section{margin-bottom:20px}.legal-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.legal-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;color:inherit;display:block;padding:25px;text-decoration:none;transition:all .2s}.legal-card:hover{border-color:#4caf50;box-shadow:0 4px 16px #0000001a;transform:translateY(-2px)}.legal-card h3{color:#333;font-size:18px;margin:0 0 12px}.legal-card p{color:#666;font-size:14px;line-height:1.6;margin:0 0 15px}.read-more{color:#4caf50;font-size:14px;font-weight:600}@media (max-width:768px){.help-content{padding:15px 15px 40px}.section-title{font-size:20px}.quick-links-grid{grid-template-columns:1fr 1fr}.quick-link-card{padding:20px 15px}.quick-link-icon{font-size:36px}.quick-link-card h3{font-size:16px}.faq-categories{gap:8px}.category-btn{font-size:13px;padding:8px 14px}.category-label{display:none}.category-btn.active .category-label{display:inline}.faq-question{font-size:14px;padding:15px}.faq-answer{padding:0 15px 15px}.faq-answer p{font-size:14px}.help-cta-card{padding:30px 20px}.help-cta-card h2{font-size:22px}.cta-buttons{flex-direction:column}.cta-btn{text-align:center;width:100%}.legal-cards{grid-template-columns:1fr}}@media (max-width:480px){.quick-links-grid{grid-template-columns:1fr}}.contact-page{background:#f5f5f5;min-height:100vh;padding-top:10px}.contact-content{margin:0 auto;max-width:1200px;padding:20px 20px 48px}.contact-grid{grid-gap:30px;align-items:start;display:grid;gap:30px;grid-template-columns:1fr 380px}.contact-form-section{width:100%}.form-card{background:#fff;border:2px solid #0c0c0c;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:35px}.form-title{color:#333;font-size:26px;font-weight:700;margin:0 0 8px}.form-subtitle{color:#666;font-size:15px;line-height:1.5;margin:0 0 25px}.alert{align-items:center;border-radius:8px;display:flex;font-size:15px;font-weight:500;gap:12px;margin-bottom:25px;padding:15px 18px}.alert-success{background:#e8f5e9;border:1px solid #4caf50;color:#2e7d32}.alert-error{background:#ffebee;border:1px solid #f44336;color:#c62828}.alert-icon{align-items:center;border-radius:50%;display:flex;font-size:18px;font-weight:700;height:24px;justify-content:center;width:24px}.alert-success .alert-icon{background:#4caf50;color:#fff}.alert-error .alert-icon{background:#f44336;color:#fff}.contact-form{display:flex;flex-direction:column;gap:20px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{color:#333;font-size:14px;font-weight:600}.required{color:#f44336}.form-input,.form-select,.form-textarea{background:#fff;border:2px solid #ddd;border-radius:8px;color:#333;font-family:inherit;font-size:15px;padding:12px 15px;transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#4caf50;box-shadow:0 0 0 3px #4caf5026;outline:none}.form-input.error,.form-select.error,.form-textarea.error{border-color:#f44336}.form-input.error:focus,.form-select.error:focus,.form-textarea.error:focus{box-shadow:0 0 0 3px #f4433626}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:#f5f5f5;cursor:not-allowed}.form-input::placeholder,.form-textarea::placeholder{color:#999}.form-select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:18px;cursor:pointer;padding-right:40px}.form-textarea{line-height:1.6;min-height:150px;resize:vertical}.textarea-footer{align-items:center;display:flex;justify-content:space-between;margin-top:4px}.char-count{color:#999;font-size:12px}.error-message{gap:4px}.error-message,.submit-btn{align-items:center;display:flex}.submit-btn{background:#4caf50;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;gap:10px;justify-content:center;margin-top:10px;padding:15px 30px;transition:all .2s}.submit-btn:hover:not(:disabled){background:#45a049;box-shadow:0 4px 12px #4caf504d;transform:translateY(-2px)}.submit-btn:disabled{background:#9e9e9e;cursor:not-allowed;transform:none}.spinner{animation:spin .8s ease-in-out infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}@keyframes spin{to{transform:rotate(1turn)}}.contact-info-section{display:flex;flex-direction:column;gap:20px}.info-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:22px}.info-card.highlight{background:#f8fff8;border-color:#4caf50}.info-card h3{color:#333;font-size:18px;font-weight:700;margin:0 0 15px}.info-item{align-items:flex-start;border-bottom:1px solid #f0f0f0;display:flex;gap:12px;padding:12px 0}.info-item:last-child{border-bottom:none;padding-bottom:0}.info-icon{font-size:20px;margin-top:2px}.info-content{display:flex;flex-direction:column;gap:4px}.info-content strong{color:#333;font-size:14px}.info-content a,.info-content span{color:#666;font-size:14px;line-height:1.4;text-decoration:none}.info-content a:hover{color:#4caf50;text-decoration:underline}.response-times{list-style:none;margin:0;padding:0}.response-times li{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:10px 0}.response-times li:last-child{border-bottom:none;padding-bottom:0}.time-label{color:#555;font-size:14px}.time-value{background:#e8f5e9;border-radius:12px;color:#4caf50;font-size:13px;font-weight:600;padding:4px 10px}.info-tip{color:#555;font-size:14px;line-height:1.6;margin:0 0 12px}.info-tip:last-child{margin-bottom:0}.info-tip a{color:#4caf50;font-weight:600;text-decoration:none}.info-tip a:hover{text-decoration:underline}.info-card.highlight p{color:#555;font-size:14px;line-height:1.6;margin:0}.info-card.highlight a{color:#4caf50;font-weight:600;text-decoration:none}.info-card.highlight a:hover{text-decoration:underline}@media (max-width:1024px){.contact-grid{grid-template-columns:1fr}.contact-info-section{flex-direction:row;flex-wrap:wrap;order:-1}.info-card{flex:1 1;min-width:280px}}@media (max-width:768px){.contact-content{padding:15px 15px 40px}.form-card{padding:25px 20px}.form-row{grid-template-columns:1fr}.form-title{font-size:22px}.contact-info-section{flex-direction:column}.info-card{min-width:auto}}@media (max-width:480px){.form-card{padding:20px 15px}.form-input,.form-select,.form-textarea{font-size:14px;padding:10px 12px}.submit-btn{font-size:15px;padding:12px 20px}}.privacy-page{background:#f5f5f5;min-height:100vh;padding-top:10px}.privacy-content{grid-gap:30px;align-items:start;display:grid;gap:30px;grid-template-columns:280px 1fr;margin:0 auto;max-width:1400px;padding:20px 20px 48px}.privacy-nav{position:relative}.privacy-main{width:100%}.policy-card{background:#fff;border:2px solid #0c0c0c;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:40px}.last-updated{margin-bottom:30px}.summary-box{background:#e8f5e9;border:2px solid #4caf50;border-radius:10px;margin-bottom:35px;padding:25px}.summary-box h2{color:#2e7d32;font-size:20px;margin:0 0 15px}.summary-box p{color:#333;font-size:15px;line-height:1.7;margin:0 0 15px}.summary-box ul{margin:0;padding-left:20px}.summary-box li{color:#444;font-size:14px;line-height:1.8}.policy-section{border-bottom:1px solid #e0e0e0;margin-bottom:40px;padding-bottom:30px;scroll-margin-top:100px}.policy-section:last-of-type{border-bottom:none;margin-bottom:20px}.policy-section h2{border-bottom:2px solid #4caf50;color:#333;font-size:24px;font-weight:700;margin:0 0 20px;padding-bottom:10px}.policy-section h3{color:#444;font-size:18px;font-weight:600;margin:25px 0 15px}.policy-section p{color:#555;font-size:15px;line-height:1.8;margin:0 0 15px}.policy-section ul{margin:0 0 15px;padding-left:25px}.policy-section li{color:#555;font-size:15px;line-height:1.8;margin-bottom:8px}.policy-section li strong{color:#333}.policy-section a{color:#4caf50;font-weight:500;text-decoration:none}.policy-section a:hover{text-decoration:underline}.info-box{background:#f5f5f5;border-left:4px solid #4caf50;color:#555;font-size:14px;line-height:1.7;margin:20px 0;padding:15px 20px}.highlight-box{background:#e3f2fd;border:2px solid #2196f3;border-radius:8px;margin:20px 0;padding:20px}.highlight-box strong{color:#1565c0;display:block;font-size:16px;margin-bottom:10px}.highlight-box p{color:#555;font-size:14px;margin:0}.warning-box{background:#fff3e0;border:2px solid #ff9800;border-radius:8px;color:#e65100;font-size:15px;margin:20px 0;padding:15px 20px}.cookies-table,.retention-table{border-collapse:collapse;font-size:14px;margin:20px 0;width:100%}.cookies-table td,.cookies-table th,.retention-table td,.retention-table th{border:1px solid #e0e0e0;padding:12px 15px;text-align:left}.cookies-table th,.retention-table th{background:#f5f5f5;color:#333;font-weight:600}.cookies-table td,.retention-table td{color:#555}.cookies-table tr:nth-child(2n),.retention-table tr:nth-child(2n){background:#fafafa}.policy-header-actions{display:flex;justify-content:flex-end;margin-bottom:20px}.policy-footer{border-top:2px solid #e0e0e0;display:flex;justify-content:center;margin-top:20px;padding-top:30px}@media print{.page-header,.policy-footer,.policy-header-actions,.print-btn,.privacy-nav{display:none!important}.privacy-content{display:block;padding:0}.policy-card{border:none;box-shadow:none;padding:0}.policy-section{page-break-inside:avoid}}@media (max-width:1024px){.privacy-content{grid-template-columns:1fr}.privacy-nav{order:2}.nav-sticky{position:static}.nav-list{flex-direction:row;flex-wrap:wrap;gap:8px}.nav-link{font-size:12px;padding:8px 12px;white-space:nowrap}.privacy-main{order:1}}@media (max-width:768px){.privacy-content{padding:15px 15px 40px}.policy-card{padding:25px 20px}.policy-section h2{font-size:20px}.policy-section h3{font-size:16px}.policy-section li,.policy-section p{font-size:14px}.summary-box{padding:20px}.summary-box h2{font-size:18px}.cookies-table,.retention-table{font-size:13px}.cookies-table td,.cookies-table th,.retention-table td,.retention-table th{padding:10px}.nav-sticky{display:none}}@media (max-width:480px){.policy-card{padding:20px 15px}.last-updated{font-size:13px;padding:10px 15px}.cookies-table,.retention-table{display:block;overflow-x:auto}}.terms-page{background:#f5f5f5;min-height:100vh;padding-top:10px}.terms-content{grid-gap:30px;align-items:start;display:grid;gap:30px;grid-template-columns:280px 1fr;margin:0 auto;max-width:1400px;padding:20px 20px 48px}.terms-nav{position:relative}.nav-sticky{background:#fff;border:2px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #0000000d;max-height:calc(100vh - 40px);overflow-y:auto;padding:20px;position:-webkit-sticky;position:sticky;top:20px}.nav-title{border-bottom:2px solid #e0e0e0;color:#333;font-size:16px;font-weight:700;margin:0 0 15px;padding-bottom:10px}.nav-list{display:flex;flex-direction:column;gap:4px;list-style:none;margin:0;padding:0}.nav-link{background:#0000;border:none;border-radius:6px;color:#555;cursor:pointer;display:block;font-size:13px;font-weight:500;line-height:1.4;padding:10px 12px;text-align:left;transition:all .2s;width:100%}.nav-link:hover{background:#f5f5f5;color:#333}.nav-link.active{background:#e8f5e9;color:#2e7d32;font-weight:600}.terms-main{width:100%}.terms-card{background:#fff;border:2px solid #0c0c0c;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:40px}.last-updated{align-items:center;background:#f0f4f8;border-radius:8px;color:#555;display:inline-flex;font-size:14px;gap:10px;margin-bottom:25px;padding:12px 20px}.update-icon{font-size:18px}.intro-box{background:#f5f5f5;border-left:4px solid #4caf50;border-radius:0 8px 8px 0;margin-bottom:35px;padding:20px 25px}.intro-box p{color:#444;font-size:15px;line-height:1.7;margin:0 0 15px}.intro-box p:last-child{margin-bottom:0}.terms-section{border-bottom:1px solid #e0e0e0;margin-bottom:40px;padding-bottom:30px;scroll-margin-top:100px}.terms-section:last-of-type{border-bottom:none;margin-bottom:20px}.terms-section h2{border-bottom:2px solid #4caf50;color:#333;font-size:24px;font-weight:700;margin:0 0 20px;padding-bottom:10px}.terms-section h3{color:#444;font-size:18px;font-weight:600;margin:25px 0 15px}.terms-section p{color:#555;font-size:15px;line-height:1.8;margin:0 0 15px}.terms-section ul{margin:0 0 15px;padding-left:25px}.terms-section li{color:#555;font-size:15px;line-height:1.8;margin-bottom:8px}.terms-section a{color:#4caf50;font-weight:500;text-decoration:none}.terms-section a:hover{text-decoration:underline}.important-box{background:#fff3e0;border:2px solid #ff9800;border-radius:8px;margin:20px 0;padding:20px}.important-box strong{color:#e65100;display:block;font-size:16px;margin-bottom:10px}.important-box p{color:#555;font-size:14px;margin:0}.legal-box{background:#fafafa;border:2px solid #ddd;border-radius:8px;margin:20px 0;padding:25px}.legal-box h3{color:#333;font-size:16px;margin-top:0}.legal-box h3:first-child{margin-top:0}.legal-box p{color:#555;font-size:13px;line-height:1.7;text-transform:none}.legal-box ul{margin:10px 0;padding-left:20px}.legal-box li{color:#555;font-size:13px;line-height:1.7}.contact-box{background:#f5f5f5;border:2px solid #ddd;border-radius:8px;margin:20px 0;padding:20px}.contact-box p{font-size:15px;margin:0 0 8px}.contact-box p:last-child{margin-bottom:0}.contact-box a{color:#4caf50;text-decoration:none}.contact-box a:hover{text-decoration:underline}.terms-footer{border-top:2px solid #e0e0e0;display:flex;justify-content:center;margin-top:20px;padding-top:30px}.terms-header-actions{display:flex;justify-content:flex-end;margin-bottom:20px}.print-btn{align-items:center;background:#4caf50;border:2px solid #4caf50;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 25px;transition:all .2s}.print-btn:hover{background:#43a047;border-color:#43a047}@media print{.page-header,.print-btn,.terms-nav{display:none!important}.terms-content{display:block;padding:0}.terms-card{border:none;box-shadow:none;padding:0}.terms-section{page-break-inside:avoid}.legal-box{border:1px solid #ccc}}@media (max-width:1024px){.terms-content{grid-template-columns:1fr}.terms-nav{order:2}.nav-sticky{max-height:none;position:static}.nav-list{flex-direction:row;flex-wrap:wrap;gap:8px}.nav-link{font-size:12px;padding:8px 12px;white-space:nowrap}.terms-main{order:1}}@media (max-width:768px){.terms-content{padding:15px 15px 40px}.terms-card{padding:25px 20px}.terms-section h2{font-size:20px}.terms-section h3{font-size:16px}.terms-section li,.terms-section p{font-size:14px}.intro-box{padding:15px 20px}.intro-box p{font-size:14px}.legal-box{padding:20px}.legal-box li,.legal-box p{font-size:12px}.nav-sticky{display:none}}@media (max-width:480px){.terms-card{padding:20px 15px}.last-updated{font-size:13px;padding:10px 15px}.contact-box,.important-box,.legal-box{padding:15px}}.variant-profiles-section{background:#fff;border:3px solid #4caf50;border-radius:8px;grid-column:1/-1;margin-bottom:15px;max-width:100%;padding:15px}.variant-profiles-section h2{border-bottom:3px solid #4caf50;color:#333;font-size:18px;margin:0 0 5px;padding-bottom:8px}.variant-profiles-section .section-description{color:#666;font-size:13px;margin:0 0 12px}.variant-config-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:15px}.variant-config-btn{align-items:center;border:2px solid #0000;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:700;gap:6px;padding:8px 16px;transition:all .2s}.variant-config-btn:disabled{cursor:not-allowed;opacity:.5}.variant-config-btn .btn-icon{font-size:14px}.variant-config-btn-save{background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff}.variant-config-btn-save:hover:not(:disabled){box-shadow:0 4px 8px #4caf504d;transform:translateY(-2px)}.variant-config-btn-load{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.variant-config-btn-load:hover:not(:disabled){box-shadow:0 4px 8px #ff98004d;transform:translateY(-2px)}.variant-config-btn-import{background:linear-gradient(135deg,#9c27b0,#7b1fa2);color:#fff}.variant-config-btn-import:hover:not(:disabled){box-shadow:0 4px 8px #9c27b04d;transform:translateY(-2px)}.saved-variants-list{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr);max-height:200px;overflow-y:auto}.saved-variant-item{align-items:center;background:#f9f9f9;border:2px solid #ddd;border-radius:6px;display:flex;justify-content:space-between;padding:8px 12px;transition:all .2s}.saved-variant-item:hover{background:#f0f0f0;border-color:#4caf50}.variant-info{align-items:center;display:flex;flex:1 1;flex-direction:row;gap:12px;margin-right:15px;min-width:0}.variant-name{color:#333;font-size:14px;font-weight:700;white-space:nowrap}.variant-size{background:#e0e0e0;border-radius:3px;color:#666;font-size:12px;font-weight:600;padding:2px 6px}.variant-date{color:#999;font-size:11px;white-space:nowrap}.variant-item-actions{display:flex;flex-shrink:0;gap:6px}.variant-item-btn{border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;transition:all .2s}.variant-item-btn.load{background:#2196f3;color:#fff}.variant-item-btn.load:hover{background:#1976d2}.variant-item-btn.export{background:#607d8b;color:#fff;padding:6px 8px}.variant-item-btn.export:hover{background:#455a64}.variant-item-btn.delete{background:#f44336;color:#fff;padding:6px 8px}.variant-item-btn.delete:hover{background:#d32f2f}.no-variants-message{background:#f9f9f9;border:2px dashed #ddd;border-radius:8px;color:#666;font-style:italic;padding:20px;text-align:center}.variant-dialog-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.variant-dialog{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:450px;padding:24px;width:90%}.variant-dialog-load{max-width:550px}.variant-dialog h3{border-bottom:2px solid #4caf50;color:#333;font-size:20px;margin:0 0 16px;padding-bottom:10px}.variant-dialog-subtitle{color:#666;font-size:14px;margin-bottom:16px}.variant-dialog-body{margin-bottom:20px}.variant-dialog-body p{color:#333;margin:0 0 10px}.variant-dialog-field{margin-bottom:16px}.variant-dialog-field label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:6px}.variant-dialog-field input,.variant-dialog-field textarea{border:2px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.variant-dialog-field input:focus,.variant-dialog-field textarea:focus{border-color:#4caf50;outline:none}.variant-dialog-field textarea{min-height:60px;resize:vertical}.variant-dialog-info{background:#e8f5e9;border-radius:4px;color:#2e7d32;font-size:13px;margin-bottom:16px;padding:8px 12px}.variant-dialog-error{background:#ffebee;border:1px solid #ffcdd2;border-radius:6px;color:#c62828;font-size:14px;margin-bottom:16px;padding:10px 12px}.variant-dialog-success{background:#e8f5e9;border:1px solid #c8e6c9;border-radius:6px;color:#2e7d32;font-size:15px;margin-bottom:16px;padding:16px;text-align:center}.variant-dialog-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.variant-dialog-btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.variant-dialog-btn.cancel{background:#f5f5f5;color:#666}.variant-dialog-btn.cancel:hover{background:#e0e0e0}.variant-dialog-btn.save{background:#4caf50;color:#fff}.variant-dialog-btn.save:hover:not(:disabled){background:#388e3c}.variant-dialog-btn.save:disabled{background:#ccc;cursor:not-allowed}.variant-dialog-btn.delete{background:#f44336;color:#fff}.variant-dialog-btn.delete:hover:not(:disabled){background:#d32f2f}.variant-dialog-list{margin-bottom:16px;max-height:300px;overflow-y:auto}.variant-dialog-item{border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;margin-bottom:8px;padding:12px;transition:all .2s}.variant-dialog-item:hover{background:#f9fff9;border-color:#4caf50}.variant-dialog-item-info{display:flex;flex-direction:column;gap:4px}.variant-dialog-item-name{color:#333;font-size:15px;font-weight:700}.variant-dialog-item-meta{color:#666;font-size:12px}@media (max-width:600px){.variant-config-btn{font-size:13px;padding:6px 12px}.saved-variants-list{grid-template-columns:1fr}.saved-variant-item{align-items:flex-start;flex-direction:column;gap:8px}.variant-info{margin-right:0}.variant-item-actions{align-self:flex-end}}.variant-creator-container{background:#fafafa;font-family:Arial,sans-serif;margin:0 auto;max-width:1600px;min-height:80vh;padding:10px}.variant-creator-container>.page-header{margin-bottom:20px}.variant-info-panel{background-color:#fff;border:2px solid #000;border-radius:10px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;padding:20px}.creator-layout{align-items:flex-start;display:flex;gap:20px;margin-bottom:20px}.guidelines-panel{background-color:#fff;border:2px solid #000;border-radius:10px;box-shadow:0 2px 8px #0000001a;flex:0 0 280px;max-height:800px;overflow-y:auto;padding:20px;position:-webkit-sticky;position:sticky;top:20px}.guidelines-panel h3{border-bottom:2px solid #4caf50;color:#333;font-size:20px;margin:0 0 20px;padding-bottom:10px}.guideline-section{border-bottom:1px solid #f0f0f0;margin-bottom:20px;padding-bottom:15px}.guideline-section:last-child{border-bottom:none}.guideline-section h4{color:#444;font-size:16px;margin:0 0 10px}.guideline-section p{color:#666;font-size:14px;margin:5px 0}.guideline-notes{background-color:#f9f9f9;border-radius:5px;color:#666;font-style:italic;margin-top:10px!important;padding:8px}.guideline-section ul{margin:10px 0;padding-left:20px}.guideline-section li{color:#666;font-size:13px;margin:5px 0}.level-badge{border-radius:3px;color:#fff;display:inline-block;font-size:11px;font-weight:700;margin-right:5px;padding:2px 8px}.level-badge.low{background-color:#90ee90;color:#333}.level-badge.intermediate{background-color:gold;color:#333}.level-badge.high{background-color:tomato}.level-badge.checkmate{background-color:#4169e1}.validation-section{background-color:#f9f9f9;border:none!important;border-radius:8px;padding:15px}.recommendations-list{margin:10px 0;padding-left:20px}.recommendations-list li{color:#555;font-size:13px;line-height:1.4;margin:6px 0}.config-summary{background-color:#fff;border:1px solid #ddd;border-radius:5px;padding:10px}.config-summary p{font-size:13px;margin:4px 0}.validation-success{color:#4caf50;font-weight:700;margin:0}.validation-issues{display:flex;flex-direction:column;gap:8px}.validation-item{border-radius:5px;font-size:13px;padding:8px}.validation-item.error{background-color:#ffebee;border-left:3px solid #c62828;color:#c62828}.validation-item.warning{background-color:#fff3e0;border-left:3px solid #ef6c00;color:#ef6c00}.board-panel{align-items:center;background-color:#fff;border:2px solid #000;border-radius:10px;box-shadow:0 2px 8px #0000001a;display:flex;flex:1 1;flex-direction:column;padding:20px}.board-controls{background-color:#f5f5f5;border-radius:8px;gap:15px;justify-content:center;margin-bottom:15px;padding:15px;width:100%}.control-group{align-items:center;display:flex;gap:8px}.control-group label{color:#333;font-size:14px;font-weight:700}.size-selector{background-color:#fff;border:2px solid #4caf50;border-radius:4px;color:#333;padding:8px 12px}.clear-btn,.size-selector{cursor:pointer;font-size:14px;font-weight:700}.clear-btn{background-color:#f44336;border:none;border-radius:4px;color:#fff;padding:8px 16px;transition:background-color .2s}.clear-btn:hover{background-color:#d32f2f}.color-selection{display:flex;gap:10px;margin-bottom:15px}.color-btn{background-color:#fff;border:2px solid #ddd;border-radius:5px;cursor:pointer;font-size:14px;font-weight:700;padding:10px 20px;transition:all .2s}.color-btn.active{background-color:#4caf50;border-color:#4caf50;color:#fff}.color-btn:hover{box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.square{transition:background-color .2s,opacity .2s}.square:hover{box-shadow:inset 0 0 10px #0000004d;opacity:.7}.piece{cursor:pointer;height:100%;width:100%}.piece-image{max-height:90%;max-width:90%}.piece-image.white-piece{filter:brightness(0) invert(1) drop-shadow(0 0 2px rgba(0,0,0,.8))}.piece-image.black-piece{filter:brightness(0) drop-shadow(0 0 2px rgba(255,255,255,.5))}.board-stats{background-color:#f5f5f5;border-radius:8px;color:#333;display:flex;font-size:14px;font-weight:700;gap:20px;margin-top:15px;padding:10px 20px}.variant-info-inputs{align-items:flex-end;display:flex;flex:1 1;gap:15px}.input-group{display:flex;flex:1 1;flex-direction:column;gap:5px}.input-group label{color:#333;font-size:14px;font-weight:700}.input-group input{border:2px solid #ddd;border-radius:5px;font-size:14px;padding:10px;transition:border-color .2s}.input-group input:focus{border-color:#4caf50;outline:none}.save-variant-btn{align-self:center;background-color:#4caf50;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;padding:12px 24px;transition:all .2s;white-space:nowrap}.save-variant-btn:hover:not(:disabled){background-color:#45a049;box-shadow:0 4px 12px #4caf504d;transform:translateY(-2px)}.save-variant-btn:active:not(:disabled){transform:translateY(0)}.save-variant-btn:disabled{background-color:#ccc;cursor:not-allowed;opacity:.6}.piece-library-panel{background-color:#fff;border:2px solid #000;border-radius:10px;box-shadow:0 2px 8px #0000001a;flex:0 0 300px;max-height:800px;overflow-y:auto;padding:20px}.piece-library-panel h3{border-bottom:2px solid #4caf50;color:#333;font-size:20px;margin:0 0 15px;padding-bottom:10px}@keyframes flashBorder{0%,to{border-color:#000}50%{border-color:#4caf50}}@keyframes flashText{0%,to{opacity:1}50%{opacity:.4}}.step-hint-container{align-items:flex-start;background:linear-gradient(135deg,#4caf50,#388e3c);border-radius:6px;color:#fff;display:flex;font-size:13px;font-weight:600;gap:12px;margin-bottom:15px;padding:10px 15px}.step-hint-container.board-step-hint{flex-shrink:0;margin-bottom:0;margin-left:15px;max-width:500px}.step-hint-icon{animation:flashIcon 1.5s ease-in-out infinite;flex-shrink:0;font-size:24px}@keyframes flashIcon{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.9)}}.step-hint-content{flex:1 1;text-align:left}.level-mismatch-error{animation:flashText 1s ease-in-out infinite;background:linear-gradient(135deg,#f44336,#d32f2f);border-radius:6px;color:#fff;font-size:13px;font-weight:600;padding:10px 15px;text-align:center}.level-mismatch-error.board-step-hint{flex-shrink:0;margin-bottom:0;margin-left:15px;max-width:400px}.step-hint-title{font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:4px;opacity:.9;text-transform:uppercase}.step-hint-message{font-size:13px}.step-hint-bullets{font-size:12px;line-height:1.5;margin:6px 0 0;padding-left:20px;text-align:left}.step-hint-bullets li{margin-bottom:2px}.class-filters{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:15px}.class-filter-btn{background-color:#f0f0f0;border:2px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:11px;font-weight:700;padding:5px 10px;text-transform:capitalize;transition:all .2s}.class-filter-btn:hover{box-shadow:0 2px 4px #0003;opacity:.8;transform:translateY(-1px)}.selected-piece-info{color:#666;font-size:13px;text-align:center}.selected-piece-info:not(:empty){background-color:#f9f9f9;border-radius:5px;margin-bottom:10px;padding:8px}.usage-instructions{margin-bottom:10px}.usage-instructions p{color:#1b5e20;font-size:13px;font-weight:500;line-height:1.6;margin:6px 0}.usage-instructions p:first-child{color:#1b5e20;font-size:14px;font-weight:700;margin-bottom:10px;text-decoration:underline}.piece-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr}.piece-card{align-items:center;background-color:#fff;border:2px solid #000;border-radius:6px;cursor:pointer;display:flex;gap:8px;padding:8px;transition:all .2s}.piece-card:hover{box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.piece-card.selected{background-color:#e8f5e9;border-width:3px}.piece-card-image{align-items:center;background-color:#f0f0f0;border-radius:5px;display:flex;flex:0 0 50px;height:50px;justify-content:center;position:relative}.piece-card-image img{max-height:45px;max-width:45px;object-fit:contain}.piece-index{background-color:#000000b3;border-radius:2px;color:#fff;font-size:8px;font-weight:700;padding:1px 3px;position:absolute;right:2px;top:2px}.piece-card-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.piece-name{color:#333;font-size:13px;font-weight:700}.piece-abbr{color:#666;font-size:16px;font-weight:700}.piece-class{border-radius:3px;color:#fff;display:inline-block;font-size:10px;padding:2px 6px;text-transform:capitalize;width:-webkit-fit-content;width:fit-content}.bottom-controls{align-items:center;background-color:#fff;border:2px solid #000;border-radius:10px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:center;padding:20px}@media (max-width:1400px){.creator-layout{flex-direction:column}.guidelines-panel,.piece-library-panel{flex:1 1;max-height:none;max-width:100%;position:static}.board-panel{width:100%}}@media (max-width:768px){.variant-creator-container{padding:10px}.square{height:40px;width:40px}.rank-label{font-size:12px;height:40px;width:20px}.file-label-bottom{font-size:12px;width:40px}.board-controls{flex-direction:column;gap:10px}.variant-info-inputs{align-items:stretch;flex-direction:column}.save-variant-btn{margin-top:10px;width:100%}}.guidelines-panel::-webkit-scrollbar,.piece-library-panel::-webkit-scrollbar{width:8px}.guidelines-panel::-webkit-scrollbar-track,.piece-library-panel::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.guidelines-panel::-webkit-scrollbar-thumb,.piece-library-panel::-webkit-scrollbar-thumb{background:#888;border-radius:10px}.guidelines-panel::-webkit-scrollbar-thumb:hover,.piece-library-panel::-webkit-scrollbar-thumb:hover{background:#555}.modal-overlay{align-items:center;animation:fadeIn .2s ease-in;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.modal-content{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:500px;width:90%}.modal-header{border-bottom:2px solid #f0f0f0;padding:24px 24px 16px}.modal-header h2{color:#333;font-size:24px;margin:0}.success-header h2{color:#4caf50}.error-header h2{color:#f44336}.modal-body{color:#555;font-size:16px;line-height:1.6;padding:24px}.modal-body p{margin:0 0 16px}.modal-body p:last-child{margin-bottom:0}.success-message{color:#333;font-size:18px;margin-bottom:20px!important}.success-list{list-style:none;margin:20px 0;padding:0}.success-list li{color:#4caf50;font-size:15px;padding:8px 0}.success-instruction{background-color:#e8f5e9;border-left:4px solid #4caf50;border-radius:8px;font-weight:500;margin-top:20px!important;padding:16px}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:16px 24px 24px}.modal-btn{border:none;border-radius:6px;cursor:pointer;font-size:15px;font-weight:600;padding:10px 24px;transition:all .2s}.modal-btn:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.modal-btn:active{transform:translateY(0)}.cancel-btn{background-color:#f5f5f5;color:#666}.cancel-btn:hover{background-color:#e0e0e0}.confirm-btn{background-color:#4caf50;color:#fff}.confirm-btn:hover{background-color:#45a049}.error-modal .confirm-btn{background-color:#f44336}.error-modal .confirm-btn:hover{background-color:#d32f2f}@media (max-width:600px){.modal-content{max-width:none;width:95%}.modal-header h2{font-size:20px}.modal-body{font-size:14px;padding:20px}.modal-footer{flex-direction:column-reverse}.modal-btn{width:100%}}.edit-mode-panel{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px solid #2196f3;border-radius:8px;margin-bottom:15px;padding:12px 16px}.edit-mode-checkbox{align-items:center;cursor:pointer;display:flex;gap:10px}.edit-mode-checkbox input[type=checkbox]{accent-color:#2196f3;cursor:pointer;height:18px;width:18px}.edit-mode-label{color:#1565c0;font-size:14px;font-weight:600}.edit-mode-hint{color:#1976d2;font-size:13px;font-style:italic;margin:8px 0 0 28px}.game-content-wrapper{margin:0 auto;max-width:1600px;padding:5px}.board-controls-container{align-items:center;background-color:#f9f9f9;border:2px solid #333;border-radius:8px;display:flex;flex-wrap:wrap;gap:5px;margin-bottom:5px;padding:5px}.piece-stats-panel{align-items:center;background-color:#f9f9f9;border:2px solid #333;border-radius:8px;display:flex;gap:30px;margin-bottom:5px;min-height:24px;padding:5px 10px;width:100%}.ai-stats-panel{align-items:center;background-color:#e3f2fd;border:2px solid #1e1f20;border-radius:4px;display:flex;font-size:12px;margin-bottom:5px;min-height:44px;padding:5px;width:100%}.ai-stats-panel.thinking{background-color:#fff3cd;border-color:#ffc107;font-weight:700}.chess-board-container{font-family:Arial,sans-serif;margin:20px auto;max-width:1500px;padding:5px}.board-header{align-items:center;border-bottom:2px solid #333;display:flex;justify-content:flex-start;margin-bottom:5px;padding-bottom:5px}.board-header h2{color:#333;margin:0}.board-header .board-controls{display:none}.chess-game-layout{align-items:flex-start;display:flex;gap:5px}.left-panel-column{flex:0 0 236px;min-width:236px}.mode-selector-bar{background-color:#f9f9f9;border:2px solid #333;border-radius:8px;margin-bottom:5px;padding:5px}.mode-selector-bar label{display:block;margin-bottom:5px}.mode-select,.mode-selector-bar label{color:#333;font-size:14px;font-weight:700}.mode-select{background-color:#fff;border:2px solid #4caf50;border-radius:4px;cursor:pointer;padding:5px 10px;transition:all .2s;width:100%}.mode-select:hover{background-color:#f0f0f0}.mode-select:focus{box-shadow:0 0 0 3px #4caf504d;outline:none}.connection-status-inline{background-color:#fff;border:1px solid #ddd;border-radius:4px;font-size:12px;margin-top:5px;padding:5px}.connection-status-inline .connected{color:#4caf50;font-weight:700}.connection-status-inline .disconnected{color:#f44336;font-weight:700}.room-code-inline{border-left:2px solid #ddd;margin-left:10px;padding-left:5px}.room-code-inline strong{font-family:monospace;font-size:14px}.board-and-right-panels{align-items:flex-start;display:flex;flex:1 1;flex-direction:row;gap:5px}.board-center-container{align-items:flex-start;display:flex;flex:1 1;justify-content:center}.right-panels-container{flex:0 0 auto;max-width:320px;min-width:300px}.move-history-panel{position:-webkit-sticky;position:sticky;top:20px}.color-customization{borderradius:8px;background-color:#f9f9f9;border:1px solid #ddd;margin-bottom:5px;padding:5px}.color-customization,.color-picker-group{align-items:center;display:flex;gap:5px}.color-picker-group label{color:#333;font-size:14px;font-weight:700}.color-picker{border:2px solid #4caf50;border-radius:4px;cursor:pointer;height:35px;width:50px}.color-value{background-color:#fff;border:1px solid #ddd;border-radius:3px;color:#666;font-family:monospace;font-size:12px;padding:4px 8px}.board-controls{align-items:center;display:flex;gap:5px}.setup-selector{background-color:#fff;border:2px solid #4caf50;border-radius:4px;color:#333;cursor:pointer;font-size:14px;font-weight:700;padding:5px 10px;transition:all .2s}.setup-selector:hover{background-color:#f0f0f0}.setup-selector:focus{box-shadow:0 0 0 3px #4caf504d;outline:none}.control-btn{background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:5px 10px;transition:background-color .2s}.control-btn:hover{background-color:#45a049}.control-btn:active{transform:scale(.98)}.board-wrapper{align-items:center;display:flex;gap:0;margin-bottom:5px}.rank-labels{display:flex;flex-direction:column;gap:0;margin-right:5px}.rank-label{align-items:center;color:#666;display:flex;font-size:14px;font-weight:700;height:60px;justify-content:center;width:25px}.chess-board{background-color:#fff;border:3px solid #333;box-shadow:0 4px 8px #0003;display:grid;position:relative}.square{align-items:center;cursor:pointer;display:flex;height:60px;justify-content:center;position:relative;transition:background-color .2s;width:60px}.square.light{background-color:#f0d9b5}.square.dark{background-color:#b58863}.square:hover{opacity:.8}.square.selected{background-color:#a5d6a7!important;box-shadow:inset 0 0 0 3px #2e7d32}.piece{align-items:center;cursor:grab;display:flex;height:150%;justify-content:center;transition:transform .1s;width:150%}.piece:active{cursor:grabbing}.piece:hover{transform:scale(1.1)}.piece-image{max-height:100%;max-width:100%;object-fit:contain;pointer-events:none}.piece-image.white-piece{filter:invert(1) drop-shadow(0 0 2px rgba(0,0,0,.8))}.piece-image.black-piece{filter:drop-shadow(0 0 2px rgba(255,255,255,.5))}.file-labels-bottom{display:flex;gap:0;margin-left:30px}.file-label-bottom{color:#666;font-size:14px;font-weight:700;padding-top:5px;text-align:center;width:60px}.info-panel{background-color:#f5f5f5;border:1px solid #ddd;border-radius:8px;margin-top:5px;padding:5px}.info-item{color:#333;padding:5px 0}.info-item strong{color:#000;margin-right:8px}@media (max-width:1500px){.chess-game-layout{flex-direction:column}.left-panel-column{flex:1 1;min-width:0;min-width:auto;width:100%}.move-history-panel{position:static}.board-and-right-panels{flex-direction:column}.right-panels-container{max-width:100%;width:100%}}@media (max-width:768px){.chess-board-container{padding:5px}.square{height:45px;width:45px}.rank-label{font-size:12px;height:45px;width:20px}.file-label-bottom{font-size:12px;width:45px}.board-header{align-items:flex-start;flex-direction:column;gap:5px}.control-btn{font-size:12px;padding:5px 10px}.file-labels-bottom{margin-left:25px}.chess-game-layout{gap:5px}.left-panel-column{flex:0 0 auto}}@keyframes piece-move{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.piece.moving{animation:piece-move .3s ease}.play-online-container{margin:0 auto;max-width:1500px;padding:5px}.connection-status{background:#fff;border-radius:20px;box-shadow:0 2px 8px #0000001a;padding:5px 10px;position:fixed;right:20px;top:20px;z-index:1000}.connected{color:#4caf50;font-weight:700}.disconnected{color:#f44336;font-weight:700}.error-banner{background-color:#ffebee;border-left:4px solid #c62828;border-radius:8px;color:#c62828;margin:20px 0;padding:5px}.game-setup-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:5px;padding:5px}.game-setup-section h3{color:#333;margin-bottom:5px;margin-top:0}.game-select{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:16px;padding:5px;width:100%}.game-select:hover{border-color:#4caf50}.waiting-room{animation:pulse 2s infinite;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;margin-top:5px;padding:5px;text-align:center}@keyframes pulse{0%,to{opacity:1}50%{opacity:.9}}.waiting-room h3{font-size:24px;margin-top:0}.room-code-display{align-items:center;background:#fff3;border-radius:8px;display:flex;gap:5px;justify-content:center;margin:20px 0;padding:5px}.room-code-display strong{font-family:monospace;font-size:32px;letter-spacing:4px}.copy-btn{background:#fff;border:none;border-radius:6px;color:#667eea;cursor:pointer;font-weight:700;padding:5px 10px;transition:all .3s}.copy-btn:hover{background:#f0f0f0;transform:scale(1.05)}.play-online-game{background:#f5f5f5;display:flex;flex-direction:column;height:100vh}.game-header{background:#fff;box-shadow:0 2px 4px #0000001a;justify-content:space-between;padding:5px 10px}.connection-info,.game-header{align-items:center;display:flex}.connection-info{gap:5px}.status-connected{color:#4caf50;font-weight:700}.status-disconnected{color:#f44336;font-weight:700}.room-code{align-items:center;background:#f0f0f0;border-radius:6px;display:flex;gap:10px;padding:5px 10px}.room-code strong{font-family:monospace;font-size:18px;letter-spacing:2px}.copy-btn-small{background:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:5px 10px;transition:background .3s}.copy-btn-small:hover{background:#0b7dda}.turn-indicator{text-align:center}.your-turn{animation:blink 1s infinite;background:#4caf50;border-radius:20px;color:#fff;display:inline-block;font-size:14px;font-weight:700;padding:5px 10px}@keyframes blink{0%,to{opacity:1}50%{opacity:.7}}.opponent-turn{background:#ff9800;border-radius:20px;display:inline-block;font-size:14px}.leave-game-btn,.opponent-turn{color:#fff;font-weight:700;padding:5px 10px}.leave-game-btn{background:#f44336;border:none;border-radius:6px;cursor:pointer;transition:background .3s}.leave-game-btn:hover{background:#d32f2f}.game-content{display:flex;flex:1 1;gap:5px;overflow:auto;padding:5px}.center-panel{align-items:center;display:flex;flex:1 1;justify-content:center}.side-panel{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow-y:auto;padding:5px;width:400px}@media (max-width:1024px){.game-content{flex-direction:column}.side-panel{width:100%}}@media (max-width:768px){.game-header{gap:5px;padding:5px}.game-header,.room-code-display{flex-direction:column}.waiting-room{padding:5px}.room-code-display strong{font-size:24px}}.color-scheme-selector-wrapper{align-items:center;display:flex;gap:15px}.save-color-scheme-btn{background-color:#4caf50;border:none;border-radius:4px;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;font-size:14px;font-weight:700;padding:8px 16px;transition:all .2s;white-space:nowrap}.save-color-scheme-btn:hover{background-color:#45a049;box-shadow:0 4px 6px #00000026;transform:translateY(-1px)}.save-color-scheme-btn:active{box-shadow:0 2px 4px #0000001a;transform:translateY(0)}.color-scheme-dropdown-container{align-items:center;display:flex;flex:1 1;gap:15px}.color-scheme-select{background-color:#fff;border:2px solid #4caf50;border-radius:4px;color:#333;cursor:pointer;font-size:14px;font-weight:700;min-width:200px;padding:8px 12px;transition:all .2s}.color-scheme-select:hover{background-color:#f0f0f0}.color-scheme-select:focus{box-shadow:0 0 0 3px #4caf504d;outline:none}.color-preview-container{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.color-preview-item{align-items:center;background-color:#f5f5f5;border:2px solid #0000;border-radius:6px;cursor:pointer;display:flex;padding:4px;position:relative;transition:all .2s}.color-preview-item:hover{background-color:#e8f5e9;border-color:#4caf50;transform:scale(1.05)}.color-preview-item.selected{background-color:#e3f2fd;border-color:#2196f3;box-shadow:0 0 0 2px #2196f34d}.color-preview-boxes{display:flex;gap:2px}.color-preview-box{border:1px solid #333;border-radius:3px;box-shadow:0 1px 2px #0003;height:20px;width:20px}.delete-scheme-btn{align-items:center;background-color:#f44336;border:2px solid #fff;border-radius:50%;color:#fff;cursor:pointer;display:none;font-size:14px;font-weight:700;height:18px;justify-content:center;line-height:1;padding:0;position:absolute;right:-6px;top:-6px;transition:all .2s;width:18px}.color-preview-item:hover .delete-scheme-btn{display:flex}.delete-scheme-btn:hover{background-color:#d32f2f;transform:scale(1.1)}.save-dialog-overlay{align-items:center;animation:fadeIn .2s;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.save-dialog{animation:slideUp .3s;background-color:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:450px;min-width:400px;padding:25px}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.save-dialog h3{color:#333;font-size:20px;margin:0 0 20px;text-align:center}.color-preview-save{gap:10px;margin-bottom:20px}.color-box,.color-preview-save{display:flex;justify-content:center}.color-box{align-items:flex-end;border:2px solid #333;border-radius:8px;box-shadow:0 2px 8px #00000026;height:100px;padding-bottom:8px;width:100px}.color-box span{background-color:#ffffffe6;border-radius:4px;color:#333;font-size:12px;font-weight:700;padding:2px 8px}.scheme-name-input{border:2px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:14px;margin-bottom:15px;padding:12px;transition:border-color .2s;width:100%}.scheme-name-input:focus{border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a;outline:none}.error-message{background-color:#ffebee;border-left:4px solid #f44336;border-radius:4px;color:#f44336;font-size:13px;margin-bottom:15px;padding:8px}.save-dialog-actions{display:flex;gap:10px;justify-content:flex-end;margin-bottom:10px}.btn-cancel,.btn-save{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:700;padding:10px 20px;transition:all .2s}.btn-cancel{background-color:#e0e0e0;color:#333}.btn-cancel:hover{background-color:#d0d0d0}.btn-save{background-color:#4caf50;color:#fff}.btn-save:hover{background-color:#45a049}.scheme-count-info{color:#666;font-size:12px;font-style:italic;text-align:center}.success-toast{animation:slideInRight .3s,fadeOut .5s 2.5s;background-color:#4caf50;border-radius:8px;bottom:30px;box-shadow:0 4px 12px #0000004d;color:#fff;font-weight:700;padding:15px 25px;position:fixed;right:30px;z-index:10001}@keyframes slideInRight{0%{opacity:0;transform:translateX(400px)}to{opacity:1;transform:translateX(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@media (max-width:768px){.color-scheme-selector-wrapper{align-items:flex-start;flex-direction:column;gap:10px}.color-scheme-dropdown-container{flex-direction:column;width:100%}.color-scheme-select{width:100%}.save-dialog{margin:20px;min-width:90%}.color-preview-save{align-items:center;flex-direction:column}.color-box{width:120px}}.ai-settings-container{background:#fff;font-family:Arial,sans-serif;margin:0 auto;max-width:1312px;min-height:100vh;padding:10px}.settings-content{grid-gap:12px;display:grid;gap:12px;grid-template-columns:640px 640px;justify-content:center}.settings-section{background-color:#fff;border:2px solid #000;border-radius:10px;box-shadow:0 2px 8px #0000001a;padding:10px}.settings-section.full-width-section{grid-column:1/-1;justify-self:center;max-width:640px}.settings-section.compact-section{padding:7px}.settings-section h2{border-bottom:2px solid #4caf50;color:#333;font-size:22px;margin:0 0 7px;padding-bottom:4px}.settings-section.compact-section h2{margin:0 0 4px;padding-bottom:3px}.section-description{color:#666;font-size:15px;font-style:italic;font-weight:700;margin:0 0 9px}.difficulty-buttons{display:flex;flex-wrap:wrap;gap:7px}.compact-section .difficulty-buttons{gap:5px}.difficulty-btn{background-color:#fff;border:2px solid #ddd;border-radius:8px;color:#333;cursor:pointer;font-size:15px;font-weight:700;padding:7px 18px;transition:all .2s}.compact-section .difficulty-btn{padding:5px 14px}.difficulty-btn:hover{box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.difficulty-btn.active{background-color:#4caf50;border-color:#4caf50;color:#fff}.engine-selector{display:flex;gap:12px;justify-content:center;margin:10px 0}.engine-btn{align-items:center;background-color:#fff;border:2px solid #ddd;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;min-width:120px;padding:12px 20px;transition:all .2s}.engine-btn:hover{border-color:#888;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.engine-btn.active{background-color:#e8f5e9;border-color:#4caf50}.engine-btn.active .engine-name{color:#2e7d32}.engine-icon{font-size:28px;margin-bottom:4px}.engine-name{color:#333;font-size:16px;font-weight:700}.engine-desc{color:#666;font-size:11px;margin-top:2px}.collapsible-header{align-items:center;display:flex;justify-content:space-between;transition:color .2s}.collapsible-header:hover{color:#4caf50}.settings-section .time-control+.time-control{margin-top:12px}.weight-control{margin-bottom:9px}.weight-control label{align-items:center;color:#333;display:flex;font-size:15px;font-weight:700;justify-content:space-between;margin-bottom:3px}.weight-value{background-color:#4caf50;border-radius:4px;color:#fff;font-size:15px;font-weight:700;padding:2px 7px}.weight-control input[type=range]{-webkit-appearance:none;background:#ddd;border-radius:4px;height:8px;outline:none;width:100%}.weight-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#4caf50;border-radius:50%;cursor:pointer;height:20px;-webkit-transition:all .2s;transition:all .2s;width:20px}.weight-control input[type=range]::-webkit-slider-thumb:hover{background:#45a049;transform:scale(1.2)}.weight-control input[type=range]::-moz-range-thumb{background:#4caf50;border:none;border-radius:50%;cursor:pointer;height:20px;-moz-transition:all .2s;transition:all .2s;width:20px}.weight-control input[type=range]::-moz-range-thumb:hover{background:#45a049;transform:scale(1.2)}.checkbox-control{background-color:#f9f9f9;border:2px solid #ddd;border-radius:8px;margin-bottom:9px;padding:7px}.checkbox-control label{align-items:center;color:#333;cursor:pointer;display:flex;font-size:15px;font-weight:700;gap:7px}.checkbox-control input[type=checkbox]{accent-color:#4caf50;cursor:pointer;height:18px;width:18px}.checkbox-control span{flex:1 1}.feature-description{color:#666;font-size:15px;font-style:italic;font-weight:700;margin:3px 0 0 25px}.time-control label{align-items:center;color:#333;display:flex;font-size:15px;font-weight:700;justify-content:space-between;margin-bottom:4px}.compact-section .time-control label{margin-bottom:3px}.time-value{background-color:#2196f3;border-radius:4px;color:#fff;font-size:15px;font-weight:700;padding:2px 7px}.time-control input[type=range]{-webkit-appearance:none;background:#ddd;border-radius:4px;height:7px;margin-bottom:4px;outline:none;width:100%}.compact-section .time-control input[type=range]{margin-bottom:3px}.time-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#2196f3;border-radius:50%;cursor:pointer;height:20px;-webkit-transition:all .2s;transition:all .2s;width:20px}.time-control input[type=range].at-max-value::-webkit-slider-thumb{background:#f44336}.time-control input[type=range]::-webkit-slider-thumb:hover{background:#1976d2;transform:scale(1.2)}.time-control input[type=range].at-max-value::-webkit-slider-thumb:hover{background:#d32f2f}.time-control input[type=range]::-moz-range-thumb{background:#2196f3;border:none;border-radius:50%;cursor:pointer;height:20px;-moz-transition:all .2s;transition:all .2s;width:20px}.time-control input[type=range].at-max-value::-moz-range-thumb{background:#f44336}.time-control input[type=range]::-moz-range-thumb:hover{background:#1976d2;transform:scale(1.2)}.time-control input[type=range].at-max-value::-moz-range-thumb:hover{background:#d32f2f}.time-control input[type=range].high-threads::-webkit-slider-thumb{background:#9c27b0}.time-control input[type=range].high-threads::-webkit-slider-thumb:hover{background:#7b1fa2}.time-control input[type=range].high-threads::-moz-range-thumb{background:#9c27b0}.time-control input[type=range].high-threads::-moz-range-thumb:hover{background:#7b1fa2}.time-markers{color:#666;display:flex;font-size:15px;font-weight:700;justify-content:space-between;padding:0 4px}.compact-section .time-markers{padding:0 3px}.priority-list{display:flex;flex-direction:column;gap:5px}.priority-item{align-items:center;background-color:#f9f9f9;border:2px solid #ddd;border-radius:8px;display:flex;gap:7px;padding:7px;transition:all .2s}.priority-item:hover{background-color:#f0f0f0;border-color:#4caf50}.priority-rank{align-items:center;background-color:#4caf50;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:15px;font-weight:700;height:27px;justify-content:center;width:27px}.priority-label{color:#333;flex:1 1;font-size:15px;font-weight:700}.priority-controls{display:flex;gap:4px}.priority-btn{align-items:center;background-color:#fff;border:2px solid #ddd;border-radius:4px;color:#666;cursor:pointer;display:flex;font-size:15px;font-weight:700;height:25px;justify-content:center;transition:all .2s;width:25px}.priority-btn:hover:not(:disabled){background-color:#4caf50;border-color:#4caf50;color:#fff;transform:scale(1.1)}.priority-btn:disabled{cursor:not-allowed;opacity:.3}.priority-btn:active:not(:disabled){transform:scale(.95)}@media (max-width:1024px){.settings-content{grid-template-columns:1fr}}@media (max-width:768px){.ai-settings-container,.settings-section{padding:10px}.settings-section h2{font-size:20px}.difficulty-buttons{flex-direction:column}.difficulty-btn{width:100%}.priority-item{flex-wrap:wrap}.priority-label{margin-top:5px;width:100%}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.settings-section{animation:fadeIn .3s ease-in}.config-profiles-section{background:#fff;border:3px solid #4caf50;border-radius:8px;grid-column:1/-1;margin-bottom:15px;max-width:100%;padding:15px}.config-profiles-section h2{border-bottom:3px solid #4caf50;color:#333;font-size:18px;margin:0 0 5px;padding-bottom:8px}.config-profiles-section .section-description{color:#666;font-size:13px;font-style:normal;font-weight:400;margin:0 0 12px}.config-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:15px}.config-btn{align-items:center;border:2px solid #0000;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:700;gap:6px;padding:8px 16px;transition:all .2s}.config-btn:disabled{cursor:not-allowed;opacity:.5}.config-btn .btn-icon{font-size:14px}.config-btn-save{background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff}.config-btn-save:hover:not(:disabled){box-shadow:0 4px 8px #4caf504d;transform:translateY(-2px)}.config-btn-load{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.config-btn-load:hover:not(:disabled){box-shadow:0 4px 8px #ff98004d;transform:translateY(-2px)}.config-btn-import{background:linear-gradient(135deg,#9c27b0,#7b1fa2);color:#fff}.config-btn-import:hover:not(:disabled){box-shadow:0 4px 8px #9c27b04d;transform:translateY(-2px)}.saved-configs-list{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));max-height:200px;overflow-y:auto}.saved-config-item{align-items:center;background:#f9f9f9;border:2px solid #ddd;border-radius:6px;display:flex;justify-content:space-between;padding:8px 12px;transition:all .2s}.saved-config-item:hover{background:#f0f0f0;border-color:#4caf50}.config-info{align-items:center;display:flex;flex:1 1;flex-direction:row;gap:12px;margin-right:15px;min-width:0}.config-name{color:#333;font-size:14px;font-weight:700;white-space:nowrap}.config-desc{background:#e0e0e0;border-radius:3px;color:#666;font-size:12px;font-weight:600;max-width:150px;overflow:hidden;padding:2px 6px;text-overflow:ellipsis;white-space:nowrap}.config-date{color:#999;font-size:11px;white-space:nowrap}.config-item-actions{display:flex;flex-shrink:0;gap:6px}.config-item-btn{border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;transition:all .2s}.config-item-btn.load{background:#2196f3;color:#fff}.config-item-btn.load:hover{background:#1976d2}.config-item-btn.export{background:#607d8b;color:#fff;padding:6px 8px}.config-item-btn.export:hover{background:#455a64}.config-item-btn.delete{background:#f44336;color:#fff;padding:6px 8px}.config-item-btn.delete:hover{background:#d32f2f}.show-all-configs-checkbox{align-items:center;color:#555;cursor:pointer;display:flex;font-size:13px;gap:8px;margin-top:8px;padding:6px 12px}.show-all-configs-checkbox input[type=checkbox]{cursor:pointer;height:16px;width:16px}.show-all-configs-checkbox span{-webkit-user-select:none;user-select:none}.no-configs-message{background:#f9f9f9;border:2px dashed #ddd;border-radius:8px;color:#666;font-style:italic;padding:20px;text-align:center}.config-dialog-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.config-dialog{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:450px;padding:24px;width:90%}.config-dialog-load{max-width:550px}.config-dialog h3{border-bottom:2px solid #4caf50;color:#333;font-size:20px;margin:0 0 16px;padding-bottom:10px}.config-dialog-subtitle{color:#666;font-size:14px;margin-bottom:16px}.config-dialog-field{margin-bottom:16px}.config-dialog-field label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:6px}.config-dialog-field input,.config-dialog-field textarea{border:2px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.config-dialog-field input:focus,.config-dialog-field textarea:focus{border-color:#4caf50;outline:none}.config-dialog-field textarea{min-height:60px;resize:vertical}.config-dialog-error{background:#ffebee;border:1px solid #ffcdd2;border-radius:6px;color:#c62828;font-size:14px;margin-bottom:16px;padding:10px 12px}.config-dialog-success{background:#e8f5e9;border:1px solid #c8e6c9;border-radius:6px;color:#2e7d32;font-size:15px;margin-bottom:16px;padding:16px;text-align:center}.config-dialog-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.config-dialog-btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.config-dialog-btn.cancel{background:#f5f5f5;color:#666}.config-dialog-btn.cancel:hover{background:#e0e0e0}.config-dialog-btn.save{background:#4caf50;color:#fff}.config-dialog-btn.save:hover:not(:disabled){background:#388e3c}.config-dialog-btn.save:disabled{background:#ccc;cursor:not-allowed}.config-dialog-list{margin-bottom:16px;max-height:300px;overflow-y:auto}.config-dialog-item{border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;margin-bottom:8px;padding:12px;transition:all .2s}.config-dialog-item:hover{background:#f9fff9;border-color:#4caf50}.config-dialog-item-info{display:flex;flex-direction:column;gap:4px}.config-dialog-item-name{color:#333;font-size:15px;font-weight:700}.config-dialog-item-desc{color:#666;font-size:13px;font-style:italic}.config-dialog-item-meta{color:#666;font-size:12px}@media (max-width:768px){.config-actions{flex-direction:column}.config-btn{justify-content:center;width:100%}.saved-configs-list{grid-template-columns:1fr}.saved-config-item{align-items:flex-start;flex-direction:column;gap:8px}.config-info{margin-right:0}.config-item-actions{align-self:flex-end}}.leaderboard-container{background:linear-gradient(135deg,#f0f4f8,#e2e8f0);color:#1a202c;margin:0 auto;max-width:1400px;min-height:100vh;padding:10px}.leaderboard-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.stat-card{background:#fff;border:3px solid #9333ea;border-radius:12px;box-shadow:0 2px 4px #0000000d;padding:10px;text-align:center;transition:all .3s ease}.stat-card:hover{border-color:orange;box-shadow:0 8px 16px #0000001a;transform:translateY(-5px)}.stat-value{color:orange;font-size:1.6rem;font-weight:700;margin-bottom:3px}.stat-label{color:#718096;font-size:12.8px;font-weight:700;letter-spacing:1px;text-transform:uppercase}.leaderboard-table-container{background:#fff;border:3px solid #9333ea;border-radius:12px;box-shadow:0 4px 16px #00000014;overflow:hidden}.leaderboard-table{border-collapse:collapse;width:100%}.leaderboard-table thead{background:linear-gradient(135deg,orange,#ff8c00);border-bottom:3px solid #ff8c00}.leaderboard-table th{color:#fff;font-size:16px;font-weight:700;letter-spacing:1px;padding:15px;text-align:left;text-transform:uppercase}.sortable-header{cursor:pointer;position:relative;transition:all .2s ease;-webkit-user-select:none;user-select:none}.sortable-header:hover{background:#fff3;text-shadow:0 0 8px #0003}.sortable-header:active{transform:scale(.98)}.sort-icon{display:inline-block;font-size:16px;font-weight:700;margin-left:8px;transition:all .2s ease}.sort-icon.inactive{color:#00f;opacity:1}.sort-icon.active{color:#000;font-size:20px;font-weight:800;opacity:1;text-shadow:0 0 5px #0000004d}.player-row{border-bottom:1px solid #e2e8f0;transition:all .3s ease}.player-row:hover{background:#fffaf0;transform:scale(1.005)}.player-row:nth-child(2n){background:#f7fafc}.player-row:nth-child(2n):hover{background:#fffaf0}.leaderboard-table td{color:#2d3748;font-size:16px;font-weight:700;padding:15px}.rank-cell{font-size:1.1rem;font-weight:700}.rank-number{align-items:center;display:inline-flex;gap:5px}.player-cell{min-width:200px}.player-info{gap:12px}.player-avatar,.player-info{align-items:center;display:flex}.player-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #e2e8f0;border-radius:50%;color:#fff;font-size:1.2rem;font-weight:700;height:40px;justify-content:center;width:40px}.player-names{display:flex;flex-direction:column}.player-display-name{color:#2d3748;font-weight:600}.player-username{color:#2d3748;font-size:16px;font-weight:700}.rating-cell{color:orange;font-size:1.1rem;font-weight:700}.peak-cell{color:#718096;font-weight:500}.games-cell{color:#4a5568;font-weight:500}.win-cell .win{color:#48bb78;font-weight:600}.lose-cell .loss{color:#f56565;font-weight:600}.draw-cell .draw{color:#718096;font-weight:600}.winrate-cell{color:#4299e1;font-weight:600}.variant-cell{color:#9f7aea}.lastgame-cell,.variant-cell{font-size:16px;font-weight:700}.lastgame-cell{color:#718096}.leaderboard-loading{color:#718096;font-size:1.5rem;padding:100px 20px;text-align:center}.leaderboard-empty{background:#fff;border:2px solid #e2e8f0;border-radius:12px;margin:20px 0;padding:60px 20px;text-align:center}.leaderboard-empty h3{color:#2d3748;margin-bottom:10px}.leaderboard-empty p{color:#718096}.reset-filter-button{background:orange;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:700;margin-top:20px;padding:10px 20px;transition:all .3s ease}.reset-filter-button:hover{background:#ff8c00;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}@media (max-width:1200px){.leaderboard-table{font-size:16px}.leaderboard-table td,.leaderboard-table th{padding:10px 8px}}@media (max-width:768px){.leaderboard-table-container{overflow-x:auto}.leaderboard-table{min-width:1000px}}.rating-info-card{background:#fff;border:3px solid #4caf50;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;overflow:hidden}.rating-info-header{align-items:center;background:linear-gradient(135deg,#4caf50,#388e3c);cursor:pointer;display:flex;justify-content:space-between;padding:12px 20px;transition:all .2s ease}.rating-info-header:hover{background:linear-gradient(135deg,#66bb6a,#4caf50)}.rating-info-title{align-items:center;color:#fff;display:flex;font-size:18px;font-weight:700;gap:10px}.rating-info-icon{font-size:22px}.rating-info-toggle{color:#fff;font-size:14px;font-weight:700}.rating-info-content{background:#f8fff8;padding:20px}.rating-info-description{color:#333;font-size:15px;line-height:1.6;margin:0 0 16px}.rating-info-details{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:20px}.rating-detail-item{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:8px;display:flex;justify-content:space-between;padding:10px 14px}.rating-detail-label{color:#666;font-size:13px;font-weight:600}.rating-detail-value{color:#4caf50;font-size:14px;font-weight:700}.rating-info-types{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.rating-type-item{border-radius:8px;padding:14px}.rating-type-item.blended{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px solid #2196f3}.rating-type-item.variant{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border:2px solid #ff9800}.rating-type-item strong{color:#333;display:block;font-size:14px;margin-bottom:6px}.rating-type-item p{color:#555;font-size:13px;line-height:1.5;margin:0}.stat-card.highlight{background:linear-gradient(135deg,#f0fff0,#e8f5e9);border-color:#4caf50}.stat-card.highlight .stat-value{color:#4caf50}.stat-card.info{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-color:#2196f3}.stat-card.info .stat-label{color:#1976d2}@media (max-width:768px){.rating-info-types{grid-template-columns:1fr}.rating-info-details{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.rating-info-details{grid-template-columns:1fr}.rating-info-header{padding:10px 14px}.rating-info-title{font-size:16px}}.App{background:#fff;min-height:100vh}
/*# sourceMappingURL=main.d5b9bb64.css.map*/