/* /CardQuiz.razor.rz.scp.css */
.cardquiz .reading-text[b-bhmm75lyp6] { line-height: 1.6; }
.cardquiz .stat-pill[b-bhmm75lyp6] {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 999px;
    padding: .4rem .75rem;
    display: inline-flex; gap: .5rem; align-items: baseline;
}
.cardquiz .stat-pill .label[b-bhmm75lyp6] { color: var(--bs-secondary-color); font-size: .85rem; }
.cardquiz .stat-pill .value[b-bhmm75lyp6] { font-weight: 600; }


.cardquiz .board[b-bhmm75lyp6] { display: grid; align-items: start; justify-items: center; padding-top: .25rem; }
.cardquiz .pick-btn[b-bhmm75lyp6] { padding: 1.25rem 1.5rem; }


/* Flip card */
.flip-card[b-bhmm75lyp6] { perspective: 1200px; width: min(780px, 100%); }
.flip-inner[b-bhmm75lyp6] { position: relative; width: 100%; transform-style: preserve-3d; transition: transform .6s ease; will-change: transform; }
.flip-inner.flipped[b-bhmm75lyp6] { transform: rotateY(180deg); }
.flip-front[b-bhmm75lyp6], .flip-back[b-bhmm75lyp6] { position: absolute; inset: 0; backface-visibility: hidden; }
.flip-back[b-bhmm75lyp6] { transform: rotateY(180deg); }


.qa-card[b-bhmm75lyp6] {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 1rem; padding: 1.25rem; min-height: 220px;
    display: flex; flex-direction: column; justify-content: start; align-items: start;
    box-shadow: 0 10px 24px rgba(0,0,0,.08);
}
.qa-text[b-bhmm75lyp6] { font-size: 1.15rem; line-height: 1.7; }


/* Enter animations */
.deal-in[b-bhmm75lyp6] { animation: deal-b-bhmm75lyp6 .35s ease-out; }
@keyframes deal-b-bhmm75lyp6 { from { transform: translateY(12px) scale(.98); opacity: 0 } to { transform: translateY(0) scale(1); opacity: 1 } }
.show-answer[b-bhmm75lyp6] { animation: pop-b-bhmm75lyp6 .25s ease-in; }
@keyframes pop-b-bhmm75lyp6 { from { transform: scale(.98); } to { transform: scale(1); } }


/* Finish overlay */
.finish-overlay[b-bhmm75lyp6] { position: fixed; inset: 0; background: rgba(0,0,0,.4); display: grid; place-items: center; z-index: 1050; }
.finish-dialog[b-bhmm75lyp6] { background: var(--bs-body-bg); border: 1px solid var(--bs-border-color); border-radius: 1rem; padding: 1.25rem 1.25rem 1rem; width: min(520px, 92vw); box-shadow: 0 20px 50px rgba(0,0,0,.2); }


/* Small helpers */
.audio-wrap[b-bhmm75lyp6] { background: var(--bs-tertiary-bg); }
/* /CrosswordBoard.razor.rz.scp.css */
.cw-wrapper[b-n2ut86gbc1] { 
    --cw-cell: 2.6rem; 
    --cw-gap: .35rem; 
    --cw-step: calc(var(--cw-cell) + var(--cw-gap));
}

.cw-grid[b-n2ut86gbc1] { 
    overflow: visible; 
    border: none; 
    position: relative;
}
.cw-word[b-n2ut86gbc1] { gap: var(--cw-gap); }

.cw-cell[b-n2ut86gbc1] {
    width: var(--cw-cell);
    height: var(--cw-cell);
    text-align: center;
    text-transform: uppercase;
    font-weight: 600;
    line-height: 1;
    padding: 0 .25rem;
    border-radius: .375rem;
    border-width: 2px;
    box-sizing: border-box; flex: 0 0 auto;
}
.cw-cell.secret[b-n2ut86gbc1] {
    background: var(--bs-warning-bg-subtle);
    border-color: var(--bs-warning-border-subtle);
    border-width: 2px;
}
.cw-cell.ok[b-n2ut86gbc1] { border-color: var(--bs-success-border-subtle); }
.cw-cell.err[b-n2ut86gbc1] { border-color: var(--bs-danger-border-subtle); }

