.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #eee;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px 16px 0 0}.modal-header h2{margin:0;font-size:1.5rem}.modal-header .btn-icon{color:#fff;background:#fff3}.modal-header .btn-icon:hover{background:#ffffff4d}.success-modal{max-width:700px}.success-header{background:linear-gradient(135deg,#4caf50,#45a049)}.success-info{padding:1rem 0}.success-info h3{margin:0 0 1rem;color:#333;font-size:1.25rem}.warning-text{padding:.75rem;background:#fff3cd;border:1px solid #ffc107;border-radius:8px;color:#856404;margin-bottom:1.5rem;font-weight:500}.setup-section{margin-bottom:1.5rem}.setup-section:last-child{margin-bottom:0}.setup-section label{display:block;margin-bottom:.5rem;font-weight:600;color:#667eea;font-size:1rem}.code-block{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#f5f5f5;border:2px solid #e0e0e0;border-radius:8px;font-family:Courier New,monospace;margin-bottom:.5rem}.code-block code{flex:1;font-size:.9rem;color:#333;word-break:break-all}.code-block .btn-icon{background:#fff;color:#667eea;padding:.5rem}.code-block .btn-icon:hover{background:#667eea;color:#fff}.hint-text{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#666;margin:0}.hint-text svg{flex-shrink:0}.modal-body{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#333}.required{color:#f44336}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled,.form-group select:disabled{background:#f5f5f5;cursor:not-allowed}.error-message{padding:.75rem;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;margin-bottom:1rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #eee;background:#f9f9f9;border-radius:0 0 16px 16px}.btn-secondary{background:#fff;border:2px solid #e0e0e0;color:#666}.btn-secondary:hover{background:#f5f5f5;border-color:#ccc}.btn-primary:disabled{opacity:.7;cursor:not-allowed}@media (max-width: 640px){.modal-content{max-width:100%;border-radius:16px 16px 0 0;margin-top:auto}.modal-footer{flex-direction:column}.modal-footer button{width:100%}}.clients-container{max-width:1200px;margin:0 auto}.clients-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.clients-header h2{margin:0;color:#333;font-size:2rem}.clients-count{color:#666;margin-top:.25rem;font-size:.95rem}.clients-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#667eea}.spin{animation:spin 1s linear infinite}.api-key-alert{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;margin-bottom:1.5rem;box-shadow:0 4px 6px #0000001a}.api-key-alert strong{display:block;margin-bottom:.5rem;font-size:1.05rem}.api-key-display{display:flex;align-items:center;gap:.75rem;margin-top:.5rem;padding:.75rem;background:#fff3;border-radius:8px}.api-key-display code{flex:1;font-family:Courier New,monospace;font-size:.9rem;word-break:break-all}.clients-empty{text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d}.clients-empty svg{color:#667eea;opacity:.5;margin-bottom:1.5rem}.clients-empty h3{color:#333;margin-bottom:1.5rem}.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.client-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;transition:all .3s}.client-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.client-card-header{padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;align-items:flex-start}.client-info h3{margin:0 0 .5rem;font-size:1.25rem}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600}.status-badge.active{background:#4caf504d;color:#4caf50;background:#ffffff4d}.status-badge.inactive{background:#f443364d;color:#f44336;background:#fff3}.client-actions{display:flex;gap:.5rem}.client-card-body{padding:1.5rem}.client-field{margin-bottom:1.5rem}.client-field label{display:block;font-weight:600;color:#666;margin-bottom:.5rem;font-size:.9rem}.api-key-field{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#f5f5f5;border-radius:8px}.api-key-field code{flex:1;font-family:Courier New,monospace;font-size:.85rem;color:#666}.api-key-field code.revealed{color:#333}.api-key-actions{display:flex;gap:.25rem}.client-dates{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding-top:1rem;border-top:1px solid #eee}.client-date{display:flex;flex-direction:column;gap:.25rem}.date-label{font-size:.85rem;color:#666}.date-value{font-weight:600;color:#333}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:1rem}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.btn-icon{display:inline-flex;align-items:center;justify-content:center;padding:.5rem;border:none;background:#fff3;color:#fff;border-radius:6px;cursor:pointer;transition:all .2s}.client-card-body .btn-icon{background:#f5f5f5;color:#667eea}.btn-icon:hover{background:#ffffff4d;transform:scale(1.1)}.client-card-body .btn-icon:hover{background:#e8e8e8}.btn-danger{color:#f44336}.btn-danger.confirm{background:#f44336;color:#fff}@media (max-width: 768px){.clients-grid{grid-template-columns:1fr}.client-card-header{flex-direction:column;gap:1rem}.client-actions{width:100%;justify-content:flex-end}.client-dates{grid-template-columns:1fr}}.devices-management{padding:2rem 0}.section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.section-header h2{margin:0 0 .5rem;color:#1a1a1a}.section-description{color:#666;margin:0}.error-message{display:flex;align-items:center;gap:.75rem;padding:1rem;background-color:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;margin-bottom:1.5rem}.client-selector{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.client-selector label{font-weight:600;color:#333;white-space:nowrap}.client-selector select{flex:1;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;color:#333;background:#fff;cursor:pointer;transition:border-color .2s}.client-selector select:hover:not(:disabled){border-color:#2e7d32}.client-selector select:focus{outline:none;border-color:#2e7d32;box-shadow:0 0 0 3px #2e7d321a}.client-selector select:disabled{background:#f5f5f5;cursor:not-allowed}.btn-icon{padding:.75rem;background:transparent;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;color:#666;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icon:hover:not(:disabled){background:#f5f5f5;border-color:#2e7d32;color:#2e7d32}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.spinning{animation:spin 1s linear infinite}.devices-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:2rem}.devices-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.devices-header h3{margin:0;color:#1a1a1a}.btn-secondary{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#f5f5f5;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;font-weight:600;color:#333;cursor:pointer;transition:all .2s}.btn-secondary:hover:not(:disabled){background:#ebebeb;border-color:#2e7d32;color:#2e7d32}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#666}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:#999}.empty-state svg{color:#ccc;margin-bottom:1.5rem}.empty-state h3{margin:0 0 .5rem;color:#666}.empty-state p{margin:.5rem 0;color:#999}.empty-state .hint{max-width:500px;font-size:.9rem;color:#aaa;margin-top:1rem}.devices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.device-card{background:#fafafa;border:2px solid #e0e0e0;border-radius:12px;padding:1.5rem;transition:all .2s}.device-card:hover{border-color:#2e7d32;box-shadow:0 4px 12px #2e7d321a}.device-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.device-header svg{color:#2e7d32;flex-shrink:0}.device-header-text{display:flex;flex-direction:column;gap:.25rem;min-width:0;flex:1}.device-name{font-size:1rem;font-weight:600;color:#1a1a1a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.device-id-small{font-family:Monaco,Courier New,monospace;font-size:.75rem;color:#999}.device-id{font-family:Monaco,Courier New,monospace;font-size:.9rem;color:#666;font-weight:600}.device-info{margin-bottom:1.5rem}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.info-row .label{font-size:.9rem;color:#666;font-weight:500}.info-row .value{font-size:.9rem;color:#333;font-weight:600}.btn-danger{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:#fff;border:2px solid #d32f2f;border-radius:8px;font-size:.95rem;font-weight:600;color:#d32f2f;cursor:pointer;transition:all .2s}.btn-danger:hover:not(:disabled){background:#d32f2f;color:#fff}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.game-types-container{max-width:1200px;margin:0 auto}.game-types-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.game-types-header h2{margin:0;color:#333;font-size:2rem}.game-types-description{color:#666;margin-top:.25rem;font-size:.95rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#667eea}.loading-state p{margin-top:1rem;font-size:1.1rem}.spinner{width:48px;height:48px;border:4px solid #e0e0e0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;margin-bottom:1.5rem}.error-icon{font-size:1.5rem}.btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.game-types-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.game-type-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:1.5rem;transition:all .3s;display:flex;justify-content:space-between;align-items:center;gap:1.5rem}.game-type-card:hover{box-shadow:0 4px 16px #0000001f}.game-type-edit-form{width:100%;display:grid;gap:1rem}.game-type-edit-form .form-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.5rem}.game-type-info{display:flex;align-items:center;gap:1rem;flex:1}.game-type-icon{font-size:2rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px}.game-type-details{flex:1}.game-type-details h3{margin:0 0 .25rem;font-size:1.1rem;color:#333}.game-type-details p{margin:0 0 .5rem;color:#666;font-size:.9rem}.game-type-meta{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.game-type-id{font-family:Monaco,Courier New,monospace;font-size:.75rem;background:#f0f0f0;padding:2px 6px;border-radius:4px;color:#666}.game-type-status{font-size:.8rem;padding:2px 8px;border-radius:12px;font-weight:600}.game-type-status.enabled{background:#667eea1a;color:#667eea}.game-type-status.disabled{background:#c8c8c833;color:#999}.game-type-order{font-size:.8rem;color:#666}.game-type-actions{display:flex;gap:.5rem;align-items:center}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:2px solid #e0e0e0;background:#fff;color:#666;border-radius:8px;cursor:pointer;transition:all .2s;font-size:1.2rem;font-weight:700}.btn-icon:hover:not(:disabled){background:#667eea;color:#fff;border-color:#667eea;transform:scale(1.05)}.btn-icon:disabled{opacity:.3;cursor:not-allowed}.btn-secondary-small{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-size:.9rem;font-weight:600;color:#333;cursor:pointer;transition:all .2s}.btn-secondary-small:hover:not(:disabled){background:#f5f5f5;border-color:#667eea;color:#667eea}.btn-secondary-small:disabled{opacity:.5;cursor:not-allowed}.btn-danger-small{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:2px solid #ffcdd2;border-radius:8px;font-size:.9rem;font-weight:600;color:#d32f2f;cursor:pointer;transition:all .2s}.btn-danger-small:hover:not(:disabled){background:#ffebee;border-color:#d32f2f}.btn-danger-small:disabled{opacity:.5;cursor:not-allowed}.saving-indicator{display:flex;align-items:center}.spinner-small{width:20px;height:20px;border:2px solid #e0e0e0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;padding:2rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.modal-header h3{margin:0;font-size:1.5rem;color:#333}.close-button{background:none;border:none;font-size:2rem;cursor:pointer;color:#666;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.close-button:hover{color:#333}.modal-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.95rem;font-weight:600;color:#333}.form-group input{padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:.5rem;padding-top:1rem;border-top:2px solid #f0f0f0}.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#f5f5f5;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;font-weight:600;color:#333;cursor:pointer;transition:all .2s}.btn-secondary:hover:not(:disabled){background:#e8e8e8;border-color:#667eea;color:#667eea}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.game-types-info{margin-top:2rem}.info-box{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000d}.info-box h4{font-size:1.1rem;font-weight:600;color:#333;margin:0 0 1rem}.info-box ul{list-style:none;padding:0;margin:0}.info-box li{font-size:.95rem;color:#666;padding:.5rem 0 .5rem 1.5rem;position:relative;line-height:1.5}.info-box li:before{content:"•";position:absolute;left:.5rem;color:#667eea;font-weight:700;font-size:1.2rem}@media (max-width: 768px){.game-types-list{grid-template-columns:1fr}.game-types-header{flex-direction:column;align-items:flex-start}}.app{min-height:100vh;display:flex;flex-direction:column;background:#f5f5f5}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem;width:100%}.app-header{background:#fff;box-shadow:0 2px 8px #00000014;padding:1.5rem 0;position:sticky;top:0;z-index:100;border-bottom:3px solid #2e7d32}.header-content{display:flex;justify-content:space-between;align-items:center;gap:2rem}.app-header h1{font-size:2rem;font-weight:700;color:#2e7d32;margin:0}.subtitle{color:#666;margin-top:.25rem;font-size:1rem}.lang-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:2px solid #2e7d32;background:#fff;color:#2e7d32;border-radius:8px;font-weight:600;transition:all .2s;cursor:pointer}.lang-toggle:hover{background:#2e7d32;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #2e7d3233}.tabs-container{background:#fff;border-bottom:2px solid #e0e0e0;box-shadow:0 2px 4px #0000000d;position:sticky;top:81px;z-index:90}.tabs{display:flex;gap:.5rem;padding:0}.tab{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:transparent;border:none;border-bottom:3px solid transparent;color:#666;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;position:relative}.tab:hover{color:#2e7d32;background:#2e7d320d}.tab.active{color:#2e7d32;border-bottom-color:#2e7d32;background:#2e7d320d}.tab svg{flex-shrink:0}.app-main{flex:1;padding:3rem 0}.app-footer{background:#fff;border-top:1px solid #e0e0e0;padding:1.5rem 0;text-align:center;color:#666}@media (max-width: 768px){.app-header h1{font-size:1.5rem}.header-content{flex-direction:column;text-align:center}.lang-toggle{width:100%;justify-content:center}.tabs{flex-direction:column;gap:0}.tab{border-bottom:1px solid #e0e0e0;border-left:3px solid transparent}.tab.active{border-bottom-color:#e0e0e0;border-left-color:#2e7d32}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;color:#333;line-height:1.6}code{font-family:Courier New,Courier,monospace}button,input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#555}
