/* Game Review Summary component family. All classes are prefixed `grs-`. */

.grs-page {
    --grs-green: #5b8a3c;
    --grs-green-deep: #2f5524;
    --grs-green-mid: #71a84f;
    --grs-green-soft: #eef4e3;
    --grs-ink: #1c2417;
    --grs-muted: #75806c;
    --grs-line: #e4e8db;
    --grs-card-bg: #ffffff;
    --grs-amber: #d99e1b;
    --grs-orange: #e07b2f;
    --grs-red: #d23f31;
    --grs-board-light: #f0f1d8;
    --grs-board-dark: #86a666;
    --grs-board-frame: #5f7748;

    display: grid;
    gap: 1.1rem;
    color: var(--grs-ink);
}

.grs-page--embedded > *,
.grs-page--embedded .grs-moments__list > *,
.grs-page--embedded .grs-donut__chart svg {
    animation: none;
    opacity: 1;
}

.grs-page--embedded .grs-evalgraph__line {
    animation: none;
    stroke-dasharray: none;
    stroke-dashoffset: 0;
}

.grs-leaf {
    display: inline-block;
    width: 1.05em;
    height: 1.05em;
    margin-left: 0.35rem;
    object-fit: contain;
    opacity: 0.85;
    vertical-align: -0.18em;
}

/* ---------- Buttons ---------- */

.grs-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    padding: 0.55rem 1.15rem;
    border-radius: 8px;
    border: 1px solid transparent;
    font-weight: 600;
    font-size: 0.88rem;
    cursor: pointer;
    transition: background 0.15s ease, border-color 0.15s ease, transform 0.15s ease;
}

.grs-button--outline {
    background: var(--grs-card-bg);
    border-color: var(--grs-line);
    color: var(--grs-ink);
}

.grs-button--outline:hover {
    border-color: var(--grs-green);
    background: var(--grs-green-soft);
}

.grs-button--primary {
    background: var(--grs-green);
    color: #fff;
    box-shadow: 0 8px 18px rgba(91, 138, 60, 0.35);
}

.grs-button--primary:hover {
    background: var(--grs-green-deep);
    transform: translateY(-1px);
}

/* ---------- Page header ---------- */

.grs-header {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: 104px;
    padding-right: clamp(7rem, 18vw, 15rem);
}

.grs-header__copy {
    min-width: 0;
}

.grs-header__title {
    margin: 0;
    font-size: 1.9rem;
    font-weight: 800;
    letter-spacing: 0;
}

.grs-header__art {
    position: absolute;
    right: 0;
    bottom: -0.3rem;
    width: clamp(6.5rem, 15vw, 13.5rem);
    max-height: 9.5rem;
    object-fit: contain;
    object-position: right bottom;
    pointer-events: none;
    user-select: none;
}

.grs-header .grs-button {
    position: relative;
    z-index: 1;
}

/* ---------- Stepper ---------- */

.grs-stepper {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    max-width: 560px;
}

.grs-stepper__step {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    white-space: nowrap;
}

.grs-stepper__dot {
    display: grid;
    place-items: center;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: 2px solid var(--grs-ink);
    font-size: 0.85rem;
    font-weight: 700;
}

.grs-stepper__label {
    font-weight: 600;
    font-size: 0.92rem;
}

.grs-stepper__step.is-current .grs-stepper__dot {
    background: var(--grs-green-deep);
    border-color: var(--grs-green-deep);
    color: #fff;
}

.grs-stepper__step.is-current .grs-stepper__label {
    font-weight: 800;
}

.grs-stepper__step.is-upcoming .grs-stepper__dot,
.grs-stepper__step.is-upcoming .grs-stepper__label {
    color: var(--grs-muted);
    border-color: var(--grs-muted);
}

.grs-stepper__arrow {
    flex: 1 1 40px;
    height: 2px;
    min-width: 30px;
    background: var(--grs-ink);
    position: relative;
    opacity: 0.75;
}

.grs-stepper__arrow::after {
    content: "";
    position: absolute;
    right: -1px;
    top: -4px;
    border-left: 8px solid var(--grs-ink);
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
}