.cw-clue[b-n2ut86gbc1] { padding-left: calc(var(--cw-cell) * 0.25); }

.cw-float-clue[b-n2ut86gbc1] {
    position: absolute;
    left: 0;
    top: calc(-1 * (1.6rem + .5rem));
    opacity: 0;
    transform: translateY(4px);
    transition: .15s ease;
    pointer-events: none;
    z-index: 20;
    display: none !important; 
}
.cw-float-clue.show[b-n2ut86gbc1] {
    opacity: 1;
    transform: translateY(0);
}
.cw-float-clue-inner[b-n2ut86gbc1] {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: .5rem;
    padding: .25rem .5rem;
    max-width: min(92vw, 50rem);
    font-size: .9rem;
}
.cw-clue-portal[b-n2ut86gbc1]{
    position: fixed;
    z-index: 2000; /* nad kartou i scale wrappery, pod modalem klidně zvyšte */
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: .5rem;
    padding: .25rem .5rem;
    max-width: min(92vw, 50rem);
    font-size: .9rem;
    box-shadow: 0 .25rem .5rem rgba(0,0,0,.1);
    display: none;        /* skryto dokud není fokus */
    pointer-events: none; /* ať nekrade kliky */
}

.cw-secret[b-n2ut86gbc1] { background: var(--bs-tertiary-bg); }
.cw-secret .cw-secret-cell[b-n2ut86gbc1] {
    display: inline-block;
    width: var(--cw-cell);
    height: calc(var(--cw-cell) - .6rem);
    border: 1px dashed var(--bs-border-color);
    border-radius: .375rem;
    text-align: center;
    font-weight: 700;
    line-height: calc(var(--cw-cell) - .8rem);
    font-size: 1.05rem;
}

.cw-rowno[b-n2ut86gbc1]{
    width: 1.6rem;
    height: 1.6rem;
    border: 1px solid var(--bs-border-color);
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: .8rem;
    line-height: 1;
    margin-right: var(--cw-gap);
    user-select: none;
    flex: 0 0 auto;
}

.cw-scale-outer[b-n2ut86gbc1]{
    position: relative;
    width: 100%;
    overflow-x: hidden; /* přepíná se JS na auto při scale=0.3 a pořád nepasuje */
    overflow-y: hidden;
    overscroll-behavior: contain; 
}
.cw-scale-inner[b-n2ut86gbc1]{
    transform-origin: top left;
    will-change: transform;
}



