/* QR-triggered passage squares dialog and print layout. */

#printSquaresDialog {
    width: min(1300px, 98vw);
}

.squares-dialog-shell {
    max-height: min(90vh, 980px);
    overflow: auto;
}

.squares-dialog-layout {
    display: grid;
    grid-template-columns: minmax(250px, 320px) minmax(0, 1fr);
    gap: .9rem;
    align-items: start;
}

.squares-dialog-controls {
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 1;
    padding-bottom: .35rem;
    border-bottom: 1px solid rgba(0, 0, 0, .06);
}

.squares-preview-title {
    margin: 0 0 .45rem;
    font-size: 1rem;
    font-weight: 700;
}

.squares-preview-host {
    max-height: min(64vh, 760px);
    overflow: auto;
    padding: .7rem;
    border: 1px solid var(--color-border-strong);
    border-radius: 10px;
    background: linear-gradient(180deg, #fcfcfc 0%, #f3f3f3 100%);
}

.squares-preview-empty {
    margin: 0;
    color: #4e5d6c;
}

.passage-squares-sheet {
    display: none;
}

.passage-squares-pages {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.passage-squares-page {
    width: calc(8.5in - (var(--print-page-margin-x) * 2));
    max-width: calc(8.5in - (var(--print-page-margin-x) * 2));
    min-height: calc(var(--print-page-height) - (var(--print-page-margin-y) * 2));
    margin: 0 auto;
    padding: .16in;
    background: #fff;
    border: 1px solid #ddd;
    color: #101010;
    box-sizing: border-box;
}

.passage-squares-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-template-rows: repeat(4, minmax(0, 1fr));
    gap: .14in;
    min-height: 100%;
}

.passage-square {
    border: 1.5px solid #5e6f80;
    border-radius: 7px;
    padding: .08in .1in;
    display: flex;
    flex-direction: column;
    gap: .04in;
    break-inside: avoid;
    overflow: hidden;
    background: #fff;
}

.passage-square-head {
    display: flex;
    justify-content: space-between;
    gap: .08in;
    align-items: baseline;
}

.passage-square-reference {
    margin: 0;
    font-size: .6rem;
    font-weight: 700;
    line-height: 1.2;
    color: #1b2f45;
}

.passage-square-brand {
    font-size: .5rem;
    font-weight: 700;
    color: #3c4d5f;
    white-space: nowrap;
}

.passage-square-text {
    margin: 0;
    font-size: .5rem;
    line-height: 1.35;
    color: #172432;
}

.passage-square-meta {
    margin-top: auto;
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: .08in;
}

.passage-square-labels {
    min-width: 0;
}

.passage-square-group,
.passage-square-theme,
.passage-square-activity {
    margin: 0;
    font-size: .46rem;
    line-height: 1.25;
    color: #2f3f4f;
}

.passage-square-qr {
    width: .6in;
    height: .6in;
    border: 1px solid #d0dfef;
    border-radius: 4px;
    padding: 1px;
    box-sizing: border-box;
    background: #fff;
    flex-shrink: 0;
}

.passage-square-qr canvas,
.passage-square-qr img {
    width: 100%;
    height: 100%;
    display: block;
    image-rendering: pixelated;
}

@media (max-width: 980px) {
    .squares-dialog-layout {
        grid-template-columns: 1fr;
    }

    .squares-dialog-controls {
        position: static;
        border-bottom: none;
    }

    .squares-preview-host {
        max-height: 50vh;
    }
}

@media (max-width: 650px) {
    .passage-squares-grid {
        grid-template-columns: 1fr;
        grid-template-rows: none;
    }
}

@media print {
    body[data-print-size="squares"] .no-print,
    body[data-print-size="squares"] dialog,
    body[data-print-size="squares"] .print-sheet,
    body[data-print-size="squares"] .print-sheet-half {
        display: none !important;
    }

    body[data-print-size="squares"] .passage-squares-sheet {
        display: block;
    }

    body[data-print-size="squares"] .passage-squares-pages {
        gap: 0;
    }

    body[data-print-size="squares"] .passage-squares-page {
        border: 0;
        margin: 0 auto;
        page-break-after: always;
        break-after: page;
    }

    body[data-print-size="squares"] .passage-squares-page:last-child {
        page-break-after: auto;
        break-after: auto;
    }
}