/* ---------- Cards ---------- */

.grs-card {
    background: var(--grs-card-bg);
    border: 1px solid var(--grs-line);
    border-radius: 8px;
    padding: 1.1rem 1.25rem;
    box-shadow: 0 4px 14px rgba(28, 36, 23, 0.05);
}

.grs-card__head {
    margin-bottom: 0.8rem;
}

.grs-card__title {
    margin: 0;
    font-size: 0.98rem;
    font-weight: 700;
}

/* ---------- Game info bar ---------- */

.grs-infobar {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    background: var(--grs-card-bg);
    border: 1px solid var(--grs-line);
    border-radius: 8px;
    box-shadow: 0 4px 14px rgba(28, 36, 23, 0.05);
}

.grs-infobar__cell {
    min-width: 0;
    padding: 0.85rem 1.2rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.15rem;
}

.grs-infobar__cell + .grs-infobar__cell {
    border-left: 1px solid var(--grs-line);
}

.grs-infobar__player {
    flex-direction: row;
    align-items: center;
    gap: 0.7rem;
}

.grs-infobar__glyph {
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    font-size: 1.35rem;
    line-height: 1;
    flex: none;
}

.grs-infobar__glyph--white {
    background: #f4f2e7;
    border: 1px solid var(--grs-line);
    color: var(--grs-ink);
}

.grs-infobar__glyph--black {
    background: var(--grs-ink);
    color: #fff;
}

.grs-infobar__label {
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--grs-muted);
}

.grs-infobar__name,
.grs-infobar__value {
    display: flex;
    align-items: baseline;
    gap: 0.45rem;
    font-size: 0.95rem;
    flex-wrap: wrap;
}

.grs-infobar__title-badge {
    background: var(--grs-green);
    color: #fff;
    font-size: 0.62rem;
    font-weight: 800;
    padding: 0.12rem 0.4rem;
    border-radius: 6px;
    letter-spacing: 0.04em;
}

.grs-infobar__rating,
.grs-infobar__sub {
    color: var(--grs-muted);
    font-size: 0.85rem;
}

.grs-infobar__icon {
    color: var(--grs-muted);
    font-size: 0.9rem;
    align-self: center;
}

/* ---------- Stat strip ---------- */

.grs-statstrip {
    display: flex;
    flex-wrap: wrap;
    background: var(--grs-card-bg);
    border: 1px solid var(--grs-line);
    border-radius: 8px;
    box-shadow: 0 4px 14px rgba(28, 36, 23, 0.05);
}

.grs-statstrip__cell {
    flex: 1 1 0;
    min-width: 130px;
    padding: 1rem 1.2rem;
    text-align: center;
}

.grs-statstrip__cell + .grs-statstrip__cell {
    border-left: 1px solid var(--grs-line);
}

.grs-statstrip__label {
    display: block;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--grs-muted);
    margin-bottom: 0.3rem;
}

.grs-statstrip__value {
    font-size: 1.55rem;
    font-weight: 800;
    letter-spacing: 0;
}

.grs-statstrip__value--accent {
    color: var(--grs-green-deep);
}

.grs-statstrip__sub {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--grs-muted);
}

/* ---------- Main layout ---------- */

.grs-main {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.95fr);
    gap: 1.1rem;
    align-items: start;
}

.grs-main__left {
    display: grid;
    gap: 1.1rem;
}

.grs-main__charts {
    display: grid;
    /* Stack the eval graph and donut as soon as both can't fit at a
       readable width, instead of clipping the donut legend. */
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr));
    gap: 1.1rem;
    align-items: stretch;
}

.grs-main__minis {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.1rem;
    align-items: stretch;
}

/* ---------- Evaluation graph ---------- */

.grs-evalgraph {
    width: 100%;
    height: auto;
    display: block;
}

.grs-evalgraph__grid {
    stroke: var(--grs-line);
    stroke-width: 1;
}

.grs-evalgraph__zero {
    stroke: #b9c1ad;
    stroke-width: 1.4;
}

