/* ═══════════════════════════════════════════
   DAILY — card grid + finale prize (v2)
   ═══════════════════════════════════════════ */

.daily-body {
    background: var(--cream);
    padding: var(--space-3) var(--space-3) var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

/* ── Header (title + tabs) ───────────────── */
.daily-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--space-2);
}

.daily-head-l {
    min-width: 0;
    flex: 1;
}

.daily-title {
    font-family: var(--font-display);
    font-size: var(--fs-xs);
    color: var(--hot);
    letter-spacing: 0.5px;
    margin-bottom: 3px;
}

.daily-sub {
    font-family: var(--font-body);
    font-size: var(--fs-xs);
    color: var(--mid);
    line-height: 1.4;
}

.daily-end {
    flex-shrink: 0;
    text-align: right;
}

.daily-end-lbl {
    font-family: var(--font-display);
    font-size: 7px;
    color: var(--hot);
    letter-spacing: 0.5px;
    margin-bottom: 2px;
}

.daily-end-val {
    font-family: var(--font-display);
    font-size: var(--fs-xs);
    color: var(--pink);
    letter-spacing: 0.5px;
}

/* ── Progress bar ────────────────────────── */
.daily-progress {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.daily-bar {
    flex: 1;
    height: 12px;
    background: var(--soft);
    border: 2px solid var(--dark);
    border-radius: var(--radius-pill);
    overflow: hidden;
}

.daily-bar-fill {
    height: 100%;
    width: 0;
    background: var(--pink);
    transition: width .25s ease-out;
}

.daily-bar-meta {
    font-family: var(--font-display);
    font-size: 8px;
    color: var(--hot);
    letter-spacing: 0.5px;
    flex-shrink: 0;
}

/* ── Day grid: 4 + 4 + (2+1×finale) = 11 cells ── */
.dstars {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-2);
}

/* Each card */
.day-card {
    border: 2px solid var(--dark);
    border-radius: var(--radius-md);
    padding: 8px 4px 6px;
    text-align: center;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    min-height: 72px;
    background: #fff;
    transition: transform .1s;
}

.day-label {
    font-family: var(--font-display);
    font-size: 8px;
    color: var(--dark);
    letter-spacing: 0.5px;
}

.day-icon {
    font-size: 18px;
    line-height: 1;
    margin: 1px 0;
}

.day-pts {
    font-family: var(--font-display);
    font-size: 8px;
    color: var(--dark);
    letter-spacing: 0.5px;
}

/* States */
.day-claimed {
    background: var(--pink);
    color: #fff;
    box-shadow: 0 2px 0 var(--dark);
}
.day-claimed .day-label,
.day-claimed .day-pts { color: #fff; }

.day-today {
    background: var(--cream);
    border: 2.5px solid var(--pink);
    box-shadow: 0 3px 0 var(--dark);
    cursor: pointer;
    color: var(--hot);
}
.day-today:hover { transform: translateY(-2px); }
.day-today .day-label,
.day-today .day-pts { color: var(--hot); }

.day-today-badge {
    position: absolute;
    top: -9px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--pink);
    color: #fff;
    font-family: var(--font-display);
    font-size: 7px;
    padding: 3px 8px;
    border-radius: var(--radius-pill);
    letter-spacing: 0.5px;
    border: 1.5px solid var(--dark);
    white-space: nowrap;
}

.day-locked {
    background: var(--cream-deep);
    border-style: dashed;
    border-color: var(--hot);
    color: var(--hot);
    opacity: 0.7;
    cursor: not-allowed;
}
.day-locked .day-label,
.day-locked .day-pts { color: var(--hot); }

/* Finale day (last day of the week) — wider, horizontal */
.day-finale {
    grid-column: span 2;
    flex-direction: row;
    gap: var(--space-2);
    padding: 8px 12px;
    text-align: left;
    justify-content: flex-start;
}
.day-finale .day-icon { font-size: 26px; margin: 0; }
.day-finale .day-finale-text { display: flex; flex-direction: column; gap: 2px; }
.day-finale .day-pts { font-size: 10px; }

/* ── Week prize (footer card) ────────────── */
.week-prize {
    background: #fff;
    border: 2px solid var(--dark);
    border-radius: var(--radius-md);
    padding: 10px 12px;
    display: flex;
    align-items: center;
    gap: var(--space-3);
    box-shadow: 0 2px 0 var(--dark);
}

.week-prize-icon {
    width: 40px;
    height: 40px;
    background: var(--pink);
    border: 2px solid var(--dark);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    flex-shrink: 0;
}

.week-prize-text {
    flex: 1;
    min-width: 0;
}

.week-prize-title {
    font-family: var(--font-display);
    font-size: 9px;
    color: var(--hot);
    letter-spacing: 0.5px;
    margin-bottom: 3px;
}

.week-prize-desc {
    font-family: var(--font-body);
    font-size: var(--fs-xs);
    color: var(--mid);
    line-height: 1.35;
}

.week-prize-btn {
    background: var(--soft);
    color: var(--hot);
    border: 2px solid var(--dark);
    border-radius: var(--radius-pill);
    padding: 5px 10px;
    font-family: var(--font-display);
    font-size: 8px;
    cursor: not-allowed;
    letter-spacing: 0.5px;
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
    box-shadow: 0 2px 0 var(--dark);
}
.week-prize-btn-icon { font-size: 10px; line-height: 1; }

.week-prize-btn:not(:disabled) {
    background: var(--pink);
    color: #fff;
    cursor: pointer;
}
.week-prize-btn:not(:disabled):hover { transform: translateY(-1px); }

.week-prize.claimed .week-prize-icon { background: var(--green); }
.week-prize.claimed .week-prize-btn {
    background: var(--green-soft);
    color: var(--dark);
    cursor: default;
}
