*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#e0e0e0;background:#0f1923;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}#root{min-height:100dvh}.app-layout{flex-direction:column;min-height:100dvh;padding-bottom:64px;display:flex}.app-main{flex:1}.page{max-width:960px;margin:0 auto;padding:2rem 1rem}.page-title{color:#fff;margin-bottom:1.5rem;font-size:1.8rem}.back-link{color:#6ea8d9;margin-bottom:1.5rem;font-size:.9rem;text-decoration:none;display:inline-block}.back-link:hover{text-decoration:underline}button{color:#fff;cursor:pointer;background:#8b1538;border:none;border-radius:6px;padding:.5rem 1rem;font-family:inherit;font-size:.9rem}button:hover{background:#a41d45}button:disabled{opacity:.5;cursor:default}input,textarea,select{color:#e0e0e0;background:#0f1923;border:1px solid #2d3d4f;border-radius:6px;outline:none;padding:.6rem .8rem;font-family:inherit;font-size:.9rem}input:focus,select:focus{border-color:#8b1538}.error{color:#e0556a;text-align:center;margin-bottom:.5rem;font-size:.85rem}.empty{color:#5a6a7a;text-align:center;padding:2rem;font-size:.9rem}.bottom-nav{z-index:100;background:#1a2634;border-top:1px solid #2d3d4f;justify-content:space-around;padding:6px 0;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:#5a6a7a;border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:4px 16px;font-size:11px;text-decoration:none;transition:color .15s;display:flex}.nav-item.active{color:#e0e0e0}.nav-item svg{width:20px;height:20px}.login-page{background:#0f1923;justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.login-card{text-align:center;background:#1a2634;border:1px solid #2d3d4f;border-radius:12px;width:100%;max-width:380px;padding:40px 32px}.login-icon{color:#8b1538;margin-bottom:16px}.login-card h1{color:#fff;margin-bottom:2px;font-size:1.6rem;font-weight:700}.login-card h2{color:#89a;margin-bottom:6px;font-size:1rem;font-weight:400}.login-subtitle{color:#5a6a7a;margin-bottom:24px;font-size:.8rem}.login-card input{width:100%;margin-bottom:12px}.login-card input::placeholder{color:#5a6a7a}.login-card button{width:100%;padding:.65rem;font-size:1rem;font-weight:600}.login-card .error{margin-bottom:8px}.dev-link-box{text-align:center;background:#1a2634;border:1px dashed #3a5068;border-radius:8px;margin:1rem 0;padding:1rem}.dev-label{color:#7a8a9a;margin-bottom:.5rem;font-size:.8rem}.magic-link-btn{color:#fff;background:#2d8a4e;border-radius:6px;padding:.5rem 1rem;font-size:.95rem;font-weight:600;text-decoration:none;display:inline-block}.magic-link-btn:hover{background:#36a35c}.dev-hint{color:#5a6a7a;margin-top:.5rem;font-size:.75rem}.login-card button.link{color:#4a7aaa;background:0 0;width:auto;padding:0;font-weight:400;text-decoration:underline;display:inline}.progress-section{background:#1a2634;border-radius:8px;margin-bottom:24px;padding:16px}.progress-bar-wrap{background:#2d3d4f;border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden}.progress-bar{background:linear-gradient(90deg,#8b1538,#a41d45);border-radius:4px;height:100%;transition:width .4s}.progress-text{color:#89a;font-size:.8rem;font-weight:500}.empty-hint{text-align:center;color:#5a6a7a;background:#1a2634;border:1px dashed #2d3d4f;border-radius:8px;margin-bottom:24px;padding:24px;font-size:.85rem}.groups{flex-direction:column;gap:1.5rem;display:flex}.group-label{color:#89a;text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px;font-size:.9rem;font-weight:600}.album-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;display:grid}.album-team-card{color:inherit;background:#1a2634;border:1px solid #2d3d4f;border-radius:8px;flex-direction:column;align-items:center;padding:16px 12px;text-decoration:none;transition:transform .15s,box-shadow .15s,border-color .2s;display:flex}.album-team-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.album-team-card.collected{border-color:#2a9d8f}.album-crest-wrap{width:64px;height:64px;margin-bottom:10px;position:relative}.album-crest{object-fit:contain;z-index:1;width:100%;height:100%;transition:filter .3s}.album-crest.locked{filter:grayscale()opacity(.2)}.lock-icon{color:#5a6a7a;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.album-team-card h3{color:#fff;text-align:center;margin-bottom:2px;font-size:.85rem;font-weight:600}.team-progress{color:#5a6a7a;font-size:.7rem}.team-mini-bar{background:#2d3d4f;border-radius:2px;width:100%;height:3px;margin-top:6px;overflow:hidden}.team-mini-fill{background:#2a9d8f;border-radius:2px;height:100%;transition:width .3s}.team-album-header{border-bottom:1px solid #2d3d4f;flex-direction:column;align-items:center;margin-bottom:24px;padding-bottom:20px;display:flex}.team-album-crest-wrap{background:#1a2634;border:2px solid #2d3d4f;border-radius:8px;justify-content:center;align-items:center;width:120px;height:154px;margin-bottom:12px;display:flex;position:relative;overflow:hidden}.team-album-crest-wrap.collected{background:linear-gradient(135deg,#d8d8d8 0%,#f5f5f5 25%,silver 50%,#f0f0f0 75%,#b8b8b8 100%);border:2px solid #ffffff4d;box-shadow:0 2px 10px #0000004d}.team-album-crest-wrap.collected:after{content:"";pointer-events:none;background:linear-gradient(105deg,#0000 30%,#fff6 45%,#ffffff1a 55%,#0000 70%) 0 0/200% 100%;animation:3s ease-in-out infinite sheen;position:absolute;inset:0}.team-album-crest{object-fit:contain;z-index:1;width:90px;height:90px;transition:filter .3s}.team-album-crest.locked{filter:grayscale()opacity(.2)}.crest-lock{color:#5a6a7a;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.team-album-header h1{color:#fff;margin-bottom:4px;font-size:1.4rem;font-weight:700}.group-badge{color:#89a;background:#2d3d4f;border-radius:10px;padding:2px 10px;font-size:.7rem}.player-slots-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;display:grid}.player-slot{background:#1a2634;border:1px solid #2d3d4f;border-radius:10px;transition:border-color .2s;overflow:hidden}.player-slot.filled{border-color:#2a9d8f}.slot-portrait{aspect-ratio:3/4;justify-content:center;align-items:flex-end;display:flex;position:relative;overflow:hidden}.player-slot[data-pos=Goalkeeper] .slot-portrait{background:linear-gradient(160deg,#4a3a1e 0%,#3a2e16 50%,#33301a 100%)}.player-slot[data-pos=Defender] .slot-portrait{background:linear-gradient(160deg,#1e3a5f 0%,#162a3a 50%,#1a2a3f 100%)}.player-slot[data-pos=Midfielder] .slot-portrait{background:linear-gradient(160deg,#1e5f3a 0%,#163a2a 50%,#1a3330 100%)}.player-slot[data-pos=Forward] .slot-portrait{background:linear-gradient(160deg,#5f1e2e 0%,#3a1620 50%,#331a22 100%)}.slot-portrait img{object-fit:contain;object-position:bottom;width:90%;height:95%}.slot-placeholder{color:#ffffff14;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.slot-number{color:#ffffff26;font-size:1.4rem;font-weight:700;line-height:1;position:absolute;top:.4rem;left:.5rem}.slot-position{text-transform:uppercase;letter-spacing:.05em;color:#89a;background:#0f1923b3;border-radius:3px;padding:.15rem .4rem;font-size:.65rem;font-weight:600;position:absolute;top:.5rem;right:.5rem}.slot-body{text-align:center;padding:.6rem .75rem .75rem}.slot-body h3{color:#fff;white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:.85rem;font-weight:600;overflow:hidden}.slot-captain{color:#1a2634;background:#d4a017;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;font-size:.7rem;font-weight:800;line-height:1;display:flex;position:absolute;bottom:.5rem;left:.5rem}.slot-status{color:#5a6a7a;font-size:.7rem;font-weight:500}.slot-age{color:#5a6a7a;margin-bottom:.15rem;font-size:.7rem;display:block}.slot-club{color:#6a7a8a;white-space:nowrap;text-overflow:ellipsis;margin-bottom:.5rem;font-size:.7rem;display:block;overflow:hidden}.slot-stats{justify-content:center;gap:.75rem;display:flex}.slot-stat{flex-direction:column;align-items:center;display:flex}.stat-value{color:#fff;font-size:.9rem;font-weight:700;line-height:1.2}.stat-label{color:#5a6a7a;text-transform:uppercase;letter-spacing:.05em;font-size:.6rem}.pack-idle{justify-content:center;padding:48px 0;display:flex}.pack-open-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#8b1538,#6b0f2b);border:none;border-radius:16px;flex-direction:column;align-items:center;gap:4px;padding:48px 72px;font-size:1.3rem;font-weight:700;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 8px 24px #8b15384d}.pack-open-btn:hover{background:linear-gradient(135deg,#a41d45,#8b1538);transform:scale(1.03);box-shadow:0 12px 32px #8b153873}.pack-open-btn small{opacity:.75;font-size:.85rem;font-weight:400}.pack-open-btn.secondary{color:#e0e0e0;background:#1a2634;padding:14px 32px;font-size:.95rem;box-shadow:0 2px 8px #0000004d}.pack-open-btn.secondary:hover{background:#2d3d4f}.pack-loading{text-align:center;color:#89a;padding:64px 0}.spinner{border:3px solid #2d3d4f;border-top-color:#8b1538;border-radius:50%;width:40px;height:40px;margin:0 auto 16px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes sheen{0%,to{background-position:200% 0}50%{background-position:-200% 0}}.sticker-reveal-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:20px;display:grid}.sticker-reveal-card{cursor:pointer;border-radius:10px;min-height:240px;transition:transform .3s,box-shadow .3s}.sticker-reveal-card.revealed{cursor:default;background:#1a2634;border:1px solid #2d3d4f;padding:10px}.sticker-reveal-card.revealed:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0006}.sticker-reveal-card.handled{opacity:.55}.sticker-back{aspect-ratio:3/4;color:#89a;background:linear-gradient(135deg,#1a2634,#2d3d4f);border:1px solid #2d3d4f;border-radius:10px;justify-content:center;align-items:center;font-size:48px;font-weight:900;display:flex}.sticker-front{flex-direction:column;align-items:center;gap:8px;display:flex}.sticker-image-wrap{aspect-ratio:1;border-radius:8px;justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.sticker-image-wrap[data-type=team]{background:#2d3d4f66}.sticker-image-wrap[data-type=player]{background:linear-gradient(160deg,#1e3a5f 0%,#162a3a 100%)}.sticker-image-wrap img{object-fit:contain;width:80%;height:80%}.sticker-no-image{background:#2d3d4f;border-radius:50%;width:64px;height:64px}.sticker-number{color:#ffffff26;font-size:20px;font-weight:800;position:absolute;top:4px;left:6px}.sticker-info{text-align:center}.sticker-info h3{color:#fff;margin-bottom:1px;font-size:.8rem;font-weight:600}.sticker-position{color:#6ea8d9;text-transform:uppercase;font-size:.65rem;font-weight:600}.sticker-info small{color:#5a6a7a;font-size:.65rem;display:block}.sticker-actions{flex-direction:column;gap:4px;width:100%;display:flex}.btn-stick,.btn-duplicate{cursor:pointer;border:none;border-radius:5px;padding:6px 8px;font-family:inherit;font-size:.7rem;font-weight:600;transition:background .15s}.btn-stick{color:#fff;background:#2a9d8f}.btn-stick:hover{background:#21867a}.btn-duplicate{color:#89a;background:#2d3d4f}.btn-duplicate:hover{background:#3a5060}.sticker-done{color:#5a6a7a;padding:4px 0;font-size:.7rem;font-weight:500}.reveal-next-btn{color:#e0e0e0;cursor:pointer;background:0 0;border:1px solid #8b1538;border-radius:8px;margin:0 auto 16px;padding:10px 24px;font-family:inherit;font-size:.9rem;font-weight:600;display:block}.reveal-next-btn:hover{background:#8b15381a}.pack-summary{text-align:center;padding:16px}.pack-summary p{color:#89a;margin-bottom:16px;font-size:.9rem}.empty-state{text-align:center;color:#5a6a7a;flex-direction:column;align-items:center;gap:8px;padding:64px 24px;display:flex}.empty-state svg{color:#2d3d4f;margin-bottom:8px}.empty-state p{color:#89a;font-size:1rem;font-weight:600}.empty-state span{max-width:260px;font-size:.8rem}.btn-link{color:#fff;background:#8b1538;border-radius:8px;margin-top:12px;padding:10px 24px;font-size:.9rem;font-weight:600;text-decoration:none}.btn-link:hover{background:#a41d45}.duplicates-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;display:grid}.duplicate-card{background:#1a2634;border:1px solid #2d3d4f;border-radius:10px;flex-direction:column;align-items:center;gap:8px;padding:14px;transition:transform .15s;display:flex}.duplicate-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.dup-image-wrap{justify-content:center;align-items:center;width:80px;height:80px;display:flex;position:relative}.dup-image-wrap img{object-fit:contain;width:100%;height:100%}.dup-count-badge{color:#fff;background:#8b1538;border-radius:50%;justify-content:center;align-items:center;min-width:22px;height:22px;padding:0 4px;font-size:11px;font-weight:700;display:flex;position:absolute;top:-6px;right:-6px}.dup-info{text-align:center}.btn-stick-small{color:#fff;cursor:pointer;background:#2a9d8f;border:none;border-radius:5px;padding:4px 10px;font-family:inherit;font-size:.7rem;font-weight:600;transition:background .15s}.btn-stick-small:hover{background:#21867a}.btn-stick-small:disabled{opacity:.5;cursor:default}.dup-info h3{color:#fff;margin-bottom:2px;font-size:.8rem;font-weight:600}.dup-type{color:#5a6a7a;font-size:.65rem}.skeleton-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;display:grid}.skeleton-card{background:#1a2634;border:1px solid #2d3d4f;border-radius:8px;height:150px;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}