.grs-evalgraph__line {
    fill: none;
    stroke: var(--grs-green-deep);
    stroke-width: 2.4;
    stroke-linejoin: round;
    stroke-linecap: round;
}

.grs-evalgraph__tick {
    fill: var(--grs-muted);
    font-size: 12px;
    font-family: inherit;
}

.grs-evalgraph__phase {
    fill: var(--grs-muted);
    font-size: 12.5px;
    font-weight: 600;
    font-family: inherit;
}

.grs-evalgraph__peak-dot {
    fill: var(--grs-green-deep);
    stroke: #fff;
    stroke-width: 2;
}

.grs-evalgraph__peak-badge {
    fill: #243018;
}

.grs-evalgraph__peak-text {
    fill: #fff;
    font-size: 12px;
    font-weight: 700;
    font-family: inherit;
}

/* ---------- Move classification donut ---------- */

.grs-donut {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.9rem 1.1rem;
}

.grs-donut__chart {
    width: 132px;
    flex: none;
}

.grs-donut__legend {
    list-style: none;
    margin: 0;
    padding: 0;
    flex: 1 1 11rem;
    min-width: 0;
    display: grid;
    gap: 0.42rem;
}

.grs-donut__legend-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.83rem;
}

.grs-donut__swatch {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex: none;
}

.grs-donut__legend-label {
    flex: 1;
}

.grs-donut__legend-count {
    font-weight: 700;
}

.grs-donut__legend-pct {
    color: var(--grs-muted);
    min-width: 2.6em;
    text-align: right;
}

.grs-donut__total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 0.9rem;
    padding-top: 0.7rem;
    border-top: 1px solid var(--grs-line);
    font-size: 0.9rem;
}

.grs-donut__total strong {
    font-size: 1.05rem;
}

/* ---------- Board snapshot ---------- */

.grs-board {
    display: grid;
    grid-template-columns: 1rem minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr) 1rem;
    grid-template-areas:
        "ranks grid"
        ". files";
    gap: 0.3rem;
    width: 100%;
    max-width: 460px;
    margin: 0 auto;
    align-items: stretch;
}

.grs-board__grid {
    grid-area: grid;
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    width: 100%;
    min-width: 0;
    aspect-ratio: 1;
    border: 2px solid var(--grs-board-frame);
    border-radius: 8px;
    overflow: hidden;
}

.grs-board__square {
    position: relative;
    display: grid;
    place-items: center;
    min-width: 0;
    min-height: 0;
    overflow: hidden;
}

.grs-board__square--light {
    background: var(--grs-board-light);
}

.grs-board__square--dark {
    background: var(--grs-board-dark);
}

.grs-board__square--highlight::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(222, 235, 100, 0.62);
}

.grs-board__piece {
    position: relative;
    z-index: 1;
    display: grid;
    place-items: center;
    width: 88%;
    height: 88%;
    pointer-events: none;
}

.grs-board__piece-svg,
.grs-board__piece-fallback {
    grid-area: 1 / 1;
    width: 100%;
    height: 100%;
}

.grs-board__piece-svg {
    display: block;
    position: relative;
    z-index: 1;
}

.grs-board__piece-fallback {
    display: none;
    place-items: center;
    color: var(--grs-ink);
    font-size: clamp(1.15rem, 6vw, 2.2rem);
    line-height: 1;
    opacity: 0.2;
    user-select: none;
}

.grs-board__badge {
    position: absolute;
    top: 2px;
    right: 2px;
    display: grid;
    place-items: center;
    width: 32%;
    aspect-ratio: 1;
    border-radius: 50%;
    background: var(--grs-green);
    color: #fff;
    font-size: 0.55rem;
    line-height: 1;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
}

.grs-board__ranks {
    grid-area: ranks;
    display: flex;
    flex-direction: column;
}

.grs-board__files {
    grid-area: files;
    display: flex;
}

.grs-board__ranks span,
.grs-board__files span {
    flex: 1;
    display: grid;
    place-items: center;
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--grs-muted);
}

/* ---------- Key moments ---------- */

