@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800;900&family=Space+Mono:wght@400;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #fdf6e3;--bg-card: #ffffff;--bg-hover: #f5edd5;--bg-input: #faf2dc;--text: #3a2e1c;--text-muted: #8a7c60;--primary: #3d8b6e;--primary-hover: #2f7059;--primary-light: rgba(61, 139, 110, .12);--accent: #c0392b;--accent-hover: #a93226;--accent-light: rgba(192, 57, 43, .1);--gold: #c9a85c;--gold-hover: #b8943f;--gold-light: rgba(201, 168, 92, .15);--success: #3d8b6e;--warning: #d4a759;--border: #e8dcc8;--shadow: 0 2px 12px rgba(58, 46, 28, .07);--shadow-lg: 0 6px 28px rgba(58, 46, 28, .1);--shadow-tile: 0 4px 12px rgba(58, 46, 28, .15), inset 0 1px 0 rgba(255,255,255,.5);--radius: 16px;--radius-sm: 10px;--radius-lg: 24px;--nav-height: 68px;--header-height: 56px;--sidebar-width: 220px;--transition: .22s ease;--transition-bounce: .35s cubic-bezier(.34, 1.56, .64, 1)}body{font-family:Nunito,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-hover)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes tileFlip{0%{transform:rotateY(-90deg) scale(.85);opacity:0}60%{transform:rotateY(10deg) scale(1.04);opacity:1}to{transform:rotateY(0) scale(1);opacity:1}}@keyframes bounce{0%{transform:scale(1)}30%{transform:scale(1.18)}60%{transform:scale(.95)}80%{transform:scale(1.06)}to{transform:scale(1)}}@keyframes floatTile{0%,to{transform:translateY(0) rotate(0)}33%{transform:translateY(-14px) rotate(3deg)}66%{transform:translateY(-6px) rotate(-2deg)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes stagger-in{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.stagger-1{animation:stagger-in .45s ease both;animation-delay:.05s}.stagger-2{animation:stagger-in .45s ease both;animation-delay:.1s}.stagger-3{animation:stagger-in .45s ease both;animation-delay:.15s}.stagger-4{animation:stagger-in .45s ease both;animation-delay:.2s}.stagger-5{animation:stagger-in .45s ease both;animation-delay:.25s}.stagger-6{animation:stagger-in .45s ease both;animation-delay:.3s}.stagger-7{animation:stagger-in .45s ease both;animation-delay:.35s}.stagger-8{animation:stagger-in .45s ease both;animation-delay:.4s}.tile{display:inline-flex;align-items:center;justify-content:center;width:36px;height:46px;background:linear-gradient(145deg,#fff9ee,#f5e8c0);border:2px solid #d4b878;border-radius:6px;box-shadow:var(--shadow-tile);font-size:1.2rem;position:relative;flex-shrink:0}.tile:after{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;border-radius:4px;border:1px solid rgba(212,184,120,.35);pointer-events:none}.tile-sm{width:26px;height:34px;font-size:.85rem;border-radius:4px}.tile-lg{width:52px;height:66px;font-size:1.7rem;border-radius:8px}.tile-row{display:flex;gap:4px;align-items:center}.app{display:flex;flex-direction:column;min-height:100vh}.top-header{position:sticky;top:0;z-index:30;background:var(--bg-card);border-bottom:1px solid var(--border);padding:0 16px;height:var(--header-height);display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 8px #3a2e1c0f}.header-left{display:flex;align-items:center;gap:10px}.logo{font-size:1.1rem;font-weight:800;color:var(--primary);letter-spacing:-.3px;display:flex;align-items:center;gap:6px}.logo-tile{font-size:1.3rem}.header-right{display:flex;align-items:center;gap:10px}.group-selector-header select{background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:5px 10px;font-size:.8rem;font-family:inherit;cursor:pointer}.header-user{display:flex;align-items:center;gap:7px}.header-user .avatar{width:30px;height:30px;border-radius:50%;border:2px solid var(--primary-light)}.header-user-name{font-size:.85rem;font-weight:600;color:var(--text)}.btn-logout{background:none;border:1px solid var(--border);color:var(--text-muted);padding:5px 12px;border-radius:8px;cursor:pointer;font-size:.78rem;font-family:inherit;font-weight:600;transition:all var(--transition)}.btn-logout:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-light)}.sidebar{width:var(--sidebar-width);background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:30;box-shadow:2px 0 16px #3a2e1c0d;overflow-y:auto}.sidebar-brand{padding:20px 18px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;text-decoration:none}.sidebar-brand-text{font-size:1.1rem;font-weight:800;color:var(--primary);letter-spacing:-.3px;line-height:1.2}.sidebar-brand-sub{font-size:.68rem;color:var(--text-muted);font-weight:600;letter-spacing:.5px;text-transform:uppercase}.sidebar-group-selector{padding:12px 16px;border-bottom:1px solid var(--border)}.sidebar-group-selector label{font-size:.7rem;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);font-weight:700;display:block;margin-bottom:5px}.sidebar-group-selector select{width:100%;background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:7px 10px;font-size:.85rem;font-family:inherit;font-weight:600;cursor:pointer}.sidebar-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px}.sidebar-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text-muted);font-size:.9rem;font-weight:600;text-decoration:none;transition:all var(--transition);position:relative;cursor:pointer}.sidebar-nav-item:hover{background:var(--bg-hover);color:var(--primary);text-decoration:none}.sidebar-nav-item.active{background:var(--primary-light);color:var(--primary)}.sidebar-nav-item.active:before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:3px;background:var(--primary);border-radius:0 3px 3px 0}.sidebar-nav-icon{font-size:1.25rem;width:28px;text-align:center;flex-shrink:0}.sidebar-nav-item.nav-record-sidebar{background:var(--accent);color:#fff;margin-top:6px;justify-content:center;font-weight:700}.sidebar-nav-item.nav-record-sidebar:hover{background:var(--accent-hover);color:#fff}.sidebar-nav-item.nav-record-sidebar.active{background:var(--accent);color:#fff}.sidebar-nav-item.nav-record-sidebar.active:before{display:none}.sidebar-footer{padding:14px 12px;border-top:1px solid var(--border)}.sidebar-user{display:flex;align-items:center;gap:10px;margin-bottom:10px}.sidebar-user .avatar{width:34px;height:34px;border-radius:50%;border:2px solid var(--primary-light);flex-shrink:0}.sidebar-user-info{min-width:0}.sidebar-user-name{font-size:.88rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:20;background:var(--bg-card);border-top:2px solid var(--border);display:flex;justify-content:space-around;align-items:stretch;height:var(--nav-height);box-shadow:0 -3px 16px #3a2e1c14;padding-bottom:env(safe-area-inset-bottom,0)}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:2px;text-decoration:none;color:var(--text-muted);font-size:.65rem;font-weight:700;letter-spacing:.02em;transition:color var(--transition);padding:6px 0;position:relative}.nav-item:hover{color:var(--primary);text-decoration:none}.nav-item.active{color:var(--primary)}.nav-item.active:before{content:"";position:absolute;top:0;left:20%;right:20%;height:3px;background:var(--primary);border-radius:0 0 4px 4px}.nav-icon{font-size:1.4rem;line-height:1}.nav-label{font-size:.62rem;font-weight:700;letter-spacing:.03em}.nav-item.nav-record .nav-icon{background:var(--accent);color:#fff;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-top:-14px;box-shadow:0 3px 14px #c0392b59;transition:transform var(--transition-bounce),box-shadow var(--transition)}.nav-item.nav-record:hover .nav-icon{animation:bounce .5s ease}.nav-item.nav-record.active .nav-icon{background:var(--primary);box-shadow:0 3px 14px #3d8b6e59}.main-content{flex:1;display:flex;flex-direction:column;padding-bottom:calc(var(--nav-height) + 16px);min-width:0}.main-content.full{padding-bottom:0}.page{padding:24px 20px;max-width:720px;margin:0 auto;width:100%;animation:fadeInUp .35s ease both}.page h2{font-size:1.55rem;font-weight:800;margin-bottom:20px;letter-spacing:-.4px;color:var(--text)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-header h2{margin-bottom:0}.subtitle{color:var(--text-muted);margin-bottom:16px;font-size:.88rem;font-weight:500}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px;box-shadow:var(--shadow);transition:box-shadow var(--transition)}.card:hover{box-shadow:var(--shadow-lg)}.card h3{font-size:1rem;margin-bottom:14px;color:var(--text);font-weight:700}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:700;cursor:pointer;border:1.5px solid var(--border);background:var(--bg-card);color:var(--text);transition:all var(--transition);font-family:inherit;text-decoration:none}.btn:hover{background:var(--bg-hover);text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover);color:#fff;text-decoration:none}.btn-accent{background:var(--accent);border-color:var(--accent);color:#fff}.btn-accent:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:#fff;text-decoration:none}.btn-record{background:var(--accent);border-color:var(--accent);color:#fff;font-size:1rem;padding:12px 28px;border-radius:var(--radius-lg);font-weight:800;letter-spacing:.02em;transition:transform var(--transition-bounce),background var(--transition),box-shadow var(--transition);box-shadow:0 4px 16px #c0392b4d}.btn-record:hover{background:var(--accent-hover);color:#fff;animation:bounce .5s ease;text-decoration:none}.btn-secondary{background:transparent;border-color:var(--border)}.btn-sm{padding:5px 12px;font-size:.8rem}.btn-icon{background:none;border:none;cursor:pointer;font-size:1.1rem;color:var(--text-muted);padding:4px 8px;border-radius:6px;transition:all var(--transition)}.btn-delete:hover{color:var(--accent);background:var(--accent-light)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border);font-size:.88rem}.table th{color:var(--text-muted);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.6px}.table tr.highlight td{background:var(--gold-light)}.table tr:last-child td{border-bottom:none}.rank{font-weight:800}.player-link{display:inline-flex;align-items:center;gap:6px;color:var(--primary);font-weight:600}.tag{color:var(--text-muted);font-size:.78rem;font-family:Space Mono,monospace;background:var(--bg-input);padding:2px 7px;border-radius:6px;font-weight:400}input,select,textarea{background:var(--bg-input);color:var(--text);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-size:.9rem;width:100%;font-family:inherit;font-weight:500;transition:border-color var(--transition),box-shadow var(--transition)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:.8rem;color:var(--text-muted);font-weight:700;letter-spacing:.3px;text-transform:uppercase}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-inline{display:flex;gap:8px;align-items:center}.form-inline input{flex:1}.error-msg{background:var(--accent-light);border:1.5px solid rgba(192,57,43,.22);color:var(--accent);padding:10px 14px;border-radius:var(--radius-sm);margin-bottom:16px;font-size:.88rem;font-weight:600}.players-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.player-slot{background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius);padding:14px;transition:border-color var(--transition)}.player-slot:focus-within{border-color:var(--primary)}.player-slot label{font-size:.75rem;color:var(--text-muted);margin-bottom:6px;display:block;font-weight:700;letter-spacing:.3px;text-transform:uppercase}.player-slot select{margin-bottom:8px}.analyzing{color:var(--warning);font-size:.85rem;margin-left:8px;font-weight:600}.success-text{color:var(--success);font-size:.85rem;margin-left:8px;font-weight:600}.game-card{padding:16px 20px}.game-card-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.game-date{font-weight:700;font-size:.88rem;color:var(--text)}.badge{background:var(--primary-light);color:var(--primary);padding:3px 9px;border-radius:8px;font-size:.72rem;font-weight:700}.badge-accent{background:var(--accent-light);color:var(--accent)}.badge-gold{background:var(--gold-light);color:var(--gold-hover)}.badge-sm{background:var(--primary-light);color:var(--primary);padding:2px 7px;border-radius:6px;font-size:.68rem;font-weight:600}.game-players{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.game-player{text-align:center;padding:10px 8px;border-radius:var(--radius-sm);background:var(--bg-input);transition:background var(--transition)}.game-player.winner{background:var(--gold-light);border:1.5px solid rgba(201,168,92,.3)}.player-score{display:block;font-size:1.2rem;font-weight:800;margin:4px 0;color:var(--text)}.player-tag-sm{display:block;font-size:.7rem;color:var(--text-muted);font-family:Space Mono,monospace}.crown{display:inline-block;background:var(--gold);color:#fff;font-size:.62rem;font-weight:800;padding:2px 6px;border-radius:4px;margin-top:4px;letter-spacing:.5px}.game-detail,.game-notes{margin-top:10px;font-size:.85rem;color:var(--text-muted);font-weight:500}.game-image{margin-top:10px}.game-image img{max-width:200px;border-radius:var(--radius-sm);cursor:pointer}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:20px}.page-info{color:var(--text-muted);font-size:.82rem;font-weight:600}.stat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px}.stat-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);padding:14px;text-align:center;box-shadow:var(--shadow);animation:tileFlip .5s ease both;transition:transform var(--transition),box-shadow var(--transition)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-value{font-size:1.65rem;font-weight:800;color:var(--primary)}.stat-label{font-size:.68rem;color:var(--text-muted);margin-top:2px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.player-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding:20px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.back-link{display:inline-flex;align-items:center;gap:5px;margin-bottom:14px;font-size:.85rem;color:var(--text-muted);font-weight:600;transition:color var(--transition)}.back-link:hover{color:var(--primary)}.highlight-text{font-size:1.3rem;font-weight:800;color:var(--gold)}.category-grid{display:grid;gap:4px}.category-item{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--border)}.category-item:last-child{border-bottom:none}.category-name{font-weight:700;min-width:130px;font-size:.9rem}.category-stats{font-size:.78rem;color:var(--text-muted);min-width:130px;display:flex;gap:10px;font-weight:500}.category-bar{flex:1;height:6px;background:var(--bg-input);border-radius:3px;overflow:hidden}.category-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--gold));border-radius:3px;transition:width .6s ease}.recent-games-list{display:flex;flex-direction:column;gap:6px}.recent-game{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:var(--radius-sm);background:var(--bg-input);transition:background var(--transition)}.recent-game.won{border-left:3px solid var(--success)}.recent-game.lost{border-left:3px solid var(--text-muted)}.game-date-sm{font-size:.78rem;color:var(--text-muted);min-width:60px;font-weight:500}.game-score-sm{font-weight:700;min-width:60px}.result-badge{font-size:.68rem;font-weight:800;padding:2px 7px;border-radius:5px;margin-left:auto}.result-badge.win{background:var(--primary-light);color:var(--primary)}.result-badge.loss{background:var(--bg-input);color:var(--text-muted)}.player-card{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;transition:box-shadow var(--transition),transform var(--transition)}.player-card:hover{transform:translate(2px)}.player-card-info{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.player-name-link{font-weight:700;font-size:.95rem;color:var(--primary)}.joined{font-size:.78rem;color:var(--text-muted);font-weight:500}.edit-inline{display:flex;gap:6px;align-items:center}.edit-inline input{width:160px}.invite-section{margin-bottom:18px}.invite-section h4{margin-bottom:8px;font-size:.9rem;font-weight:700}.invite-code{background:var(--bg-input);padding:5px 11px;border-radius:6px;font-family:Space Mono,monospace;font-size:.95rem;margin-right:8px}.invite-result{margin-top:10px;padding:12px;background:var(--bg-input);border-radius:var(--radius-sm);border:1px solid var(--border)}.hint{font-size:.78rem;color:var(--text-muted);margin-top:4px;font-weight:500}.members-list{display:flex;flex-direction:column;gap:4px}.member-item{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--border);transition:background var(--transition)}.member-item:last-child{border-bottom:none}.member-name{font-weight:600;min-width:120px}.groups-list{display:flex;flex-direction:column;gap:4px}.group-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition)}.group-item:hover{background:var(--bg-hover)}.group-item.active{background:var(--primary-light);border-left:3px solid var(--primary)}.group-name{font-weight:700}.member-count{font-size:.78rem;color:var(--text-muted);font-weight:500}.chart-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.chart-half{min-width:0}.login-page{display:flex;min-height:100vh;background:var(--bg);position:relative;overflow:hidden}.login-tiles-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.login-tile-float{position:absolute;font-size:2.5rem;opacity:.12;animation:floatTile linear infinite;-webkit-user-select:none;user-select:none}.login-tile-float:nth-child(1){left:5%;top:10%;animation-duration:7s;font-size:3rem}.login-tile-float:nth-child(2){left:15%;top:65%;animation-duration:9s;font-size:2rem;animation-delay:1s}.login-tile-float:nth-child(3){left:25%;top:30%;animation-duration:6s;animation-delay:2s}.login-tile-float:nth-child(4){left:70%;top:15%;animation-duration:8s;animation-delay:.5s;font-size:2rem}.login-tile-float:nth-child(5){left:80%;top:55%;animation-duration:7s;animation-delay:1.5s;font-size:3rem}.login-tile-float:nth-child(6){left:90%;top:80%;animation-duration:10s;animation-delay:.3s}.login-tile-float:nth-child(7){left:45%;top:75%;animation-duration:8s;animation-delay:2.5s;font-size:2rem}.login-tile-float:nth-child(8){left:55%;top:5%;animation-duration:6s;animation-delay:1s;font-size:2rem}.login-main{display:flex;align-items:center;justify-content:center;flex:1;padding:32px 20px;position:relative;z-index:1}.login-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:48px 44px;text-align:center;max-width:420px;width:100%;box-shadow:var(--shadow-lg);animation:fadeInUp .5s ease both}.login-tiles-row{display:flex;justify-content:center;gap:5px;margin-bottom:20px}.login-card h1{font-size:2rem;color:var(--text);margin-bottom:6px;font-weight:900;letter-spacing:-.5px}.login-card h1 span{color:var(--primary)}.login-card .tagline{color:var(--text-muted);margin-bottom:32px;font-size:.94rem;font-weight:500}.login-button-wrapper{display:flex;justify-content:center;margin-bottom:16px}.login-divider{color:var(--text-muted);font-size:.8rem;margin:14px 0;font-weight:600;position:relative}.login-divider:before,.login-divider:after{content:"";position:absolute;top:50%;width:38%;height:1px;background:var(--border)}.login-divider:before{left:0}.login-divider:after{right:0}.btn-dev-login{width:100%;padding:10px 20px;background:transparent;color:var(--text-muted);border:1.5px solid var(--border);border-radius:10px;cursor:pointer;font-size:.85rem;font-family:inherit;font-weight:600;transition:all var(--transition)}.btn-dev-login:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.avatar{width:28px;height:28px;border-radius:50%}.avatar-sm{width:22px;height:22px;border-radius:50%;margin-right:4px;vertical-align:middle}.avatar-lg{width:60px;height:60px;border-radius:50%;border:3px solid var(--primary-light);box-shadow:0 2px 10px #3d8b6e33}.wrapped-page{max-width:720px}.wrapped-player-selector{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.wrapped-cards{display:flex;flex-direction:column;gap:16px}.wrapped-card{border-radius:var(--radius-lg);padding:36px 28px;color:#fff;text-align:center;min-height:190px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);animation:tileFlip .55s ease both}.wrapped-card:nth-child(1){animation-delay:.05s}.wrapped-card:nth-child(2){animation-delay:.1s}.wrapped-card:nth-child(3){animation-delay:.15s}.wrapped-card:nth-child(4){animation-delay:.2s}.wrapped-card:nth-child(5){animation-delay:.25s}.wrapped-card:nth-child(6){animation-delay:.3s}.wrapped-card:nth-child(7){animation-delay:.35s}.wrapped-card:nth-child(8){animation-delay:.4s}.wrapped-card-content{width:100%}.wrapped-card h3{font-size:1.4rem;margin-bottom:4px;color:#fff;font-weight:800}.wrapped-tag{font-family:Space Mono,monospace;opacity:.75;font-size:.88rem}.wrapped-big-number{font-size:3.8rem;font-weight:900;line-height:1.1;margin:10px 0 6px}.wrapped-big-number.wrapped-text{font-size:2.1rem}.wrapped-medium-number{font-size:2.4rem;font-weight:800}.wrapped-stat{font-size:.9rem;opacity:.85;margin-top:4px;font-weight:500}.wrapped-row{display:flex;justify-content:center;gap:40px;margin-top:14px}.wrapped-categories{margin-top:14px;text-align:left}.wrapped-cat-item{display:flex;justify-content:space-between;padding:6px 0;font-size:.88rem;opacity:.85;border-bottom:1px solid rgba(255,255,255,.18)}.wrapped-facts{list-style:none;text-align:left}.wrapped-facts li{padding:8px 0;border-bottom:1px solid rgba(255,255,255,.18);font-size:.92rem;font-weight:500}.wrapped-facts li:last-child{border-bottom:none}.wrapped-card:nth-child(1){background:linear-gradient(135deg,#3d8b6e,#2a6b52)}.wrapped-card:nth-child(2){background:linear-gradient(135deg,#c0392b,#922b21)}.wrapped-card:nth-child(3){background:linear-gradient(135deg,#c9a85c,#9e7c2b)}.wrapped-card:nth-child(4){background:linear-gradient(135deg,#5b8db8,#3a6d96)}.wrapped-card:nth-child(5){background:linear-gradient(135deg,#8e44ad,#6c3483)}.wrapped-card:nth-child(6){background:linear-gradient(135deg,#3d8b6e,#5b8db8)}.wrapped-card:nth-child(7){background:linear-gradient(135deg,#c0392b,#8e44ad)}.wrapped-card:nth-child(8){background:linear-gradient(135deg,#5b8db8,#3d8b6e)}.loading{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:200px;color:var(--text-muted);font-size:.92rem;gap:12px;font-weight:600}.loading-spinner{font-size:2rem;animation:spin 1s linear infinite}.empty-state{text-align:center;padding:36px;color:var(--text-muted)}.empty-state p{font-weight:600;margin-bottom:12px}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.hub-page{padding:24px 20px;max-width:760px;margin:0 auto;width:100%}.hub-greeting{background:linear-gradient(135deg,var(--primary) 0%,#2a6b52 100%);border-radius:var(--radius-lg);padding:24px;color:#fff;margin-bottom:20px;display:flex;align-items:center;gap:18px;box-shadow:0 6px 24px #3d8b6e40;animation:slideInLeft .45s ease both;position:relative;overflow:hidden}.hub-greeting:after{content:"🀄";position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:3.5rem;opacity:.15}.hub-greeting-avatar{width:60px;height:60px;border-radius:50%;border:3px solid rgba(255,255,255,.4);flex-shrink:0}.hub-greeting-avatar-placeholder{width:60px;height:60px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0}.hub-greeting-text h2{font-size:1.4rem;font-weight:800;margin-bottom:2px;color:#fff}.hub-greeting-text p{opacity:.85;font-size:.9rem;font-weight:500}.hub-greeting-tag{font-family:Space Mono,monospace;opacity:.7;font-size:.8rem;margin-top:2px}.hub-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.hub-stat-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);padding:16px;text-align:center;box-shadow:var(--shadow);animation:tileFlip .5s ease both;transition:transform var(--transition),box-shadow var(--transition);cursor:default}.hub-stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.hub-stat-value{font-size:2rem;font-weight:800;color:var(--primary);line-height:1.1}.hub-stat-label{font-size:.68rem;color:var(--text-muted);margin-top:4px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.hub-stat-icon{font-size:1.3rem;margin-bottom:6px}.hub-section-title{font-size:.8rem;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:6px}.hub-cards-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}.hub-nemesis-card{background:linear-gradient(135deg,var(--accent) 0%,#922b21 100%);border-radius:var(--radius);padding:18px;color:#fff;box-shadow:0 4px 16px #c0392b38;animation:slideInRight .45s ease both;animation-delay:.1s}.hub-nemesis-card h4{font-size:.72rem;text-transform:uppercase;letter-spacing:.6px;opacity:.8;margin-bottom:6px;font-weight:700}.hub-nemesis-name{font-size:1.4rem;font-weight:800;margin-bottom:2px}.hub-nemesis-sub{font-size:.82rem;opacity:.8;font-weight:500}.hub-nemesis-emoji{font-size:2rem;margin-bottom:6px}.hub-fav-card{background:linear-gradient(135deg,var(--gold) 0%,#9e7c2b 100%);border-radius:var(--radius);padding:18px;color:#fff;box-shadow:0 4px 16px #c9a85c40;animation:slideInRight .45s ease both;animation-delay:.15s}.hub-fav-card h4{font-size:.72rem;text-transform:uppercase;letter-spacing:.6px;opacity:.8;margin-bottom:6px;font-weight:700}.hub-fav-name{font-size:1.15rem;font-weight:800;margin-bottom:2px}.hub-fav-icon{font-size:2rem;margin-bottom:6px}.hub-cohorts{animation:fadeInUp .45s ease both;animation-delay:.2s}.hub-cohort-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;cursor:pointer;transition:all var(--transition)}.hub-cohort-item:hover{border-color:var(--primary);background:var(--primary-light);transform:translate(3px)}.hub-cohort-item.active{border-color:var(--primary);background:var(--primary-light)}.hub-cohort-name{font-weight:700;font-size:.95rem}.hub-cohort-meta{font-size:.78rem;color:var(--text-muted);font-weight:500}.hub-quick-actions{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap;animation:fadeInUp .45s ease both}@media(min-width:900px){.top-header{display:none}.sidebar{display:flex}.app{flex-direction:row}.main-content{margin-left:var(--sidebar-width);padding-bottom:40px}.bottom-nav{display:none}.page{padding:32px 36px;max-width:860px}.hub-page{padding:32px 36px;max-width:900px}.hub-stats-grid,.stat-cards{grid-template-columns:repeat(4,1fr)}.chart-row{grid-template-columns:1fr 1fr}}@media(max-width:899px){.sidebar{display:none}.page{padding:20px 16px}.page h2{font-size:1.35rem}.hub-page{padding:20px 16px}.hub-stats-grid{grid-template-columns:repeat(3,1fr);gap:8px}.hub-cards-row{grid-template-columns:1fr}.stat-cards{grid-template-columns:repeat(2,1fr);gap:8px}.stat-card{padding:12px 8px}.stat-value{font-size:1.35rem}.players-grid,.form-row,.chart-row{grid-template-columns:1fr}.game-players{grid-template-columns:repeat(2,1fr)}.login-card{margin:16px;padding:36px 24px}.player-card{flex-direction:column;align-items:flex-start;gap:8px}.hub-greeting{padding:18px}.hub-greeting-text h2{font-size:1.2rem}}@media(max-width:480px){.hub-stats-grid{grid-template-columns:repeat(3,1fr);gap:6px}.hub-stat-value{font-size:1.55rem}.hub-stat-label{font-size:.6rem}}.wizard-launch-link{display:inline-flex;margin-bottom:16px;font-size:.9rem}.wizard-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);animation:fadeInUp .3s ease}.wizard-stepper{display:flex;justify-content:center;gap:4px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border)}.wizard-step{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:.78rem;font-weight:600;color:var(--text-muted);transition:all var(--transition)}.wizard-step-number{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;background:var(--bg-input);border:1.5px solid var(--border);color:var(--text-muted);transition:all var(--transition)}.wizard-step-label{display:none}.wizard-step-active{color:var(--primary)}.wizard-step-active .wizard-step-number{background:var(--primary);border-color:var(--primary);color:#fff}.wizard-step-active .wizard-step-label{display:inline}.wizard-step-completed .wizard-step-number{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.wizard-nav{display:flex;justify-content:space-between;gap:12px;margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}.wizard-nav .btn{min-width:100px;min-height:44px;justify-content:center}.wizard-body{min-height:200px}.table-setup{display:flex;flex-direction:column;gap:20px}.mahjong-table{display:grid;grid-template-areas:". top ." "left center right" ". bottom .";grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto 1fr auto;gap:8px;min-height:280px;position:relative}.seat-slot{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 8px;background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius-sm);transition:all var(--transition);min-width:0}.seat-top{grid-area:top}.seat-bottom{grid-area:bottom}.seat-left{grid-area:left}.seat-right{grid-area:right}.seat-east{border-color:var(--gold);background:var(--gold-light)}.seat-label{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;text-align:center}.seat-dealer-tag{display:inline-block;margin-left:4px;font-size:.65rem;color:var(--gold-hover);font-weight:800}.seat-add-btn{width:44px;height:44px;border-radius:50%;border:2px dashed var(--border);background:transparent;font-size:1.4rem;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);font-family:inherit}.seat-add-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.seat-filled{display:flex;align-items:center;gap:4px;flex-wrap:wrap;justify-content:center}.seat-player-name{background:none;border:none;font-family:inherit;font-size:.85rem;font-weight:700;color:var(--text);cursor:pointer;padding:4px 8px;border-radius:6px;transition:background var(--transition);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.seat-player-name:hover{background:var(--bg-hover)}.seat-east-btn{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--border);background:var(--bg-card);font-size:.7rem;font-weight:800;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);font-family:inherit}.seat-east-btn:hover{border-color:var(--gold);color:var(--gold-hover);background:var(--gold-light)}.seat-picker{position:absolute;top:100%;left:50%;transform:translate(-50%);z-index:50;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);min-width:160px;max-height:200px;overflow-y:auto;animation:fadeIn .15s ease}.seat-picker-item{display:block;width:100%;padding:10px 14px;border:none;background:none;font-family:inherit;font-size:.85rem;font-weight:600;color:var(--text);cursor:pointer;text-align:left;transition:background var(--transition);min-height:44px;display:flex;align-items:center}.seat-picker-item:hover{background:var(--bg-hover)}.seat-picker-active{color:var(--primary);background:var(--primary-light)}.seat-picker-remove{color:var(--accent);border-bottom:1px solid var(--border)}.seat-picker-remove:hover{background:var(--accent-light)}.seat-picker-empty{padding:10px 14px;font-size:.82rem;color:var(--text-muted)}.table-center{grid-area:center;display:flex;align-items:center;justify-content:center;background:var(--bg-hover);border:1.5px solid var(--border);border-radius:var(--radius-sm)}.table-center-icon{font-size:2rem;opacity:.4}.table-options{display:grid;grid-template-columns:1fr 1fr;gap:14px}.table-checkbox-label{display:flex!important;align-items:center;gap:8px;cursor:pointer;font-size:.9rem!important;color:var(--text)!important;font-weight:500!important;text-transform:none!important;letter-spacing:0!important;padding:10px 0}.table-checkbox-label input[type=checkbox]{width:auto;accent-color:var(--primary)}.photo-capture{display:flex;flex-direction:column;gap:16px}.photo-instructions{font-size:.88rem;color:var(--text-muted);line-height:1.5}.photo-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:12px}.photo-slot{background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px;display:flex;flex-direction:column;gap:8px;transition:border-color var(--transition)}.photo-slot-header{display:flex;justify-content:space-between;align-items:center}.photo-slot-name{font-size:.78rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.photo-status-ok{font-size:.7rem;font-weight:800;color:var(--success);background:#3d8b6e1f;padding:2px 8px;border-radius:10px}.photo-status-err{font-size:.7rem;font-weight:800;color:var(--accent);background:var(--accent-light);padding:2px 8px;border-radius:10px}.photo-slot-body{display:flex;align-items:center;justify-content:center;min-height:80px}.photo-camera-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px;border:2px dashed var(--border);border-radius:var(--radius-sm);background:transparent;cursor:pointer;color:var(--text-muted);font-family:inherit;font-size:.82rem;font-weight:600;transition:all var(--transition);width:100%;min-height:44px}.photo-camera-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.photo-camera-icon{font-size:1.5rem}.photo-preview-wrap{position:relative;width:100%;border-radius:8px;overflow:hidden}.photo-preview{width:100%;height:auto;max-height:120px;object-fit:cover;border-radius:8px;display:block}.photo-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fdf6e3cc;display:flex;align-items:center;justify-content:center}.photo-slot-actions{display:flex;gap:6px;justify-content:center}.photo-file-input{display:none}.results-review{display:flex;flex-direction:column;gap:16px}.results-instructions{font-size:.88rem;color:var(--text-muted);line-height:1.5}.results-players{display:flex;flex-direction:column;gap:12px}.results-player-card{background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:14px;display:flex;flex-direction:column;gap:10px;transition:border-color var(--transition)}.results-winner{border-color:var(--gold);background:var(--gold-light)}.results-player-header{display:flex;justify-content:space-between;align-items:center}.results-player-name{font-weight:700;font-size:.95rem;display:flex;align-items:center;gap:8px}.results-winner-badge{font-size:.68rem;font-weight:800;color:var(--gold-hover);background:var(--gold-light);padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.3px}.results-winner .results-winner-badge{background:#c9a85c4d}.confidence-badge{font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:10px;font-family:Space Mono,monospace}.confidence-high{color:var(--success);background:#3d8b6e1f}.confidence-med{color:var(--warning);background:#d4a75926}.confidence-low{color:var(--accent);background:var(--accent-light)}.results-thumb{width:80px;height:60px;object-fit:cover;border-radius:6px;border:1px solid var(--border)}.results-tiles-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.results-no-tiles{font-size:.82rem;color:var(--text-muted);font-style:italic}.results-tile-editor{display:flex;flex-direction:column;gap:10px}.results-hand-info{display:flex;align-items:center;gap:8px}.results-hand-category{font-size:.82rem;font-weight:600;color:var(--primary);background:var(--primary-light);padding:2px 10px;border-radius:8px}.results-hand-points{font-size:.78rem;font-weight:700;color:var(--text-muted);font-family:Space Mono,monospace}.results-score-row{display:flex;align-items:center;gap:10px}.results-score-label{font-size:.78rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.results-score-input{width:80px;text-align:center;font-weight:700;font-family:Space Mono,monospace}.results-winner-radio{display:flex!important;align-items:center;gap:4px;cursor:pointer;font-size:.82rem!important;font-weight:600!important;color:var(--text)!important;text-transform:none!important;letter-spacing:0!important;white-space:nowrap;margin-bottom:0!important}.results-winner-radio input[type=radio]{width:auto;accent-color:var(--gold)}.confirm-save{display:flex;flex-direction:column;gap:16px}.wizard-summary{display:flex;flex-direction:column;gap:20px}.wizard-summary-section h4{font-size:.8rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:10px}.wizard-summary-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:.88rem}.wizard-summary-label{color:var(--text-muted);font-weight:600}.wizard-summary-player{background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px;margin-bottom:8px}.wizard-summary-winner{border-color:var(--gold);background:var(--gold-light)}.wizard-summary-player-header{display:flex;justify-content:space-between;align-items:center}.wizard-summary-player-name{font-weight:700;font-size:.9rem;display:flex;align-items:center;gap:8px}.wizard-summary-player-score{font-weight:700;font-family:Space Mono,monospace;font-size:.88rem}.wizard-summary-tiles{margin-top:8px}.wizard-save-btn{width:100%;text-align:center;justify-content:center}.tile-display{display:inline-flex;flex-wrap:wrap;gap:3px;align-items:center}.tile-display-sm .tile{font-size:.7rem;padding:2px 5px;min-width:22px}.tile-display-md .tile{font-size:.82rem;padding:3px 6px;min-width:26px}.tile-display-lg .tile{font-size:1rem;padding:4px 8px;min-width:32px}.tile{display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-family:Space Mono,monospace;border-radius:4px;border:1px solid rgba(0,0,0,.1);background:var(--bg-card);box-shadow:0 1px 3px #00000014;line-height:1;-webkit-user-select:none;user-select:none}.tile-crak{color:#c0392b;border-color:#c0392b40}.tile-bam{color:#27ae60;border-color:#27ae6040}.tile-dot{color:#2980b9;border-color:#2980b940}.tile-wind{color:var(--text);border-color:#3a2e1c33}.tile-dragon-red{color:#c0392b;border-color:#c0392b40}.tile-dragon-green{color:#27ae60;border-color:#27ae6040}.tile-dragon-white{color:var(--text-muted);border-color:var(--border)}.tile-flower{color:#d63384;border-color:#d6338440}.tile-joker{color:var(--gold-hover);border-color:#c9a85c59;background:var(--gold-light)}.tile-selector{display:flex;flex-direction:column;gap:12px}.tile-selector-count{font-size:.78rem;font-weight:700;color:var(--text-muted);text-align:right;font-family:Space Mono,monospace}.tile-selector-selected{display:flex;flex-wrap:wrap;gap:4px;padding:10px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-sm);min-height:44px;align-items:center}.tile-selector-empty{font-size:.82rem;color:var(--text-muted);font-style:italic}.tile-removable{cursor:pointer;transition:all var(--transition);position:relative}.tile-removable:hover{opacity:.6;transform:scale(.92)}.tile-selector-groups{display:flex;flex-direction:column;gap:8px}.tile-selector-group-label{font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px}.tile-row{display:flex;flex-wrap:wrap;gap:4px}.tile-pick{cursor:pointer;min-width:36px;min-height:36px;font-size:.88rem;padding:4px 6px;position:relative;transition:all var(--transition)}.tile-pick:hover:not(.tile-disabled){transform:scale(1.1);box-shadow:var(--shadow)}.tile-pick:active:not(.tile-disabled){transform:scale(.95)}.tile-disabled{opacity:.35;cursor:not-allowed}.tile-badge{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;background:var(--primary);color:#fff;font-size:.6rem;font-weight:800;display:flex;align-items:center;justify-content:center;line-height:1;font-family:Nunito,sans-serif}@media(max-width:600px){.wizard-container{margin:0 -8px;padding:14px;border-radius:var(--radius-sm)}.wizard-stepper{gap:2px;margin-bottom:16px;padding-bottom:12px}.wizard-step{padding:4px 8px}.wizard-step-label{font-size:.7rem}.mahjong-table{min-height:240px;gap:6px}.seat-slot{padding:8px 6px}.seat-player-name{font-size:.78rem}.photo-grid{gap:8px}.photo-slot{padding:8px}.tile-pick{min-width:32px;min-height:32px;font-size:.8rem}.table-options{grid-template-columns:1fr}}
