*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0510;--surface:#130a20;--surface2:#1c0f30;--surface3:#271440;--pink:#f72585;--pink-dim:#a01858;--purple:#b429f9;--violet:#7209b7;--text:#fdf0ff;--text-dim:#9d7ab5;--border:hsla(0,0%,100%,.07);--tile:96px;--gap:4px;--radius:10px;--radius-lg:18px}@media (max-width:560px){:root{--tile:62px;--gap:3px}}body,html{height:100%;min-height:100vh}body{font-family:Nunito,sans-serif;background:var(--bg);background-image:radial-gradient(ellipse 90% 60% at 10% 0,rgba(114,9,183,.35) 0,transparent 55%),radial-gradient(ellipse 70% 70% at 90% 100%,rgba(247,37,133,.25) 0,transparent 55%);color:var(--text);overflow-x:hidden}.app{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:36px 20px 64px}.header{text-align:center;margin-bottom:40px}.header h1{font-family:Boogaloo,cursive;font-size:clamp(2.4rem,6vw,3.8rem);letter-spacing:.04em;background:linear-gradient(135deg,#f72585,#fff 50%,#b429f9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:8px}.header p{color:var(--text-dim);font-size:.9rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.header--game{display:flex;align-items:center;gap:16px;text-align:left;flex-wrap:wrap;justify-content:center;margin-bottom:28px}.header--game h1{font-size:clamp(1.6rem,4vw,2.4rem);margin-bottom:0}.game-label{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--pink);background:rgba(247,37,133,.12);border:1px solid rgba(247,37,133,.3);padding:4px 10px;border-radius:20px}.back-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);font-family:Nunito,sans-serif;font-size:.85rem;font-weight:700;padding:8px 14px;border-radius:var(--radius);cursor:pointer;transition:color .15s,border-color .15s,background .15s;white-space:nowrap;-moz-user-select:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.back-btn:hover{color:var(--text);border-color:hsla(0,0%,100%,.2);background:var(--surface3)}.select-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:18px;gap:18px;width:100%;max-width:900px;margin-bottom:28px}@media (max-width:780px){.select-grid{grid-template-columns:repeat(3,1fr);gap:14px}}@media (max-width:520px){.select-grid{grid-template-columns:repeat(2,1fr);gap:12px}}.select-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s;-moz-user-select:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.select-card:hover{transform:translateY(-5px) scale(1.02);border-color:rgba(247,37,133,.5);box-shadow:0 16px 40px rgba(0,0,0,.5),0 0 0 1px rgba(247,37,133,.2),0 0 30px rgba(247,37,133,.15)}.select-card:active{transform:translateY(-2px) scale(1.01)}.card-preview{position:relative;aspect-ratio:1;overflow:hidden}.card-hover-overlay{position:absolute;inset:0;background:rgba(10,5,16,.6);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.select-card:hover .card-hover-overlay{opacity:1}.card-play-btn{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;font-family:Boogaloo,cursive;font-size:1.1rem;letter-spacing:.06em;padding:10px 22px;border-radius:30px;box-shadow:0 4px 20px rgba(247,37,133,.5);transform:scale(.85);transition:transform .2s}.select-card:hover .card-play-btn{transform:scale(1)}.mini-board{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(5,1fr);width:100%;height:100%;grid-gap:1px;gap:1px;background:#000}.mini-tile{background-color:var(--surface3);background-repeat:no-repeat}.card-info{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;gap:8px}.card-name{font-size:.88rem;font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-label{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--pink);white-space:nowrap}.select-hint{color:var(--text-dim);font-size:.8rem;font-weight:600;letter-spacing:.05em;text-align:center}.layout{display:flex;gap:28px;align-items:flex-start;justify-content:center;width:100%;max-width:900px}@media (max-width:700px){.layout{flex-direction:column;align-items:center}}.stats{display:flex;gap:12px;margin-bottom:14px}.stat{flex:1 1;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 16px;text-align:center}.stat-label{display:block;font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-dim);font-weight:700;margin-bottom:2px}.stat-value{display:block;font-family:Boogaloo,monospace;font-size:1.9rem;color:var(--pink);line-height:1}.board-clip,.board-wrap{position:relative}.board-clip{border:2px solid var(--surface3);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 0 0 1px hsla(0,0%,100%,.04),0 20px 60px rgba(0,0,0,.7),0 0 50px rgba(247,37,133,.15);display:inline-block;background:var(--bg)}.board{display:grid;grid-template-columns:repeat(5,var(--tile));grid-template-rows:repeat(5,var(--tile));grid-gap:var(--gap);gap:var(--gap);-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none}.tile{width:var(--tile);height:var(--tile);background-color:var(--surface3);background-repeat:no-repeat;cursor:-webkit-grab;cursor:grab;position:relative;transition:transform .12s ease,box-shadow .12s ease,filter .12s ease}.tile:active{cursor:-webkit-grabbing;cursor:grabbing}.tile--drag{opacity:.38;transform:scale(.92);filter:brightness(.6)}.tile--over{outline:3px solid var(--pink);outline-offset:-3px;filter:brightness(1.22)}.preview-overlay{position:absolute;inset:0;z-index:20;border-radius:calc(var(--radius-lg) - 2px);overflow:hidden;pointer-events:none}.preview-overlay img{width:100%;height:100%;object-fit:cover}.controls-col{display:flex;flex-direction:column;gap:10px;min-width:160px}@media (max-width:700px){.controls-col{flex-direction:row;flex-wrap:wrap;justify-content:center;min-width:unset}}.btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border:none;border-radius:var(--radius);font-family:Nunito,sans-serif;font-size:.9rem;font-weight:700;cursor:pointer;letter-spacing:.03em;transition:transform .1s,box-shadow .1s,filter .1s;white-space:nowrap;-moz-user-select:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.btn:hover:not(:disabled){transform:translateY(-2px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--primary{background:linear-gradient(135deg,var(--pink) 0,var(--purple) 100%);color:#fff;box-shadow:0 4px 20px rgba(247,37,133,.4)}.btn--primary:hover:not(:disabled){box-shadow:0 8px 28px rgba(247,37,133,.6);filter:brightness(1.1)}.btn--secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn--secondary:hover:not(:disabled){background:var(--surface3);border-color:hsla(0,0%,100%,.14)}.btn--outline{background:transparent;color:var(--text-dim);border:1px dashed hsla(0,0%,100%,.18)}.btn--outline:hover:not(:disabled){color:var(--text);border-color:hsla(0,0%,100%,.3)}.instructions{margin-top:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}.instructions h3{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--pink-dim);font-weight:800;margin-bottom:12px}.instructions ol{list-style:none;counter-reset:step;display:flex;flex-direction:column;gap:8px}.instructions ol li{counter-increment:step;display:flex;align-items:center;gap:10px;font-size:.8rem;color:var(--text-dim);font-weight:600}.instructions ol li:before{content:counter(step);width:20px;height:20px;border-radius:50%;background:var(--surface3);color:var(--pink);font-size:.68rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}@media (max-width:700px){.instructions{display:none}}.win-overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .3s ease}.win-card{background:var(--surface2);border:1px solid rgba(247,37,133,.35);border-radius:24px;padding:48px 52px;text-align:center;box-shadow:0 40px 80px rgba(0,0,0,.7),0 0 70px rgba(247,37,133,.2);animation:popIn .4s cubic-bezier(.34,1.56,.64,1);max-width:400px;width:90%}.win-emoji{font-size:4rem;margin-bottom:16px;display:block;animation:bounce .6s ease .3s both}.win-card h2{font-family:Boogaloo,cursive;font-size:2.6rem;background:linear-gradient(135deg,var(--pink),var(--purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px}.win-card p{color:var(--text-dim);font-size:.95rem;font-weight:600;margin-bottom:28px;line-height:1.7}.win-card strong{color:var(--text)}.win-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%{transform:scale(0)}60%{transform:scale(1.25)}to{transform:scale(1)}}