.grs-card--moments {
    /* Size to content; stretching to the tall left column leaves a large
       empty void under the moments list. */
    align-self: start;
}

.grs-moments {
    display: grid;
    grid-template-columns: minmax(210px, 0.85fr) minmax(0, 1.15fr);
    gap: 1.1rem;
    align-items: start;
}

.grs-moments__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.5rem;
}

.grs-moments__item {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    width: 100%;
    padding: 0.6rem 0.7rem;
    background: transparent;
    border: 1px solid transparent;
    border-radius: 8px;
    cursor: pointer;
    text-align: left;
    font: inherit;
    color: inherit;
    transition: background 0.15s ease, border-color 0.15s ease;
}

.grs-moments__item:hover {
    background: var(--grs-green-soft);
}

.grs-moments__item.is-selected {
    background: var(--grs-green-soft);
    border-color: var(--grs-green);
}

.grs-moments__index {
    display: grid;
    place-items: center;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    color: #fff;
    font-size: 0.8rem;
    font-weight: 700;
    flex: none;
}

.grs-moments__move {
    display: grid;
    line-height: 1.25;
}

.grs-moments__move strong {
    font-size: 0.92rem;
}

.grs-moments__move small {
    color: var(--grs-muted);
    font-size: 0.76rem;
}

.grs-moments__delta {
    margin-left: auto;
    font-weight: 800;
    font-size: 0.88rem;
}

.grs-moments__headline {
    margin: 0.9rem 0 0.3rem;
    text-align: center;
    font-size: 1.08rem;
    font-weight: 800;
}

.grs-moments__description {
    margin: 0;
    text-align: center;
    color: var(--grs-muted);
    font-size: 0.88rem;
    line-height: 1.5;
}

.grs-moments__view-all {
    margin-top: 1rem;
}

.grs-moments__spotlight {
    display: grid;
    justify-items: center;
    min-width: 0;
}

.grs-moments__spotlight .grs-board {
    width: min(100%, 360px);
}

/* Tone colors shared by badges, chips, and headlines. */
.grs-tone-bg--brilliant { background: var(--grs-green-deep); }
.grs-tone-bg--great { background: var(--grs-green-mid); }
.grs-tone-bg--good { background: var(--grs-green); }
.grs-tone-bg--inaccuracy { background: var(--grs-amber); }
.grs-tone-bg--mistake { background: var(--grs-orange); }
.grs-tone-bg--blunder { background: var(--grs-red); }

.grs-tone-text--brilliant { color: var(--grs-green-deep); }
.grs-tone-text--great { color: var(--grs-green-mid); }
.grs-tone-text--good { color: var(--grs-green); }
.grs-tone-text--inaccuracy { color: var(--grs-amber); }
.grs-tone-text--mistake { color: var(--grs-orange); }
.grs-tone-text--blunder { color: var(--grs-red); }

/* ---------- Tactics & motifs ---------- */

.grs-tactics__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.55rem;
}

.grs-tactics__empty {
    margin: 0;
    padding: 0.75rem 0.8rem;
    border-radius: 8px;
    background: var(--grs-green-soft);
    color: var(--grs-muted);
    font-size: 0.86rem;
}

.grs-tactics__row {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    font-size: 0.86rem;
}

.grs-tactics__icon {
    color: var(--grs-green-deep);
    font-size: 0.95rem;
    width: 1.2em;
    text-align: center;
}

.grs-tactics__label {
    flex: 1;
}

.grs-tactics__count {
    font-weight: 700;
}

.grs-tactics__total {
    display: flex;
    justify-content: space-between;
    margin-top: 0.8rem;
    padding-top: 0.65rem;
    border-top: 1px solid var(--grs-line);
    font-size: 0.88rem;
    font-weight: 600;
}

/* ---------- Coaching recommendations ---------- */

.grs-coaching__list {
    list-style: none;
    margin: 0 0 0.9rem;
    padding: 0;
    display: grid;
    gap: 0.7rem;
}

.grs-coaching__row {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    font-size: 0.84rem;
    line-height: 1.4;
}

