.image-preloader{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#1e3c72,#2a5298);display:flex;align-items:center;justify-content:center;z-index:9999;font-family:Arial,sans-serif}.preloader-content{text-align:center;color:#fff;max-width:400px;padding:2rem}.preloader-logo{margin-bottom:1.5rem}.preloader-logo img{width:80px;height:80px;border-radius:12px;box-shadow:0 8px 32px #0000004d}.preloader-content h2{margin:0 0 .5rem;font-size:1.8rem;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.3)}.preloader-content p{margin:0 0 2rem;font-size:1rem;opacity:.9;line-height:1.5}.progress-container{margin-bottom:2rem}.progress-bar{width:100%;height:8px;background:#fff3;border-radius:4px;overflow:hidden;margin-bottom:.5rem;box-shadow:inset 0 2px 4px #0003}.progress-fill{height:100%;background:linear-gradient(90deg,#4caf50,#45a049);border-radius:4px;transition:width .3s ease;box-shadow:0 0 10px #4caf5080}.progress-text{font-size:.9rem;font-weight:600;opacity:.8}.loading-tips{margin-top:1.5rem;padding:1rem;background:#ffffff1a;border-radius:8px;border:1px solid rgba(255,255,255,.2)}.loading-tips p{margin:0;font-size:.85rem;opacity:.8}.image-preloader-simple{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;color:#fff}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid #4caf50;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.image-preloader-error{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#ff6b6b,#ee5a52);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;color:#fff;text-align:center;padding:2rem}.image-preloader-error h3{margin:0 0 1rem;font-size:1.5rem}.image-preloader-error p{margin:0 0 1.5rem;font-size:1rem;opacity:.9;max-width:400px;line-height:1.5}.image-preloader-error button{background:#fff3;border:2px solid rgba(255,255,255,.3);color:#fff;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .3s ease}.image-preloader-error button:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}@media (max-width: 480px){.preloader-content{padding:1rem;max-width:300px}.preloader-content h2{font-size:1.5rem}.preloader-logo img{width:60px;height:60px}}.image-preloader-inline{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem .5rem;background:none;border-radius:8px;box-shadow:none;width:100%;max-width:320px;margin:0 auto}.image-preloader-inline.error{color:#b00020;font-size:1rem;background:#fff0f0;border:1px solid #ffbdbd;border-radius:6px;padding:.5rem 1rem}.progress-bar{width:100%;height:8px;background:#eee;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#4caf50,#45a049);border-radius:4px;transition:width .3s ease}.progress-text{font-size:.95rem;font-weight:500;color:#333;margin-top:.25rem}.footer{background:var(--card-background);border-top:1px solid var(--border-color);margin-top:5rem;padding:2rem 0 0}.footer-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.footer-section h3{color:var(--text-color);font-size:1.2rem;font-weight:600;margin:0 0 1rem}.footer-section p{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0 0 1rem}.footer-section ul{list-style:none;padding:0;margin:0}.footer-section ul li{margin-bottom:.5rem}.footer-section ul li a,.footer-section ul li button{color:var(--text-secondary);text-decoration:none;font-size:.9rem;transition:color .3s ease;background:none;border:none;cursor:pointer;padding:0;font-family:inherit}.footer-section ul li a:hover,.footer-section ul li button:hover{color:var(--accent-color)}.social-links{display:flex;gap:1rem;margin-top:1rem}.social-link{color:var(--text-secondary);text-decoration:none;font-size:.9rem;transition:color .3s ease}.social-link:hover{color:var(--accent-color)}.footer-expandable{max-width:1200px;margin:0 auto;padding:0 2rem}.expandable-section{background:var(--background-color-secondary);border-radius:12px;padding:2rem;margin:1rem 0;border:1px solid var(--border-color);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.expandable-section h4{color:var(--text-color);font-size:1.1rem;font-weight:600;margin:0 0 1.5rem}.expandable-section p{color:var(--text-secondary);font-size:.9rem;line-height:1.6;margin:0 0 1rem}.expandable-section p:last-child{margin-bottom:0}.faq-item,.troubleshooting-item{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.faq-item:last-child,.troubleshooting-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.faq-item h5,.troubleshooting-item h5{color:var(--text-color);font-size:1rem;font-weight:600;margin:0 0 .5rem}.faq-item p,.troubleshooting-item p{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.footer-bottom{background:var(--background-color-secondary);border-top:1px solid var(--border-color);margin-top:2rem;padding:1.5rem 0}.footer-bottom-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-bottom-content p{color:var(--text-secondary);font-size:.9rem;margin:0}.footer-bottom-links{color:var(--text-secondary);font-size:.9rem}@media (max-width: 768px){.footer-content{grid-template-columns:1fr;gap:1.5rem;padding:0 1rem}.footer-expandable{padding:0 1rem}.expandable-section{padding:1.5rem}.footer-bottom-content{flex-direction:column;text-align:center;padding:0 1rem}}@media (max-width: 480px){.footer{padding:1.5rem 0 0}.footer-content,.footer-expandable{padding:0 1rem}.expandable-section{padding:1rem}.footer-bottom{padding:1rem 0}}:root{--primary-color: #2c3e50;--secondary-color: #34495e;--accent-color: #e74c3c;--text-color: #ecf0f1;--text-secondary: #bdc3c7;--background-color: #1a1a1a;--background-color-secondary: #383838;--card-background: #2c2c2c;--card-background-secondary: #252525;--success-color: #27ae60;--warning-color: #f39c12;--border-color: #3d3d3d;--table-background-row-primary: #1c1c1c;--table-background-row-secondary: #222222;--input-background: rgba(255, 255, 255, .05)}body{margin:0;background-color:var(--background-color);color:var(--text-color);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.App{min-height:100vh;display:flex;flex-direction:column;background-color:var(--background-color)}.main-content{flex:1;display:flex;flex-direction:column}.navbar{display:flex;justify-content:space-between;align-items:center;padding:.5rem 2rem;background-color:var(--primary-color);color:var(--text-color);box-shadow:0 2px 4px #0003;height:60px}.navbar-brand{display:flex;align-items:center;flex-shrink:0}.navbar-brand a{color:var(--text-color);text-decoration:none;display:flex;align-items:center}.navbar-logo{height:150px;width:auto;object-fit:contain}.navbar-menu{display:flex;gap:2rem}.navbar-item{position:relative}.dropdown-trigger{cursor:pointer;padding:.5rem;color:var(--text-color);text-decoration:none}.dropdown-trigger a{color:var(--text-color);text-decoration:none}.dropdown-trigger:hover>a,.dropdown-trigger:hover{color:var(--accent-color)}.dropdown-menu{position:absolute;top:100%;left:0;background-color:var(--card-background);min-width:200px;box-shadow:0 4px 6px #0000004d;border-radius:4px;z-index:1000;display:none}.dropdown-menu.active,.navbar-item:hover .dropdown-menu{display:block}.dropdown-menu a{display:block;padding:.75rem 1rem;color:var(--text-color);text-decoration:none}.dropdown-menu a:hover{background-color:var(--secondary-color)}.navbar-end{display:flex;align-items:center;gap:1rem}.auth-buttons{display:flex;gap:.5rem}.button{padding:.5rem 1rem;border-radius:4px;text-decoration:none;font-weight:500;transition:all .3s ease}.button.is-light{background-color:var(--text-color);color:var(--primary-color);border:1px solid var(--border-color)}.button.is-light:hover{background-color:var(--text-secondary)}.button.is-primary{background-color:var(--accent-color);color:var(--text-color);border:none}.button.is-primary:hover{background-color:#c0392b}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:700;font-size:1.2rem;text-decoration:none;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.user-avatar:hover{box-shadow:0 4px 8px #e74c3c4d}.user-profile{display:flex;align-items:center;gap:1rem}.logout-button{padding:.5rem 1rem;background:linear-gradient(135deg,#ff6b6b,#ee5a52);color:#fff;border:none;border-radius:4px;font-weight:500;cursor:pointer;transition:all .3s ease}.logout-button:hover{background:linear-gradient(135deg,#ee5a52,#d63031);transform:translateY(-1px);box-shadow:0 4px 8px #ff6b6b4d}.text-accent{color:var(--accent-color)}.text-success{color:var(--success-color)}.text-warning{color:var(--warning-color)}.bg-card{background-color:var(--card-background);border:1px solid var(--border-color);border-radius:8px}.border{border:1px solid var(--border-color)}.deck-display{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1rem;background:var(--card-background);border-radius:8px;border:1px solid var(--border-color)}.deck-info{display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center}.deck-visual{position:relative;width:100px;height:140px}.deck-pile{position:absolute;width:100%;height:100%;border-radius:8px;background:linear-gradient(135deg,#2c3e50,#34495e);box-shadow:0 2px 4px #0000004d}.card{width:100px;height:140px;border-radius:8px;transition:transform .3s ease}.card-image{width:100%;height:100%;object-fit:cover;border-radius:8px}.card-back{width:100%;height:100%;background:linear-gradient(135deg,#e74c3c,#c0392b);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}.card-back img{width:80%;height:80%;object-fit:contain}@keyframes flipCard{0%{transform:rotateY(0)}to{transform:rotateY(180deg)}}.flip-card{animation:flipCard .6s ease-in-out}.info-link{color:var(--accent-color);text-decoration:none}body.mobile-menu-open{overflow:hidden}.navbar-desktop{display:flex}.navbar-mobile{display:none}@media (max-width: 900px){.navbar{padding:.5rem 1rem}.navbar-desktop{display:none}.navbar-mobile{display:flex}.navbar-logo{height:100px}.navbar-brand{flex:1}.navbar-burger{display:flex;flex-direction:column;justify-content:space-around;width:30px;height:25px;background:transparent;border:none;cursor:pointer;padding:0;z-index:10}.navbar-burger span{width:100%;height:3px;background:var(--text-color);border-radius:3px;transition:all .3s ease;transform-origin:center}.navbar-burger.is-active span{background:var(--accent-color)}.navbar-burger.is-active span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.navbar-burger.is-active span:nth-child(2){opacity:0}.navbar-burger.is-active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.navbar-menu-mobile-container{position:fixed;top:60px;left:0;width:100%;height:calc(100vh - 60px);background:var(--primary-color);transform:translate(-100%);transition:transform .3s ease;z-index:999;display:flex;flex-direction:column;justify-content:space-between}.navbar-menu-mobile-container.is-active{transform:translate(0)}.mobile-nav-links{flex:1;padding:2rem 1rem}.navbar-menu-mobile-container .navbar-item{margin-bottom:1rem}.navbar-menu-mobile-container .dropdown-trigger{display:flex;justify-content:space-between;align-items:center;padding:1rem;color:var(--text-color);text-decoration:none;border-bottom:1px solid var(--border-color)}.navbar-menu-mobile-container .dropdown-trigger:after{content:"▼";transition:transform .3s ease}.navbar-menu-mobile-container .dropdown-trigger.active:after{transform:rotate(180deg)}.navbar-menu-mobile-container .dropdown-menu{position:static;background:var(--card-background);box-shadow:none;border-radius:0;display:none;margin-top:.5rem}.navbar-menu-mobile-container .dropdown-menu.active{display:block}.navbar-menu-mobile-container .dropdown-menu a{padding:.75rem 2rem}.navbar-end.is-mobile{padding:1rem;border-top:1px solid var(--border-color)}.navbar-end.is-mobile .user-profile,.navbar-end.is-mobile .auth-buttons{flex-direction:column;gap:1rem;width:100%}.navbar-end.is-mobile .user-avatar{width:50px;height:50px;font-size:1.5rem}.navbar-end.is-mobile .button{width:100%;text-align:center}}@media (max-width: 600px){.navbar{padding:.5rem}.navbar-logo{height:80px}.dropdown-trigger{padding:.25rem}.dropdown-menu a{padding:.5rem .75rem}.auth-buttons,.user-profile{gap:.5rem}}@media (min-width: 901px){.navbar-burger{display:none}}.live-game-link{margin-top:7px}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem}.loading-spinner:before{content:"";width:40px;height:40px;border:3px solid var(--border-color);border-top:3px solid var(--accent-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.App{min-height:100vh}}:root{--card-scale: 1;--card-base-width: 60px;--card-base-height: 84px}body{margin:0;padding:0;font-family:Arial,sans-serif}.shoe-card-horizontal,.shoe-container img,.shoe-cards-horizontal img{transform:none!important;transform-origin:initial!important}.card-img,.card-image,.card img,.hand .card img,.dealer-area .card img,.player-area .card img,.shoe-card-horizontal,.shoe-card-item img,.card-positioner .card-image,.flip-card img,.hidden-deck img,[class*=Card] img,[class*=card] img,div[class*=Card] img,div[class*=card] img{object-fit:contain;max-width:100%;max-height:100%}.shoe-card-horizontal,.shoe-container img,.shoe-cards-horizontal img{width:18px!important;height:28px!important;object-fit:cover!important}.hand .card,.dealer-area .card,.player-area .card,.card-positioner,.hidden-deck,[class*=Card],[class*=card]{overflow:visible}.hand,.dealer-hand,.player-hand,.cards,.DealerHand,.PlayerHand,.Cards{gap:calc(4px * var(--card-scale))}
