/* My Punches page */
.controls {
    margin-bottom: var(--space-md);
    flex-wrap: wrap;
    gap: var(--space-md);
}

.view-toggle {
    display: inline-flex;
    background: var(--surface-container);
    border-radius: var(--radius-xl);
    padding: 4px;
}

.view-toggle__btn {
    padding: 6px 18px;
    border: 0;
    background: transparent;
    border-radius: var(--radius-lg);
    font: inherit;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--on-surface-variant);
    cursor: pointer;
}

.view-toggle__btn.is-active {
    background: var(--surface-container-lowest);
    color: var(--primary);
    box-shadow: var(--shadow-sm);
}

.controls__divider {
    width: 1px;
    height: 24px;
    background: var(--outline-variant);
}

/* Calendar */
.calendar-card {
    padding: var(--space-md);
}

.calendar-weekdays,
.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 1px;
}

.calendar-weekdays {
    margin-bottom: var(--space-sm);
}

.calendar-weekdays > div {
    text-align: center;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--outline);
}

.calendar-grid {
    background: var(--outline-variant);
    border: 1px solid var(--outline-variant);
    border-radius: var(--radius-xl);
    overflow: hidden;
}

.day-cell {
    background: var(--surface-container-lowest);
    min-height: 96px;
    padding: var(--space-xs);
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    cursor: pointer;
    transition: background 0.1s ease;
}

.day-cell:hover {
    background: var(--surface-container-low);
}

.day-cell--empty {
    background: var(--surface-container-low);
    cursor: default;
}

.day-cell--today .day-cell__num {
    color: var(--primary);
    font-weight: 700;
}

.day-cell__num {
    font-size: 12px;
    font-weight: 600;
}

.day-cell__chip {
    margin-top: auto;
    background: rgba(108, 248, 187, 0.3);
    border: 1px solid var(--secondary-container);
    border-radius: var(--radius-lg);
    padding: 4px 6px;
}

.day-cell__chip p {
    margin: 0;
    font-size: 10px;
    color: var(--on-secondary-container);
}

.day-cell__chip .worked {
    font-weight: 700;
}

.day-cell__ot {
    color: var(--tertiary);
    font-weight: 700;
}

/* List view */
.list-day {
    padding: var(--space-md);
    border-bottom: 1px solid var(--outline-variant);
}

.list-day:last-child {
    border-bottom: 0;
}

.list-day__head {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin-bottom: var(--space-sm);
}

.list-day__date {
    text-align: center;
    width: 52px;
    padding: 4px;
    border-radius: var(--radius-xl);
    background: var(--primary-container);
    color: var(--on-primary-container);
}

.list-day__date .dow {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
}

.list-day__date .dom {
    font-size: 18px;
    font-weight: 700;
}

.list-event {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 12px;
    border: 1px solid var(--outline-variant);
    border-radius: var(--radius-xl);
    margin-bottom: var(--space-xs);
}

/* Day modal */
.day-events {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    max-height: 320px;
    overflow-y: auto;
    margin-bottom: var(--space-md);
}

.day-event {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 12px;
    border: 1px solid var(--outline-variant);
    border-radius: var(--radius-xl);
}

.day-event__actions {
    display: flex;
    gap: 4px;
}

.day-event__actions button {
    border: 0;
    background: transparent;
    cursor: pointer;
    color: var(--on-surface-variant);
    padding: 4px;
    border-radius: var(--radius-lg);
}

.day-event__actions button:hover {
    background: var(--surface-container);
    color: var(--primary);
}

.day-event--inferred {
    opacity: 0.6;
    border-style: dashed;
}

.day-add {
    border-top: 1px solid var(--outline-variant);
    padding-top: var(--space-md);
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.day-add__row {
    gap: var(--space-sm);
}

.list-empty {
    padding: 16px;
}

.list-day__head .btn--icon {
    margin-left: auto;
}