.grs-coaching__icon {
    display: grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border: 1px solid var(--grs-line);
    border-radius: 8px;
    color: var(--grs-green-deep);
    font-size: 0.85rem;
    flex: none;
}

.grs-card--coaching .grs-button {
    width: 100%;
    padding: 0.45rem 0.8rem;
    font-size: 0.82rem;
}

/* ---------- Insights ---------- */

.grs-insights {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem;
}

.grs-insights__heading {
    margin: 0 0 0.5rem;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--grs-muted);
}

.grs-insights__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.45rem;
}

.grs-insights__chip {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.4rem 0.55rem;
    border-radius: 8px;
    font-size: 0.78rem;
    font-weight: 600;
}

.grs-insights__chip--strength {
    background: var(--grs-green-soft);
}

.grs-insights__chip--strength .bi {
    color: var(--grs-green);
}

.grs-insights__chip--weakness {
    background: #faf3e2;
}

.grs-insights__chip--weakness .bi {
    color: var(--grs-amber);
}

/* ---------- Phase insights ---------- */

.grs-phases__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
}

.grs-phases__row {
    display: grid;
    grid-template-columns: 120px minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.8rem;
    padding: 0.55rem 0;
    font-size: 0.88rem;
}

.grs-phases__row + .grs-phases__row {
    border-top: 1px dashed var(--grs-line);
}

.grs-phases__name {
    font-weight: 700;
    color: var(--grs-green-deep);
}

.grs-phases__comment {
    color: var(--grs-muted);
}

.grs-phases__score {
    font-weight: 800;
}

.grs-phases__score.is-positive {
    color: var(--grs-green);
}

.grs-phases__score.is-negative {
    color: var(--grs-red);
}

/* ---------- Drill CTA ---------- */

.grs-cta {
    display: grid;
    justify-items: center;
    gap: 0.5rem;
    padding: 0.4rem 0 0.8rem;
}

.grs-cta__button {
    font-size: 1.02rem;
    padding: 0.85rem 2.2rem;
    border-radius: 8px;
}

.grs-cta__caption {
    margin: 0;
    color: var(--grs-muted);
    font-size: 0.85rem;
}

/* ---------- Responsive ---------- */

@media (max-width: 1500px) {
    .grs-main__minis {
        grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    }

    /* When the three mini cards wrap to two columns, let the last one
       span the full row instead of leaving a hole in the grid. */
    .grs-main__minis > *:nth-child(3):last-child {
        grid-column: 1 / -1;
    }
}

@media (max-width: 1280px) {
    .grs-main {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 1100px) {
    .grs-infobar {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .grs-infobar__cell:nth-child(3n + 1) {
        border-left: 0;
    }

    .grs-infobar__cell:nth-child(n + 4) {
        border-top: 1px solid var(--grs-line);
    }
}

@media (max-width: 900px) {
    .grs-header {
        min-height: auto;
        padding-right: 0;
    }

    .grs-header__art {
        display: none;
    }

    .grs-main__charts {
        grid-template-columns: minmax(0, 1fr);
    }

    .grs-moments {
        grid-template-columns: minmax(0, 1fr);
    }

    .grs-stepper {
        max-width: none;
    }
}

@media (max-width: 640px) {
    .grs-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .grs-header__title {
        font-size: 1.55rem;
        line-height: 1.15;
    }

    .grs-header .grs-button {
        width: 100%;
    }

    .grs-stepper {
        gap: 0.45rem;
    }

    .grs-stepper__step {
        gap: 0.35rem;
    }

    .grs-stepper__dot {
        width: 28px;
        height: 28px;
    }

    .grs-stepper__label {
        font-size: 0.84rem;
    }

    .grs-stepper__arrow {
        flex: 0 0 22px;
        min-width: 22px;
    }

    .grs-infobar {
        grid-template-columns: minmax(0, 1fr);
    }

    .grs-infobar__cell {
        border-left: 0;
    }

    .grs-infobar__cell + .grs-infobar__cell {
        border-top: 1px solid var(--grs-line);
    }
}