/* Menší displeje – buňky o chlup menší */
@media (max-width: 420px) {
    .cw-wrapper[b-n2ut86gbc1] { --cw-cell: 2.4rem; }
}
/* /PexesoBoard.razor.rz.scp.css */
.pexeso-root[b-nmpy3i6xrp] { display:flex; flex-direction:column; height:100dvh; width:100%; overflow:hidden; }
.scorebar[b-nmpy3i6xrp] { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: .75rem; padding: 1rem; }
.scorebar .players[b-nmpy3i6xrp] { display: flex; gap: .5rem; flex-wrap: wrap; }
.player[b-nmpy3i6xrp] { padding: .4rem .6rem; border-radius: .75rem; background: #e0e0e0; }
.player.active[b-nmpy3i6xrp] { outline: 2px solid #0000ff; background: #bbbbff; }
.player .name[b-nmpy3i6xrp] { font-weight: 600; }
.player .stats[b-nmpy3i6xrp] { font-size: .9rem; opacity: .8; }
/*.scorebar .right { display:flex; align-items:center; gap:.5rem; }
.btn { border: 0; border-radius: .6rem; padding: .4rem .7rem; cursor: pointer; background: #e7e7e7; }
.btn.primary { background: #2b8a3e; color: white; }*/


.board[b-nmpy3i6xrp] {
  flex:1 1 auto; display:grid; gap:var(--gap,8px);
  width:100%; height:100%;
  grid-template-columns: repeat(var(--cols,2), var(--cell,100px));
  grid-template-rows:    repeat(var(--rows,2), var(--cell,100px));
  justify-content:center; align-content:center;
}
.card[b-nmpy3i6xrp] { position:relative; width:var(--cell,100px); height:var(--cell,100px);
        aspect-ratio:1/1; padding:0; border:none; background:transparent; cursor:pointer; }
.card.matched[b-nmpy3i6xrp] { opacity: .5; pointer-events: none; }
.card:disabled[b-nmpy3i6xrp] { cursor: default; }


.card-inner[b-nmpy3i6xrp] { position: relative; width: 100%; height: 100%; transform-style: preserve-3d; transition: transform .3s ease; }
.card-inner.flipped[b-nmpy3i6xrp] { transform: rotateY(180deg); }
.card-face[b-nmpy3i6xrp] { position: absolute; inset: 0; width: 100%; height: 100%; backface-visibility: hidden; object-fit: cover; border-radius: .6rem; box-shadow: 0 2px 8px rgba(0,0,0,.15); }
.card-front[b-nmpy3i6xrp] { transform: rotateY(180deg); }
.card-back[b-nmpy3i6xrp] { }


.overlay[b-nmpy3i6xrp] { position: fixed; inset: 0; background: rgba(0,0,0,.45); display: grid; place-items: center; }
.dialog[b-nmpy3i6xrp] { background: white; padding: 1rem 1.25rem; border-radius: .9rem; width: min(540px, 92vw); box-shadow: 0 12px 40px rgba(0,0,0,.35); }
.dialog h2[b-nmpy3i6xrp] { margin-top: 0; }
.dialog .result[b-nmpy3i6xrp] { font-weight: 600; }
.dialog .message[b-nmpy3i6xrp] { opacity: .9; }
.dialog .actions[b-nmpy3i6xrp] { display: flex; justify-content: end; gap: .5rem; margin-top: .5rem; }


/* Ulehčení mobilům */
@media (max-width: 640px) {
.scorebar[b-nmpy3i6xrp] { grid-template-columns: 1fr; gap: .5rem; }
.scorebar .right[b-nmpy3i6xrp] { justify-content: space-between; }
}
/* /PuzzleBoard.razor.rz.scp.css */
.puzzle-root[b-bf8w7mfp7y] {
  width: 100%;
  min-height: 70vh;
  display: grid;
  place-items: center;
  padding: clamp(8px, 2vw, 24px);
}

.puzzle-board[b-bf8w7mfp7y] {
  position: relative;
  width: min(90vmin, 900px); /* responzivní čtverec */
  max-width: 100%;
  background: radial-gradient(circle at 30% 30%, #f6f7fb, #e9ebf3);
  border-radius: 20px;
  box-shadow: 0 6px 30px rgba(0,0,0,.1) inset;
  overflow: visible; /* necháme dílky přesahovat */
  touch-action: none; 
  -webkit-tap-highlight-color: transparent;

}

.piece[b-bf8w7mfp7y] {
  position: absolute;
  touch-action: none; /* pro plynulé drag na dotyku */
  transform-origin: top left;
  user-select: none;
  pointer-events:auto;
  -webkit-tap-highlight-color: transparent;
}

.piece img[b-bf8w7mfp7y] {
  width: 100%;
  height: 100%;
  pointer-events: none; /* eventy bereme na wrapperu kvůli rotaci/scale */
}

.rotate-btn[b-bf8w7mfp7y] {
  position: absolute;
  right: 6px; bottom: 6px;
  padding: 6px 8px;
  border-radius: 10px;
  border: none;
  background: rgba(255,255,255,.8);
  box-shadow: 0 2px 8px rgba(0,0,0,.2);
  cursor: pointer;
}

.puzzle-full[b-bf8w7mfp7y] {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: contain;
  border-radius: 20px;
}

.fade-in-zoom[b-bf8w7mfp7y] {
  animation: showZoom-b-bf8w7mfp7y .6s ease both;
}
@keyframes showZoom-b-bf8w7mfp7y {
  from { opacity: 0; transform: scale(.98); }
  to   { opacity: 1; transform: scale(1); }
}

.puzzle-win[b-bf8w7mfp7y] {
  position: absolute;
  inset: auto 0 8%;
  text-align: center;
  font-size: clamp(18px, 3.5vmin, 36px);
  font-weight: 700;
  color: #2a2a2a;
  text-shadow: 0 2px 8px rgba(255,255,255,.8);
}
